Changeset ab8c6a6 for libcfa/src
- Timestamp:
- Oct 26, 2020, 12:17:28 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:
- 342be43
- Parents:
- 912cc7d7
- Location:
- libcfa/src/concurrency
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
libcfa/src/concurrency/exception.cfa
r912cc7d7 rab8c6a6 19 19 #include <unwind.h> 20 20 #undef HIDE_EXPORTS 21 22 extern void __cfactx_thrd_leave(); 21 23 } 22 24 … … 52 54 53 55 STOP_AT_END_FUNCTION(thread_cancelstop, 54 // TODO: Instead pass information to the joiner. 55 abort();56 __cfactx_thrd_leave(); 57 __cabi_abort( "Resumed cancelled thread" ); 56 58 ) 57 59 … … 85 87 stop_param = (void *)0x22; 86 88 } else { 89 this_thread->self_cor.cancellation = unwind_exception; 90 87 91 stop_func = thread_cancelstop; 88 92 stop_param = this_thread; -
libcfa/src/concurrency/monitor.cfa
r912cc7d7 rab8c6a6 306 306 /* paranoid */ verify( thrd->state == Halted ); 307 307 unpark( new_owner ); 308 }309 310 // Join a thread311 forall( dtype T | is_thread(T) )312 T & join( T & this ) {313 $monitor * m = get_monitor(this);314 void (*dtor)(T& mutex this) = ^?{};315 monitor_dtor_guard_t __guard = { &m, (fptr_t)dtor, true };316 {317 return this;318 }319 308 } 320 309 -
libcfa/src/concurrency/thread.cfa
r912cc7d7 rab8c6a6 19 19 20 20 #include "kernel_private.hfa" 21 #include "exception.hfa" 21 22 22 23 #define __CFA_INVOKE_PRIVATE__ … … 58 59 } 59 60 61 FORALL_DATA_INSTANCE(ThreadCancelled, (dtype thread_t), (thread_t)) 62 63 forall(dtype T) 64 void copy(ThreadCancelled(T) * dst, ThreadCancelled(T) * src) { 65 dst->virtual_table = src->virtual_table; 66 dst->the_thread = src->the_thread; 67 dst->the_exception = src->the_exception; 68 } 69 70 forall(dtype T) 71 const char * msg(ThreadCancelled(T) *) { 72 return "ThreadCancelled"; 73 } 74 75 struct __cfaehm_node { 76 struct _Unwind_Exception unwind_exception; 77 struct __cfaehm_node * next; 78 int handler_index; 79 }; 80 81 forall(dtype T) 82 static void default_thread_cancel_handler(ThreadCancelled(T) & ) { 83 abort( "Unhandled thread cancellation.\n" ); 84 } 85 86 forall(dtype T | is_thread(T) | IS_EXCEPTION(ThreadCancelled, (T))) 87 void ?{}( thread_dtor_guard_t & this, 88 T & thrd, void(*defaultResumptionHandler)(ThreadCancelled(T) &)) { 89 $monitor * m = get_monitor(thrd); 90 void (*dtor)(T& mutex this) = ^?{}; 91 bool join = defaultResumptionHandler != (void(*)(ThreadCancelled(T)&))0; 92 (this.mg){&m, (void(*)())dtor, join}; 93 { 94 $thread * desc = get_thread(thrd); 95 struct _Unwind_Exception * cancellation = desc->self_cor.cancellation; 96 if ( likely(0p == cancellation) ) { 97 return; 98 } else if ( Cancelled == desc->state ) { 99 return; 100 } 101 desc->state = Cancelled; 102 if (!join) { 103 defaultResumptionHandler = default_thread_cancel_handler; 104 } 105 ThreadCancelled(T) except; 106 // TODO: Remove explitate vtable set once trac#186 is fixed. 107 except.virtual_table = &get_exception_vtable(&except); 108 except.the_thread = &thrd; 109 except.the_exception = (exception_t *)(1 + (__cfaehm_node *)cancellation); 110 throwResume except; 111 112 except.the_exception->virtual_table->free( except.the_exception ); 113 free( cancellation ); 114 desc->self_cor.cancellation = 0p; 115 } 116 } 117 118 void ^?{}( thread_dtor_guard_t & this ) { 119 ^(this.mg){}; 120 } 121 60 122 //----------------------------------------------------------------------------- 61 123 // Starting and stopping threads … … 93 155 } 94 156 157 //----------------------------------------------------------------------------- 158 forall(dtype T | is_thread(T) | IS_RESUMPTION_EXCEPTION(ThreadCancelled, (T))) 159 T & join( T & this ) { 160 thread_dtor_guard_t guard = { this, defaultResumptionHandler }; 161 return this; 162 } 163 95 164 // Local Variables: // 96 165 // mode: c // -
libcfa/src/concurrency/thread.hfa
r912cc7d7 rab8c6a6 22 22 #include "kernel.hfa" 23 23 #include "monitor.hfa" 24 #include "exception.hfa" 24 25 25 26 //----------------------------------------------------------------------------- 26 27 // thread trait 27 28 trait is_thread(dtype T) { 28 29 30 29 void ^?{}(T& mutex this); 30 void main(T& this); 31 $thread* get_thread(T& this); 31 32 }; 33 34 FORALL_DATA_EXCEPTION(ThreadCancelled, (dtype thread_t), (thread_t)) ( 35 thread_t * the_thread; 36 exception_t * the_exception; 37 ); 38 39 forall(dtype T) 40 void copy(ThreadCancelled(T) * dst, ThreadCancelled(T) * src); 41 42 forall(dtype T) 43 const char * msg(ThreadCancelled(T) *); 32 44 33 45 // define that satisfies the trait without using the thread keyword … … 65 77 static inline void ?{}($thread & this, const char * const name, struct cluster & cl ) { this{ name, cl, 0p, 65000 }; } 66 78 static inline void ?{}($thread & this, const char * const name, struct cluster & cl, size_t stackSize ) { this{ name, cl, 0p, stackSize }; } 79 80 struct thread_dtor_guard_t { 81 monitor_dtor_guard_t mg; 82 }; 83 84 forall( dtype T | is_thread(T) | IS_EXCEPTION(ThreadCancelled, (T)) ) 85 void ?{}( thread_dtor_guard_t & this, T & thrd, void(*)(ThreadCancelled(T) &) ); 86 void ^?{}( thread_dtor_guard_t & this ); 67 87 68 88 //----------------------------------------------------------------------------- … … 108 128 //---------- 109 129 // join 110 forall( dtype T | is_thread(T) )130 forall( dtype T | is_thread(T) | IS_RESUMPTION_EXCEPTION(ThreadCancelled, (T)) ) 111 131 T & join( T & this ); 112 132
Note: See TracChangeset
for help on using the changeset viewer.