⚠️ Hi there.. thanks for coming to the forums. Exciting news! we’re now in the process of moving to our new forum platform that will offer better functionality and is contained within the main Dialog website. All posts and accounts have been migrated. We’re now accepting traffic on the new forum only - please POST any new threads at//www.xmece.com/support. We’ll be fixing bugs / optimising the searching and tagging over the coming days.
Hi, dialog When the DA14681 in extended sleep mode , can it wake up by uart receive interrupt and receive data bytes from the transciver? And how to set it?
The UART hardware is turned off in Extended sleep mode and so you cannot use it to wake the system up.
However, there is a workaround which you have to be very carefull about and it is not an officially recommended one.
You can map the UART pin to a GPIO for external wakeup just before going to sleep and use it as a trigger for wakeup and then map the pin back to UART after wakeup to receive the data over UART.
However, you got to be very carefull about managing the following things: baudrate, debounce and wakeup delay.
hi LC, Now it can wake up from extended sleep mode via uart rx pin . But sometimes it will enter "HW_UART_INT_BUSY_DETECTED" interrupt after system wake up. Although I could use "hw_uart_transmit_fifo_empty(uart)" to exit "HW_UART_INT_BUSY_DETECTED" interrupt , I found the baudrate is incorrect which led to wrong character transfer. How to solve this problem?
So first of all, you are configuring the UART Rx pin as a GPIO before going into sleep mode and you enabled the wakeup interrupt on this pin with 1 event to count. And to wakeup the system you are sending an @ character that can pull the pin low for enough clock cycles.
After you wakeup you then enable the UART. Is your implementation doing this and still you see the HW_UART_INT_BUSY_DETECTED interrupt. Please confirm.
Hi, LC Yes, I can configure the UART Rx pin as a GPIO wakeup pin and can wakeup the system. Now it worked well in most cases . But I didn't sending only an @ character. Because sometimes only one @ character is not enough clock cycles to wake up . But when I send a long string (over 20 bytes @ character, baudrate 38400) to wake up the system , it's easier to occured "HW_UART_INT_BUSY_DETECTED" interrupt and it seems that the baudrate is wrong. Configured code is as below: ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// void console_uart_leave_from_sleepmode(void) { hw_wkup_set_pin_state(UART_RX_PORT, UART_RX_PIN, false); hw_gpio_set_pin_function(UART_RX_PORT, UART_RX_PIN, HW_GPIO_MODE_INPUT_PULLUP, hw_gpio_func_uart_rx); // rx引脚启用 console_uart_init(); uart_rx_int_enable(HW_UART1, true); } void console_uart_prepare_for_sleepmode(void) {
Hello guxiang,
The UART hardware is turned off in Extended sleep mode and so you cannot use it to wake the system up.
However, there is a workaround which you have to be very carefull about and it is not an officially recommended one.
You can map the UART pin to a GPIO for external wakeup just before going to sleep and use it as a trigger for wakeup and then map the pin back to UART after wakeup to receive the data over UART.
However, you got to be very carefull about managing the following things: baudrate, debounce and wakeup delay.
Best,
LC
Hi , LC
你能给我一个演示代码吗?
Hello guxiang,
This method is used in the codeless project referred below. Take at look at the user_prepare_sleep() function as a starting point.
https://support.dialog-semiconductor.com/connectivity/reference-design/smartbond-codeless-serial-link
Best,
LC
hi, LC
The file showed "restricted" for me . Can give me the permission to download it?
我的电子邮件:414095539@qq.com
Hello guxiang,
它是由于许可协议,在下载文件之前需要接受。请接受许可证,您应该能够在此支持门户上下载文件。
Best,
LC
hi , LC
我接受了许可协议并提交了它,但它没有回复我,我仍然无法访问下载文件。
Hello guxiang,
Can you provide a valid address and other details in your profile. We need some valid information to provide access to the content on the portal.
Best,
LC
Hi LC ,
我已经更新了我的个人资料。请再次检查一下。
Hi guxiang,
You should be able to download the content now.
Best,
LC
hi LC,
Now it can wake up from extended sleep mode via uart rx pin . But sometimes it will enter "HW_UART_INT_BUSY_DETECTED" interrupt after system wake up. Although I could use "hw_uart_transmit_fifo_empty(uart)" to exit "HW_UART_INT_BUSY_DETECTED" interrupt , I found the baudrate is incorrect which led to wrong character transfer. How to solve this problem?
Hello guxiang,
So first of all, you are configuring the UART Rx pin as a GPIO before going into sleep mode and you enabled the wakeup interrupt on this pin with 1 event to count. And to wakeup the system you are sending an @ character that can pull the pin low for enough clock cycles.
After you wakeup you then enable the UART. Is your implementation doing this and still you see the HW_UART_INT_BUSY_DETECTED interrupt. Please confirm.
Best,
LC
Hi, LC
Yes, I can configure the UART Rx pin as a GPIO wakeup pin and can wakeup the system. Now it worked well in most cases . But I didn't sending only an @ character. Because sometimes only one @ character is not enough clock cycles to wake up . But when I send a long string (over 20 bytes @ character, baudrate 38400) to wake up the system , it's easier to occured "HW_UART_INT_BUSY_DETECTED" interrupt and it seems that the baudrate is wrong.
Configured code is as below:
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void console_uart_leave_from_sleepmode(void)
{
hw_wkup_set_pin_state(UART_RX_PORT, UART_RX_PIN, false);
hw_gpio_set_pin_function(UART_RX_PORT, UART_RX_PIN, HW_GPIO_MODE_INPUT_PULLUP,
hw_gpio_func_uart_rx); // rx引脚启用
console_uart_init();
uart_rx_int_enable(HW_UART1, true);
}
void console_uart_prepare_for_sleepmode(void)
{
hw_wkup_init(null);
hw_wkup_reset_counter();
hw_wkup_set_debounce_time(0);
hw_wkup_set_counter_threshold(1);
hw_gpio_set_pin_function(HW_GPIO_PORT_4, HW_GPIO_PIN_7, HW_GPIO_MODE_INPUT_PULLUP, HW_GPIO_FUNC_GPIO);
hw_wkup_set_pin_state(HW_GPIO_PORT_4, HW_GPIO_PIN_7, true);//configure rx pin as wake up pin
hw_wkup_set_pin_trigger(HW_GPIO_PORT_4, HW_GPIO_PIN_7, HW_WKUP_PIN_STATE_LOW);
hw_wkup_register_interrupt(wkup_handler,configlary_max_syscall_interrupt_priority);
hw_gpio_set_pin_function(UART_RX_PORT, UART_RX_PIN, HW_GPIO_MODE_INPUT,
HW_GPIO_FUNC_GPIO);// RX pin disable
uart_rx_int_enable(HW_UART1, false);
uart_clock_disable();
}