- Timestamp:
- 2006-04-09T15:33:38Z (20 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 602c9101
- Parents:
- 016acbe
- Location:
- generic
- Files:
- 
      - 2 edited
 
 - 
          
  include/proc/task.h (modified) (3 diffs)
- 
          
  src/proc/task.c (modified) (7 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      generic/include/proc/task.hr016acbe r7f6e755 32 32 #include <typedefs.h> 33 33 #include <synch/spinlock.h> 34 #include <adt/btree.h> 34 35 #include <adt/list.h> 35 36 #include <ipc/ipc.h> … … 40 41 char *name; 41 42 link_t th_head; /**< List of threads contained in this task. */ 42 link_t tasks_link; /**< Link to other tasks within the system. */43 43 as_t *as; /**< Address space. */ 44 task_id_t taskid; 44 task_id_t taskid; /**< Unique identity of task */ 45 45 46 46 /* IPC stuff */ … … 51 51 52 52 extern spinlock_t tasks_lock; 53 extern link_t tasks_head;53 extern btree_t tasks_btree; 54 54 55 55 extern void task_init(void); 
- 
      generic/src/proc/task.cr016acbe r7f6e755 36 36 #include <arch.h> 37 37 #include <panic.h> 38 #include <adt/btree.h> 38 39 #include <adt/list.h> 39 40 #include <ipc/ipc.h> … … 43 44 44 45 SPINLOCK_INITIALIZE(tasks_lock); 45 LIST_INITIALIZE(tasks_head);46 btree_t tasks_btree; 46 47 static task_id_t task_counter = 0; 47 48 … … 54 55 { 55 56 TASK = NULL; 57 btree_create(&tasks_btree); 56 58 } 57 59 … … 77 79 spinlock_initialize(&ta->lock, "task_ta_lock"); 78 80 list_initialize(&ta->th_head); 79 list_initialize(&ta->tasks_link);80 81 ta->as = as; 81 82 ta->name = name; … … 93 94 94 95 ta->taskid = ++task_counter; 95 list_append(&ta->tasks_link, &tasks_head);96 btree_insert(&tasks_btree, (__native) ta, (void *) ta, NULL); 96 97 97 98 spinlock_unlock(&tasks_lock); … … 152 153 { 153 154 link_t *cur; 154 task_t *t;155 155 ipl_t ipl; 156 int i;157 156 158 157 /* Messing with thread structures, avoid deadlock */ … … 160 159 spinlock_lock(&tasks_lock); 161 160 162 for (cur=tasks_head.next; cur!=&tasks_head; cur=cur->next) { 163 t = list_get_instance(cur, task_t, tasks_link); 164 spinlock_lock(&t->lock); 165 printf("%s: address=%P, taskid=%Q, as=%P, ActiveCalls: %d", 166 t->name, t, t->taskid, t->as, atomic_get(&t->active_calls)); 167 for (i=0; i < IPC_MAX_PHONES; i++) { 168 if (t->phones[i].callee) 169 printf(" Ph(%d): %P ", i,t->phones[i].callee); 161 for (cur = tasks_btree.leaf_head.next; cur != &tasks_btree.leaf_head; cur = cur->next) { 162 btree_node_t *node; 163 int i; 164 165 node = list_get_instance(cur, btree_node_t, leaf_link); 166 for (i = 0; i < node->keys; i++) { 167 task_t *t; 168 int j; 169 170 t = (task_t *) node->value[i]; 171 172 spinlock_lock(&t->lock); 173 printf("%s: address=%P, taskid=%Q, as=%P, ActiveCalls: %d", 174 t->name, t, t->taskid, t->as, atomic_get(&t->active_calls)); 175 for (j=0; j < IPC_MAX_PHONES; j++) { 176 if (t->phones[j].callee) 177 printf(" Ph(%d): %P ", j, t->phones[j].callee); 178 } 179 printf("\n"); 180 spinlock_unlock(&t->lock); 170 181 } 171 printf("\n");172 spinlock_unlock(&t->lock);173 182 } 174 183 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
