Changeset 21ad568 for libcfa/src
- Timestamp:
- Dec 14, 2023, 1:55:49 PM (11 months ago)
- Branches:
- master
- Children:
- ca9d65e
- Parents:
- 610354a (diff), 142930b (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - Location:
- libcfa/src
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
libcfa/src/exception.c
r610354a r21ad568 55 55 } 56 56 57 struct __cfaehm_base_exception_t * __cfaehm_get_current_exception(void) {58 return this_exception_context()->current_exception;59 }60 57 61 58 // RESUMPTION ================================================================ … … 312 309 struct _Unwind_Context * unwind_context) 313 310 { 314 // __cfadbg_print_safe(exception, "CFA: 0x%lx\n", _Unwind_GetCFA(context));311 //! __cfadbg_print_safe(exception, "CFA: 0x%lx\n", _Unwind_GetCFA(unwind_context)); 315 312 __cfadbg_print_safe(exception, "Personality function (%d, %x, %llu, %p, %p):", 316 313 version, actions, exception_class, unwind_exception, unwind_context); … … 482 479 // and simply linked from libcfa but there is one problem left, see the exception table for details 483 480 __attribute__((noinline)) 484 int__cfaehm_try_terminate(void (*try_block)(),485 __attribute__((unused))void (*catch_block)(int index, exception_t * except),481 void __cfaehm_try_terminate(void (*try_block)(), 482 void (*catch_block)(int index, exception_t * except), 486 483 __attribute__((unused)) int (*match_block)(exception_t * except)) { 487 484 //! volatile int xy = 0; 488 //! printf("%p %p %p \n", &try_block, &match_block, &xy);485 //! printf("%p %p %p %p\n", &try_block, &catch_block, &match_block, &xy); 489 486 490 487 // Setup the personality routine and exception table. … … 510 507 511 508 // Normal return for when there is no throw. 512 return 0;509 return; 513 510 514 511 // Exceptionnal path … … 521 518 asm volatile (".CATCH:"); 522 519 523 return EXCEPT_TO_NODE( this_exception_context()->current_exception )->handler_index; 520 // Exception handler 521 // Note: Saving the exception context on the stack breaks termination exceptions. 522 catch_block( EXCEPT_TO_NODE( this_exception_context()->current_exception )->handler_index, 523 this_exception_context()->current_exception ); 524 524 } 525 525 -
libcfa/src/exception.h
r610354a r21ad568 43 43 extern struct __cfavir_type_info __cfatid_exception_t; 44 44 45 struct __cfaehm_base_exception_t * __cfaehm_get_current_exception(void);46 45 47 46 void __cfaehm_cancel_stack(exception_t * except) __attribute__((noreturn)); … … 58 57 59 58 // Function catches termination exceptions. 60 int__cfaehm_try_terminate(59 void __cfaehm_try_terminate( 61 60 void (*try_block)(), 62 61 void (*catch_block)(int index, exception_t * except),
Note: See TracChangeset
for help on using the changeset viewer.