From 7b7a5d514bd72591103879e4daa1a99b235d8750 Mon Sep 17 00:00:00 2001 From: Yuanyao Zhong <82843247+yyzhong-g@users.noreply.github.com> Date: Mon, 1 Nov 2021 10:59:55 -0400 Subject: [PATCH] Add pw_trace functionality to esp32 all cluster app (#11203) Add pw_trace rpc service to Rpc.cpp. --- examples/all-clusters-app/esp32/CMakeLists.txt | 1 + .../all-clusters-app/esp32/main/CMakeLists.txt | 4 ++++ examples/all-clusters-app/esp32/main/Rpc.cpp | 16 ++++++++++++++++ 3 files changed, 21 insertions(+) diff --git a/examples/all-clusters-app/esp32/CMakeLists.txt b/examples/all-clusters-app/esp32/CMakeLists.txt index 2b918486608660..024a42a8d4d43c 100644 --- a/examples/all-clusters-app/esp32/CMakeLists.txt +++ b/examples/all-clusters-app/esp32/CMakeLists.txt @@ -45,6 +45,7 @@ include(third_party/connectedhomeip/third_party/pigweed/repo/pw_build/pigweed.cm pw_set_backend(pw_log pw_log_basic) pw_set_backend(pw_assert pw_assert_log) pw_set_backend(pw_sys_io pw_sys_io.esp32) +pw_set_backend(pw_trace pw_trace_tokenized) add_subdirectory(third_party/connectedhomeip/third_party/pigweed/repo) add_subdirectory(third_party/connectedhomeip/third_party/nanopb/repo) diff --git a/examples/all-clusters-app/esp32/main/CMakeLists.txt b/examples/all-clusters-app/esp32/main/CMakeLists.txt index bd0f28a8d4e55a..4ddaced3059673 100644 --- a/examples/all-clusters-app/esp32/main/CMakeLists.txt +++ b/examples/all-clusters-app/esp32/main/CMakeLists.txt @@ -188,6 +188,10 @@ target_link_libraries(${COMPONENT_LIB} PUBLIC pw_hdlc pw_log pw_rpc.server + pw_trace_tokenized + pw_trace_tokenized.trace_buffer + pw_trace_tokenized.rpc_service + pw_trace_tokenized.protos.nanopb_rpc ) set_property(TARGET ${chip_lib} APPEND PROPERTY LINK_LIBRARIES ${COMPONENT_LIB}) diff --git a/examples/all-clusters-app/esp32/main/Rpc.cpp b/examples/all-clusters-app/esp32/main/Rpc.cpp index 59990de03e7a93..60377ec2df4d74 100644 --- a/examples/all-clusters-app/esp32/main/Rpc.cpp +++ b/examples/all-clusters-app/esp32/main/Rpc.cpp @@ -44,7 +44,9 @@ #include "pw_containers/flat_map.h" #include "pw_status/status.h" #include "pw_status/try.h" +#include "pw_trace_tokenized/trace_rpc_service_nanopb.h" #include "wifi_service/wifi_service.rpc.pb.h" +#include #include "WiFiProvisioning.h" @@ -52,6 +54,17 @@ static const char * TAG = "RPC"; +// Define trace time for pw_trace +PW_TRACE_TIME_TYPE pw_trace_GetTraceTime() +{ + return (PW_TRACE_TIME_TYPE) chip::System::SystemClock().GetMonotonicMicroseconds64().count(); +} +// Microsecond time source +size_t pw_trace_GetTraceTimeTicksPerSecond() +{ + return 1000000; +} + namespace chip { namespace rpc { namespace { @@ -291,6 +304,7 @@ Esp32Button button_service; Esp32Device device_service; Lighting lighting_service; Wifi wifi_service; +pw::trace::TraceService trace_service; void RegisterServices(pw::rpc::Server & server) { @@ -298,6 +312,8 @@ void RegisterServices(pw::rpc::Server & server) server.RegisterService(device_service); server.RegisterService(lighting_service); server.RegisterService(wifi_service); + server.RegisterService(trace_service); + PW_TRACE_SET_ENABLED(true); } void RunRpcService(void *)