mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
2fc9bd61bf
This commit refactors the ulp component. Files are now divided based on type of ulp, viz., fsm or risc-v. Files common to both are maintained in the ulp_common folder. This commit also adds menuconfig options for ULP within the ulp component instead of presenting target specific configuations for ulp.
52 lines
2.0 KiB
C
52 lines
2.0 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#ifndef __ULP_COMMON_H__
|
|
#define __ULP_COMMON_H__
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
#include "esp_err.h"
|
|
#include "ulp_common_defs.h"
|
|
|
|
/**
|
|
* @brief Set one of ULP wakeup period values
|
|
*
|
|
* ULP coprocessor starts running the program when the wakeup timer counts up
|
|
* to a given value (called period). There are 5 period values which can be
|
|
* programmed into SENS_ULP_CP_SLEEP_CYCx_REG registers, x = 0..4 for ESP32, and
|
|
* one period value which can be programmed into RTC_CNTL_ULP_CP_TIMER_1_REG register for ESP32-S2/S3.
|
|
* By default, for ESP32, wakeup timer will use the period set into SENS_ULP_CP_SLEEP_CYC0_REG,
|
|
* i.e. period number 0. ULP program code can use SLEEP instruction to select
|
|
* which of the SENS_ULP_CP_SLEEP_CYCx_REG should be used for subsequent wakeups.
|
|
*
|
|
* However, please note that SLEEP instruction issued (from ULP program) while the system
|
|
* is in deep sleep mode does not have effect, and sleep cycle count 0 is used.
|
|
*
|
|
* For ESP32-S2/S3 the SLEEP instruction not exist. Instead a WAKE instruction will be used.
|
|
*
|
|
* @param period_index wakeup period setting number (0 - 4)
|
|
* @param period_us wakeup period, us
|
|
* @note The ULP FSM requires two clock cycles to wakeup before being able to run the program.
|
|
* Then additional 16 cycles are reserved after wakeup waiting until the 8M clock is stable.
|
|
* The FSM also requires two more clock cycles to go to sleep after the program execution is halted.
|
|
* The minimum wakeup period that may be set up for the ULP
|
|
* is equal to the total number of cycles spent on the above internal tasks.
|
|
* For a default configuration of the ULP running at 150kHz it makes about 133us.
|
|
* @return
|
|
* - ESP_OK on success
|
|
* - ESP_ERR_INVALID_ARG if period_index is out of range
|
|
*/
|
|
esp_err_t ulp_set_wakeup_period(size_t period_index, uint32_t period_us);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif // __ULP_COMMON_H__
|