From b3f626e0f9c8e28db37aa2edffb9665641483111 Mon Sep 17 00:00:00 2001 From: Yufeng Wang Date: Mon, 22 Nov 2021 11:48:08 -0800 Subject: [PATCH 1/3] Reporting relevant attribute change when various faults are detected --- .../general_diagnostics_server.cpp | 63 +++++++++++++++++++ src/include/platform/DiagnosticDataProvider.h | 20 +++++- 2 files changed, 82 insertions(+), 1 deletion(-) diff --git a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp index dc35be5453494c..8ac65c37e77ce2 100644 --- a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp +++ b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp @@ -213,6 +213,69 @@ class GeneralDiagnosticDelegate : public DeviceLayer::ConnectivityManagerDelegat } } } + + // Get called when the Node detects a hardware fault has been raised. + void OnHardwareFaultsDetected() override + { + ChipLogProgress(Zcl, "GeneralDiagnosticDelegate: OnHardwareFaultsDetected"); + + for (uint16_t index = 0; index < emberAfEndpointCount(); index++) + { + if (emberAfEndpointIndexIsEnabled(index)) + { + EndpointId endpointId = emberAfEndpointFromIndex(index); + + if (emberAfContainsServer(endpointId, GeneralDiagnostics::Id)) + { + // If General Diagnostics cluster is implemented on this endpoint + MatterReportingAttributeChangeCallback(endpointId, GeneralDiagnostics::Id, + GeneralDiagnostics::Attributes::ActiveHardwareFaults::Id); + } + } + } + } + + // Get called when the Node detects a radio fault has been raised. + void OnHardwareFaultsDetected() override + { + ChipLogProgress(Zcl, "GeneralDiagnosticDelegate: OnHardwareFaultsDetected"); + + for (uint16_t index = 0; index < emberAfEndpointCount(); index++) + { + if (emberAfEndpointIndexIsEnabled(index)) + { + EndpointId endpointId = emberAfEndpointFromIndex(index); + + if (emberAfContainsServer(endpointId, GeneralDiagnostics::Id)) + { + // If General Diagnostics cluster is implemented on this endpoint + MatterReportingAttributeChangeCallback(endpointId, GeneralDiagnostics::Id, + GeneralDiagnostics::Attributes::GetActiveRadioFaults::Id); + } + } + } + } + + // Get called when the Node detects a network fault has been raised. + void OnHardwareFaultsDetected() override + { + ChipLogProgress(Zcl, "GeneralDiagnosticDelegate: OnHardwareFaultsDetected"); + + for (uint16_t index = 0; index < emberAfEndpointCount(); index++) + { + if (emberAfEndpointIndexIsEnabled(index)) + { + EndpointId endpointId = emberAfEndpointFromIndex(index); + + if (emberAfContainsServer(endpointId, GeneralDiagnostics::Id)) + { + // If General Diagnostics cluster is implemented on this endpoint + MatterReportingAttributeChangeCallback(endpointId, GeneralDiagnostics::Id, + GeneralDiagnostics::Attributes::GetActiveNetworkFaults::Id); + } + } + } + } }; GeneralDiagnosticDelegate gDiagnosticDelegate; diff --git a/src/include/platform/DiagnosticDataProvider.h b/src/include/platform/DiagnosticDataProvider.h index b64914688c1d4d..e83f8f05f1088e 100644 --- a/src/include/platform/DiagnosticDataProvider.h +++ b/src/include/platform/DiagnosticDataProvider.h @@ -49,9 +49,27 @@ class DiagnosticsDelegate /** * @brief - * Called after the current device is rebooted + * Called after the current device is rebooted. */ virtual void OnDeviceRebooted() {} + + /** + * @brief + * Called when the Node detects a hardware fault has been raised. + */ + virtual void OnHardwareFaultsDetected() {} + + /** + * @brief + * Called when the Node detects a radio fault has been raised. + */ + virtual void OnRadioFaultsDetected() {} + + /** + * @brief + * Called when the Node detects a network fault has been raised. + */ + virtual void OnNetworkFaultsDetected() {} }; /** From fbdd947d7f6bb8cd8383a4b7a87509a245d17fb1 Mon Sep 17 00:00:00 2001 From: Yufeng Wang Date: Mon, 22 Nov 2021 12:14:29 -0800 Subject: [PATCH 2/3] Update src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp Co-authored-by: Michael Sandstedt --- .../general_diagnostics_server/general_diagnostics_server.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp index 8ac65c37e77ce2..054a24adde2848 100644 --- a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp +++ b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp @@ -236,7 +236,7 @@ class GeneralDiagnosticDelegate : public DeviceLayer::ConnectivityManagerDelegat } // Get called when the Node detects a radio fault has been raised. - void OnHardwareFaultsDetected() override + void OnRadioFaultsDetected() override { ChipLogProgress(Zcl, "GeneralDiagnosticDelegate: OnHardwareFaultsDetected"); From e119b2ac51f084b95956ca7de1fd1109e73c5027 Mon Sep 17 00:00:00 2001 From: Yufeng Wang Date: Mon, 22 Nov 2021 12:14:34 -0800 Subject: [PATCH 3/3] Update src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp Co-authored-by: Michael Sandstedt --- .../general_diagnostics_server.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp index 054a24adde2848..daa3b6b90b98eb 100644 --- a/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp +++ b/src/app/clusters/general_diagnostics_server/general_diagnostics_server.cpp @@ -250,14 +250,14 @@ class GeneralDiagnosticDelegate : public DeviceLayer::ConnectivityManagerDelegat { // If General Diagnostics cluster is implemented on this endpoint MatterReportingAttributeChangeCallback(endpointId, GeneralDiagnostics::Id, - GeneralDiagnostics::Attributes::GetActiveRadioFaults::Id); + GeneralDiagnostics::Attributes::ActiveRadioFaults::Id); } } } } // Get called when the Node detects a network fault has been raised. - void OnHardwareFaultsDetected() override + void OnNetworkFaultsDetected() override { ChipLogProgress(Zcl, "GeneralDiagnosticDelegate: OnHardwareFaultsDetected"); @@ -271,7 +271,7 @@ class GeneralDiagnosticDelegate : public DeviceLayer::ConnectivityManagerDelegat { // If General Diagnostics cluster is implemented on this endpoint MatterReportingAttributeChangeCallback(endpointId, GeneralDiagnostics::Id, - GeneralDiagnostics::Attributes::GetActiveNetworkFaults::Id); + GeneralDiagnostics::Attributes::ActiveNetworkFaults::Id); } } }