ulp_common.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. // Copyright 2016-2018 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #pragma once
  15. /* This file contains definitions that are common between esp32/ulp.h
  16. and esp32s2/ulp.h
  17. */
  18. #ifdef __cplusplus
  19. extern "C" {
  20. #endif
  21. /**@{*/
  22. #define ESP_ERR_ULP_BASE 0x1200 /*!< Offset for ULP-related error codes */
  23. #define ESP_ERR_ULP_SIZE_TOO_BIG (ESP_ERR_ULP_BASE + 1) /*!< Program doesn't fit into RTC memory reserved for the ULP */
  24. #define ESP_ERR_ULP_INVALID_LOAD_ADDR (ESP_ERR_ULP_BASE + 2) /*!< Load address is outside of RTC memory reserved for the ULP */
  25. #define ESP_ERR_ULP_DUPLICATE_LABEL (ESP_ERR_ULP_BASE + 3) /*!< More than one label with the same number was defined */
  26. #define ESP_ERR_ULP_UNDEFINED_LABEL (ESP_ERR_ULP_BASE + 4) /*!< Branch instructions references an undefined label */
  27. #define ESP_ERR_ULP_BRANCH_OUT_OF_RANGE (ESP_ERR_ULP_BASE + 5) /*!< Branch target is out of range of B instruction (try replacing with BX) */
  28. /**@}*/
  29. union ulp_insn; // Declared in the chip-specific ulp.h header
  30. typedef union ulp_insn ulp_insn_t;
  31. /**
  32. * @brief Resolve all macro references in a program and load it into RTC memory
  33. * @param load_addr address where the program should be loaded, expressed in 32-bit words
  34. * @param program ulp_insn_t array with the program
  35. * @param psize size of the program, expressed in 32-bit words
  36. * @return
  37. * - ESP_OK on success
  38. * - ESP_ERR_NO_MEM if auxiliary temporary structure can not be allocated
  39. * - one of ESP_ERR_ULP_xxx if program is not valid or can not be loaded
  40. */
  41. esp_err_t ulp_process_macros_and_load(uint32_t load_addr, const ulp_insn_t* program, size_t* psize);
  42. /**
  43. * @brief Load ULP program binary into RTC memory
  44. *
  45. * ULP program binary should have the following format (all values little-endian):
  46. *
  47. * 1. MAGIC, (value 0x00706c75, 4 bytes)
  48. * 2. TEXT_OFFSET, offset of .text section from binary start (2 bytes)
  49. * 3. TEXT_SIZE, size of .text section (2 bytes)
  50. * 4. DATA_SIZE, size of .data section (2 bytes)
  51. * 5. BSS_SIZE, size of .bss section (2 bytes)
  52. * 6. (TEXT_OFFSET - 12) bytes of arbitrary data (will not be loaded into RTC memory)
  53. * 7. .text section
  54. * 8. .data section
  55. *
  56. * Linker script in components/ulp/ld/esp32.ulp.ld produces ELF files which
  57. * correspond to this format. This linker script produces binaries with load_addr == 0.
  58. *
  59. * @param load_addr address where the program should be loaded, expressed in 32-bit words
  60. * @param program_binary pointer to program binary
  61. * @param program_size size of the program binary
  62. * @return
  63. * - ESP_OK on success
  64. * - ESP_ERR_INVALID_ARG if load_addr is out of range
  65. * - ESP_ERR_INVALID_SIZE if program_size doesn't match (TEXT_OFFSET + TEXT_SIZE + DATA_SIZE)
  66. * - ESP_ERR_NOT_SUPPORTED if the magic number is incorrect
  67. */
  68. esp_err_t ulp_load_binary(uint32_t load_addr, const uint8_t* program_binary, size_t program_size);
  69. /**
  70. * @brief Run the program loaded into RTC memory
  71. * @param entry_point entry point, expressed in 32-bit words
  72. * @return ESP_OK on success
  73. */
  74. esp_err_t ulp_run(uint32_t entry_point);
  75. /**
  76. * @brief Set one of ULP wakeup period values
  77. *
  78. * ULP coprocessor starts running the program when the wakeup timer counts up
  79. * to a given value (called period). There are 5 period values which can be
  80. * programmed into SENS_ULP_CP_SLEEP_CYCx_REG registers, x = 0..4 for ESP32, and
  81. * one period value which can be programmed into RTC_CNTL_ULP_CP_TIMER_1_REG register for ESP32-S2.
  82. * By default, for ESP32, wakeup timer will use the period set into SENS_ULP_CP_SLEEP_CYC0_REG,
  83. * i.e. period number 0. ULP program code can use SLEEP instruction to select
  84. * which of the SENS_ULP_CP_SLEEP_CYCx_REG should be used for subsequent wakeups.
  85. *
  86. * However, please note that SLEEP instruction issued (from ULP program) while the system
  87. * is in deep sleep mode does not have effect, and sleep cycle count 0 is used.
  88. *
  89. * For ESP32-s2 the SLEEP instruction not exist. Instead a WAKE instruction will be used.
  90. *
  91. * @param period_index wakeup period setting number (0 - 4)
  92. * @param period_us wakeup period, us
  93. * @note The ULP FSM requires two clock cycles to wakeup before being able to run the program.
  94. * Then additional 16 cycles are reserved after wakeup waiting until the 8M clock is stable.
  95. * The FSM also requires two more clock cycles to go to sleep after the program execution is halted.
  96. * The minimum wakeup period that may be set up for the ULP
  97. * is equal to the total number of cycles spent on the above internal tasks.
  98. * For a default configuration of the ULP running at 150kHz it makes about 133us.
  99. * @return
  100. * - ESP_OK on success
  101. * - ESP_ERR_INVALID_ARG if period_index is out of range
  102. */
  103. esp_err_t ulp_set_wakeup_period(size_t period_index, uint32_t period_us);
  104. #ifdef __cplusplus
  105. }
  106. #endif