test_trace.c 34 KB

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