Changeset 62273d1 in mainline
- Timestamp:
- 2019-08-07T04:27:24Z (6 years ago)
- Children:
- 2f44fafd
- Parents:
- 70d28e8
- git-author:
- Michal Koutný <xm.koutny+hos@…> (2015-10-08 21:46:22)
- git-committer:
- Matthieu Riolo <matthieu.riolo@…> (2019-08-07 04:27:24)
- Location:
- uspace
- Files:
- 
      - 6 edited
 
 - 
          
  app/tester/proc/dummy_task.c (modified) (1 diff)
- 
          
  app/tester/proc/task_wait.c (modified) (11 diffs)
- 
          
  lib/c/include/types/task.h (modified) (1 diff)
- 
          
  srv/taskman/main.c (modified) (6 diffs)
- 
          
  srv/taskman/task.c (modified) (6 diffs)
- 
          
  srv/taskman/task.h (modified) (1 diff)
 
Legend:
- Unmodified
- Added
- Removed
- 
      uspace/app/tester/proc/dummy_task.cr70d28e8 r62273d1 48 48 static void dummy_fail(void) 49 49 { 50 task_id_t id = task_get_id(); 51 printf("Gonna shoot myself (%" PRIu64 ").\n", id); 50 52 behavior_func_t func = NULL; 51 53 func(); 
- 
      uspace/app/tester/proc/task_wait.cr70d28e8 r62273d1 67 67 task_exit_t texit; 68 68 69 TPRINTF("11 match ");69 TPRINTF("11 match\n"); 70 70 71 71 task_wait_set(&wait, TASK_WAIT_EXIT); … … 73 73 TASSERT(rc == EOK); 74 74 75 rc = task_wait(&wait, &texit, &retval); 75 TPRINTF("waiting..."); 76 rc = task_wait(&wait, &texit, &retval); 77 TPRINTF("done.\n"); 76 78 TASSERT(rc == EOK); 77 79 TASSERT(texit == TASK_EXIT_UNEXPECTED); 78 TPRINTF("OK ");80 TPRINTF("OK\n"); 79 81 /* ---- */ 80 82 81 TPRINTF("12 lost wait ");83 TPRINTF("12 lost wait\n"); 82 84 83 85 task_wait_set(&wait, TASK_WAIT_RETVAL); … … 85 87 TASSERT(rc == EOK); 86 88 87 rc = task_wait(&wait, &texit, &retval); 89 TPRINTF("waiting..."); 90 rc = task_wait(&wait, &texit, &retval); 91 TPRINTF("done.\n"); 88 92 TASSERT(rc == EINVAL); 89 TPRINTF("OK ");90 /* ---- */ 91 92 TPRINTF("13 partial match ");93 TPRINTF("OK\n"); 94 /* ---- */ 95 96 TPRINTF("13 partial match\n"); 93 97 94 98 task_wait_set(&wait, TASK_WAIT_RETVAL | TASK_WAIT_EXIT); … … 96 100 TASSERT(rc == EOK); 97 101 98 rc = task_wait(&wait, &texit, &retval); 102 TPRINTF("waiting..."); 103 rc = task_wait(&wait, &texit, &retval); 104 TPRINTF("done.\n"); 99 105 TASSERT(rc == EOK); 100 106 TASSERT(texit == TASK_EXIT_UNEXPECTED); 101 107 /* retval is undefined */ 102 TPRINTF("OK ");103 /* ---- */ 104 105 TPRINTF("21 ignore retval ");108 TPRINTF("OK\n"); 109 /* ---- */ 110 111 TPRINTF("21 ignore retval\n"); 106 112 107 113 task_wait_set(&wait, TASK_WAIT_EXIT); … … 109 115 TASSERT(rc == EOK); 110 116 111 rc = task_wait(&wait, &texit, &retval); 117 TPRINTF("waiting..."); 118 rc = task_wait(&wait, &texit, &retval); 119 TPRINTF("done.\n"); 112 120 TASSERT(rc == EOK); 113 121 TASSERT(texit == TASK_EXIT_NORMAL); 114 122 /* retval is unknown */ 115 TPRINTF("OK ");116 /* ---- */ 117 118 TPRINTF("22 good match ");123 TPRINTF("OK\n"); 124 /* ---- */ 125 126 TPRINTF("22 good match\n"); 119 127 120 128 task_wait_set(&wait, TASK_WAIT_RETVAL); … … 122 130 TASSERT(rc == EOK); 123 131 124 rc = task_wait(&wait, &texit, &retval); 132 TPRINTF("waiting..."); 133 rc = task_wait(&wait, &texit, &retval); 134 TPRINTF("done.\n"); 125 135 TASSERT(rc == EOK); 126 136 /* exit is not expected */ 127 137 TASSERT(retval == EOK); 128 138 task_kill(tid); /* Terminate daemon */ 129 TPRINTF("OK ");130 /* ---- */ 131 132 TPRINTF("23 partial match (non-exited task) ");139 TPRINTF("OK\n"); 140 /* ---- */ 141 142 TPRINTF("23 partial match (non-exited task)\n"); 133 143 134 144 // TODO should update wait for synchronized exit waiting … … 137 147 TASSERT(rc == EOK); 138 148 139 rc = task_wait(&wait, &texit, &retval); 149 TPRINTF("waiting..."); 150 rc = task_wait(&wait, &texit, &retval); 151 TPRINTF("done.\n"); 140 152 TASSERT(rc == EOK); 141 153 /* exit is not expected */ 142 154 TASSERT(retval == EOK); 143 155 task_kill(tid); /* Terminate daemon */ 144 TPRINTF("OK ");145 /* ---- */ 146 147 TPRINTF("31 on exit return ");156 TPRINTF("OK\n"); 157 /* ---- */ 158 159 TPRINTF("31 on exit return\n"); 148 160 149 161 task_wait_set(&wait, TASK_WAIT_EXIT); … … 151 163 TASSERT(rc == EOK); 152 164 153 rc = task_wait(&wait, &texit, &retval); 165 TPRINTF("waiting..."); 166 rc = task_wait(&wait, &texit, &retval); 167 TPRINTF("done.\n"); 154 168 TASSERT(rc == EOK); 155 169 TASSERT(texit == TASK_EXIT_NORMAL); 156 170 /* retval is unknown */ 157 TPRINTF("OK ");158 /* ---- */ 159 160 161 TPRINTF("32 keep retval until exit ");171 TPRINTF("OK\n"); 172 /* ---- */ 173 174 175 TPRINTF("32 keep retval until exit\n"); 162 176 163 177 task_wait_set(&wait, TASK_WAIT_RETVAL); … … 165 179 TASSERT(rc == EOK); 166 180 167 rc = task_wait(&wait, &texit, &retval); 181 TPRINTF("waiting..."); 182 rc = task_wait(&wait, &texit, &retval); 183 TPRINTF("done.\n"); 168 184 TASSERT(rc == EOK); 169 185 /* exit is unknown */ … … 172 188 rc = task_kill(tid); 173 189 TASSERT(rc == ENOENT); 174 TPRINTF("OK ");175 /* ---- */ 176 177 TPRINTF("33 double good match ");190 TPRINTF("OK\n"); 191 /* ---- */ 192 193 TPRINTF("33 double good match\n"); 178 194 179 195 task_wait_set(&wait, TASK_WAIT_RETVAL | TASK_WAIT_EXIT); … … 181 197 TASSERT(rc == EOK); 182 198 183 rc = task_wait(&wait, &texit, &retval); 199 TPRINTF("waiting..."); 200 rc = task_wait(&wait, &texit, &retval); 201 TPRINTF("done.\n"); 184 202 TASSERT(rc == EOK); 185 203 TASSERT(texit == TASK_EXIT_NORMAL); 186 204 TASSERT(retval == EOK); 187 TPRINTF("OK ");205 TPRINTF("OK\n"); 188 206 /* ---- */ 189 207 
- 
      uspace/lib/c/include/types/task.hr70d28e8 r62273d1 37 37 38 38 typedef enum { 39 TASK_EXIT_RUNNING, /**< Internal taskman value. */ 39 40 TASK_EXIT_NORMAL, 40 41 TASK_EXIT_UNEXPECTED 
- 
      uspace/srv/taskman/main.cr70d28e8 r62273d1 79 79 async_exchange_end(exch); 80 80 81 // TODO leak? what happens with referenced sessions 81 82 free(sess_ref); 82 83 … … 116 117 int rc = task_set_retval(icall); 117 118 async_answer_0(iid, rc); 119 } 120 121 static void task_exit_event(ipc_callid_t iid, ipc_call_t *icall, void *arg) 122 { 123 printf("%s:%i\n", __func__, __LINE__); 124 // TODO design substitution for taskmon (monitoring) 125 task_id_t id = MERGE_LOUP32(IPC_GET_ARG1(*icall), IPC_GET_ARG2(*icall)); 126 task_terminated(id, (task_exit_t)arg); 118 127 } 119 128 … … 161 170 async_answer_0(iid, ENOMEM); 162 171 } 163 164 172 165 173 /* Create callback connection */ … … 170 178 return; 171 179 } 180 181 /* Remember task_id */ 182 int rc = task_id_intro(icall); 183 184 if (rc != EOK) { 185 async_answer_0(iid, rc); 186 free(sess_ref); 187 return; 188 } 172 189 async_answer_0(iid, EOK); 173 190 191 /* Notify spawners */ 174 192 link_initialize(&sess_ref->link); 175 193 prodcons_produce(&sess_queue, &sess_ref->link); … … 220 238 printf(NAME ": HelenOS task manager\n"); 221 239 240 /* Initialization */ 222 241 prodcons_initialize(&sess_queue); 223 242 int rc = task_init(); … … 226 245 } 227 246 247 rc = async_event_subscribe(EVENT_EXIT, task_exit_event, (void *)EVENT_EXIT); 248 if (rc != EOK) { 249 printf("Cannot register for exit events (%i).\n", rc); 250 return rc; 251 } 252 253 rc = async_event_subscribe(EVENT_FAULT, task_exit_event, (void *)EVENT_FAULT); 254 if (rc != EOK) { 255 printf("Cannot register for fault events (%i).\n", rc); 256 return rc; 257 } 258 228 259 /* We're service too */ 229 260 rc = service_register(SERVICE_TASKMAN); 230 261 if (rc != EOK) { 231 printf("Cannot register at naming service (%i). ", rc);262 printf("Cannot register at naming service (%i).\n", rc); 232 263 return rc; 233 264 } 
- 
      uspace/srv/taskman/task.cr70d28e8 r62273d1 52 52 53 53 task_id_t id; /**< Task ID. */ 54 bool finished;/**< Task is done. */54 task_exit_t exit;/**< Task is done. */ 55 55 bool have_rval; /**< Task returned a value. */ 56 56 int retval; /**< The return value. */ … … 185 185 186 186 hashed_task_t *ht = hash_table_get_inst(link, hashed_task_t, link); 187 if ( !ht->finished)187 if (ht->exit == TASK_EXIT_RUNNING) 188 188 continue; 189 189 190 190 if (!(pr->callid & IPC_CALLID_NOTIFICATION)) { 191 texit = ht->have_rval ? TASK_EXIT_NORMAL : 192 TASK_EXIT_UNEXPECTED; 191 texit = ht->exit; 193 192 async_answer_2(pr->callid, EOK, texit, 194 193 ht->retval); … … 216 215 } 217 216 218 if (ht->finished) { 219 task_exit_t texit = ht->have_rval ? TASK_EXIT_NORMAL : 220 TASK_EXIT_UNEXPECTED; 217 if (ht->exit != TASK_EXIT_RUNNING) { 218 task_exit_t texit = ht->exit; 221 219 async_answer_2(callid, EOK, texit, ht->retval); 222 220 return; … … 242 240 } 243 241 244 int ns_task_id_intro(ipc_call_t *call)245 { 246 247 task_id_t id = MERGE_LOUP32(IPC_GET_ARG1(*call), IPC_GET_ARG2(*call));248 249 ht_link_t *link = hash_table_find(&phone_to_id, &call->in_phone_hash);242 int task_id_intro(ipc_call_t *call) 243 { 244 // TODO think about task_id reuse and this 245 // R lock 246 ht_link_t *link = hash_table_find(&task_hash_table, &call->in_task_id); 247 // R unlock 250 248 if (link != NULL) 251 249 return EEXISTS; 252 253 p2i_entry_t *entry = (p2i_entry_t *) malloc(sizeof(p2i_entry_t));254 if (entry == NULL)255 return ENOMEM;256 250 257 251 hashed_task_t *ht = (hashed_task_t *) malloc(sizeof(hashed_task_t)); 258 252 if (ht == NULL) 259 253 return ENOMEM; 260 261 /* 262 * Insert into the phone-to-id map. 263 */ 264 265 entry->in_phone_hash = call->in_phone_hash; 266 entry->id = id; 267 hash_table_insert(&phone_to_id, &entry->link); 268 254 269 255 /* 270 256 * Insert into the main table. 271 257 */ 272 273 ht->id = id; 274 ht->finished = false; 258 ht->id = call->in_task_id; 259 ht->exit = TASK_EXIT_RUNNING; 275 260 ht->have_rval = false; 276 261 ht->retval = -1; 262 // W lock 277 263 hash_table_insert(&task_hash_table, &ht->link); 278 279 return EOK; 280 } 281 282 static int get_id_by_phone(sysarg_t phone_hash, task_id_t *id) 283 { 284 ht_link_t *link = hash_table_find(&phone_to_id, &phone_hash); 285 if (link == NULL) 286 return ENOENT; 287 288 p2i_entry_t *entry = hash_table_get_inst(link, p2i_entry_t, link); 289 *id = entry->id; 264 // W unlock 290 265 291 266 return EOK; … … 302 277 hash_table_get_inst(link, hashed_task_t, link) : NULL; 303 278 304 if ((ht == NULL) || (ht-> finished))305 return E OK; // TODO EINVAL when registration works;306 307 ht->finished = true;279 if ((ht == NULL) || (ht->exit != TASK_EXIT_RUNNING)) 280 return EINVAL; 281 282 // TODO process additional flag to retval 308 283 ht->have_rval = true; 309 284 ht->retval = IPC_GET_ARG1(*call); … … 314 289 } 315 290 316 int ns_task_disconnect(ipc_call_t *call) 317 { 318 task_id_t id; 319 int rc = get_id_by_phone(call->in_phone_hash, &id); 320 if (rc != EOK) 321 return rc; 322 323 /* Delete from phone-to-id map. */ 324 hash_table_remove(&phone_to_id, &call->in_phone_hash); 325 291 void task_terminated(task_id_t id, task_exit_t texit) 292 { 326 293 /* Mark task as finished. */ 294 // R lock 327 295 ht_link_t *link = hash_table_find(&task_hash_table, &id); 296 // R unlock 328 297 if (link == NULL) 329 return EOK;298 return; 330 299 331 300 hashed_task_t *ht = hash_table_get_inst(link, hashed_task_t, link); 332 301 333 ht->finished = true; 334 302 ht->exit = texit; 335 303 process_pending_wait(); 336 hash_table_remove(&task_hash_table, &id); 337 338 return EOK; 304 305 // W lock 306 hash_table_remove_item(&task_hash_table, &ht->link); 307 // W unlock 339 308 } 340 309 
- 
      uspace/srv/taskman/task.hr70d28e8 r62273d1 44 44 extern int task_set_retval(ipc_call_t *); 45 45 46 extern int ns_task_id_intro(ipc_call_t *); 47 extern int ns_task_disconnect(ipc_call_t *); 48 46 extern int task_id_intro(ipc_call_t *); 47 extern void task_terminated(task_id_t, task_exit_t); 49 48 50 49 #endif 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
