diff options
author | Rich Felker <dalias@aerifal.cx> | 2019-05-22 15:17:12 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2019-05-22 15:17:12 -0400 |
commit | 3c59a868956636bc8adafb1b168d090897692532 (patch) | |
tree | d6aa3ab65678f8cad5d6655ddf7723b283fc6751 /arch | |
parent | a60b9e06861e56c0810bae0249b421e1758d281a (diff) | |
download | musl-3c59a868956636bc8adafb1b168d090897692532.tar.gz musl-3c59a868956636bc8adafb1b168d090897692532.tar.bz2 musl-3c59a868956636bc8adafb1b168d090897692532.tar.xz musl-3c59a868956636bc8adafb1b168d090897692532.zip |
fix vrregset_t layout and member naming on powerpc64
the mistaken layout seems to have been adapted from 32-bit powerpc,
where vscr and vrsave are packed into the same 128-bit slot in a way
that looks like it relies on non-overlapping-ness of the value bits in
big endian.
the powerpc64 port accounted for the fact that the 64-bit ABI puts
each in its own 128-bit slot, but ordered them incorrectly (matching
the bit order used on the 32-bit ABI), and failed to account for vscr
being padded according to endianness so that it can be accessed via
vector moves.
in addition to ABI layout, our definition used different logical
member layout/naming from glibc, where vscr is a structure to
facilitate access as a 32-bit word or a 128-bit vector. the
inconsistency here was unintentional, so fix it.
Diffstat (limited to 'arch')
-rw-r--r-- | arch/powerpc64/bits/signal.h | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/arch/powerpc64/bits/signal.h b/arch/powerpc64/bits/signal.h index 34693a68..94c7a327 100644 --- a/arch/powerpc64/bits/signal.h +++ b/arch/powerpc64/bits/signal.h @@ -17,10 +17,14 @@ typedef struct { typedef struct { unsigned __int128 vrregs[32]; - unsigned _pad[3]; - unsigned vrsave; - unsigned vscr; - unsigned _pad2[3]; + struct { +#if __BIG_ENDIAN__ + unsigned _pad[3], vscr_word; +#else + unsigned vscr_word, _pad[3]; +#endif + } vscr; + unsigned vrsave, _pad[3]; } vrregset_t; typedef struct sigcontext { |