* gas/hppa/reloc/reloc.exp (r_no_reloc): Tweak output to match
authorJeff Law <law@redhat.com>
Mon, 17 Oct 1994 04:27:13 +0000 (04:27 +0000)
committerJeff Law <law@redhat.com>
Mon, 17 Oct 1994 04:27:13 +0000 (04:27 +0000)
        current reality.

gas/testsuite/ChangeLog
gas/testsuite/gas/hppa/reloc/reloc.exp

index f76e418..5eb5fec 100644 (file)
@@ -1,3 +1,15 @@
+Sun Oct 16 22:25:56 1994  Jeff Law  (law@snake.cs.utah.edu)
+
+       * gas/hppa/reloc/reloc.exp (r_no_reloc): Tweak output to match
+       current reality.
+
+Wed Sep 28 21:21:34 1994  Jeff Law  (law@snake.cs.utah.edu)
+
+       * gas/hppa/reloc/reduce.s: Renamed from relocreduce.s
+       * gas/hppa/reloc/reduce2.s: Renamed from relocreduce2.s
+       * gas/hppa/reloc/r_no_reloc.s: Renamed from r_no_relocbug.s
+       * gas/hppa/reloc/reloc.exp: Changed accordingly.
+
 Wed Sep 28 13:25:10 1994  Ian Lance Taylor  (ian@sanguine.cygnus.com)
 
        * gas/mips/beq.d, gas/mips/beq.s: Test that unconditional branch
index 829f07a..ae93efc 100755 (executable)
@@ -62,10 +62,10 @@ proc do_ble_relocation_test {} {
 }
 
 proc do_relocation_reduction_tests {} {
-    set testname "relocreduce.s: Test relocation reductions (part 2)"
+    set testname "reduce.s: Test relocation reductions (part 2)"
     set x 0
 
-    if [gas_test_old "relocreduce.s" "" "Relocation reductions (part1)"] then {
+    if [gas_test_old "reduce.s" "" "Relocation reductions (part1)"] then {
        objdump_start_no_subdir "a.out" "-r"
 
        # Check to make sure relocations involving procedure labels 
@@ -90,6 +90,38 @@ proc do_relocation_reduction_tests {} {
 
     # Did we find what we were looking for?  If not, flunk it.
     if [expr $x==2] then { pass $testname } else { fail $testname }
+
+    set testname "reduce2.s: More relocation reduction tests (part 2)"
+    set x 0
+
+    if [gas_test_old "reduce2.s" "" "More relocatoin  reductions (part1)"] then {
+       objdump_start_no_subdir "a.out" "-r"
+
+       # Check to make sure DLT relative relocs are not reduced to sym+addend
+       # Doing so doesn't work as one might expect
+       while 1 {
+           expect {
+               -re "^00000004\[^\n\]*DLT\[^\n\]*L.C0000\[^\n\]*\n"
+                   { set x [expr $x+1] }
+               -re "^0000001c\[^\n\]*DLT\[^\n\]*L.C0000\[^\n\]*\n"
+                   { set x [expr $x+1] }
+               -re "^00000030\[^\n\]*DLT\[^\n\]*L.C0001\[^\n\]*\n"
+                   { set x [expr $x+1] }
+               -re "^00000048\[^\n\]*DLT\[^\n\]*L.C0001\[^\n\]*\n"
+                   { set x [expr $x+1] }
+               -re "\[^\n\]*\n"                { }
+               timeout                         { perror "timeout\n"; break }
+               eof                             { break }
+            }
+       }
+    }
+
+    # This was intended to do any cleanup necessary.  It kinda looks like it
+    # isn't needed, but just in case, please keep it in for now.
+    objdump_finish
+
+    # Did we find what we were looking for?  If not, flunk it.
+    if [expr $x==2] then { pass $testname } else { fail $testname }
 }
 
 proc do_ble_mode_selector_test {} {
@@ -366,8 +398,6 @@ proc do_round_mode_test {} {
                        { set x [expr $x+1] }
                    -re "^00000014\[^\n\]*R_R_MODE\[^\n\]*\n" 
                        { fail $testname }
-                   -re "^00000018\[^\n\]*R_R_MODE\[^\n\]*\n"
-                       { set x [expr $x+1] }
                    -re "^0000001c\[^\n\]*R_R_MODE\[^\n\]*\n" 
                        { fail $testname }
                    -re "\[^\n\]*\n"            { }
@@ -385,7 +415,7 @@ proc do_round_mode_test {} {
        if [istarget hppa*-*-*elf*] then {
            if [expr $x==8] then { pass $testname } else { fail $testname }
        } else {
-           if [expr $x==4] then { pass $testname } else { fail $testname }
+           if [expr $x==3] then { pass $testname } else { fail $testname }
        }
     }
 }
@@ -445,6 +475,34 @@ proc do_function_reloc_bug {} {
 
 }
 
+proc do_r_no_reloc {} {
+    set testname "r_no_reloc.s: Test for reloc bug in 4-byte R_NO_RELCOATION fixups (part 2)"
+    set x 0
+
+    if [gas_test_old "r_no_reloc.s" "" "Test for reloc bug in 4-byte R_NO_RELOCATION fixups (part 1)"] {
+       objdump_start_no_subdir "a.out" "-r"
+
+       # Make sure GAS generated a correct relocation for the reference.
+       while 1 {
+           expect {
+               -re "^000c0004\[^\n\]*PLABEL\[^\n]*g\[^\n\]*\n" 
+                   { set x [expr $x+1] }
+               -re "\[^\n\]*\n"                { }
+               timeout                         { perror "timeout\n"; break }
+               eof                             { break }
+            }
+       }
+
+       # This was intended to do any cleanup necessary.  It kinda looks like it
+       # isn't needed, but just in case, please keep it in for now.
+       objdump_finish
+
+       # Did we find what we were looking for?  If not, flunk it.
+       if [expr $x==1] then { pass $testname } else { fail $testname }
+
+    }
+}
+
 if [istarget hppa*-*-*] then {
     # Make sure we put the right relocation entry on a BLE instruction.
     do_ble_relocation_test
@@ -485,4 +543,8 @@ if [istarget hppa*-*-*] then {
     # Test for a bug found when a function was used in a non-branching
     # instruction *without* a plabel (for portable runtime model)
     do_function_reloc_bug
+
+    # Test for an off-by-one bug in the handling of 4-byte R_NO_RELOCATION
+    # fixups.
+    do_r_no_reloc
 }