Nick Clifton 81f5558e3d * elf32-h8300 (h8_relax_section): Add new relaxation of mov
@(disp:32,ERx) to mov @(disp:16,ERx).
	(R_H8_DISP32A16): New reloc.
	Comments added and corrected.
	* reloc.c (BFD_RELOC_H8_DISP32A16): New reloc.
	* bfd-in2.h: Regenerate.
	* libbfd.h: Regenerate.

	* ld.texinfo (H8/300): Add description of relaxation of
	mov @(disp:32,ERx) to mov @(disp:16,ERx).

	* ld-h8300/h8300.exp: Add new relax-7 test on ELF.
	* ld-h8300/relax-2.s: Add other direction and .w/.l variants of
	mov insns.
	* ld-h8300/relax-2.d: Update expected disassembly.
	* ld-h8300/relax-7a.s: New: tests for mov @(disp:32,ERx) -> mov
	@(disp:16,ERx).
	* ld-h8300/relax-7b.s: New: Likewise.
	* ld-h8300/relax-7.d: New: expected disassembly.

	* config/tc-h8300.c (do_a_fix_imm): Add relaxation of mov
	@(disp:32,ERx) to mov @(disp:16,ERx) insns by new reloc
	R_H8_DISP32A16.
	* config/tc-h8300.h: Remove duplicated defines.
2013-03-21 16:08:07 +00:00

82 lines
2.3 KiB
Makefile

# name: H8300 Relaxation Test 7
# source: relax-7?.s
# ld: --relax -m h8300self
# objdump: -d -s --no-show-raw-insn
.*: file format .*-h8300
Contents of section .text:
0100 1a801aa2 7a01ffff 80000100 6f2201d0 [^\000]*
0110 59206e0a ff016e8a ff016e1a 00016e9a [^\000]*
0120 00015470 6f02fff2 6f82fff2 6f120002 [^\000]*
0130 6f920002 54700100 6f028004 01006f82 [^\000]*
0140 80040100 6f120004 01006f92 00045470 [^\000]*
0150 7a000100 78006b01 fff25470 78006a2a [^\000]*
0160 ffff7ff1 78006aaa ffff7ff1 78106a2a [^\000]*
0170 00008000 78106aaa 00008000 54707800 [^\000]*
0180 6b22ffff 7ffa7800 6ba2ffff 7ffa7810 [^\000]*
0190 6b220000 80007810 6ba20000 80005470 [^\000]*
01a0 01007800 6b2200ff ff040100 78806ba2 [^\000]*
01b0 00ffff04 01007810 6b220000 80000100 [^\000]*
01c0 78906ba2 00008000 5470 [^\000]*
Contents of section .rodata:
01cc 00000112 00000124 00000136 0000015c [^\000]*
01dc 0000017e 000001a0 00000150 01007800 [^\000]*
01ec 6b200000 01e80000 [^\000]*
Disassembly of section .text:
00000100 <_start>:
100: sub.l er0,er0
102: sub.l er2,er2
104: mov.l #0xffff8000,er1
10a: mov.l @\(0x1d0:16,er2\),er2
110: jmp @er2
00000112 <.L20>:
112: mov.b @\(0xff01:16,er0\),r2l
116: mov.b r2l,@\(0xff01:16,er0\)
11a: mov.b @\(0x1:16,er1\),r2l
11e: mov.b r2l,@\(0x1:16,er1\)
122: rts[\t]*
00000124 <.L21>:
124: mov.w @\(0xfff2:16,er0\),r2
128: mov.w r2,@\(0xfff2:16,er0\)
12c: mov.w @\(0x2:16,er1\),r2
130: mov.w r2,@\(0x2:16,er1\)
134: rts[\t]*
00000136 <.L22>:
136: mov.l @\(0x8004:16,er0\),er2
13c: mov.l er2,@\(0x8004:16,er0\)
142: mov.l @\(0x4:16,er1\),er2
148: mov.l er2,@\(0x4:16,er1\)
14e: rts[\t]*
00000150 <.L100Relax>:
150: mov.l #0x1007800,er0
156: mov.w @0xfff2:16,r1
15a: rts[\t]*
0000015c <.L30noRelax>:
15c: mov.b @\(0xffff7ff1:32,er0\),r2l
164: mov.b r2l,@\(0xffff7ff1:32,er0\)
16c: mov.b @\(0x8000:32,er1\),r2l
174: mov.b r2l,@\(0x8000:32,er1\)
17c: rts[\t]*
0000017e <.L31noRelax>:
17e: mov.w @\(0xffff7ffa:32,er0\),r2
186: mov.w r2,@\(0xffff7ffa:32,er0\)
18e: mov.w @\(0x8000:32,er1\),r2
196: mov.w r2,@\(0x8000:32,er1\)
19e: rts[\t]*
000001a0 <.L32noRelax>:
1a0: mov.l @\(0xffff04:32,er0\),er2
1aa: mov.l er2,@\(0xffff04:32,er0\)
1b4: mov.l @\(0x8000:32,er1\),er2
1be: mov.l er2,@\(0x8000:32,er1\)
1c8: rts[\t]*