diff options
author | Rich Felker <dalias@aerifal.cx> | 2012-11-23 14:35:25 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012-11-23 14:35:25 -0500 |
commit | c72fc23843906e2571e817a62c94cee15648b7dc (patch) | |
tree | 539517daf0b9e34cba766a89d9775722456f5c41 /arch/microblaze | |
parent | ac562aa1ef4012f617583f474a8d8e5c972ed6ee (diff) | |
download | musl-c72fc23843906e2571e817a62c94cee15648b7dc.tar.gz musl-c72fc23843906e2571e817a62c94cee15648b7dc.tar.xz musl-c72fc23843906e2571e817a62c94cee15648b7dc.zip |
sigcontext/mcontext cleanup for arch-specific bits
with these changes, the members/types of mcontext_t and related stuff should closely match the glibc definitions. unlike glibc, however, the definitions here avoid using typedefs as much as possible and work directly with the underlying types, to minimize namespace pollution from signal.h in the default (_BSD_SOURCE) profile. this is a first step in improving compatibility with applications which poke at context/register information -- mainly debuggers, trace utilities, etc. additional definitions in ucontext.h and other headers may be needed later. if feature test macros are used to request a conforming namespace, mcontext_t is replaced with an opaque structure of the equivalent size and alignment; conforming programs cannot examine its contents anyway.
Diffstat (limited to 'arch/microblaze')
-rw-r--r-- | arch/microblaze/bits/signal.h | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/arch/microblaze/bits/signal.h b/arch/microblaze/bits/signal.h index c1aaa9cb..bb60d0dd 100644 --- a/arch/microblaze/bits/signal.h +++ b/arch/microblaze/bits/signal.h @@ -1,9 +1,24 @@ #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE) +#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE) +typedef struct sigcontext +{ + struct { + unsigned long r0, r1, r2, r3, r4, r5, r6, r7; + unsigned long r8, r9, r10, r11, r12, r13, r14, r15; + unsigned long r16, r17, r18, r19, r20, r21, r22, r23; + unsigned long r24, r25, r26, r27, r28, r29, r30, r31; + unsigned long pc, msr, ear, esr, fsr; + int pt_mode; + } regs; + unsigned long oldmask; +} mcontext_t; +#else typedef struct { unsigned long __regs[39]; } mcontext_t; +#endif typedef struct __ucontext { unsigned long uc_flags; @@ -22,21 +37,6 @@ typedef struct __ucontext { #define SA_RESETHAND 0x80000000 #define SA_RESTORER 0x04000000 -#if defined(_GNU_SOURCE) || defined(_BSD_SOURCE) -struct sigcontext -{ - struct { - unsigned long r0, r1, r2, r3, r4, r5, r6, r7; - unsigned long r8, r9, r10, r11, r12, r13, r14, r15; - unsigned long r16, r17, r18, r19, r20, r21, r22, r23; - unsigned long r24, r25, r26, r27, r28, r29, r30, r31; - unsigned long pc, msr, ear, esr, fsr; - int pt_mode; - } regs; - unsigned long oldmask; -}; -#endif - #endif #define SIGHUP 1 |