test_trace.c 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915
  1. /*
  2. * SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <stddef.h>
  7. #include <stdint.h>
  8. #include <string.h>
  9. #include <stdio.h>
  10. #include <stdarg.h>
  11. #include "unity.h"
  12. #include "driver/gptimer.h"
  13. #include "esp_intr_alloc.h"
  14. #include "esp_rom_sys.h"
  15. #include "freertos/FreeRTOS.h"
  16. #include "freertos/semphr.h"
  17. #include "freertos/task.h"
  18. #if CONFIG_APPTRACE_ENABLE == 1
  19. #include "esp_app_trace.h"
  20. #include "esp_app_trace_util.h"
  21. #define ESP_APPTRACE_TEST_USE_PRINT_LOCK 0
  22. #define ESP_APPTRACE_TEST_PRN_WRERR_MAX 5
  23. #define ESP_APPTRACE_TEST_BLOCKS_BEFORE_CRASH 100
  24. #define ESP_APPTRACE_TEST_BLOCK_SIZE 1024
  25. #define LOG_LOCAL_LEVEL ESP_LOG_VERBOSE
  26. #include "esp_log.h"
  27. const static char *TAG = "esp_apptrace_test";
  28. #if ESP_APPTRACE_TEST_USE_PRINT_LOCK == 1
  29. #define ESP_APPTRACE_TEST_LOG( format, ... ) \
  30. do { \
  31. BaseType_t ret; \
  32. if (xPortInIsrContext()) \
  33. ret = xSemaphoreTakeFromISR(s_print_lock, NULL); \
  34. else \
  35. ret = xSemaphoreTake(s_print_lock, portMAX_DELAY); \
  36. if (ret == pdTRUE) { \
  37. esp_rom_printf(format, ##__VA_ARGS__); \
  38. if (xPortInIsrContext()) \
  39. xSemaphoreGiveFromISR(s_print_lock, NULL); \
  40. else \
  41. xSemaphoreGive(s_print_lock); \
  42. } \
  43. } while(0)
  44. #else
  45. #define ESP_APPTRACE_TEST_LOG( format, ... ) \
  46. do { \
  47. esp_rom_printf(format, ##__VA_ARGS__); \
  48. } while(0)
  49. #endif
  50. #define ESP_APPTRACE_TEST_LOG_LEVEL( _L_, level, format, ... ) \
  51. do { \
  52. if (LOG_LOCAL_LEVEL >= level) { \
  53. ESP_APPTRACE_TEST_LOG(LOG_FORMAT(_L_, format), esp_log_early_timestamp(), TAG, ##__VA_ARGS__); \
  54. } \
  55. } while(0)
  56. #define ESP_APPTRACE_TEST_LOGE( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(E, ESP_LOG_ERROR, format, ##__VA_ARGS__)
  57. #define ESP_APPTRACE_TEST_LOGW( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(W, ESP_LOG_WARN, format, ##__VA_ARGS__)
  58. #define ESP_APPTRACE_TEST_LOGI( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(I, ESP_LOG_INFO, format, ##__VA_ARGS__)
  59. #define ESP_APPTRACE_TEST_LOGD( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(D, ESP_LOG_DEBUG, format, ##__VA_ARGS__)
  60. #define ESP_APPTRACE_TEST_LOGV( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(V, ESP_LOG_VERBOSE, format, ##__VA_ARGS__)
  61. #define ESP_APPTRACE_TEST_LOGO( format, ... ) ESP_APPTRACE_TEST_LOG_LEVEL(E, ESP_LOG_NONE, format, ##__VA_ARGS__)
  62. #if CONFIG_APPTRACE_SV_ENABLE == 0
  63. #define ESP_APPTRACE_TEST_WRITE(_b_, _s_) esp_apptrace_write(ESP_APPTRACE_DEST_TRAX, _b_, _s_, ESP_APPTRACE_TMO_INFINITE)
  64. #define ESP_APPTRACE_TEST_WRITE_FROM_ISR(_b_, _s_) esp_apptrace_write(ESP_APPTRACE_DEST_TRAX, _b_, _s_, 0UL)
  65. #define ESP_APPTRACE_TEST_WRITE_NOWAIT(_b_, _s_) esp_apptrace_write(ESP_APPTRACE_DEST_TRAX, _b_, _s_, 0)
  66. typedef struct {
  67. uint8_t *buf;
  68. uint32_t buf_sz;
  69. uint8_t mask;
  70. uint32_t period; // trace write period in us
  71. uint32_t wr_err;
  72. uint32_t wr_cnt;
  73. } esp_apptrace_test_gen_data_t;
  74. typedef struct {
  75. gptimer_handle_t gptimer;
  76. bool (*isr_func)(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx);
  77. esp_apptrace_test_gen_data_t data;
  78. } esp_apptrace_test_timer_arg_t;
  79. typedef struct {
  80. int nowait;
  81. int core;
  82. int prio;
  83. void (*task_func)(void *);
  84. esp_apptrace_test_gen_data_t data;
  85. volatile int stop;
  86. SemaphoreHandle_t done;
  87. uint32_t timers_num;
  88. esp_apptrace_test_timer_arg_t *timers;
  89. } esp_apptrace_test_task_arg_t;
  90. typedef struct {
  91. uint32_t tasks_num;
  92. esp_apptrace_test_task_arg_t *tasks;
  93. } esp_apptrace_test_cfg_t;
  94. #if ESP_APPTRACE_TEST_USE_PRINT_LOCK == 1
  95. static SemaphoreHandle_t s_print_lock;
  96. #endif
  97. static uint64_t esp_apptrace_test_ts_get(void);
  98. static bool esp_apptrace_test_timer_isr(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx)
  99. {
  100. esp_apptrace_test_timer_arg_t *tim_arg = (esp_apptrace_test_timer_arg_t *)user_ctx;
  101. uint32_t *ts = (uint32_t *)(tim_arg->data.buf + sizeof(uint32_t));
  102. *ts = (uint32_t)esp_apptrace_test_ts_get();
  103. memset(tim_arg->data.buf + 2 * sizeof(uint32_t), tim_arg->data.wr_cnt & tim_arg->data.mask, tim_arg->data.buf_sz - 2 * sizeof(uint32_t));
  104. int res = ESP_APPTRACE_TEST_WRITE_FROM_ISR(tim_arg->data.buf, tim_arg->data.buf_sz);
  105. if (res == ESP_OK) {
  106. tim_arg->data.wr_err = 0;
  107. }
  108. tim_arg->data.wr_cnt++;
  109. return true;
  110. }
  111. static bool esp_apptrace_test_timer_isr_crash(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx)
  112. {
  113. esp_apptrace_test_timer_arg_t *tim_arg = (esp_apptrace_test_timer_arg_t *)user_ctx;
  114. if (tim_arg->data.wr_cnt < ESP_APPTRACE_TEST_BLOCKS_BEFORE_CRASH) {
  115. uint32_t *ts = (uint32_t *)(tim_arg->data.buf + sizeof(uint32_t));
  116. *ts = (uint32_t)esp_apptrace_test_ts_get();//xthal_get_ccount();//xTaskGetTickCount();
  117. memset(tim_arg->data.buf + 2 * sizeof(uint32_t), tim_arg->data.wr_cnt & tim_arg->data.mask, tim_arg->data.buf_sz - 2 * sizeof(uint32_t));
  118. int res = ESP_APPTRACE_TEST_WRITE_FROM_ISR(tim_arg->data.buf, tim_arg->data.buf_sz);
  119. if (res != ESP_OK) {
  120. esp_rom_printf("tim-%x: Failed to write trace %d %x!\n", tim_arg->gptimer, res, tim_arg->data.wr_cnt & tim_arg->data.mask);
  121. } else {
  122. esp_rom_printf("tim-%x: Written chunk%d %d bytes, %x\n",
  123. timer, tim_arg->data.wr_cnt, tim_arg->data.buf_sz, tim_arg->data.wr_cnt & tim_arg->data.mask);
  124. tim_arg->data.wr_cnt++;
  125. }
  126. } else {
  127. uint32_t *ptr = 0;
  128. *ptr = 1000;
  129. }
  130. return true;
  131. }
  132. static void esp_apptrace_dummy_task(void *p)
  133. {
  134. esp_apptrace_test_task_arg_t *arg = (esp_apptrace_test_task_arg_t *) p;
  135. TickType_t tmo_ticks = arg->data.period / (1000 * portTICK_PERIOD_MS);
  136. ESP_APPTRACE_TEST_LOGI("%x: run dummy task (period %u us, %u timers)", xTaskGetCurrentTaskHandle(), arg->data.period, arg->timers_num);
  137. for (int i = 0; i < arg->timers_num; i++) {
  138. gptimer_config_t timer_config = {
  139. .clk_src = GPTIMER_CLK_SRC_DEFAULT,
  140. .direction = GPTIMER_COUNT_UP,
  141. .resolution_hz = 1000000,
  142. };
  143. TEST_ESP_OK(gptimer_new_timer(&timer_config, &arg->timers[i].gptimer));
  144. *(uint32_t *)arg->timers[i].data.buf = (uint32_t)arg->timers[i].gptimer | (1 << 31);
  145. ESP_APPTRACE_TEST_LOGI("%x: start timer %x period %u us", xTaskGetCurrentTaskHandle(), arg->timers[i].gptimer, arg->timers[i].data.period);
  146. gptimer_alarm_config_t alarm_config = {
  147. .reload_count = 0,
  148. .alarm_count = arg->timers[i].data.period,
  149. .flags.auto_reload_on_alarm = true,
  150. };
  151. gptimer_event_callbacks_t cbs = {
  152. .on_alarm = arg->timers[i].isr_func,
  153. };
  154. TEST_ESP_OK(gptimer_register_event_callbacks(arg->timers[i].gptimer, &cbs, &arg->timers[i]));
  155. TEST_ESP_OK(gptimer_set_alarm_action(arg->timers[i].gptimer, &alarm_config));
  156. TEST_ESP_OK(gptimer_start(arg->timers[i].gptimer));
  157. }
  158. int i = 0;
  159. while (!arg->stop) {
  160. ESP_APPTRACE_TEST_LOGD("%x: dummy task work %d.%d", xTaskGetCurrentTaskHandle(), cpu_hal_get_core_id(), i++);
  161. if (tmo_ticks) {
  162. vTaskDelay(tmo_ticks);
  163. }
  164. }
  165. for (int i = 0; i < arg->timers_num; i++) {
  166. TEST_ESP_OK(gptimer_stop(arg->timers[i].gptimer));
  167. TEST_ESP_OK(gptimer_del_timer(arg->timers[i].gptimer));
  168. }
  169. xSemaphoreGive(arg->done);
  170. vTaskDelay(1);
  171. vTaskDelete(NULL);
  172. }
  173. static void esp_apptrace_test_task(void *p)
  174. {
  175. esp_apptrace_test_task_arg_t *arg = (esp_apptrace_test_task_arg_t *) p;
  176. int res;
  177. TickType_t tmo_ticks = arg->data.period / (1000 * portTICK_PERIOD_MS);
  178. ESP_APPTRACE_TEST_LOGI("%x: run (period %u us, stamp mask %x, %u timers)", xTaskGetCurrentTaskHandle(), arg->data.period, arg->data.mask, arg->timers_num);
  179. for (int i = 0; i < arg->timers_num; i++) {
  180. gptimer_config_t timer_config = {
  181. .clk_src = GPTIMER_CLK_SRC_DEFAULT,
  182. .direction = GPTIMER_COUNT_UP,
  183. .resolution_hz = 1000000,
  184. };
  185. TEST_ESP_OK(gptimer_new_timer(&timer_config, &arg->timers[i].gptimer));
  186. *(uint32_t *)arg->timers[i].data.buf = ((uint32_t)arg->timers[i].gptimer) | (1 << 31) | (cpu_hal_get_core_id() ? 0x1 : 0);
  187. ESP_APPTRACE_TEST_LOGI("%x: start timer %x period %u us", xTaskGetCurrentTaskHandle(), arg->timers[i].gptimer, arg->timers[i].data.period);
  188. gptimer_alarm_config_t alarm_config = {
  189. .reload_count = 0,
  190. .alarm_count = arg->timers[i].data.period,
  191. .flags.auto_reload_on_alarm = true,
  192. };
  193. gptimer_event_callbacks_t cbs = {
  194. .on_alarm = arg->timers[i].isr_func,
  195. };
  196. TEST_ESP_OK(gptimer_register_event_callbacks(arg->timers[i].gptimer, &cbs, &arg->timers[i]));
  197. TEST_ESP_OK(gptimer_set_alarm_action(arg->timers[i].gptimer, &alarm_config));
  198. TEST_ESP_OK(gptimer_start(arg->timers[i].gptimer));
  199. }
  200. *(uint32_t *)arg->data.buf = (uint32_t)xTaskGetCurrentTaskHandle() | (cpu_hal_get_core_id() ? 0x1 : 0);
  201. arg->data.wr_cnt = 0;
  202. arg->data.wr_err = 0;
  203. while (!arg->stop) {
  204. uint32_t *ts = (uint32_t *)(arg->data.buf + sizeof(uint32_t));
  205. *ts = (uint32_t)esp_apptrace_test_ts_get();
  206. memset(arg->data.buf + 2 * sizeof(uint32_t), arg->data.wr_cnt & arg->data.mask, arg->data.buf_sz - 2 * sizeof(uint32_t));
  207. // ESP_APPTRACE_TEST_LOGD("%x:%x: Write chunk%d %d bytes, %x", xTaskGetCurrentTaskHandle(), *ts, arg->data.wr_cnt, arg->data.buf_sz, arg->data.wr_cnt & arg->data.mask);
  208. if (arg->nowait) {
  209. res = ESP_APPTRACE_TEST_WRITE_NOWAIT(arg->data.buf, arg->data.buf_sz);
  210. } else {
  211. res = ESP_APPTRACE_TEST_WRITE(arg->data.buf, arg->data.buf_sz);
  212. }
  213. if (res) {
  214. if (1) { //arg->data.wr_err++ < ESP_APPTRACE_TEST_PRN_WRERR_MAX) {
  215. ESP_APPTRACE_TEST_LOGE("%x: Failed to write trace %d %x!", xTaskGetCurrentTaskHandle(), res, arg->data.wr_cnt & arg->data.mask);
  216. if (arg->data.wr_err == ESP_APPTRACE_TEST_PRN_WRERR_MAX) {
  217. ESP_APPTRACE_TEST_LOGE("\n");
  218. }
  219. }
  220. } else {
  221. if (0) {
  222. ESP_APPTRACE_TEST_LOGD("%x:%x: Written chunk%d %d bytes, %x", xTaskGetCurrentTaskHandle(), *ts, arg->data.wr_cnt, arg->data.buf_sz, arg->data.wr_cnt & arg->data.mask);
  223. }
  224. arg->data.wr_err = 0;
  225. }
  226. arg->data.wr_cnt++;
  227. if (tmo_ticks) {
  228. vTaskDelay(tmo_ticks);
  229. }
  230. }
  231. for (int i = 0; i < arg->timers_num; i++) {
  232. TEST_ESP_OK(gptimer_stop(arg->timers[i].gptimer));
  233. TEST_ESP_OK(gptimer_del_timer(arg->timers[i].gptimer));
  234. }
  235. xSemaphoreGive(arg->done);
  236. vTaskDelay(1);
  237. vTaskDelete(NULL);
  238. }
  239. static void esp_apptrace_test_task_crash(void *p)
  240. {
  241. esp_apptrace_test_task_arg_t *arg = (esp_apptrace_test_task_arg_t *) p;
  242. ESP_APPTRACE_TEST_LOGE("%x: run (period %u us, stamp mask %x, %u timers)", xTaskGetCurrentTaskHandle(), arg->data.period, arg->data.mask, arg->timers_num);
  243. arg->data.wr_cnt = 0;
  244. *(uint32_t *)arg->data.buf = (uint32_t)xTaskGetCurrentTaskHandle();
  245. for (int i = 0; i < ESP_APPTRACE_TEST_BLOCKS_BEFORE_CRASH; i++) {
  246. uint32_t *ts = (uint32_t *)(arg->data.buf + sizeof(uint32_t));
  247. *ts = (uint32_t)esp_apptrace_test_ts_get();
  248. memset(arg->data.buf + sizeof(uint32_t), arg->data.wr_cnt & arg->data.mask, arg->data.buf_sz - sizeof(uint32_t));
  249. int res = ESP_APPTRACE_TEST_WRITE(arg->data.buf, arg->data.buf_sz);
  250. if (res) {
  251. ESP_APPTRACE_TEST_LOGE("%x: Failed to write trace %d %x!", xTaskGetCurrentTaskHandle(), res, arg->data.wr_cnt & arg->data.mask);
  252. } else {
  253. ESP_APPTRACE_TEST_LOGD("%x: Written chunk%d %d bytes, %x", xTaskGetCurrentTaskHandle(), arg->data.wr_cnt, arg->data.buf_sz, arg->data.wr_cnt & arg->data.mask);
  254. }
  255. arg->data.wr_cnt++;
  256. }
  257. vTaskDelay(500);
  258. uint32_t *ptr = 0;
  259. *ptr = 1000;
  260. xSemaphoreGive(arg->done);
  261. vTaskDelay(1);
  262. vTaskDelete(NULL);
  263. }
  264. static gptimer_handle_t ts_gptimer;
  265. static uint64_t esp_apptrace_test_ts_get(void)
  266. {
  267. uint64_t ts = 0;
  268. gptimer_get_raw_count(ts_gptimer, &ts);
  269. return ts;
  270. }
  271. static void esp_apptrace_test_ts_init(void)
  272. {
  273. gptimer_config_t timer_config = {
  274. .clk_src = GPTIMER_CLK_SRC_DEFAULT,
  275. .direction = GPTIMER_COUNT_UP,
  276. .resolution_hz = 10000000,
  277. };
  278. TEST_ESP_OK(gptimer_new_timer(&timer_config, &ts_gptimer));
  279. ESP_APPTRACE_TEST_LOGI("Use timer %x for TS", ts_gptimer);
  280. TEST_ESP_OK(gptimer_start(ts_gptimer));
  281. }
  282. static void esp_apptrace_test_ts_cleanup(void)
  283. {
  284. TEST_ESP_OK(gptimer_stop(ts_gptimer));
  285. TEST_ESP_OK(gptimer_del_timer(ts_gptimer));
  286. ts_gptimer = NULL;
  287. }
  288. static void esp_apptrace_test(esp_apptrace_test_cfg_t *test_cfg)
  289. {
  290. esp_apptrace_test_task_arg_t dummy_task_arg = {
  291. .core = 0,
  292. .prio = 3,
  293. .task_func = esp_apptrace_test_task_crash,
  294. .data.buf = NULL,
  295. .data.buf_sz = 0,
  296. .data.period = 500000,
  297. .timers_num = 0,
  298. .timers = NULL,
  299. };
  300. #if ESP_APPTRACE_TEST_USE_PRINT_LOCK == 1
  301. s_print_lock = xSemaphoreCreateBinary();
  302. if (!s_print_lock) {
  303. esp_rom_printf("%s: Failed to create print lock!", TAG);
  304. return;
  305. }
  306. xSemaphoreGive(s_print_lock);
  307. #else
  308. #endif
  309. for (int i = 0; i < test_cfg->tasks_num; i++) {
  310. test_cfg->tasks[i].data.mask = 0xFF;
  311. test_cfg->tasks[i].stop = 0;
  312. test_cfg->tasks[i].done = xSemaphoreCreateBinary();
  313. TEST_ASSERT_NOT_NULL(test_cfg->tasks[i].done);
  314. for (int k = 0; k < test_cfg->tasks[i].timers_num; k++) {
  315. test_cfg->tasks[i].timers[k].data.mask = 0xFF;
  316. }
  317. }
  318. esp_apptrace_test_ts_init();
  319. for (int i = 0; i < test_cfg->tasks_num; i++) {
  320. char name[30];
  321. TaskHandle_t thnd;
  322. sprintf(name, "apptrace_test%d", i);
  323. xTaskCreatePinnedToCore(test_cfg->tasks[i].task_func, name, 2048, &test_cfg->tasks[i], test_cfg->tasks[i].prio, &thnd, test_cfg->tasks[i].core);
  324. ESP_APPTRACE_TEST_LOGI("Created task %x", thnd);
  325. }
  326. xTaskCreatePinnedToCore(esp_apptrace_dummy_task, "dummy0", 2048, &dummy_task_arg, dummy_task_arg.prio, NULL, 0);
  327. #if CONFIG_FREERTOS_UNICORE == 0
  328. xTaskCreatePinnedToCore(esp_apptrace_dummy_task, "dummy1", 2048, &dummy_task_arg, dummy_task_arg.prio, NULL, 1);
  329. #endif
  330. for (int i = 0; i < test_cfg->tasks_num; i++) {
  331. //arg1.stop = 1;
  332. xSemaphoreTake(test_cfg->tasks[i].done, portMAX_DELAY);
  333. }
  334. for (int i = 0; i < test_cfg->tasks_num; i++) {
  335. if (test_cfg->tasks[i].done) {
  336. vSemaphoreDelete(test_cfg->tasks[i].done);
  337. }
  338. }
  339. esp_apptrace_test_ts_cleanup();
  340. #if ESP_APPTRACE_TEST_USE_PRINT_LOCK == 1
  341. vSemaphoreDelete(s_print_lock);
  342. #else
  343. #endif
  344. }
  345. static esp_apptrace_test_task_arg_t s_test_tasks[4];
  346. static esp_apptrace_test_timer_arg_t s_test_timers[2];
  347. static uint8_t s_bufs[6][ESP_APPTRACE_TEST_BLOCK_SIZE];
  348. TEST_CASE("App trace test (1 task + 1 crashed timer ISR @ 1 core)", "[trace][ignore]")
  349. {
  350. esp_apptrace_test_cfg_t test_cfg = {
  351. .tasks_num = 1,
  352. .tasks = s_test_tasks,
  353. };
  354. memset(s_test_timers, 0, sizeof(s_test_timers));
  355. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  356. s_test_timers[0].isr_func = esp_apptrace_test_timer_isr_crash;
  357. s_test_timers[0].data.buf = s_bufs[0];
  358. s_test_timers[0].data.buf_sz = sizeof(s_bufs[0]);
  359. s_test_timers[0].data.period = 1000;
  360. s_test_tasks[0].core = 0;
  361. s_test_tasks[0].prio = 3;
  362. s_test_tasks[0].task_func = esp_apptrace_dummy_task;
  363. s_test_tasks[0].data.buf = NULL;
  364. s_test_tasks[0].data.buf_sz = 0;
  365. s_test_tasks[0].data.period = 1000000;
  366. s_test_tasks[0].timers_num = 1;
  367. s_test_tasks[0].timers = s_test_timers;
  368. esp_apptrace_test(&test_cfg);
  369. }
  370. TEST_CASE("App trace test (1 crashed task)", "[trace][ignore]")
  371. {
  372. esp_apptrace_test_task_arg_t s_test_tasks[1];
  373. esp_apptrace_test_cfg_t test_cfg = {
  374. .tasks_num = 1,
  375. .tasks = s_test_tasks,
  376. };
  377. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  378. s_test_tasks[0].core = 0;
  379. s_test_tasks[0].prio = 3;
  380. s_test_tasks[0].task_func = esp_apptrace_test_task_crash;
  381. s_test_tasks[0].data.buf = s_bufs[0];
  382. s_test_tasks[0].data.buf_sz = sizeof(s_bufs[0]);
  383. s_test_tasks[0].data.period = 6000;
  384. s_test_tasks[0].timers_num = 0;
  385. s_test_tasks[0].timers = NULL;
  386. esp_apptrace_test(&test_cfg);
  387. }
  388. #if CONFIG_FREERTOS_UNICORE == 0
  389. TEST_CASE("App trace test (2 tasks + 1 timer @ each core", "[trace][ignore]")
  390. {
  391. int ntask = 0;
  392. esp_apptrace_test_cfg_t test_cfg = {
  393. .tasks_num = 4,
  394. .tasks = s_test_tasks,
  395. };
  396. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  397. memset(s_test_timers, 0, sizeof(s_test_timers));
  398. s_test_timers[0].isr_func = esp_apptrace_test_timer_isr;
  399. s_test_timers[0].data.buf = s_bufs[0];
  400. s_test_timers[0].data.buf_sz = sizeof(s_bufs[0]);
  401. s_test_timers[0].data.period = 150;
  402. s_test_timers[1].isr_func = esp_apptrace_test_timer_isr;
  403. s_test_timers[1].data.buf = s_bufs[1];
  404. s_test_timers[1].data.buf_sz = sizeof(s_bufs[1]);
  405. s_test_timers[1].data.period = 150;
  406. s_test_tasks[ntask].core = 0;
  407. s_test_tasks[ntask].prio = 4;
  408. s_test_tasks[ntask].task_func = esp_apptrace_test_task;
  409. s_test_tasks[ntask].data.buf = s_bufs[2];
  410. s_test_tasks[ntask].data.buf_sz = sizeof(s_bufs[2]);
  411. s_test_tasks[ntask].data.period = 1000;
  412. s_test_tasks[ntask].timers_num = 1;
  413. s_test_tasks[ntask].timers = &s_test_timers[0];
  414. ntask++;
  415. s_test_tasks[ntask].core = 0;
  416. s_test_tasks[ntask].prio = 3;
  417. s_test_tasks[ntask].task_func = esp_apptrace_test_task;
  418. s_test_tasks[ntask].data.buf = s_bufs[3];
  419. s_test_tasks[ntask].data.buf_sz = sizeof(s_bufs[3]);
  420. s_test_tasks[ntask].data.period = 0;
  421. s_test_tasks[ntask].timers_num = 0;
  422. s_test_tasks[ntask].timers = NULL;
  423. ntask++;
  424. s_test_tasks[ntask].core = 1;
  425. s_test_tasks[ntask].prio = 4;
  426. s_test_tasks[ntask].task_func = esp_apptrace_test_task;
  427. s_test_tasks[ntask].data.buf = s_bufs[4];
  428. s_test_tasks[ntask].data.buf_sz = sizeof(s_bufs[4]);
  429. s_test_tasks[ntask].data.period = 1000;
  430. s_test_tasks[ntask].timers_num = 1;
  431. s_test_tasks[ntask].timers = &s_test_timers[1];
  432. ntask++;
  433. s_test_tasks[ntask].core = 1;
  434. s_test_tasks[ntask].prio = 3;
  435. s_test_tasks[ntask].task_func = esp_apptrace_test_task;
  436. s_test_tasks[ntask].data.buf = s_bufs[5];
  437. s_test_tasks[ntask].data.buf_sz = sizeof(s_bufs[5]);
  438. s_test_tasks[ntask].data.period = 0;
  439. s_test_tasks[ntask].timers_num = 0;
  440. s_test_tasks[ntask].timers = NULL;
  441. ntask++;
  442. esp_apptrace_test(&test_cfg);
  443. }
  444. #endif
  445. TEST_CASE("App trace test (1 task + 1 timer @ 1 core)", "[trace][ignore]")
  446. {
  447. esp_apptrace_test_cfg_t test_cfg = {
  448. .tasks_num = 1,
  449. .tasks = s_test_tasks,
  450. };
  451. memset(s_test_timers, 0, sizeof(s_test_timers));
  452. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  453. s_test_timers[0].isr_func = esp_apptrace_test_timer_isr;
  454. s_test_timers[0].data.buf = s_bufs[0];
  455. s_test_timers[0].data.buf_sz = sizeof(s_bufs[0]);
  456. s_test_timers[0].data.period = 150;
  457. s_test_tasks[0].core = 0;
  458. s_test_tasks[0].prio = 3;
  459. s_test_tasks[0].task_func = esp_apptrace_test_task;
  460. s_test_tasks[0].data.buf = s_bufs[1];
  461. s_test_tasks[0].data.buf_sz = sizeof(s_bufs[1]);
  462. s_test_tasks[0].data.period = 0;
  463. s_test_tasks[0].timers_num = 1;
  464. s_test_tasks[0].timers = s_test_timers;
  465. esp_apptrace_test(&test_cfg);
  466. }
  467. #if CONFIG_FREERTOS_UNICORE == 0
  468. TEST_CASE("App trace test (2 tasks (nowait): 1 @ each core)", "[trace][ignore]")
  469. {
  470. esp_apptrace_test_cfg_t test_cfg = {
  471. .tasks_num = 2,
  472. .tasks = s_test_tasks,
  473. };
  474. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  475. s_test_tasks[0].nowait = 1;
  476. s_test_tasks[0].core = 0;
  477. s_test_tasks[0].prio = 3;
  478. s_test_tasks[0].task_func = esp_apptrace_test_task;
  479. s_test_tasks[0].data.buf = s_bufs[0];
  480. s_test_tasks[0].data.buf_sz = sizeof(s_bufs[0]);
  481. s_test_tasks[0].data.period = 6700;
  482. s_test_tasks[0].timers_num = 0;
  483. s_test_tasks[0].timers = NULL;
  484. s_test_tasks[1].nowait = 1;
  485. s_test_tasks[1].core = 1;
  486. s_test_tasks[1].prio = 3;
  487. s_test_tasks[1].task_func = esp_apptrace_test_task;
  488. s_test_tasks[1].data.buf = s_bufs[1];
  489. s_test_tasks[1].data.buf_sz = sizeof(s_bufs[1]);
  490. s_test_tasks[1].data.period = 6700;
  491. s_test_tasks[1].timers_num = 0;
  492. s_test_tasks[1].timers = NULL;
  493. esp_apptrace_test(&test_cfg);
  494. }
  495. TEST_CASE("App trace test (2 tasks: 1 @ each core)", "[trace][ignore]")
  496. {
  497. esp_apptrace_test_cfg_t test_cfg = {
  498. .tasks_num = 2,
  499. .tasks = s_test_tasks,
  500. };
  501. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  502. s_test_tasks[0].core = 0;
  503. s_test_tasks[0].prio = 3;
  504. s_test_tasks[0].task_func = esp_apptrace_test_task;
  505. s_test_tasks[0].data.buf = s_bufs[0];
  506. s_test_tasks[0].data.buf_sz = sizeof(s_bufs[0]);
  507. s_test_tasks[0].data.period = 0;
  508. s_test_tasks[0].timers_num = 0;
  509. s_test_tasks[0].timers = NULL;
  510. s_test_tasks[1].core = 1;
  511. s_test_tasks[1].prio = 3;
  512. s_test_tasks[1].task_func = esp_apptrace_test_task;
  513. s_test_tasks[1].data.buf = s_bufs[1];
  514. s_test_tasks[1].data.buf_sz = sizeof(s_bufs[1]);
  515. s_test_tasks[1].data.period = 0;
  516. s_test_tasks[1].timers_num = 0;
  517. s_test_tasks[1].timers = NULL;
  518. esp_apptrace_test(&test_cfg);
  519. }
  520. #endif
  521. TEST_CASE("App trace test (1 task)", "[trace][ignore]")
  522. {
  523. esp_apptrace_test_cfg_t test_cfg = {
  524. .tasks_num = 1,
  525. .tasks = s_test_tasks,
  526. };
  527. memset(s_test_tasks, 0, sizeof(s_test_tasks));
  528. s_test_tasks[0].core = 0;
  529. s_test_tasks[0].prio = 3;
  530. s_test_tasks[0].task_func = esp_apptrace_test_task;
  531. s_test_tasks[0].data.buf = s_bufs[0];
  532. s_test_tasks[0].data.buf_sz = sizeof(s_bufs[0]);
  533. s_test_tasks[0].data.period = 0;
  534. s_test_tasks[0].timers_num = 0;
  535. s_test_tasks[0].timers = NULL;
  536. esp_apptrace_test(&test_cfg);
  537. }
  538. static int esp_logtrace_printf(const char *fmt, ...)
  539. {
  540. va_list ap;
  541. va_start(ap, fmt);
  542. int ret = esp_apptrace_vprintf_to(ESP_APPTRACE_DEST_TRAX, ESP_APPTRACE_TMO_INFINITE, fmt, ap);
  543. va_end(ap);
  544. return ret;
  545. }
  546. typedef struct {
  547. SemaphoreHandle_t done;
  548. uint32_t work_count;
  549. } esp_logtrace_task_t;
  550. static void esp_logtrace_task(void *p)
  551. {
  552. esp_logtrace_task_t *arg = (esp_logtrace_task_t *) p;
  553. ESP_APPTRACE_TEST_LOGI("%x: run log test task", xTaskGetCurrentTaskHandle());
  554. int i = 0;
  555. while (1) {
  556. esp_logtrace_printf("sample print %lx %hx %c\n", 2 * i + 0x10, 2 * i + 0x20, (2 * i + 0x30) & 0xFF);
  557. esp_logtrace_printf("sample print %lx %hx %c %lu %hu %d %d %d %d\n", i, i + 0x10, (i + 0x20) & 0xFF, i + 0x30, i + 0x40, i + 0x50, i + 0x60, i + 0x70, i + 0x80);
  558. ESP_LOGI(TAG, "%p: sample print 1", xTaskGetCurrentTaskHandle());
  559. ESP_LOGI(TAG, "%p: sample print 2 %u", xTaskGetCurrentTaskHandle(), (unsigned)i);
  560. ESP_LOGI(TAG, "%p: sample print 4 %c", xTaskGetCurrentTaskHandle(), ((i & 0xFF) % 95) + 32);
  561. ESP_LOGI(TAG, "%p: sample print 5 %f", xTaskGetCurrentTaskHandle(), 1.0);
  562. ESP_LOGI(TAG, "%p: sample print 6 %f", xTaskGetCurrentTaskHandle(), 3.45);
  563. ESP_LOGI(TAG, "%p: logtrace task work %d.%d", xTaskGetCurrentTaskHandle(), cpu_hal_get_core_id(), i);
  564. if (++i == 10000) {
  565. break;
  566. }
  567. }
  568. esp_err_t ret = esp_apptrace_flush(ESP_APPTRACE_DEST_TRAX, ESP_APPTRACE_TMO_INFINITE);
  569. if (ret != ESP_OK) {
  570. ESP_APPTRACE_TEST_LOGE("Failed to flush printf buf (%d)!", ret);
  571. }
  572. ESP_APPTRACE_TEST_LOGI("%x: finished", xTaskGetCurrentTaskHandle());
  573. xSemaphoreGive(arg->done);
  574. vTaskDelay(1);
  575. vTaskDelete(NULL);
  576. }
  577. TEST_CASE("Log trace test (2 tasks)", "[trace][ignore]")
  578. {
  579. TaskHandle_t thnd;
  580. esp_logtrace_task_t arg1 = {
  581. .done = xSemaphoreCreateBinary(),
  582. };
  583. esp_logtrace_task_t arg2 = {
  584. .done = xSemaphoreCreateBinary(),
  585. };
  586. xTaskCreatePinnedToCore(esp_logtrace_task, "logtrace0", 2048, &arg1, 3, &thnd, 0);
  587. ESP_APPTRACE_TEST_LOGI("Created task %x", thnd);
  588. #if CONFIG_FREERTOS_UNICORE == 0
  589. xTaskCreatePinnedToCore(esp_logtrace_task, "logtrace1", 2048, &arg2, 3, &thnd, 1);
  590. #else
  591. xTaskCreatePinnedToCore(esp_logtrace_task, "logtrace1", 2048, &arg2, 3, &thnd, 0);
  592. #endif
  593. ESP_APPTRACE_TEST_LOGI("Created task %x", thnd);
  594. xSemaphoreTake(arg1.done, portMAX_DELAY);
  595. vSemaphoreDelete(arg1.done);
  596. xSemaphoreTake(arg2.done, portMAX_DELAY);
  597. vSemaphoreDelete(arg2.done);
  598. }
  599. #else // #if CONFIG_APPTRACE_SV_ENABLE == 0
  600. typedef struct {
  601. gptimer_handle_t gptimer;
  602. uint32_t period;
  603. int flags;
  604. uint32_t id;
  605. } esp_sysviewtrace_timer_arg_t;
  606. typedef struct {
  607. SemaphoreHandle_t done;
  608. SemaphoreHandle_t *sync;
  609. esp_sysviewtrace_timer_arg_t *timer;
  610. uint32_t work_count;
  611. uint32_t sleep_tmo;
  612. uint32_t id;
  613. } esp_sysviewtrace_task_arg_t;
  614. static bool esp_sysview_test_timer_isr(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx)
  615. {
  616. esp_sysviewtrace_timer_arg_t *tim_arg = (esp_sysviewtrace_timer_arg_t *)user_ctx;
  617. return false;
  618. }
  619. static void esp_sysviewtrace_test_task(void *p)
  620. {
  621. esp_sysviewtrace_task_arg_t *arg = (esp_sysviewtrace_task_arg_t *) p;
  622. volatile uint32_t tmp = 0;
  623. printf("%x: run sysview task\n", (uint32_t)xTaskGetCurrentTaskHandle());
  624. if (arg->timer) {
  625. gptimer_alarm_config_t alarm_config = {
  626. .reload_count = 0,
  627. .alarm_count = arg->timer->period,
  628. .flags.auto_reload_on_alarm = true,
  629. };
  630. gptimer_event_callbacks_t cbs = {
  631. .on_alarm = esp_sysview_test_timer_isr,
  632. };
  633. TEST_ESP_OK(gptimer_register_event_callbacks(arg->timer->gptimer, &cbs, arg->timer));
  634. TEST_ESP_OK(gptimer_set_alarm_action(arg->timer->gptimer, &alarm_config));
  635. TEST_ESP_OK(gptimer_start(arg->timer->gptimer));
  636. }
  637. int i = 0;
  638. while (1) {
  639. static uint32_t count;
  640. printf("%d", arg->id);
  641. if ((++count % 80) == 0) {
  642. printf("\n");
  643. }
  644. if (arg->sync) {
  645. xSemaphoreTake(*arg->sync, portMAX_DELAY);
  646. }
  647. for (uint32_t k = 0; k < arg->work_count; k++) {
  648. tmp++;
  649. }
  650. vTaskDelay(arg->sleep_tmo / portTICK_PERIOD_MS);
  651. i++;
  652. if (arg->sync) {
  653. xSemaphoreGive(*arg->sync);
  654. }
  655. }
  656. ESP_APPTRACE_TEST_LOGI("%x: finished", xTaskGetCurrentTaskHandle());
  657. xSemaphoreGive(arg->done);
  658. vTaskDelay(1);
  659. vTaskDelete(NULL);
  660. }
  661. TEST_CASE("SysView trace test 1", "[trace][ignore]")
  662. {
  663. TaskHandle_t thnd;
  664. esp_sysviewtrace_timer_arg_t tim_arg1 = {
  665. .flags = ESP_INTR_FLAG_SHARED,
  666. .id = 0,
  667. .period = 500,
  668. };
  669. esp_sysviewtrace_task_arg_t arg1 = {
  670. .done = xSemaphoreCreateBinary(),
  671. .sync = NULL,
  672. .work_count = 10000,
  673. .sleep_tmo = 1,
  674. .timer = &tim_arg1,
  675. .id = 0,
  676. };
  677. esp_sysviewtrace_timer_arg_t tim_arg2 = {
  678. .flags = 0,
  679. .id = 1,
  680. .period = 100,
  681. };
  682. esp_sysviewtrace_task_arg_t arg2 = {
  683. .done = xSemaphoreCreateBinary(),
  684. .sync = NULL,
  685. .work_count = 10000,
  686. .sleep_tmo = 1,
  687. .timer = &tim_arg2,
  688. .id = 1,
  689. };
  690. gptimer_config_t timer_config = {
  691. .clk_src = GPTIMER_CLK_SRC_DEFAULT,
  692. .direction = GPTIMER_COUNT_UP,
  693. .resolution_hz = 1000000,
  694. };
  695. timer_config.flags.intr_shared = (tim_arg1.flags & ESP_INTR_FLAG_SHARED) == ESP_INTR_FLAG_SHARED;
  696. TEST_ESP_OK(gptimer_new_timer(&timer_config, &tim_arg1.gptimer));
  697. timer_config.flags.intr_shared = (tim_arg2.flags & ESP_INTR_FLAG_SHARED) == ESP_INTR_FLAG_SHARED;
  698. TEST_ESP_OK(gptimer_new_timer(&timer_config, &tim_arg2.gptimer));
  699. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace0", 2048, &arg1, 3, &thnd, 0);
  700. ESP_APPTRACE_TEST_LOGI("Created task %x", thnd);
  701. #if CONFIG_FREERTOS_UNICORE == 0
  702. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace1", 2048, &arg2, 5, &thnd, 1);
  703. #else
  704. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace1", 2048, &arg2, 5, &thnd, 0);
  705. #endif
  706. ESP_APPTRACE_TEST_LOGI("Created task %x", thnd);
  707. xSemaphoreTake(arg1.done, portMAX_DELAY);
  708. vSemaphoreDelete(arg1.done);
  709. xSemaphoreTake(arg2.done, portMAX_DELAY);
  710. vSemaphoreDelete(arg2.done);
  711. TEST_ESP_OK(gptimer_stop(tim_arg1.gptimer));
  712. TEST_ESP_OK(gptimer_del_timer(tim_arg1.gptimer));
  713. TEST_ESP_OK(gptimer_stop(tim_arg2.gptimer));
  714. TEST_ESP_OK(gptimer_del_timer(tim_arg2.gptimer));
  715. }
  716. TEST_CASE("SysView trace test 2", "[trace][ignore]")
  717. {
  718. TaskHandle_t thnd;
  719. esp_sysviewtrace_timer_arg_t tim_arg1 = {
  720. .flags = ESP_INTR_FLAG_SHARED,
  721. .id = 0,
  722. .period = 500,
  723. };
  724. esp_sysviewtrace_task_arg_t arg1 = {
  725. .done = xSemaphoreCreateBinary(),
  726. .sync = NULL,
  727. .work_count = 10000,
  728. .sleep_tmo = 1,
  729. .timer = &tim_arg1,
  730. .id = 0,
  731. };
  732. esp_sysviewtrace_timer_arg_t tim_arg2 = {
  733. .flags = 0,
  734. .id = 1,
  735. .period = 100,
  736. };
  737. esp_sysviewtrace_task_arg_t arg2 = {
  738. .done = xSemaphoreCreateBinary(),
  739. .sync = NULL,
  740. .work_count = 10000,
  741. .sleep_tmo = 1,
  742. .timer = &tim_arg2,
  743. .id = 1,
  744. };
  745. SemaphoreHandle_t test_sync = xSemaphoreCreateBinary();
  746. xSemaphoreGive(test_sync);
  747. esp_sysviewtrace_task_arg_t arg3 = {
  748. .done = xSemaphoreCreateBinary(),
  749. .sync = &test_sync,
  750. .work_count = 1000,
  751. .sleep_tmo = 1,
  752. .timer = NULL,
  753. .id = 2,
  754. };
  755. esp_sysviewtrace_task_arg_t arg4 = {
  756. .done = xSemaphoreCreateBinary(),
  757. .sync = &test_sync,
  758. .work_count = 10000,
  759. .sleep_tmo = 1,
  760. .timer = NULL,
  761. .id = 3,
  762. };
  763. gptimer_config_t timer_config = {
  764. .clk_src = GPTIMER_CLK_SRC_DEFAULT,
  765. .direction = GPTIMER_COUNT_UP,
  766. .resolution_hz = 1000000,
  767. };
  768. timer_config.flags.intr_shared = (tim_arg1.flags & ESP_INTR_FLAG_SHARED) == ESP_INTR_FLAG_SHARED;
  769. TEST_ESP_OK(gptimer_new_timer(&timer_config, &tim_arg1.gptimer));
  770. timer_config.flags.intr_shared = (tim_arg2.flags & ESP_INTR_FLAG_SHARED) == ESP_INTR_FLAG_SHARED;
  771. TEST_ESP_OK(gptimer_new_timer(&timer_config, &tim_arg2.gptimer));
  772. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace0", 2048, &arg1, 3, &thnd, 0);
  773. printf("Created task %x\n", (uint32_t)thnd);
  774. #if CONFIG_FREERTOS_UNICORE == 0
  775. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace1", 2048, &arg2, 4, &thnd, 1);
  776. #else
  777. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svtrace1", 2048, &arg2, 4, &thnd, 0);
  778. #endif
  779. printf("Created task %x\n", (uint32_t)thnd);
  780. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svsync0", 2048, &arg3, 3, &thnd, 0);
  781. printf("Created task %x\n", (uint32_t)thnd);
  782. #if CONFIG_FREERTOS_UNICORE == 0
  783. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svsync1", 2048, &arg4, 5, &thnd, 1);
  784. #else
  785. xTaskCreatePinnedToCore(esp_sysviewtrace_test_task, "svsync1", 2048, &arg4, 5, &thnd, 0);
  786. #endif
  787. printf("Created task %x\n", (uint32_t)thnd);
  788. xSemaphoreTake(arg1.done, portMAX_DELAY);
  789. vSemaphoreDelete(arg1.done);
  790. xSemaphoreTake(arg2.done, portMAX_DELAY);
  791. vSemaphoreDelete(arg2.done);
  792. xSemaphoreTake(arg3.done, portMAX_DELAY);
  793. vSemaphoreDelete(arg3.done);
  794. xSemaphoreTake(arg4.done, portMAX_DELAY);
  795. vSemaphoreDelete(arg4.done);
  796. vSemaphoreDelete(test_sync);
  797. TEST_ESP_OK(gptimer_stop(tim_arg1.gptimer));
  798. TEST_ESP_OK(gptimer_del_timer(tim_arg1.gptimer));
  799. TEST_ESP_OK(gptimer_stop(tim_arg2.gptimer));
  800. TEST_ESP_OK(gptimer_del_timer(tim_arg2.gptimer));
  801. }
  802. #endif // #if CONFIG_APPTRACE_SV_ENABLE == 0
  803. #endif // #if CONFIG_APPTRACE_ENABLE == 1