diff options
author | James Clarke <jrtc27@jrtc27.com> | 2016-08-10 09:47:45 -0700 |
---|---|---|
committer | Cary Coutant <ccoutant@gmail.com> | 2016-08-10 09:48:26 -0700 |
commit | 007801eeb19ed565eb4dc4020831f6d293f46930 (patch) | |
tree | 72645b53290b3cca14e8bb34ebce9a2056d8de21 /gold/ChangeLog | |
parent | 55872e496e89285814d11f03bb543091d6757318 (diff) | |
download | gdb-007801eeb19ed565eb4dc4020831f6d293f46930.zip gdb-007801eeb19ed565eb4dc4020831f6d293f46930.tar.gz gdb-007801eeb19ed565eb4dc4020831f6d293f46930.tar.bz2 |
Fix improper handling of R_SPARC_GOTDATA_OP_LOX10 relocation.
The fall-through in Target_sparc::Relocate::relocate for
R_SPARC_GOTDATA_OP_LOX10 is currently R_SPARC_GOT13, but should
clearly be R_SPARC_GOT10. GCC has been seen to emit a sethi/xor
rather than a sethi/or sequence to load a 32-bit immediate, but
if R_SPARC_GOT13 is used then bits 10-12 get zeroed out as both
the sethi and xor immediates contain them.
gold/
PR gold/20442
* sparc.cc (Target_sparc::Relocate::relocate): R_SPARC_GOTDATA_OP_LOX10
should fall back on R_SPARC_GOT10, not R_SPARC_GOT13.
Diffstat (limited to 'gold/ChangeLog')
-rw-r--r-- | gold/ChangeLog | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/gold/ChangeLog b/gold/ChangeLog index cca5455..d0a670b 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,5 +1,11 @@ 2016-08-10 James Clarke <jrtc27@jrtc27.com> + PR gold/20442 + * sparc.cc (Target_sparc::Relocate::relocate): R_SPARC_GOTDATA_OP_LOX10 + should fall back on R_SPARC_GOT10, not R_SPARC_GOT13. + +2016-08-10 James Clarke <jrtc27@jrtc27.com> + PR gold/20441 * sparc.cc (Target_sparc::Scan::check_non_pic): Allow R_SPARC_32 on sparc64. |