Changeset da3963a
- Timestamp:
- Feb 12, 2021, 12:27:08 PM (4 years ago)
- Branches:
- ADT, arm-eh, ast-experimental, enum, forall-pointer-decay, jacob/cs343-translation, master, new-ast-unique-expr, pthread-emulation, qualifiedEnum
- Children:
- 565acf59
- Parents:
- 32c2c5e
- Location:
- libcfa/src/concurrency
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
libcfa/src/concurrency/kernel.cfa
r32c2c5e rda3963a 109 109 static void __run_thread(processor * this, $thread * dst); 110 110 static void __wake_one(cluster * cltr); 111 static void wait(__bin_sem_t & this); 111 112 112 113 static void push (__cluster_idles & idles, processor & proc); … … 548 549 // Kernel Idle Sleep 549 550 //============================================================================================= 551 extern "C" { 552 char * strerror(int); 553 } 554 #define CHECKED(x) { int err = x; if( err != 0 ) abort("KERNEL ERROR: Operation \"" #x "\" return error %d - %s\n", err, strerror(err)); } 555 556 static void wait(__bin_sem_t & this) with( this ) { 557 verify(__cfaabi_dbg_in_kernel()); 558 CHECKED( pthread_mutex_lock(&lock) ); 559 while(val < 1) { 560 pthread_cond_wait(&cond, &lock); 561 } 562 val -= 1; 563 CHECKED( pthread_mutex_unlock(&lock) ); 564 } 565 566 static bool post(__bin_sem_t & this) with( this ) { 567 bool needs_signal = false; 568 569 CHECKED( pthread_mutex_lock(&lock) ); 570 if(val < 1) { 571 val += 1; 572 pthread_cond_signal(&cond); 573 needs_signal = true; 574 } 575 CHECKED( pthread_mutex_unlock(&lock) ); 576 577 return needs_signal; 578 } 579 580 #undef CHECKED 581 550 582 // Wake a thread from the front if there are any 551 583 static void __wake_one(cluster * this) { -
libcfa/src/concurrency/kernel.hfa
r32c2c5e rda3963a 34 34 #endif 35 35 36 extern "C" {37 char * strerror(int);38 }39 #define CHECKED(x) { int err = x; if( err != 0 ) abort("KERNEL ERROR: Operation \"" #x "\" return error %d - %s\n", err, strerror(err)); }40 41 36 struct __bin_sem_t { 42 37 pthread_mutex_t lock; … … 44 39 int val; 45 40 }; 46 47 static inline void ?{}(__bin_sem_t & this) with( this ) {48 // Create the mutex with error checking49 pthread_mutexattr_t mattr;50 pthread_mutexattr_init( &mattr );51 pthread_mutexattr_settype( &mattr, PTHREAD_MUTEX_ERRORCHECK_NP);52 pthread_mutex_init(&lock, &mattr);53 54 pthread_cond_init (&cond, (const pthread_condattr_t *)0p); // workaround trac#208: cast should not be required55 val = 0;56 }57 58 static inline void ^?{}(__bin_sem_t & this) with( this ) {59 CHECKED( pthread_mutex_destroy(&lock) );60 CHECKED( pthread_cond_destroy (&cond) );61 }62 63 static inline void wait(__bin_sem_t & this) with( this ) {64 verify(__cfaabi_dbg_in_kernel());65 CHECKED( pthread_mutex_lock(&lock) );66 while(val < 1) {67 pthread_cond_wait(&cond, &lock);68 }69 val -= 1;70 CHECKED( pthread_mutex_unlock(&lock) );71 }72 73 static inline bool post(__bin_sem_t & this) with( this ) {74 bool needs_signal = false;75 76 CHECKED( pthread_mutex_lock(&lock) );77 if(val < 1) {78 val += 1;79 pthread_cond_signal(&cond);80 needs_signal = true;81 }82 CHECKED( pthread_mutex_unlock(&lock) );83 84 return needs_signal;85 }86 87 #undef CHECKED88 89 41 90 42 //----------------------------------------------------------------------------- -
libcfa/src/concurrency/kernel/startup.cfa
r32c2c5e rda3963a 80 80 static void ?{}(processorCtx_t & this) {} 81 81 static void ?{}(processorCtx_t & this, processor * proc, current_stack_info_t * info); 82 static void ?{}(__bin_sem_t & this); 83 static void ^?{}(__bin_sem_t & this); 82 84 83 85 #if defined(__CFA_WITH_VERIFY__) … … 736 738 } 737 739 740 extern "C" { 741 char * strerror(int); 742 } 743 #define CHECKED(x) { int err = x; if( err != 0 ) abort("KERNEL ERROR: Operation \"" #x "\" return error %d - %s\n", err, strerror(err)); } 744 745 static void ?{}(__bin_sem_t & this) with( this ) { 746 // Create the mutex with error checking 747 pthread_mutexattr_t mattr; 748 pthread_mutexattr_init( &mattr ); 749 pthread_mutexattr_settype( &mattr, PTHREAD_MUTEX_ERRORCHECK_NP); 750 pthread_mutex_init(&lock, &mattr); 751 752 pthread_cond_init (&cond, (const pthread_condattr_t *)0p); // workaround trac#208: cast should not be required 753 val = 0; 754 } 755 756 static void ^?{}(__bin_sem_t & this) with( this ) { 757 CHECKED( pthread_mutex_destroy(&lock) ); 758 CHECKED( pthread_cond_destroy (&cond) ); 759 } 760 761 #undef CHECKED 738 762 739 763 #if defined(__CFA_WITH_VERIFY__)
Note: See TracChangeset
for help on using the changeset viewer.