SEGGER_SYSVIEW_FreeRTOS.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. /*********************************************************************
  2. * SEGGER Microcontroller GmbH & Co. KG *
  3. * The Embedded Experts *
  4. **********************************************************************
  5. * *
  6. * (c) 2015 - 2017 SEGGER Microcontroller GmbH & Co. KG *
  7. * *
  8. * www.segger.com Support: support@segger.com *
  9. * *
  10. **********************************************************************
  11. * *
  12. * SEGGER SystemView * Real-time application analysis *
  13. * *
  14. **********************************************************************
  15. * *
  16. * All rights reserved. *
  17. * *
  18. * SEGGER strongly recommends to not make any changes *
  19. * to or modify the source code of this software in order to stay *
  20. * compatible with the RTT protocol and J-Link. *
  21. * *
  22. * Redistribution and use in source and binary forms, with or *
  23. * without modification, are permitted provided that the following *
  24. * conditions are met: *
  25. * *
  26. * o Redistributions of source code must retain the above copyright *
  27. * notice, this list of conditions and the following disclaimer. *
  28. * *
  29. * o Redistributions in binary form must reproduce the above *
  30. * copyright notice, this list of conditions and the following *
  31. * disclaimer in the documentation and/or other materials provided *
  32. * with the distribution. *
  33. * *
  34. * o Neither the name of SEGGER Microcontroller GmbH & Co. KG *
  35. * nor the names of its contributors may be used to endorse or *
  36. * promote products derived from this software without specific *
  37. * prior written permission. *
  38. * *
  39. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND *
  40. * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, *
  41. * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF *
  42. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE *
  43. * DISCLAIMED. IN NO EVENT SHALL SEGGER Microcontroller BE LIABLE FOR *
  44. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR *
  45. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT *
  46. * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; *
  47. * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
  48. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT *
  49. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE *
  50. * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH *
  51. * DAMAGE. *
  52. * *
  53. **********************************************************************
  54. * *
  55. * SystemView version: V2.42 *
  56. * *
  57. **********************************************************************
  58. -------------------------- END-OF-HEADER -----------------------------
  59. File : SEGGER_SYSVIEW_FreeRTOS.h
  60. Purpose : Interface between FreeRTOS and SystemView.
  61. Revision: $Rev: 3734 $
  62. Notes:
  63. (1) Include this file at the end of FreeRTOSConfig.h
  64. */
  65. #ifndef SYSVIEW_FREERTOS_H
  66. #define SYSVIEW_FREERTOS_H
  67. #include "SEGGER_SYSVIEW.h"
  68. /*********************************************************************
  69. *
  70. * Defines, configurable
  71. *
  72. **********************************************************************
  73. */
  74. #ifndef portSTACK_GROWTH
  75. #define portSTACK_GROWTH ( -1 )
  76. #endif
  77. #define SYSVIEW_FREERTOS_MAX_NOF_TASKS CONFIG_SYSVIEW_MAX_TASKS
  78. /*********************************************************************
  79. *
  80. * Defines, fixed
  81. *
  82. **********************************************************************
  83. */
  84. // for dual-core targets we use event ID to keep core ID bit (0 or 1)
  85. // use the highest - 1 bit of event ID to indicate core ID
  86. // the highest bit can not be used due to event ID encoding method
  87. // this reduces supported ID range to [0..63] (for 1 byte IDs) plus [128..16383] (for 2 bytes IDs)
  88. // so original continuous event IDs range is split into two sub-ranges for 1-bytes IDs and 2-bytes ones
  89. // events which use apiFastID_OFFSET will have 1 byte ID,
  90. // so for the sake of bandwidth economy events which are generated more frequently should use this ID offset
  91. // currently all used events fall into this range
  92. #define apiFastID_OFFSET (32u)
  93. #define apiID_VTASKDELETE (1u)
  94. #define apiID_VTASKDELAY (2u)
  95. #define apiID_VTASKDELAYUNTIL (3u)
  96. #define apiID_VTASKSUSPEND (4u)
  97. #define apiID_ULTASKNOTIFYTAKE (5u)
  98. #define apiID_VTASKNOTIFYGIVEFROMISR (6u)
  99. #define apiID_VTASKPRIORITYINHERIT (7u)
  100. #define apiID_VTASKRESUME (8u)
  101. #define apiID_VTASKSTEPTICK (9u)
  102. #define apiID_XTASKPRIORITYDISINHERIT (10u)
  103. #define apiID_XTASKRESUMEFROMISR (11u)
  104. #define apiID_XTASKGENERICNOTIFY (12u)
  105. #define apiID_XTASKGENERICNOTIFYFROMISR (13u)
  106. #define apiID_XTASKNOTIFYWAIT (14u)
  107. #define apiID_XQUEUEGENERICCREATE (15u)
  108. #define apiID_VQUEUEDELETE (16u)
  109. #define apiID_XQUEUEGENERICRECEIVE (17u)
  110. #define apiID_XQUEUEPEEKFROMISR (18u)
  111. #define apiID_XQUEUERECEIVEFROMISR (19u)
  112. #define apiID_VQUEUEADDTOREGISTRY (20u)
  113. #define apiID_XQUEUEGENERICSEND (21u)
  114. #define apiID_XQUEUEGENERICSENDFROMISR (22u)
  115. #define apiID_VTASKPRIORITYSET (23u)
  116. #define apiID_UXTASKPRIORITYGETFROMISR (24u)
  117. #define apiID_XTASKGETTICKCOUNTFROMISR (25u)
  118. #define apiID_XEVENTGROUPCLEARBITSFROMISR (26u)
  119. #define apiID_XEVENTGROUPSETBITSFROMISR (27u)
  120. #define apiID_XEVENTGROUPGETBITSFROMISR (28u)
  121. #define apiID_XQUEUEGIVEFROMISR (29u)
  122. #define apiID_XQUEUEISQUEUEEMPTYFROMISR (30u)
  123. #define apiID_XQUEUEISQUEUEFULLFROMISR (31u) // the maximum allowed apiID for the first ID range
  124. // events which use apiSlowID_OFFSET will have 2-bytes ID
  125. #define apiSlowID_OFFSET (127u)
  126. #define apiID_VTASKALLOCATEMPUREGIONS (1u)
  127. #define apiID_UXTASKPRIORITYGET (2u)
  128. #define apiID_ETASKGETSTATE (3u)
  129. #define apiID_VTASKSTARTSCHEDULER (4u)
  130. #define apiID_VTASKENDSCHEDULER (5u)
  131. #define apiID_VTASKSUSPENDALL (6u)
  132. #define apiID_XTASKRESUMEALL (7u)
  133. #define apiID_XTASKGETTICKCOUNT (8u)
  134. #define apiID_UXTASKGETNUMBEROFTASKS (9u)
  135. #define apiID_PCTASKGETTASKNAME (10u)
  136. #define apiID_UXTASKGETSTACKHIGHWATERMARK (11u)
  137. #define apiID_VTASKSETAPPLICATIONTASKTAG (12u)
  138. #define apiID_XTASKGETAPPLICATIONTASKTAG (13u)
  139. #define apiID_VTASKSETTHREADLOCALSTORAGEPOINTER (14u)
  140. #define apiID_PVTASKGETTHREADLOCALSTORAGEPOINTER (15u)
  141. #define apiID_XTASKCALLAPPLICATIONTASKHOOK (16u)
  142. #define apiID_XTASKGETIDLETASKHANDLE (17u)
  143. #define apiID_UXTASKGETSYSTEMSTATE (18u)
  144. #define apiID_VTASKLIST (19u)
  145. #define apiID_VTASKGETRUNTIMESTATS (20u)
  146. #define apiID_XTASKNOTIFYSTATECLEAR (21u)
  147. #define apiID_XTASKGETCURRENTTASKHANDLE (22u)
  148. #define apiID_VTASKSETTIMEOUTSTATE (23u)
  149. #define apiID_XTASKCHECKFORTIMEOUT (24u)
  150. #define apiID_VTASKMISSEDYIELD (25u)
  151. #define apiID_XTASKGETSCHEDULERSTATE (26u)
  152. #define apiID_XTASKGENERICCREATE (27u)
  153. #define apiID_UXTASKGETTASKNUMBER (28u)
  154. #define apiID_VTASKSETTASKNUMBER (29u)
  155. #define apiID_ETASKCONFIRMSLEEPMODESTATUS (30u)
  156. #define apiID_XTIMERCREATE (31u)
  157. #define apiID_PVTIMERGETTIMERID (32u)
  158. #define apiID_VTIMERSETTIMERID (33u)
  159. #define apiID_XTIMERISTIMERACTIVE (34u)
  160. #define apiID_XTIMERGETTIMERDAEMONTASKHANDLE (35u)
  161. #define apiID_XTIMERPENDFUNCTIONCALLFROMISR (36u)
  162. #define apiID_XTIMERPENDFUNCTIONCALL (37u)
  163. #define apiID_PCTIMERGETTIMERNAME (38u)
  164. #define apiID_XTIMERCREATETIMERTASK (39u)
  165. #define apiID_XTIMERGENERICCOMMAND (40u)
  166. #define apiID_UXQUEUEMESSAGESWAITING (41u)
  167. #define apiID_UXQUEUESPACESAVAILABLE (42u)
  168. #define apiID_UXQUEUEMESSAGESWAITINGFROMISR (43u)
  169. #define apiID_XQUEUEALTGENERICSEND (44u)
  170. #define apiID_XQUEUEALTGENERICRECEIVE (45u)
  171. #define apiID_XQUEUECRSENDFROMISR (46u)
  172. #define apiID_XQUEUECRRECEIVEFROMISR (47u)
  173. #define apiID_XQUEUECRSEND (48u)
  174. #define apiID_XQUEUECRRECEIVE (49u)
  175. #define apiID_XQUEUECREATEMUTEX (50u)
  176. #define apiID_XQUEUECREATECOUNTINGSEMAPHORE (51u)
  177. #define apiID_XQUEUEGETMUTEXHOLDER (52u)
  178. #define apiID_XQUEUETAKEMUTEXRECURSIVE (53u)
  179. #define apiID_XQUEUEGIVEMUTEXRECURSIVE (54u)
  180. #define apiID_VQUEUEUNREGISTERQUEUE (55u)
  181. #define apiID_XQUEUECREATESET (56u)
  182. #define apiID_XQUEUEADDTOSET (57u)
  183. #define apiID_XQUEUEREMOVEFROMSET (58u)
  184. #define apiID_XQUEUESELECTFROMSET (59u)
  185. #define apiID_XQUEUESELECTFROMSETFROMISR (60u)
  186. #define apiID_XQUEUEGENERICRESET (61u)
  187. #define apiID_VLISTINITIALISE (62u)
  188. #define apiID_VLISTINITIALISEITEM (63u)
  189. #define apiID_VLISTINSERT (64u)
  190. #define apiID_VLISTINSERTEND (65u)
  191. #define apiID_UXLISTREMOVE (66u)
  192. #define apiID_XEVENTGROUPCREATE (67u)
  193. #define apiID_XEVENTGROUPWAITBITS (68u)
  194. #define apiID_XEVENTGROUPCLEARBITS (69u)
  195. #define apiID_XEVENTGROUPSETBITS (70u)
  196. #define apiID_XEVENTGROUPSYNC (71u)
  197. #define apiID_VEVENTGROUPDELETE (72u)
  198. #define apiID_UXEVENTGROUPGETNUMBER (73u)
  199. #define traceTASK_NOTIFY_TAKE() SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_ULTASKNOTIFYTAKE, xClearCountOnExit, xTicksToWait)
  200. #define traceTASK_DELAY() SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKDELAY, xTicksToDelay)
  201. #define traceTASK_DELAY_UNTIL() SEGGER_SYSVIEW_RecordVoid(apiFastID_OFFSET + apiID_VTASKDELAYUNTIL)
  202. #define traceTASK_DELETE( pxTCB ) if (pxTCB != NULL) { \
  203. SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKDELETE, \
  204. SEGGER_SYSVIEW_ShrinkId((U32)pxTCB)); \
  205. SYSVIEW_DeleteTask((U32)pxTCB); \
  206. }
  207. #define traceTASK_NOTIFY_GIVE_FROM_ISR() SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_VTASKNOTIFYGIVEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB), (U32)pxHigherPriorityTaskWoken)
  208. #define traceTASK_PRIORITY_INHERIT( pxTCB, uxPriority ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKPRIORITYINHERIT, (U32)pxMutexHolder)
  209. #define traceTASK_RESUME( pxTCB ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKRESUME, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB))
  210. #define traceINCREASE_TICK_COUNT( xTicksToJump ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKSTEPTICK, xTicksToJump)
  211. #define traceTASK_SUSPEND( pxTCB ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VTASKSUSPEND, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB))
  212. #define traceTASK_PRIORITY_DISINHERIT( pxTCB, uxBasePriority ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_XTASKPRIORITYDISINHERIT, (U32)pxMutexHolder)
  213. #define traceTASK_RESUME_FROM_ISR( pxTCB ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_XTASKRESUMEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB))
  214. #define traceTASK_NOTIFY() SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XTASKGENERICNOTIFY, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB), ulValue, eAction, (U32)pulPreviousNotificationValue)
  215. #define traceTASK_NOTIFY_FROM_ISR() SYSVIEW_RecordU32x5(apiFastID_OFFSET + apiID_XTASKGENERICNOTIFYFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxTCB), ulValue, eAction, (U32)pulPreviousNotificationValue, (U32)pxHigherPriorityTaskWoken)
  216. #define traceTASK_NOTIFY_WAIT() SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XTASKNOTIFYWAIT, ulBitsToClearOnEntry, ulBitsToClearOnExit, (U32)pulNotificationValue, xTicksToWait)
  217. #define traceQUEUE_CREATE( pxNewQueue ) SEGGER_SYSVIEW_RecordU32x3(apiFastID_OFFSET + apiID_XQUEUEGENERICCREATE, uxQueueLength, uxItemSize, ucQueueType)
  218. #define traceQUEUE_DELETE( pxQueue ) SEGGER_SYSVIEW_RecordU32(apiFastID_OFFSET + apiID_VQUEUEDELETE, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue))
  219. #define traceQUEUE_PEEK( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICRECEIVE, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer), xTicksToWait, xJustPeeking)
  220. #define traceQUEUE_PEEK_FROM_ISR( pxQueue ) SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_XQUEUEPEEKFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer))
  221. #define traceQUEUE_PEEK_FROM_ISR_FAILED( pxQueue ) SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_XQUEUEPEEKFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer))
  222. #define traceQUEUE_RECEIVE( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICRECEIVE, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer), xTicksToWait, xJustPeeking)
  223. #define traceQUEUE_RECEIVE_FAILED( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICRECEIVE, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer), xTicksToWait, xJustPeeking)
  224. #define traceQUEUE_RECEIVE_FROM_ISR( pxQueue ) SEGGER_SYSVIEW_RecordU32x3(apiFastID_OFFSET + apiID_XQUEUERECEIVEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer), (U32)pxHigherPriorityTaskWoken)
  225. #define traceQUEUE_RECEIVE_FROM_ISR_FAILED( pxQueue ) SEGGER_SYSVIEW_RecordU32x3(apiFastID_OFFSET + apiID_XQUEUERECEIVEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), SEGGER_SYSVIEW_ShrinkId((U32)pvBuffer), (U32)pxHigherPriorityTaskWoken)
  226. #define traceQUEUE_REGISTRY_ADD( xQueue, pcQueueName ) SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_VQUEUEADDTOREGISTRY, SEGGER_SYSVIEW_ShrinkId((U32)xQueue), (U32)pcQueueName)
  227. #if ( configUSE_QUEUE_SETS != 1 )
  228. #define traceQUEUE_SEND( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICSEND, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pvItemToQueue, xTicksToWait, xCopyPosition)
  229. #else
  230. #define traceQUEUE_SEND( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICSEND, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), 0, 0, xCopyPosition)
  231. #endif
  232. #define traceQUEUE_SEND_FAILED( pxQueue ) SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICSEND, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pvItemToQueue, xTicksToWait, xCopyPosition)
  233. #define traceQUEUE_SEND_FROM_ISR( pxQueue ) SEGGER_SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICSENDFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pvItemToQueue, (U32)pxHigherPriorityTaskWoken, xCopyPosition)
  234. #define traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue ) SEGGER_SYSVIEW_RecordU32x4(apiFastID_OFFSET + apiID_XQUEUEGENERICSENDFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pvItemToQueue, (U32)pxHigherPriorityTaskWoken, xCopyPosition)
  235. #define traceQUEUE_GIVE_FROM_ISR( pxQueue ) SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_XQUEUEGIVEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pxHigherPriorityTaskWoken)
  236. #define traceQUEUE_GIVE_FROM_ISR_FAILED( pxQueue ) SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET + apiID_XQUEUEGIVEFROMISR, SEGGER_SYSVIEW_ShrinkId((U32)pxQueue), (U32)pxHigherPriorityTaskWoken)
  237. #if( portSTACK_GROWTH < 0 )
  238. #define traceTASK_CREATE(pxNewTCB) if (pxNewTCB != NULL) { \
  239. SEGGER_SYSVIEW_OnTaskCreate((U32)pxNewTCB); \
  240. SYSVIEW_AddTask((U32)pxNewTCB, \
  241. &(pxNewTCB->pcTaskName[0]), \
  242. pxNewTCB->uxPriority, \
  243. (U32)pxNewTCB->pxStack, \
  244. ((U32)pxNewTCB->pxTopOfStack - (U32)pxNewTCB->pxStack) \
  245. ); \
  246. }
  247. #else
  248. #define traceTASK_CREATE(pxNewTCB) if (pxNewTCB != NULL) { \
  249. SEGGER_SYSVIEW_OnTaskCreate((U32)pxNewTCB); \
  250. SYSVIEW_AddTask((U32)pxNewTCB, \
  251. &(pxNewTCB->pcTaskName[0]), \
  252. pxNewTCB->uxPriority, \
  253. (U32)pxNewTCB->pxStack, \
  254. (U32)(pxNewTCB->pxStack-pxNewTCB->pxTopOfStack) \
  255. ); \
  256. }
  257. #endif
  258. #define traceTASK_PRIORITY_SET(pxTask, uxNewPriority) { \
  259. SEGGER_SYSVIEW_RecordU32x2(apiFastID_OFFSET+apiID_VTASKPRIORITYSET, \
  260. SEGGER_SYSVIEW_ShrinkId((U32)pxTCB), \
  261. uxNewPriority \
  262. ); \
  263. SYSVIEW_UpdateTask((U32)pxTask, \
  264. &(pxTask->pcTaskName[0]), \
  265. uxNewPriority, \
  266. (U32)pxTask->pxStack, \
  267. 0 \
  268. ); \
  269. }
  270. //
  271. // Define INCLUDE_xTaskGetIdleTaskHandle as 1 in FreeRTOSConfig.h to allow identification of Idle state.
  272. //
  273. #if ( INCLUDE_xTaskGetIdleTaskHandle == 1 )
  274. #define traceTASK_SWITCHED_IN() if(prvGetTCBFromHandle(NULL) == xTaskGetIdleTaskHandle()) { \
  275. SEGGER_SYSVIEW_OnIdle(); \
  276. } else { \
  277. SEGGER_SYSVIEW_OnTaskStartExec((U32)pxCurrentTCB[xPortGetCoreID()]); \
  278. }
  279. #else
  280. #define traceTASK_SWITCHED_IN() { \
  281. if (memcmp(pxCurrentTCB[xPortGetCoreID()]->pcTaskName, "IDLE", 5) != 0) { \
  282. SEGGER_SYSVIEW_OnTaskStartExec((U32)pxCurrentTCB[xPortGetCoreID()]); \
  283. } else { \
  284. SEGGER_SYSVIEW_OnIdle(); \
  285. } \
  286. }
  287. #endif
  288. #define traceMOVED_TASK_TO_READY_STATE(pxTCB) SEGGER_SYSVIEW_OnTaskStartReady((U32)pxTCB)
  289. #define traceREADDED_TASK_TO_READY_STATE(pxTCB)
  290. #define traceMOVED_TASK_TO_DELAYED_LIST() SEGGER_SYSVIEW_OnTaskStopReady((U32)pxCurrentTCB[xPortGetCoreID()], (1u << 2))
  291. #define traceMOVED_TASK_TO_OVERFLOW_DELAYED_LIST() SEGGER_SYSVIEW_OnTaskStopReady((U32)pxCurrentTCB[xPortGetCoreID()], (1u << 2))
  292. #define traceMOVED_TASK_TO_SUSPENDED_LIST(pxTCB) SEGGER_SYSVIEW_OnTaskStopReady((U32)pxTCB, ((3u << 3) | 3))
  293. #define traceISR_EXIT_TO_SCHEDULER() SEGGER_SYSVIEW_RecordExitISRToScheduler()
  294. #define traceISR_EXIT() SEGGER_SYSVIEW_RecordExitISR()
  295. #define traceISR_ENTER(_n_) SEGGER_SYSVIEW_RecordEnterISR(_n_)
  296. /*********************************************************************
  297. *
  298. * API functions
  299. *
  300. **********************************************************************
  301. */
  302. #ifdef __cplusplus
  303. extern "C" {
  304. #endif
  305. void SYSVIEW_AddTask (U32 xHandle, const char* pcTaskName, unsigned uxCurrentPriority, U32 pxStack, unsigned uStackHighWaterMark);
  306. void SYSVIEW_UpdateTask (U32 xHandle, const char* pcTaskName, unsigned uxCurrentPriority, U32 pxStack, unsigned uStackHighWaterMark);
  307. void SYSVIEW_DeleteTask (U32 xHandle);
  308. void SYSVIEW_SendTaskInfo (U32 TaskID, const char* sName, unsigned Prio, U32 StackBase, unsigned StackSize);
  309. void SYSVIEW_RecordU32x4 (unsigned Id, U32 Para0, U32 Para1, U32 Para2, U32 Para3);
  310. void SYSVIEW_RecordU32x5 (unsigned Id, U32 Para0, U32 Para1, U32 Para2, U32 Para3, U32 Para4);
  311. #ifdef __cplusplus
  312. }
  313. #endif
  314. #endif
  315. /*************************** End of file ****************************/