test_trace.c 34 KB

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