Changeset 6a77224 for libcfa/src/concurrency
- Timestamp:
- Oct 30, 2020, 12:01:12 PM (5 years ago)
- Branches:
- ADT, arm-eh, ast-experimental, enum, forall-pointer-decay, jacob/cs343-translation, master, new-ast-unique-expr, pthread-emulation, qualifiedEnum
- Children:
- 4ae78c1
- Parents:
- 7ee8153
- Location:
- libcfa/src/concurrency
- Files:
- 
      - 6 edited
 
 - 
          
  invoke.h (modified) (1 diff)
- 
          
  io/setup.cfa (modified) (1 diff)
- 
          
  kernel.cfa (modified) (2 diffs)
- 
          
  kernel/startup.cfa (modified) (1 diff)
- 
          
  kernel_private.hfa (modified) (1 diff)
- 
          
  thread.cfa (modified) (1 diff)
 
Legend:
- Unmodified
- Added
- Removed
- 
      libcfa/src/concurrency/invoke.hr7ee8153 r6a77224 157 157 158 158 // current execution status for coroutine 159 // Possible values are: 160 // - TICKET_BLOCKED (-1) thread is blocked 161 // - TICKET_RUNNING ( 0) thread is running 162 // - TICKET_UNBLOCK ( 1) thread should ignore next block 159 163 volatile int ticket; 160 164 enum __Coroutine_State state:8; 
- 
      libcfa/src/concurrency/io/setup.cfar7ee8153 r6a77224 250 250 // Fixup the thread state 251 251 thrd.state = Blocked; 252 thrd.ticket = 0;252 thrd.ticket = TICKET_BLOCKED; 253 253 thrd.preempted = __NO_PREEMPTION; 254 254 
- 
      libcfa/src/concurrency/kernel.cfar7ee8153 r6a77224 299 299 int old_ticket = __atomic_fetch_sub(&thrd_dst->ticket, 1, __ATOMIC_SEQ_CST); 300 300 switch(old_ticket) { 301 case 1:301 case TICKET_RUNNING: 302 302 // This is case 1, the regular case, nothing more is needed 303 303 break RUNNING; 304 case 2:304 case TICKET_UNBLOCK: 305 305 // This is case 2, the racy case, someone tried to run this thread before it finished blocking 306 306 // In this case, just run it again. … … 410 410 int old_ticket = __atomic_fetch_add(&thrd->ticket, 1, __ATOMIC_SEQ_CST); 411 411 switch(old_ticket) { 412 case 1:412 case TICKET_RUNNING: 413 413 // Wake won the race, the thread will reschedule/rerun itself 414 414 break; 415 case 0:415 case TICKET_BLOCKED: 416 416 /* paranoid */ verify( ! thrd->preempted != __NO_PREEMPTION ); 417 417 /* paranoid */ verify( thrd->state == Blocked ); 
- 
      libcfa/src/concurrency/kernel/startup.cfar7ee8153 r6a77224 441 441 442 442 static void ?{}( $thread & this, current_stack_info_t * info) with( this ) { 443 ticket = 1;443 ticket = TICKET_RUNNING; 444 444 state = Start; 445 445 self_cor{ info }; 
- 
      libcfa/src/concurrency/kernel_private.hfar7ee8153 r6a77224 65 65 // KERNEL ONLY unpark with out disabling interrupts 66 66 void __unpark( struct __processor_id_t *, $thread * thrd ); 67 68 #define TICKET_BLOCKED (-1) // thread is blocked 69 #define TICKET_RUNNING ( 0) // thread is running 70 #define TICKET_UNBLOCK ( 1) // thread should ignore next block 67 71 68 72 static inline bool __post(single_sem & this, struct __processor_id_t * id) { 
- 
      libcfa/src/concurrency/thread.cfar7ee8153 r6a77224 29 29 context{ 0p, 0p }; 30 30 self_cor{ name, storage, storageSize }; 31 ticket = 1;31 ticket = TICKET_RUNNING; 32 32 state = Start; 33 33 preempted = __NO_PREEMPTION; 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  