mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #8242 from jeromecoutant/PR_STM32_LPTICKER
STM32 LPTICKER : Fix tickless and LPTICKER_DELAY_TICKSpull/8337/head
commit
baada0e783
|
@ -145,9 +145,6 @@ void lp_ticker_init(void)
|
|||
|
||||
__HAL_LPTIM_ENABLE_IT(&LptimHandle, LPTIM_IT_CMPM);
|
||||
HAL_LPTIM_Counter_Start(&LptimHandle, 0xFFFF);
|
||||
|
||||
/* Need to write a compare value in order to get LPTIM_FLAG_CMPOK in set_interrupt */
|
||||
__HAL_LPTIM_COMPARE_SET(&LptimHandle, 0);
|
||||
}
|
||||
|
||||
static void LPTIM1_IRQHandler(void)
|
||||
|
@ -194,14 +191,14 @@ void lp_ticker_set_interrupt(timestamp_t timestamp)
|
|||
LptimHandle.Instance = LPTIM1;
|
||||
irq_handler = (void (*)(void))lp_ticker_irq_handler;
|
||||
|
||||
__HAL_LPTIM_CLEAR_FLAG(&LptimHandle, LPTIM_FLAG_CMPOK);
|
||||
__HAL_LPTIM_COMPARE_SET(&LptimHandle, timestamp);
|
||||
/* CMPOK is set by hardware to inform application that the APB bus write operation to the LPTIM_CMP register has been successfully completed */
|
||||
/* Any successive write before the CMPOK flag be set, will lead to unpredictable results */
|
||||
while (__HAL_LPTIM_GET_FLAG(&LptimHandle, LPTIM_FLAG_CMPOK) == RESET) {
|
||||
}
|
||||
|
||||
__HAL_LPTIM_CLEAR_FLAG(&LptimHandle, LPTIM_FLAG_CMPOK);
|
||||
__HAL_LPTIM_CLEAR_FLAG(&LptimHandle, LPTIM_FLAG_CMPM);
|
||||
__HAL_LPTIM_COMPARE_SET(&LptimHandle, timestamp);
|
||||
lp_ticker_clear_interrupt();
|
||||
|
||||
NVIC_EnableIRQ(LPTIM1_IRQn);
|
||||
}
|
||||
|
@ -209,6 +206,7 @@ void lp_ticker_set_interrupt(timestamp_t timestamp)
|
|||
void lp_ticker_fire_interrupt(void)
|
||||
{
|
||||
lp_Fired = 1;
|
||||
irq_handler = (void (*)(void))lp_ticker_irq_handler;
|
||||
NVIC_SetPendingIRQ(LPTIM1_IRQn);
|
||||
NVIC_EnableIRQ(LPTIM1_IRQn);
|
||||
}
|
||||
|
@ -217,9 +215,6 @@ void lp_ticker_disable_interrupt(void)
|
|||
{
|
||||
NVIC_DisableIRQ(LPTIM1_IRQn);
|
||||
LptimHandle.Instance = LPTIM1;
|
||||
/* Waiting last write operation completion */
|
||||
while (__HAL_LPTIM_GET_FLAG(&LptimHandle, LPTIM_FLAG_CMPOK) == RESET) {
|
||||
}
|
||||
}
|
||||
|
||||
void lp_ticker_clear_interrupt(void)
|
||||
|
@ -263,7 +258,6 @@ uint32_t lp_ticker_read(void)
|
|||
|
||||
void lp_ticker_set_interrupt(timestamp_t timestamp)
|
||||
{
|
||||
lp_ticker_disable_interrupt();
|
||||
rtc_set_wake_up_timer(timestamp);
|
||||
}
|
||||
|
||||
|
|
|
@ -381,6 +381,7 @@ void rtc_set_wake_up_timer(timestamp_t timestamp)
|
|||
}
|
||||
|
||||
RtcHandle.Instance = RTC;
|
||||
HAL_RTCEx_DeactivateWakeUpTimer(&RtcHandle);
|
||||
if (HAL_RTCEx_SetWakeUpTimer_IT(&RtcHandle, WakeUpCounter, RTC_WAKEUPCLOCK_RTCCLK_DIV4) != HAL_OK) {
|
||||
error("rtc_set_wake_up_timer init error\n");
|
||||
}
|
||||
|
@ -402,10 +403,7 @@ void rtc_fire_interrupt(void)
|
|||
void rtc_deactivate_wake_up_timer(void)
|
||||
{
|
||||
RtcHandle.Instance = RTC;
|
||||
__HAL_RTC_WRITEPROTECTION_DISABLE(&RtcHandle);
|
||||
__HAL_RTC_WAKEUPTIMER_DISABLE(&RtcHandle);
|
||||
__HAL_RTC_WAKEUPTIMER_DISABLE_IT(&RtcHandle, RTC_IT_WUT);
|
||||
__HAL_RTC_WRITEPROTECTION_ENABLE(&RtcHandle);
|
||||
HAL_RTCEx_DeactivateWakeUpTimer(&RtcHandle);
|
||||
NVIC_DisableIRQ(RTC_WKUP_IRQn);
|
||||
}
|
||||
|
||||
|
|
|
@ -753,6 +753,11 @@
|
|||
},
|
||||
"stdio_uart_rx": {
|
||||
"help": "default RX STDIO pins is defined in PinNames.h file, but it can be overridden"
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "https://os.mbed.com/docs/latest/porting/low-power-ticker.html",
|
||||
"value": 1,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"device_has": ["USTICKER", "LPTICKER", "RTC", "ANALOGIN", "I2C", "I2CSLAVE", "I2C_ASYNCH", "INTERRUPTIN", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "SERIAL", "SLEEP", "SPI", "SPISLAVE", "SPI_ASYNCH", "STDIO_MESSAGES"]
|
||||
|
@ -882,11 +887,6 @@
|
|||
"help": "Mask value : USE_PLL_HSE_EXTC | USE_PLL_HSE_XTAL (need HW patch) | USE_PLL_HSI",
|
||||
"value": "USE_PLL_HSE_EXTC|USE_PLL_HSI",
|
||||
"macro_name": "CLOCK_SOURCE"
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "For targets with low frequency system clock, set lpticker_delay_ticks value to 1",
|
||||
"value": 1,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0755"],
|
||||
|
@ -905,11 +905,6 @@
|
|||
"help": "Mask value : USE_PLL_HSE_EXTC | USE_PLL_HSE_XTAL (need HW patch) | USE_PLL_HSI",
|
||||
"value": "USE_PLL_HSE_EXTC|USE_PLL_HSI",
|
||||
"macro_name": "CLOCK_SOURCE"
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "For targets with low frequency system clock, set lpticker_delay_ticks value to 1",
|
||||
"value": 1,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0730"],
|
||||
|
@ -928,11 +923,6 @@
|
|||
"help": "Mask value : USE_PLL_HSE_EXTC | USE_PLL_HSE_XTAL (need HW patch) | USE_PLL_HSI",
|
||||
"value": "USE_PLL_HSE_EXTC|USE_PLL_HSI",
|
||||
"macro_name": "CLOCK_SOURCE"
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "For targets with low frequency system clock, set lpticker_delay_ticks value to 1",
|
||||
"value": 1,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0750"],
|
||||
|
@ -1131,11 +1121,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0744"],
|
||||
|
@ -1261,11 +1246,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0743"],
|
||||
|
@ -1288,11 +1268,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0743"],
|
||||
|
@ -1443,11 +1418,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"macros_add": ["USBHOST_OTHER"],
|
||||
|
@ -1479,11 +1449,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"macros_add": ["TRANSACTION_QUEUE_SIZE_SPI=2", "USBHOST_OTHER", "MBEDTLS_CONFIG_HW_SUPPORT"],
|
||||
|
@ -1518,11 +1483,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"supported_form_factors": ["ARDUINO"],
|
||||
|
@ -1552,13 +1512,9 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lpticker_delay_ticks": 4},
|
||||
"detect_code": ["0780"],
|
||||
"device_has_add": ["CRC", "SERIAL_FC", "FLASH"],
|
||||
"default_lib": "small",
|
||||
|
@ -1580,13 +1536,9 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lpticker_delay_ticks": 4},
|
||||
"detect_code": ["0790"],
|
||||
"device_has_add": ["CRC", "SERIAL_FC", "FLASH"],
|
||||
"default_lib": "small",
|
||||
|
@ -1607,13 +1559,9 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lpticker_delay_ticks": 4},
|
||||
"detect_code": ["0715"],
|
||||
"device_has_add": ["ANALOGOUT", "CRC", "SERIAL_FC", "SERIAL_ASYNCH", "FLASH"],
|
||||
"default_lib": "small",
|
||||
|
@ -1634,13 +1582,9 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lpticker_delay_ticks": 4},
|
||||
"detect_code": ["0760"],
|
||||
"device_has_add": ["ANALOGOUT", "CRC", "SERIAL_FC", "SERIAL_ASYNCH", "TRNG", "FLASH"],
|
||||
"release_versions": ["2", "5"],
|
||||
|
@ -1656,11 +1600,6 @@
|
|||
"help": "Mask value : USE_PLL_HSE_EXTC | USE_PLL_HSE_XTAL (need HW patch) | USE_PLL_HSI",
|
||||
"value": "USE_PLL_HSE_EXTC|USE_PLL_HSI",
|
||||
"macro_name": "CLOCK_SOURCE"
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "For targets with low frequency system clock, set lpticker_delay_ticks value to 1",
|
||||
"value": 1,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0710"],
|
||||
|
@ -1682,11 +1621,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0770"],
|
||||
|
@ -1709,11 +1643,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0779"],
|
||||
|
@ -1756,11 +1685,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0765"],
|
||||
|
@ -1802,11 +1726,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0827"],
|
||||
|
@ -2014,14 +1933,12 @@
|
|||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lse_available": 0},
|
||||
"overrides": {
|
||||
"lse_available": 0,
|
||||
"lpticker_delay_ticks": 4
|
||||
},
|
||||
"device_has_add": ["ANALOGOUT", "CRC", "SERIAL_FC", "FLASH"],
|
||||
"default_lib": "small",
|
||||
"release_versions": ["2"],
|
||||
|
@ -2041,13 +1958,9 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"overrides": {"lpticker_delay_ticks": 4},
|
||||
"detect_code": ["0833"],
|
||||
"device_has_add": ["ANALOGOUT", "SERIAL_FC", "SERIAL_ASYNCH", "TRNG", "FLASH"],
|
||||
"release_versions": ["2", "5"],
|
||||
|
@ -2081,11 +1994,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0815"],
|
||||
|
@ -2115,11 +2023,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0817"],
|
||||
|
@ -2144,11 +2047,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"supported_form_factors": ["ARDUINO"],
|
||||
|
@ -2172,11 +2070,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0820"],
|
||||
|
@ -4282,11 +4175,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0822"],
|
||||
|
@ -4308,11 +4196,6 @@
|
|||
"lpticker_lptim": {
|
||||
"help": "This target supports LPTIM. Set value 1 to use LPTIM for LPTICKER, or 0 to use RTC wakeup timer",
|
||||
"value": 1
|
||||
},
|
||||
"lpticker_delay_ticks": {
|
||||
"help": "In case of lpticker_lptim=1, set lpticker_delay_ticks=3",
|
||||
"value": 3,
|
||||
"macro_name": "LPTICKER_DELAY_TICKS"
|
||||
}
|
||||
},
|
||||
"detect_code": ["0823"],
|
||||
|
|
Loading…
Reference in New Issue