From 5f266a81c8323f051f0c626c6dff5d944babe0ab Mon Sep 17 00:00:00 2001 From: Chris Demetriou Date: Sat, 17 Nov 2001 02:59:06 +0000 Subject: [PATCH] 2001-11-16 Chris Demetriou * gas/mips/elf-rel5.s, gas/mips/elf-rel5.s: New test to test symbol plus offset relocations in various ways. * gas/mips/mips.exp: Run new test. --- gas/testsuite/ChangeLog | 6 ++ gas/testsuite/gas/mips/elf-rel5.d | 151 ++++++++++++++++++++++++++++++ gas/testsuite/gas/mips/elf-rel5.s | 67 +++++++++++++ gas/testsuite/gas/mips/mips.exp | 1 + 4 files changed, 225 insertions(+) create mode 100644 gas/testsuite/gas/mips/elf-rel5.d create mode 100644 gas/testsuite/gas/mips/elf-rel5.s diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog index 2d6db40a91..faafcee472 100644 --- a/gas/testsuite/ChangeLog +++ b/gas/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2001-11-16 Chris Demetriou + + * gas/mips/elf-rel5.s, gas/mips/elf-rel5.s: New test + to test symbol plus offset relocations in various ways. + * gas/mips/mips.exp: Run new test. + 2001-11-15 Alan Modra * gas/ppc/booke.d: Modify reloc and target matches for powerpc64. diff --git a/gas/testsuite/gas/mips/elf-rel5.d b/gas/testsuite/gas/mips/elf-rel5.d new file mode 100644 index 0000000000..a8b3bd3023 --- /dev/null +++ b/gas/testsuite/gas/mips/elf-rel5.d @@ -0,0 +1,151 @@ +#objdump: -dr --prefix-addresses --show-raw-insn +#name: MIPS ELF reloc 5 + +.*: +file format elf.*mips.* + +Disassembly of section \.text: +0+000000 <[^>]*> 3c050000 lui a1,0x0 +[ ]*0: R_MIPS_HI16 dg1 +0+000004 <[^>]*> [26]4a50000 (|d)addiu a1,a1,0 +[ ]*4: R_MIPS_LO16 dg1 +0+000008 <[^>]*> 3c050000 lui a1,0x0 +[ ]*8: R_MIPS_HI16 dg1 +0+00000c <[^>]*> [26]4a5000c (|d)addiu a1,a1,12 +[ ]*c: R_MIPS_LO16 dg1 +0+000010 <[^>]*> 3c050000 lui a1,0x0 +[ ]*10: R_MIPS_HI16 dg1 +0+000014 <[^>]*> [26]4a50000 (|d)addiu a1,a1,0 +[ ]*14: R_MIPS_LO16 dg1 +0+000018 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00001c <[^>]*> 3c050000 lui a1,0x0 +[ ]*1c: R_MIPS_HI16 dg1 +0+000020 <[^>]*> [26]4a5000c (|d)addiu a1,a1,12 +[ ]*20: R_MIPS_LO16 dg1 +0+000024 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000028 <[^>]*> 3c050000 lui a1,0x0 +[ ]*28: R_MIPS_HI16 dg1 +0+00002c <[^>]*> 8ca50000 lw a1,0\(a1\) +[ ]*2c: R_MIPS_LO16 dg1 +0+000030 <[^>]*> 3c050000 lui a1,0x0 +[ ]*30: R_MIPS_HI16 dg1 +0+000034 <[^>]*> 8ca5000c lw a1,12\(a1\) +[ ]*34: R_MIPS_LO16 dg1 +0+000038 <[^>]*> 3c050000 lui a1,0x0 +[ ]*38: R_MIPS_HI16 dg1 +0+00003c <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000040 <[^>]*> 8ca50000 lw a1,0\(a1\) +[ ]*40: R_MIPS_LO16 dg1 +0+000044 <[^>]*> 3c050000 lui a1,0x0 +[ ]*44: R_MIPS_HI16 dg1 +0+000048 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00004c <[^>]*> 8ca5000c lw a1,12\(a1\) +[ ]*4c: R_MIPS_LO16 dg1 +0+000050 <[^>]*> 3c050000 lui a1,0x0 +[ ]*50: R_MIPS_HI16 \.data +0+000054 <[^>]*> [26]4a5003c (|d)addiu a1,a1,60 +[ ]*54: R_MIPS_LO16 \.data +0+000058 <[^>]*> 3c050000 lui a1,0x0 +[ ]*58: R_MIPS_HI16 \.data +0+00005c <[^>]*> [26]4a50048 (|d)addiu a1,a1,72 +[ ]*5c: R_MIPS_LO16 \.data +0+000060 <[^>]*> 3c050000 lui a1,0x0 +[ ]*60: R_MIPS_HI16 \.data +0+000064 <[^>]*> [26]4a5003c (|d)addiu a1,a1,60 +[ ]*64: R_MIPS_LO16 \.data +0+000068 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00006c <[^>]*> 3c050000 lui a1,0x0 +[ ]*6c: R_MIPS_HI16 \.data +0+000070 <[^>]*> [26]4a50048 (|d)addiu a1,a1,72 +[ ]*70: R_MIPS_LO16 \.data +0+000074 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000078 <[^>]*> 3c050000 lui a1,0x0 +[ ]*78: R_MIPS_HI16 \.data +0+00007c <[^>]*> 8ca5003c lw a1,60\(a1\) +[ ]*7c: R_MIPS_LO16 \.data +0+000080 <[^>]*> 3c050000 lui a1,0x0 +[ ]*80: R_MIPS_HI16 \.data +0+000084 <[^>]*> 8ca50048 lw a1,72\(a1\) +[ ]*84: R_MIPS_LO16 \.data +0+000088 <[^>]*> 3c050000 lui a1,0x0 +[ ]*88: R_MIPS_HI16 \.data +0+00008c <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000090 <[^>]*> 8ca5003c lw a1,60\(a1\) +[ ]*90: R_MIPS_LO16 \.data +0+000094 <[^>]*> 3c050000 lui a1,0x0 +[ ]*94: R_MIPS_HI16 \.data +0+000098 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00009c <[^>]*> 8ca50048 lw a1,72\(a1\) +[ ]*9c: R_MIPS_LO16 \.data +0+0000a0 <[^>]*> 3c050000 lui a1,0x0 +[ ]*a0: R_MIPS_HI16 dg2 +0+0000a4 <[^>]*> [26]4a50000 (|d)addiu a1,a1,0 +[ ]*a4: R_MIPS_LO16 dg2 +0+0000a8 <[^>]*> 3c050000 lui a1,0x0 +[ ]*a8: R_MIPS_HI16 dg2 +0+0000ac <[^>]*> [26]4a5000c (|d)addiu a1,a1,12 +[ ]*ac: R_MIPS_LO16 dg2 +0+0000b0 <[^>]*> 3c050000 lui a1,0x0 +[ ]*b0: R_MIPS_HI16 dg2 +0+0000b4 <[^>]*> [26]4a50000 (|d)addiu a1,a1,0 +[ ]*b4: R_MIPS_LO16 dg2 +0+0000b8 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+0000bc <[^>]*> 3c050000 lui a1,0x0 +[ ]*bc: R_MIPS_HI16 dg2 +0+0000c0 <[^>]*> [26]4a5000c (|d)addiu a1,a1,12 +[ ]*c0: R_MIPS_LO16 dg2 +0+0000c4 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+0000c8 <[^>]*> 3c050000 lui a1,0x0 +[ ]*c8: R_MIPS_HI16 dg2 +0+0000cc <[^>]*> 8ca50000 lw a1,0\(a1\) +[ ]*cc: R_MIPS_LO16 dg2 +0+0000d0 <[^>]*> 3c050000 lui a1,0x0 +[ ]*d0: R_MIPS_HI16 dg2 +0+0000d4 <[^>]*> 8ca5000c lw a1,12\(a1\) +[ ]*d4: R_MIPS_LO16 dg2 +0+0000d8 <[^>]*> 3c050000 lui a1,0x0 +[ ]*d8: R_MIPS_HI16 dg2 +0+0000dc <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+0000e0 <[^>]*> 8ca50000 lw a1,0\(a1\) +[ ]*e0: R_MIPS_LO16 dg2 +0+0000e4 <[^>]*> 3c050000 lui a1,0x0 +[ ]*e4: R_MIPS_HI16 dg2 +0+0000e8 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+0000ec <[^>]*> 8ca5000c lw a1,12\(a1\) +[ ]*ec: R_MIPS_LO16 dg2 +0+0000f0 <[^>]*> 3c050000 lui a1,0x0 +[ ]*f0: R_MIPS_HI16 \.data +0+0000f4 <[^>]*> [26]4a500b4 (|d)addiu a1,a1,180 +[ ]*f4: R_MIPS_LO16 \.data +0+0000f8 <[^>]*> 3c050000 lui a1,0x0 +[ ]*f8: R_MIPS_HI16 \.data +0+0000fc <[^>]*> [26]4a500c0 (|d)addiu a1,a1,192 +[ ]*fc: R_MIPS_LO16 \.data +0+000100 <[^>]*> 3c050000 lui a1,0x0 +[ ]*100: R_MIPS_HI16 \.data +0+000104 <[^>]*> [26]4a500b4 (|d)addiu a1,a1,180 +[ ]*104: R_MIPS_LO16 \.data +0+000108 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00010c <[^>]*> 3c050000 lui a1,0x0 +[ ]*10c: R_MIPS_HI16 \.data +0+000110 <[^>]*> [26]4a500c0 (|d)addiu a1,a1,192 +[ ]*110: R_MIPS_LO16 \.data +0+000114 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000118 <[^>]*> 3c050000 lui a1,0x0 +[ ]*118: R_MIPS_HI16 \.data +0+00011c <[^>]*> 8ca500b4 lw a1,180\(a1\) +[ ]*11c: R_MIPS_LO16 \.data +0+000120 <[^>]*> 3c050000 lui a1,0x0 +[ ]*120: R_MIPS_HI16 \.data +0+000124 <[^>]*> 8ca500c0 lw a1,192\(a1\) +[ ]*124: R_MIPS_LO16 \.data +0+000128 <[^>]*> 3c050000 lui a1,0x0 +[ ]*128: R_MIPS_HI16 \.data +0+00012c <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+000130 <[^>]*> 8ca500b4 lw a1,180\(a1\) +[ ]*130: R_MIPS_LO16 \.data +0+000134 <[^>]*> 3c050000 lui a1,0x0 +[ ]*134: R_MIPS_HI16 \.data +0+000138 <[^>]*> 00b1282[1d] (|d)addu a1,a1,s1 +0+00013c <[^>]*> 8ca500c0 lw a1,192\(a1\) +[ ]*13c: R_MIPS_LO16 \.data + \.\.\. diff --git a/gas/testsuite/gas/mips/elf-rel5.s b/gas/testsuite/gas/mips/elf-rel5.s new file mode 100644 index 0000000000..c26706b3ec --- /dev/null +++ b/gas/testsuite/gas/mips/elf-rel5.s @@ -0,0 +1,67 @@ +# MIPS ELF reloc 5 + + .data + .align 2 +sp1: + .space 60 + .globl dg1 +dg1: +dl1: + .space 60 + + + .text + + .ent fn + .type fn,@function +fn: + la $5,dg1+0 + la $5,dg1+12 + la $5,dg1+0($17) + la $5,dg1+12($17) + lw $5,dg1+0 + lw $5,dg1+12 + lw $5,dg1+0($17) + lw $5,dg1+12($17) + + la $5,dl1+0 + la $5,dl1+12 + la $5,dl1+0($17) + la $5,dl1+12($17) + lw $5,dl1+0 + lw $5,dl1+12 + lw $5,dl1+0($17) + lw $5,dl1+12($17) + + la $5,dg2+0 + la $5,dg2+12 + la $5,dg2+0($17) + la $5,dg2+12($17) + lw $5,dg2+0 + lw $5,dg2+12 + lw $5,dg2+0($17) + lw $5,dg2+12($17) + + la $5,dl2+0 + la $5,dl2+12 + la $5,dl2+0($17) + la $5,dl2+12($17) + lw $5,dl2+0 + lw $5,dl2+12 + lw $5,dl2+0($17) + lw $5,dl2+12($17) + +# Force at least 8 (non-delay-slot) zero bytes, to make 'objdump' print ... + .space 8 + + .end fn + + .data + .align 2 +sp2: + .space 60 + .globl dg2 +dg2: +dl2: + .space 60 + diff --git a/gas/testsuite/gas/mips/mips.exp b/gas/testsuite/gas/mips/mips.exp index d2d13e60d5..8c3621618c 100644 --- a/gas/testsuite/gas/mips/mips.exp +++ b/gas/testsuite/gas/mips/mips.exp @@ -160,6 +160,7 @@ if { [istarget mips*-*-*] } then { run_dump_test "e32-rel4" } run_dump_test "elf${el}-rel3" + run_dump_test "elf-rel5" run_dump_test "${tmips}${el}empic" run_dump_test "empic2" if { !$no_mips16 } {