diff --git a/config/telink/chip-module/Kconfig.defaults b/config/telink/chip-module/Kconfig.defaults index 661fead1ed3e1b..85a80b22b2084f 100644 --- a/config/telink/chip-module/Kconfig.defaults +++ b/config/telink/chip-module/Kconfig.defaults @@ -161,6 +161,9 @@ endchoice if BOARD_TLSR9528A_RETENTION || BOARD_TLSR9518ADK80D_RETENTION config BOARD_TLSR9X_NON_RETENTION_RAM_CODE default y if PM + +config TELINK_B9x_MATTER_RETENTION_LAYOUT + default y if PM endif # Config dynamic interrupts to have posibility to switch between BLE/Thread radio drivers diff --git a/examples/light-switch-app/telink/prj.conf b/examples/light-switch-app/telink/prj.conf index 9d986655de9c3f..184e824904c519 100755 --- a/examples/light-switch-app/telink/prj.conf +++ b/examples/light-switch-app/telink/prj.conf @@ -56,9 +56,3 @@ CONFIG_CHIP_CERTIFICATION_DECLARATION_STORAGE=n # Enable Power Management CONFIG_PM=y -CONFIG_TELINK_B9x_MATTER_RETENTION_LAYOUT=y -CONFIG_CHIP_ICD_SLOW_POLL_INTERVAL=10000 -CONFIG_CHIP_ICD_FAST_POLLING_INTERVAL=2000 -CONFIG_CHIP_ICD_IDLE_MODE_INTERVAL=2000 -CONFIG_CHIP_ICD_ACTIVE_MODE_INTERVAL=2001 -CONFIG_CHIP_ICD_ACTIVE_MODE_THRESHOLD=2000 diff --git a/examples/platform/telink/common/include/AppTaskCommon.h b/examples/platform/telink/common/include/AppTaskCommon.h index 6652a55210f601..e0b344df5b6ec1 100644 --- a/examples/platform/telink/common/include/AppTaskCommon.h +++ b/examples/platform/telink/common/include/AppTaskCommon.h @@ -103,7 +103,7 @@ class AppTaskCommon static void StartBleAdvHandler(AppEvent * aEvent); #endif -#if APP_USE_THREAD_START_BUTTON +#if APP_USE_THREAD_START_BUTTON || !CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE static void StartThreadButtonEventHandler(void); static void StartThreadHandler(AppEvent * aEvent); #endif diff --git a/examples/platform/telink/common/src/AppTaskCommon.cpp b/examples/platform/telink/common/src/AppTaskCommon.cpp index 41899c8a1f9c73..9ffe341d97cec9 100644 --- a/examples/platform/telink/common/src/AppTaskCommon.cpp +++ b/examples/platform/telink/common/src/AppTaskCommon.cpp @@ -54,7 +54,7 @@ const struct gpio_dt_spec sBleStartButtonDt = GPIO_DT_SPEC_GET(DT_NODELABEL(key_ #if APP_USE_THREAD_START_BUTTON const struct gpio_dt_spec sThreadStartButtonDt = GPIO_DT_SPEC_GET(DT_NODELABEL(key_3), gpios); #endif -#if APP_USE_EXAMPLE_START_BUTTON +#if APP_USE_EXAMPLE_START_BUTTON const struct gpio_dt_spec sExampleActionButtonDt = GPIO_DT_SPEC_GET(DT_NODELABEL(key_4), gpios); #endif #else @@ -140,11 +140,13 @@ class AppCallbacks : public AppDelegate void OnCommissioningSessionStarted() override { isComissioningStarted = true; } void OnCommissioningSessionStopped() override { isComissioningStarted = false; } void OnCommissioningSessionEstablishmentError(CHIP_ERROR err) override { sIsCommissioningFailed = true; } +#if CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE void OnCommissioningWindowClosed() override { if (!isComissioningStarted) chip::DeviceLayer::Internal::BLEMgr().Shutdown(); } +#endif }; AppCallbacks sCallbacks; @@ -240,6 +242,10 @@ CHIP_ERROR AppTaskCommon::StartApp(void) AppEvent event = {}; +#if !CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE + StartThreadButtonEventHandler(); +#endif + while (true) { GetEvent(&event); @@ -609,7 +615,7 @@ void AppTaskCommon::FactoryResetTimerEventHandler(AppEvent * aEvent) LOG_INF("Factory Reset Trigger Counter is cleared"); } -#if APP_USE_THREAD_START_BUTTON +#if APP_USE_THREAD_START_BUTTON || !CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE void AppTaskCommon::StartThreadButtonEventHandler(void) { AppEvent event; @@ -626,8 +632,13 @@ void AppTaskCommon::StartThreadHandler(AppEvent * aEvent) if (!chip::DeviceLayer::ConnectivityMgr().IsThreadProvisioned()) { // Switch context from BLE to Thread +#if CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE Internal::BLEManagerImpl sInstance; sInstance.SwitchToIeee802154(); +#else + ThreadStackMgrImpl().SetRadioBlocked(false); + ThreadStackMgrImpl().SetThreadEnabled(true); +#endif StartDefaultThreadNetwork(); } else