6655dba246
PR 25224 bfd * Makefile.am: Add z80-elf target support. * configure.ac: Likewise. * targets.c: Likewise. * config.bfd: Add z80-elf target support and new arches: ez80 and z180. * elf32-z80.c: New file. * archures.c: Add new z80 architectures: eZ80 and Z180. * coffcode.h: Likewise. * cpu-z80.c: Likewise. * bfd-in2.h: Likewise plus additional Z80 relocations. * coff-z80.c: Add new relocations for Z80 target and local label check. gas * config/tc-z80.c: Add new architectures: Z180 and eZ80. Add support for assembler code generated by SDCC. Add new relocation types. Add z80-elf target support. * config/tc-z80.h: Add z80-elf target support. Enable dollar local labels. Local labels starts from ".L". * testsuite/gas/all/fwdexp.d: Fix failure due to symbol conflict. * testsuite/gas/all/fwdexp.s: Likewise. * testsuite/gas/z80/suffix.d: Fix failure on ELF target. * testsuite/gas/z80/z80.exp: Add new tests * testsuite/gas/z80/dollar.d: New file. * testsuite/gas/z80/dollar.s: New file. * testsuite/gas/z80/ez80_adl_all.d: New file. * testsuite/gas/z80/ez80_adl_all.s: New file. * testsuite/gas/z80/ez80_adl_suf.d: New file. * testsuite/gas/z80/ez80_isuf.s: New file. * testsuite/gas/z80/ez80_z80_all.d: New file. * testsuite/gas/z80/ez80_z80_all.s: New file. * testsuite/gas/z80/ez80_z80_suf.d: New file. * testsuite/gas/z80/r800_extra.d: New file. * testsuite/gas/z80/r800_extra.s: New file. * testsuite/gas/z80/r800_ii8.d: New file. * testsuite/gas/z80/r800_z80_doc.d: New file. * testsuite/gas/z80/z180.d: New file. * testsuite/gas/z80/z180.s: New file. * testsuite/gas/z80/z180_z80_doc.d: New file. * testsuite/gas/z80/z80_doc.d: New file. * testsuite/gas/z80/z80_doc.s: New file. * testsuite/gas/z80/z80_ii8.d: New file. * testsuite/gas/z80/z80_ii8.s: New file. * testsuite/gas/z80/z80_in_f_c.d: New file. * testsuite/gas/z80/z80_in_f_c.s: New file. * testsuite/gas/z80/z80_op_ii_ld.d: New file. * testsuite/gas/z80/z80_op_ii_ld.s: New file. * testsuite/gas/z80/z80_out_c_0.d: New file. * testsuite/gas/z80/z80_out_c_0.s: New file. * testsuite/gas/z80/z80_reloc.d: New file. * testsuite/gas/z80/z80_reloc.s: New file. * testsuite/gas/z80/z80_sli.d: New file. * testsuite/gas/z80/z80_sli.s: New file. ld * Makefile.am: Add new target z80-elf * configure.tgt: Likewise. * emultempl/z80.em: Add support for eZ80 and Z180 architectures. * emulparams/elf32z80.sh: New file. * emultempl/z80elf.em: Likewise. * testsuite/ld-z80/arch_ez80_adl.d: Likewise. * testsuite/ld-z80/arch_ez80_z80.d: Likewise. * testsuite/ld-z80/arch_r800.d: Likewise. * testsuite/ld-z80/arch_z180.d: Likewise. * testsuite/ld-z80/arch_z80.d: Likewise. * testsuite/ld-z80/comb_arch_ez80_z80.d: Likewise. * testsuite/ld-z80/comb_arch_z180.d: Likewise. * testsuite/ld-z80/labels.s: Likewise. * testsuite/ld-z80/relocs.s: Likewise. * testsuite/ld-z80/relocs_b_ez80.d: Likewise. * testsuite/ld-z80/relocs_b_z80.d: Likewise. * testsuite/ld-z80/relocs_f_z80.d: Likewise. * testsuite/ld-z80/z80.exp: Likewise. opcodes * z80-dis.c: Add support for eZ80 and Z80 instructions.
71 lines
1.8 KiB
D
71 lines
1.8 KiB
D
#name: Z80 forward PC relative relocations
|
|
#source: jr.s -z80
|
|
#source: labels.s -z80
|
|
#ld: -e 0 -Ttext 0 -Tdata 0x100
|
|
#objdump: -d
|
|
|
|
|
|
.*:[ ]+file format (coff)|(elf32)\-z80
|
|
|
|
|
|
.* \.text:
|
|
|
|
00000000 <.*>:
|
|
[ ]+0:[ ]+10 34[ ]+djnz 0x0036
|
|
[ ]+2:[ ]+18 33[ ]+jr 0x0037
|
|
[ ]+4:[ ]+20 32[ ]+jr nz,0x0038
|
|
[ ]+6:[ ]+28 31[ ]+jr z,0x0039
|
|
[ ]+8:[ ]+30 30[ ]+jr nc,0x003a
|
|
[ ]+a:[ ]+38 2f[ ]+jr c,0x003b
|
|
[ ]+c:[ ]+10 fe[ ]+djnz 0x000c
|
|
[ ]+e:[ ]+18 fe[ ]+jr 0x000e
|
|
[ ]+10:[ ]+20 fe[ ]+jr nz,0x0010
|
|
[ ]+12:[ ]+28 fe[ ]+jr z,0x0012
|
|
[ ]+14:[ ]+30 fe[ ]+jr nc,0x0014
|
|
[ ]+16:[ ]+38 fe[ ]+jr c,0x0016
|
|
[ ]+18:[ ]+10 fe[ ]+djnz 0x0018
|
|
[ ]+1a:[ ]+18 fe[ ]+jr 0x001a
|
|
[ ]+1c:[ ]+20 fe[ ]+jr nz,0x001c
|
|
[ ]+1e:[ ]+28 fe[ ]+jr z,0x001e
|
|
[ ]+20:[ ]+30 fe[ ]+jr nc,0x0020
|
|
[ ]+22:[ ]+38 fe[ ]+jr c,0x0022
|
|
[ ]+24:[ ]+10 0a[ ]+djnz 0x0030
|
|
[ ]+26:[ ]+18 09[ ]+jr 0x0031
|
|
[ ]+28:[ ]+20 08[ ]+jr nz,0x0032
|
|
[ ]+2a:[ ]+28 07[ ]+jr z,0x0033
|
|
[ ]+2c:[ ]+30 06[ ]+jr nc,0x0034
|
|
[ ]+2e:[ ]+38 05[ ]+jr c,0x0035
|
|
[ ]+30:[ ]+c9[ ]+ret
|
|
[ ]+31:[ ]+c9[ ]+ret
|
|
[ ]+32:[ ]+c9[ ]+ret
|
|
[ ]+33:[ ]+c9[ ]+ret
|
|
[ ]+34:[ ]+c9[ ]+ret
|
|
[ ]+35:[ ]+c9[ ]+ret
|
|
|
|
00000036 <label1>:
|
|
[ ]+36:[ ]+78[ ]+ld a,b
|
|
|
|
00000037 <label2>:
|
|
[ ]+37:[ ]+79[ ]+ld a,c
|
|
|
|
00000038 <label3>:
|
|
[ ]+38:[ ]+7a[ ]+ld a,d
|
|
|
|
00000039 <label4>:
|
|
[ ]+39:[ ]+7b[ ]+ld a,e
|
|
|
|
0000003a <label5>:
|
|
[ ]+3a:[ ]+7c[ ]+ld a,h
|
|
|
|
0000003b <label6>:
|
|
[ ]+3b:[ ]+7d[ ]+ld a,l
|
|
|
|
0000003c <label7>:
|
|
[ ]+3c:[ ]+7e[ ]+ld a,\(hl\)
|
|
|
|
0000003d <label8>:
|
|
[ ]+3d:[ ]+7f[ ]+ld a,a
|
|
|
|
0000003e <label9>:
|
|
[ ]+3e:[ ]+2f[ ]+cpl
|