diff --git a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.cpp b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.cpp index ee79e18ca70..cc586e671ea 100644 --- a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.cpp +++ b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.cpp @@ -374,4 +374,9 @@ ble::vendor::cypress_ble::CyH4TransportDriver& ble_cordio_get_h4_transport_drive return (ble_cordio_get_default_h4_transport_driver()); } +MBED_WEAK +void ble_cordio_set_cycfg_bt_lp_mode(bool status) { + (void)status; +} + #endif diff --git a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.h b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.h index e5657b76407..4ec1b6d3c2c 100644 --- a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.h +++ b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/CyH4TransportDriver.h @@ -137,5 +137,6 @@ class CyH4TransportDriver : public CordioHCITransportDriver { ble::vendor::cypress_ble::CyH4TransportDriver& ble_cordio_get_default_h4_transport_driver(); ble::vendor::cypress_ble::CyH4TransportDriver& ble_cordio_get_h4_transport_driver(); +void ble_cordio_set_cycfg_bt_lp_mode(bool status); #endif #endif /* CY_H4TRANSPORT_DRIVER_H_ */ diff --git a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/HCIDriver.cpp b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/HCIDriver.cpp index ff389c9f815..ae6bc61159a 100644 --- a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/HCIDriver.cpp +++ b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/HCIDriver.cpp @@ -557,3 +557,7 @@ ble::CordioHCIDriver& ble_cordio_get_hci_driver() ); return hci_driver; } + +void ble_cordio_set_lp_mode(bool status) { + ble_cordio_set_cycfg_bt_lp_mode(status); +} \ No newline at end of file diff --git a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/TARGET_PORTENTA_H7/cy_bt_cordio_cfg.cpp b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/TARGET_PORTENTA_H7/cy_bt_cordio_cfg.cpp index 2d668fed9ce..a3851782ac2 100644 --- a/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/TARGET_PORTENTA_H7/cy_bt_cordio_cfg.cpp +++ b/connectivity/drivers/ble/FEATURE_BLE/COMPONENT_CYW43XXX/TARGET_PORTENTA_H7/cy_bt_cordio_cfg.cpp @@ -35,10 +35,11 @@ #include "CyH4TransportDriver.h" #define cyhal_gpio_to_rtos(x) (x) -#define CYCFG_BT_LP_ENABLED (1) #define CYCFG_BT_HOST_WAKE_IRQ_EVENT WAKE_EVENT_ACTIVE_LOW #define CYCFG_BT_DEV_WAKE_POLARITY WAKE_EVENT_ACTIVE_LOW +bool cycfg_bt_lp_enabled = true; + /******************************************************************************* * Function Name: ble_cordio_get_h4_transport_driver ******************************************************************************** @@ -53,45 +54,30 @@ ble::vendor::cypress_ble::CyH4TransportDriver& ble_cordio_get_h4_transport_driver() { #if (defined(MBED_TICKLESS) && DEVICE_SLEEP && DEVICE_LPTICKER) - -#if (defined(CYCFG_BT_LP_ENABLED)) - if (CYCFG_BT_LP_ENABLED) { - static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( - /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), - /* RX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RX), - /* cts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_CTS), - /* rts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RTS), - /* power */ cyhal_gpio_to_rtos(CYBSP_BT_POWER), - DEF_BT_BAUD_RATE, - cyhal_gpio_to_rtos(CYBSP_BT_HOST_WAKE), - cyhal_gpio_to_rtos(CYBSP_BT_DEVICE_WAKE), - CYCFG_BT_HOST_WAKE_IRQ_EVENT, - CYCFG_BT_DEV_WAKE_POLARITY - ); - return s_transport_driver; - } else { /* CYCFG_BT_LP_ENABLED */ - static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( - /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), - /* RX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RX), - /* cts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_CTS), - /* rts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RTS), - /* power */ cyhal_gpio_to_rtos(CYBSP_BT_POWER), - DEF_BT_BAUD_RATE); - return s_transport_driver; - } -#else /* (defined(CYCFG_BT_LP_ENABLED)) */ - static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( - /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), - /* RX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RX), - /* cts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_CTS), - /* rts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RTS), - /* power */ cyhal_gpio_to_rtos(CYBSP_BT_POWER), - DEF_BT_BAUD_RATE), - cyhal_gpio_to_rtos(CYBSP_BT_HOST_WAKE), cyhal_gpio_to_rtos(CYBSP_BT_DEVICE_WAKE) - ); - return s_transport_driver; -#endif /* (defined(CYCFG_BT_LP_ENABLED)) */ - + if (cycfg_bt_lp_enabled) { + static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( + /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), + /* RX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RX), + /* cts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_CTS), + /* rts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RTS), + /* power */ cyhal_gpio_to_rtos(CYBSP_BT_POWER), + DEF_BT_BAUD_RATE, + cyhal_gpio_to_rtos(CYBSP_BT_HOST_WAKE), + cyhal_gpio_to_rtos(CYBSP_BT_DEVICE_WAKE), + CYCFG_BT_HOST_WAKE_IRQ_EVENT, + CYCFG_BT_DEV_WAKE_POLARITY + ); + return s_transport_driver; + } else { /* cycfg_bt_lp_enabled */ + static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( + /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), + /* RX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RX), + /* cts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_CTS), + /* rts */ cyhal_gpio_to_rtos(CYBSP_BT_UART_RTS), + /* power */ cyhal_gpio_to_rtos(CYBSP_BT_POWER), + DEF_BT_BAUD_RATE); + return s_transport_driver; + } #else /* (defined(MBED_TICKLESS) && DEVICE_SLEEP && DEVICE_LPTICKER) */ static ble::vendor::cypress_ble::CyH4TransportDriver s_transport_driver( /* TX */ cyhal_gpio_to_rtos(CYBSP_BT_UART_TX), @@ -103,3 +89,19 @@ ble::vendor::cypress_ble::CyH4TransportDriver& ble_cordio_get_h4_transport_drive return s_transport_driver; #endif /* (defined(MBED_TICKLESS) && DEVICE_SLEEP && DEVICE_LPTICKER) */ } + +/******************************************************************************* +* Function Name: ble_cordio_set_cycfg_bt_lp_mode +******************************************************************************** +* +* Sets the low-power mode configuration for the Bluetooth stack. +* By default, low-power mode is enabled. +* +* \param status +* - `true` to enable low-power mode. +* - `false` to disable low-power mode. +*******************************************************************************/ +void ble_cordio_set_cycfg_bt_lp_mode(bool status) +{ + cycfg_bt_lp_enabled = status; +}