diff options
author | Maciej W. Rozycki <macro@codesourcery.com> | 2014-08-22 16:52:20 +0100 |
---|---|---|
committer | Maciej W. Rozycki <macro@codesourcery.com> | 2014-08-22 16:52:20 +0100 |
commit | fbd940576f6c0891cebb4173f64968b7c50ed642 (patch) | |
tree | 1825bc914bffb212d3c1afff4f5cd5ac63df715c /ld/testsuite/ld-powerpc | |
parent | 84919466a87f5ce10cc1af8ef51d7ab9ea66ff5e (diff) | |
download | gdb-fbd940576f6c0891cebb4173f64968b7c50ed642.zip gdb-fbd940576f6c0891cebb4173f64968b7c50ed642.tar.gz gdb-fbd940576f6c0891cebb4173f64968b7c50ed642.tar.bz2 |
Power/GAS: Don't set VLE annotation for non-VLE processors/instructions
Only set the VLE flag if the instruction has been pulled via the VLE
instruction set. This way the flag is guaranteed to be set for VLE-only
instructions or for VLE-only processors, however it'll remain clear for
dual-mode instructions on dual-mode and, more importantly, standard-mode
processors.
gas/
* config/tc-ppc.c (md_assemble): Only set the PPC_APUINFO_VLE
flag if both the processor and opcode flags match.
ld/testsuite/
* ld-powerpc/apuinfo-vle.rd: New test.
* ld-powerpc/apuinfo-vle.s: New test source.
* ld-powerpc/apuinfo.rd: Adjust according to GAS PPC_APUINFO_VLE
handling change.
* ld-powerpc/powerpc.exp: Run the new test.
Diffstat (limited to 'ld/testsuite/ld-powerpc')
-rw-r--r-- | ld/testsuite/ld-powerpc/apuinfo-vle.rd | 5 | ||||
-rw-r--r-- | ld/testsuite/ld-powerpc/apuinfo-vle.s | 4 | ||||
-rw-r--r-- | ld/testsuite/ld-powerpc/apuinfo.rd | 5 | ||||
-rw-r--r-- | ld/testsuite/ld-powerpc/powerpc.exp | 7 |
4 files changed, 16 insertions, 5 deletions
diff --git a/ld/testsuite/ld-powerpc/apuinfo-vle.rd b/ld/testsuite/ld-powerpc/apuinfo-vle.rd new file mode 100644 index 0000000..79a0910 --- /dev/null +++ b/ld/testsuite/ld-powerpc/apuinfo-vle.rd @@ -0,0 +1,5 @@ +Hex dump of section '\.PPC\.EMB\.apuinfo': + 0x00000000 (?:00000008|08000000) (?:00000020|20000000) (?:00000002|02000000) 41505569 .*APUi + 0x00000010 6e666f00 (?:00420001|01004200) (?:00430001|01004300) (?:00410001|01004100) nfo.* + 0x00000020 (?:01020001|01000201) (?:01040001|01000401) (?:01010001|01000101) (?:00400001|01004000) .* + 0x00000030 01000001 .* diff --git a/ld/testsuite/ld-powerpc/apuinfo-vle.s b/ld/testsuite/ld-powerpc/apuinfo-vle.s new file mode 100644 index 0000000..06bfec9 --- /dev/null +++ b/ld/testsuite/ld-powerpc/apuinfo-vle.s @@ -0,0 +1,4 @@ + .text + .global apuinfo_vle +apuinfo_vle: + se_blr diff --git a/ld/testsuite/ld-powerpc/apuinfo.rd b/ld/testsuite/ld-powerpc/apuinfo.rd index 3c07516..4443638 100644 --- a/ld/testsuite/ld-powerpc/apuinfo.rd +++ b/ld/testsuite/ld-powerpc/apuinfo.rd @@ -6,7 +6,6 @@ #target: powerpc-eabi* Hex dump of section '.PPC.EMB.apuinfo': - 0x00000000 (00000008|08000000) (00000020|20000000) (00000002|02000000) 41505569 .*APUi + 0x00000000 (00000008|08000000) (0000001c|1c000000) (00000002|02000000) 41505569 .*APUi 0x00000010 6e666f00 (00420001|01004200) (00430001|01004300) (00410001|01004100) nfo.* - 0x00000020 (01020001|01000201) (01010001|01000101) (00400001|01004000) (01040001|01000401) .* - 0x00000030 01000001 .* + 0x00000020 (01020001|01000201) (01010001|01000101) (00400001|01004000) 01000001 .* diff --git a/ld/testsuite/ld-powerpc/powerpc.exp b/ld/testsuite/ld-powerpc/powerpc.exp index 23572c6..599b980 100644 --- a/ld/testsuite/ld-powerpc/powerpc.exp +++ b/ld/testsuite/ld-powerpc/powerpc.exp @@ -102,10 +102,13 @@ set ppcelftests { {{objdump -hw reloc.d}} "reloc.so"} {"APUinfo section processing" "-melf32ppc" "" "-a32 -me500" {apuinfo1.s apuinfo-nul.s apuinfo2.s} - {{readelf -x2 apuinfo.rd}} "apuinfo"} + {{readelf -x2 apuinfo.rd}} "apuinfo"} + {"APUinfo VLE section processing" "-melf32ppc" "" + "-a32 -me500 -mvle" {apuinfo1.s apuinfo-vle.s apuinfo2.s} + {{readelf -x2 apuinfo-vle.rd}} "apuinfo-vle"} {"APUinfo NULL section processing" "-melf32ppc" "" "-a32 -me500" {apuinfo-nul1.s apuinfo-nul.s} - {{readelf -x2 apuinfo-nul.rd}} "apuinfo"} + {{readelf -x2 apuinfo-nul.rd}} "apuinfo"} {"TLS32 static exec" "-melf32ppc" "" "-a32" {tls32.s tlslib32.s} {{objdump -dr tls32.d} {objdump -sj.got tls32.g} {objdump -sj.tdata tls32.t}} |