Changeset fbb930e for libcfa/src/concurrency
- Timestamp:
- Aug 30, 2022, 4:57:46 PM (3 years ago)
- Branches:
- ADT, ast-experimental, master, pthread-emulation
- Children:
- 01ba701
- Parents:
- cefd0b9
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
TabularUnified libcfa/src/concurrency/preemption.cfa ¶
rcefd0b9 rfbb930e 357 357 } 358 358 } 359 } 360 361 // Check whether or not there is pending preemption 362 // force_yield( __POLL_PREEMPTION ) if appropriate 363 // return true if the thread was in an interruptable state 364 // i.e. on a real processor and not in the kernel 365 // (can return true even if no preemption was pending) 366 bool poll_interrupts() libcfa_public { 367 // Cache the processor now since interrupts can start happening after the atomic store 368 processor * proc = publicTLS_get( this_processor ); 369 if ( ! proc ) return false; 370 if ( ! __preemption_enabled() ) return false; 371 372 with( __cfaabi_tls.preemption_state ){ 373 // Signal the compiler that a fence is needed but only for signal handlers 374 __atomic_signal_fence(__ATOMIC_RELEASE); 375 if( proc->pending_preemption ) { 376 proc->pending_preemption = false; 377 force_yield( __POLL_PREEMPTION ); 378 } 379 } 380 381 return true; 359 382 } 360 383 }
Note: See TracChangeset
for help on using the changeset viewer.