Changeset 24d6572 for libcfa/src/interpose.cfa
- Timestamp:
- Jun 12, 2023, 2:45:32 PM (2 years ago)
- Branches:
- ast-experimental, master
- Children:
- 62d62db
- Parents:
- 34b4268 (diff), 251ce80 (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. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
libcfa/src/interpose.cfa
r34b4268 r24d6572 10 10 // Created On : Wed Mar 29 16:10:31 2017 11 11 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Fri Mar 13 17:35:37 2020 13 // Update Count : 178 14 // 15 16 #include <stdarg.h> // va_start, va_end 12 // Last Modified On : Mon Mar 27 21:09:03 2023 13 // Update Count : 196 14 // 15 17 16 #include <stdio.h> 18 #include <string.h> // strlen19 17 #include <unistd.h> // _exit, getpid 20 #define __USE_GNU21 #include <signal.h>22 #undef __USE_GNU23 18 extern "C" { 24 19 #include <dlfcn.h> // dlopen, dlsym … … 26 21 } 27 22 28 #include "bits/debug.hfa"29 23 #include "bits/defs.hfa" 30 24 #include "bits/signal.hfa" // sigHandler_? … … 42 36 43 37 typedef void (* generic_fptr_t)(void); 38 44 39 static generic_fptr_t do_interpose_symbol( void * library, const char symbol[], const char version[] ) { 45 const char * error;46 47 40 union { generic_fptr_t fptr; void * ptr; } originalFunc; 48 41 49 42 #if defined( _GNU_SOURCE ) 50 51 52 53 54 }43 if ( version ) { 44 originalFunc.ptr = dlvsym( library, symbol, version ); 45 } else { 46 originalFunc.ptr = dlsym( library, symbol ); 47 } // if 55 48 #else 56 49 originalFunc.ptr = dlsym( library, symbol ); 57 50 #endif // _GNU_SOURCE 58 51 59 error = dlerror();60 if ( error ) abort( "interpose_symbol : internal error, %s\n", error);61 52 if ( ! originalFunc.ptr ) { // == nullptr 53 abort( "interpose_symbol : internal error, %s\n", dlerror() ); 54 } // if 62 55 return originalFunc.fptr; 63 56 } 64 57 65 58 static generic_fptr_t interpose_symbol( const char symbol[], const char version[] ) { 66 const char * error; 67 68 static void * library; 69 static void * pthread_library; 70 if ( ! library ) { 71 #if defined( RTLD_NEXT ) 72 library = RTLD_NEXT; 73 #else 74 // missing RTLD_NEXT => must hard-code library name, assuming libstdc++ 75 library = dlopen( "libc.so.6", RTLD_LAZY ); 76 error = dlerror(); 77 if ( error ) { 78 abort( "interpose_symbol : failed to open libc, %s\n", error ); 79 } 80 #endif 59 void * library; 60 61 #if defined( RTLD_NEXT ) 62 library = RTLD_NEXT; 63 #else 64 // missing RTLD_NEXT => must hard-code library name, assuming libstdc++ 65 library = dlopen( "libc.so.6", RTLD_LAZY ); 66 if ( ! library ) { // == nullptr 67 abort( "interpose_symbol : failed to open libc, %s\n", dlerror() ); 81 68 } // if 82 if ( ! pthread_library ) { 83 #if defined( RTLD_NEXT ) 84 pthread_library = RTLD_NEXT; 85 #else 86 // missing RTLD_NEXT => must hard-code library name, assuming libstdc++ 87 pthread_library = dlopen( "libpthread.so", RTLD_LAZY ); 88 error = dlerror(); 89 if ( error ) { 90 abort( "interpose_symbol : failed to open libpthread, %s\n", error ); 91 } 92 #endif 93 } // if 94 95 return do_interpose_symbol(library, symbol, version); 69 #endif // RTLD_NEXT 70 71 return do_interpose_symbol( library, symbol, version ); 96 72 } 97 73 … … 123 99 preload_libgcc(); 124 100 125 #pragma GCC diagnostic push126 #pragma GCC diagnostic ignored "-Wdiscarded-qualifiers"101 #pragma GCC diagnostic push 102 #pragma GCC diagnostic ignored "-Wdiscarded-qualifiers" 127 103 INTERPOSE_LIBC( abort, version ); 128 104 INTERPOSE_LIBC( exit , version ); 129 #pragma GCC diagnostic pop105 #pragma GCC diagnostic pop 130 106 131 107 if(__cfathreadabi_interpose_startup) __cfathreadabi_interpose_startup( do_interpose_symbol ); 108 109 // SKULLDUGGERY: In Ubuntu 22.04, someone augmented signal.h to allow SIGSTKSZ to be "sysconf(_SC_SIGSTKSZ)" in 110 // sigstksz.h, as well as 8192 in sigstack.h. HOWEVER, they forgot to provide a mechanism to tell signal.h to 111 // use sigstack.h rather than sigstksz.h. (I'm not happy.) By undefining _GNU_SOURCE before signal.h and 112 // redefining it afterwards, you can get 8192, but then nothing works correctly inside of signal.h without 113 // _GNU_SOURCE defined. So what is needed is a way to get signal.h to use sigstack.h WITH _GNU_SOURCE defined. 114 // Basically something is wrong with features.h and its use in signal.h. 115 116 #undef SIGSTKSZ 117 #define SIGSTKSZ 8192 132 118 133 119 // As a precaution (and necessity), errors that result in termination are delivered on a separate stack because … … 295 281 va_start( args, fmt ); 296 282 __abort( false, fmt, args ); 297 283 // CONTROL NEVER REACHES HERE! 298 284 va_end( args ); 299 285 } 300 286 301 287 void abort( bool signalAbort, const char fmt[], ... ) { 302 303 304 305 306 288 va_list args; 289 va_start( args, fmt ); 290 __abort( signalAbort, fmt, args ); 291 // CONTROL NEVER REACHES HERE! 292 va_end( args ); 307 293 } 308 294
Note:
See TracChangeset
for help on using the changeset viewer.