PR savannah/3331:
authorStephane Carrez <stcarrez@nerim.fr>
Sat, 26 Apr 2003 11:53:36 +0000 (11:53 +0000)
committerStephane Carrez <stcarrez@nerim.fr>
Sat, 26 Apr 2003 11:53:36 +0000 (11:53 +0000)
* elf32-m68hc11.c (m68hc11_elf_relax_section): Clear prev_insn_group
when we couldn't relax something.
* ld-m68hc11/bug-3331.d: New test.
* ld-m68hc11/bug-3331.s: New file.

bfd/ChangeLog
bfd/elf32-m68hc11.c
ld/testsuite/ChangeLog
ld/testsuite/ld-m68hc11/bug-3331.d [new file with mode: 0644]
ld/testsuite/ld-m68hc11/bug-3331.s [new file with mode: 0644]

index 10a5957aabb18911e2759d60ab96fdb66d862b3f..faa6e11dd43368ea29f7aa07c2de12961b79893b 100644 (file)
@@ -1,3 +1,9 @@
+2003-04-26  Stephane Carrez  <stcarrez@nerim.fr>
+
+       PR savannah/3331:
+       * elf32-m68hc11.c (m68hc11_elf_relax_section): Clear prev_insn_group
+       when we couldn't relax something.
+
 2003-04-25  Alan Modra  <amodra@bigpond.net.au>
 
        * elflink.h (elf_merge_symbol): When we find a regular definition
index ebd9d42b95e8480fa9a75e49ccfc3ca8132d8b69..bb0f9e974c251c3e14d0528d7bef3d1e602a6533 100644 (file)
@@ -1073,6 +1073,7 @@ m68hc11_elf_relax_section (abfd, sec, link_info, again)
             }
         }
       prev_insn_branch = 0;
+      prev_insn_group = 0;
     }
 
   if (free_relocs != NULL)
index ef513cfe8a9e727fefbea4daef1d34c0a7d6e131..a0ae7fdf8bd950c5801a1529bbea44819b7f552a 100644 (file)
@@ -1,3 +1,8 @@
+2003-04-26  Stephane Carrez  <stcarrez@nerim.fr>
+
+       * ld-m68hc11/bug-3331.d: New test.
+       * ld-m68hc11/bug-3331.s: New file.
+
 2003-04-25  Nick Clifton <nickc@redhat.com>
             J"orn Rennecke <joern.rennecke@superh.com>
 
diff --git a/ld/testsuite/ld-m68hc11/bug-3331.d b/ld/testsuite/ld-m68hc11/bug-3331.d
new file mode 100644 (file)
index 0000000..91050bf
--- /dev/null
@@ -0,0 +1,14 @@
+#source: bug-3331.s
+#as: -m68hc11
+#ld: --relax
+#objdump: -d --prefix-addresses -r
+#target: m6811-*-* m6812-*-*
+
+.*: +file format elf32-m68hc11
+
+Disassembly of section .text:
+0+8000 <_start> ldx    #0+1100 <__data_section_start>
+0+8003 <_start\+0x3> bset      0,x \#\$04
+0+8006 <L1> ldd        \#0+2 <__bss_size\+0x2>
+0+8009 <L1\+0x3> std   \*0+ <__bss_size>
+0+800b <L1\+0x5> rts
diff --git a/ld/testsuite/ld-m68hc11/bug-3331.s b/ld/testsuite/ld-m68hc11/bug-3331.s
new file mode 100644 (file)
index 0000000..19a3201
--- /dev/null
@@ -0,0 +1,23 @@
+;;; Bug #3331: Invalid group relaxation, bset uses an invalid address
+;;; http://savannah.gnu.org/bugs/?func=detailbug&bug_id=3331&group_id=2424
+;;; 
+       .sect .text
+       .globl _start
+_start:
+       .relax  L1
+       ldx     #foo            ;; This relax group must not be changed.
+       bset    0,x #4
+L1:
+       ldd     #2
+       std     table           ;; This instruction uses a symbol in page0
+                               ;; and it triggered the relaxation of the
+                               ;; previous relax group
+       rts
+
+       .sect .page0
+       .globl table
+table: .long 0
+
+       .sect .data
+       .globl foo
+foo:   .long 0