1*61c4878aSAndroid Build Coastguard Worker // Copyright 2020 The Pigweed Authors 2*61c4878aSAndroid Build Coastguard Worker // 3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not 4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of 5*61c4878aSAndroid Build Coastguard Worker // the License at 6*61c4878aSAndroid Build Coastguard Worker // 7*61c4878aSAndroid Build Coastguard Worker // https://www.apache.org/licenses/LICENSE-2.0 8*61c4878aSAndroid Build Coastguard Worker // 9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under 13*61c4878aSAndroid Build Coastguard Worker // the License. 14*61c4878aSAndroid Build Coastguard Worker //============================================================================== 15*61c4878aSAndroid Build Coastguard Worker // BUILD 16*61c4878aSAndroid Build Coastguard Worker // ninja -C out 17*61c4878aSAndroid Build Coastguard Worker // pw_strict_host_clang_debug/obj/pw_trace_tokenized/bin/trace_tokenized_example_basic 18*61c4878aSAndroid Build Coastguard Worker // 19*61c4878aSAndroid Build Coastguard Worker // RUN 20*61c4878aSAndroid Build Coastguard Worker // ./out/pw_strict_host_clang_debug/obj/pw_trace_tokenized/bin/trace_tokenized_example_basic 21*61c4878aSAndroid Build Coastguard Worker // trace.bin 22*61c4878aSAndroid Build Coastguard Worker // 23*61c4878aSAndroid Build Coastguard Worker // DECODE 24*61c4878aSAndroid Build Coastguard Worker // python pw_trace_tokenized/py/trace_tokenized.py -i trace.bin -o trace.json 25*61c4878aSAndroid Build Coastguard Worker // ./out/pw_strict_host_clang_debug/obj/pw_trace_tokenized/bin/trace_tokenized_example_basic#trace 26*61c4878aSAndroid Build Coastguard Worker // 27*61c4878aSAndroid Build Coastguard Worker // VIEW 28*61c4878aSAndroid Build Coastguard Worker // In chrome navigate to chrome://tracing, and load the trace.json file. 29*61c4878aSAndroid Build Coastguard Worker 30*61c4878aSAndroid Build Coastguard Worker #include "pw_log/log.h" 31*61c4878aSAndroid Build Coastguard Worker #include "pw_trace/example/sample_app.h" 32*61c4878aSAndroid Build Coastguard Worker #include "pw_trace_tokenized/example/trace_to_file.h" 33*61c4878aSAndroid Build Coastguard Worker #include "pw_trace_tokenized/trace_callback.h" 34*61c4878aSAndroid Build Coastguard Worker main(int argc,char ** argv)35*61c4878aSAndroid Build Coastguard Workerint main(int argc, char** argv) { // Take filename as arg 36*61c4878aSAndroid Build Coastguard Worker if (argc != 2) { 37*61c4878aSAndroid Build Coastguard Worker PW_LOG_ERROR("Expected output file name as argument.\n"); 38*61c4878aSAndroid Build Coastguard Worker return -1; 39*61c4878aSAndroid Build Coastguard Worker } 40*61c4878aSAndroid Build Coastguard Worker 41*61c4878aSAndroid Build Coastguard Worker // Enable tracing. 42*61c4878aSAndroid Build Coastguard Worker PW_TRACE_SET_ENABLED(true); 43*61c4878aSAndroid Build Coastguard Worker 44*61c4878aSAndroid Build Coastguard Worker // Dump trace data to the file passed in. 45*61c4878aSAndroid Build Coastguard Worker pw::trace::TraceToFile trace_to_file(pw::trace::GetCallbacks(), argv[1]); 46*61c4878aSAndroid Build Coastguard Worker 47*61c4878aSAndroid Build Coastguard Worker PW_LOG_INFO("Running basic trace example...\n"); 48*61c4878aSAndroid Build Coastguard Worker RunTraceSampleApp(); 49*61c4878aSAndroid Build Coastguard Worker return 0; 50*61c4878aSAndroid Build Coastguard Worker } 51