-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[ESP32] Platform diagnostics framework #36532
base: master
Are you sure you want to change the base?
[ESP32] Platform diagnostics framework #36532
Conversation
5ef9201
to
97d0be3
Compare
a93a065
to
7178050
Compare
PR #36532: Size comparison from 61e288a to 7178050 Full report (3 builds for cc32xx, stm32)
|
667abcd
to
ed14abb
Compare
PR #36532: Size comparison from 61e288a to ed14abb Full report (68 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
Would have been helpful if something in the PR title or description made it clear this is esp32-only... |
ed14abb
to
6571c5e
Compare
PR #36532: Size comparison from d8ededa to 6571c5e Full report (68 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
examples/temperature-measurement-app/esp32/main/diagnostic-logs-provider-delegate-impl.cpp
Outdated
Show resolved
Hide resolved
...ples/temperature-measurement-app/esp32/main/include/diagnostic-logs-provider-delegate-impl.h
Outdated
Show resolved
Hide resolved
...ples/temperature-measurement-app/esp32/main/include/diagnostic-logs-provider-delegate-impl.h
Outdated
Show resolved
Hide resolved
9e148bb
to
1ce3585
Compare
PR #36532: Size comparison from 0ac52eb to 1ce3585 Full report (11 builds for cc13x4_26x4, cc32xx, qpg, stm32, tizen)
|
1ce3585
to
eb088ab
Compare
PR #36532: Size comparison from ffbc362 to eb088ab Full report (3 builds for cc32xx, stm32)
|
ca96506
to
ba3ac54
Compare
ba3ac54
to
a98b1f8
Compare
PR #36532: Size comparison from ffbc362 to a98b1f8 Full report (69 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
03d2d73
to
e58bee7
Compare
PR #36532: Size comparison from 84fb78f to 3415978 Full report (69 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
3415978
to
0befb4f
Compare
PR #36532: Size comparison from 5d42d92 to 0befb4f Full report (69 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
208f588
to
e8db459
Compare
PR #36532: Size comparison from 2c11741 to e8db459 Full report (69 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
- Working backend with metric, trace and counter diagnostics - Diagnostic interface implementation with ring buffer storage - Added option ENABLE_ESP_DIAGNOSTICS_TRACE in chip KConfig - Added required options for enabling matter diagnostic trace in project Kconfig - Enabled diagnostic trace for temperature-measurement-app example
- Resolve buffer related issues - Add store diagnostic call for trace_end and trace_instant - Update scoped macro - Remove extra namespace values, spaces and print statements - Remove evicthead call for circular buffer after read successful
- Resolve buffer issues - Use single buffer for store and retrieve of diagnostics - Resolve data loss issue
…essary comments, format files, namespace changes
9d4af7b
to
8b2dc95
Compare
- Add related logic in temperature-measurement-app
8b2dc95
to
6835f62
Compare
PR #36532: Size comparison from 017e8b5 to 6835f62 Full report (69 builds for bl602, bl702, bl702l, cc13x4_26x4, cc32xx, cyw30739, efr32, esp32, linux, nrfconnect, nxp, psoc6, qpg, stm32, telink, tizen)
|
@@ -108,8 +118,24 @@ CHIP_ERROR LogProvider::PrepareLogContextForIntent(LogContext * context, IntentE | |||
switch (intent) | |||
{ | |||
case IntentEnum::kEndUserSupport: { | |||
#if CONFIG_ENABLE_ESP_DIAGNOSTICS_TRACE | |||
CircularDiagnosticBuffer & diagnosticStorage = CircularDiagnosticBuffer::GetInstance(); | |||
MutableByteSpan endUserSupportSpan(endUserBuffer, 2048); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we either define a const, or #define for this magic number 2048, and add some comment about its usage.
examples/temperature-measurement-app/esp32/main/diagnostic-logs-provider-delegate-impl.cpp
Show resolved
Hide resolved
#if CONFIG_ENABLE_ESP_DIAGNOSTICS_TRACE | ||
#include <tracing/esp32_diagnostic_trace/DiagnosticStorageManager.h> | ||
static uint8_t endUserBuffer[CONFIG_END_USER_BUFFER_SIZE]; | ||
using namespace chip::Tracing::Diagnostics; | ||
#endif // CONFIG_ENABLE_ESP_DIAGNOSTICS_TRACE |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is not used in this file, so can this be moved to .cpp?
@@ -75,14 +79,19 @@ static AppDeviceCallbacks EchoCallbacks; | |||
static void InitServer(intptr_t context) | |||
{ | |||
Esp32AppServer::Init(); // Init ZCL Data Model and CHIP App Server AND Initialize device attestation config | |||
#if CONFIG_ENABLE_ESP_DIAGNOSTICS_TRACE | |||
CircularDiagnosticBuffer & diagnosticStorage = CircularDiagnosticBuffer::GetInstance(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we can do this without singleton design. We already are passing the buffer and buffer size to the impl so IMO, singleton is not required?
|
||
void Init(uint8_t * buffer, size_t bufferLength) { chip::TLV::TLVCircularBuffer::Init(buffer, bufferLength); } | ||
|
||
CHIP_ERROR Store(DiagnosticEntry & entry) override |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
CHIP_ERROR Store(DiagnosticEntry & entry) override | |
CHIP_ERROR Store(const DiagnosticEntry & entry) override |
using HashValue = uint32_t; | ||
|
||
// Implements a murmurhash with 0 seed. | ||
uint32_t MurmurHash(const void * key) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we make this static or move inside the anonymous namespace?
Problem:
The existing implementation lacks the ability to collect diagnostics using the diagnostic-logs cluster.
Change Overview:
Platform Diagnostic Framework:
Designed to collect, store, and retrieve diagnostic data.
Implemented new backend:
Diagnostic data collection integrated using Matter Traces.
Diagnostic data is stored in a TLVCircularBuffer for efficient memory utilization.
Integration with the Temperature Measurement App for platform esp32.
Testing:
Verified commissioning and retrieval of diagnostics using the diagnostic-logs cluster over BDX on the ESP32-C3 chip with the temperature-measurement-app example.