1 function decode_stack(sp)
6 sp += 4; /* skip stored ulCriticalNesting */
8 a[16] = Debug.evaluate("*(unsigned long*)" + sp);
10 for (i = 0; i <= 15; i++)
13 a[i] = Debug.evaluate("*(unsigned long*)" + sp);
19 function add_task(task, state)
21 var tcb, task_name, current_task, regs;
23 current_task = Debug.evaluate("pxCurrentTCB");
24 tcb = Debug.evaluate("*(tskTCB *)" + task);
26 task_name = Debug.evaluate("(char*)&(*(tskTCB *)" + task + ").pcTaskName[0]");
27 task_name = "#" + tcb.uxTCBNumber + " \"" + task_name + "\"";
29 if (task == current_task)
36 regs = decode_stack(tcb.pxTopOfStack);
39 Threads.add(task_name, tcb.uxPriority, state, regs);
42 function add_list(list, state)
44 var i, index, item, task;
46 if (list && list.uxNumberOfItems>0)
48 index = list.xListEnd.pxNext;
50 for (i = 0; i < list.uxNumberOfItems; i++)
52 item = Debug.evaluate("*(ListItem_t *)" + index);
54 task = item ? item.pvOwner : 0;
57 add_task(task, state);
66 var i, list, lists, max_priority;
70 if( Debug.evaluate("pxCurrentTCB") == 0 )
73 max_priority = Debug.evaluate("uxTopUsedPriority");
75 Threads.newqueue("Ready");
76 for (i = max_priority; i >= 0; i--)
78 list = Debug.evaluate("pxReadyTasksLists[" + i + "]");
79 add_list(list, "ready");
82 Threads.newqueue("Blocked");
83 list = Debug.evaluate("pxDelayedTaskList");
86 list = Debug.evaluate("*(xList *)" + list);
87 add_list(list, "blocked");
90 list = Debug.evaluate("pxOverflowDelayedTaskList");
93 list = Debug.evaluate("*(xList *)" + list);
94 add_list(list, "blocked");
97 Threads.newqueue("Suspended");
98 list = Debug.evaluate("xSuspendedTaskList");
101 add_list(list, "suspended");