mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
bb6bf75e7a
This patch started off just adding the warnings in tc-ppc.c about incorrect usage of @l, @h and @ha in instructions that don't have 16-bit D-form fields. That unfortunately showed up three warnings in ld/testsuite/ld-powerpc/vle-multiseg.s on instructions like e_li r3, IV_table@l+0x00 which was being assembled to 8: 70 60 00 00 e_li r3,0 a: R_PPC_ADDR16_LO IV_table The ADDR16_LO reloc is of course completely bogus on e_li, which has a split 20-bit signed integer field in bits 0x1f7fff, the low 11 bit in 0x7ff, the next 5 bits in 0x1f0000, and the high 4 bits in 0x7800. Applying an ADDR16_LO reloc to the instruction potentially changes the e_li instruction to e_add2i., e_add2is, e_cmp16i, e_mull2i, e_cmpl16i, e_cmph16i, e_cmphl16i, e_or2i, e_and2i., e_or2is, e_lis, e_and2is, or some invalid encodings. Now there is a relocation that suits e_li, R_PPC_VLE_ADDR20, which was added 2017-09-05 but I can't see code in gas to generate the relocation. In any case, VLE_ADDR20 probably doesn't have the correct semantics for @l since ideally you'd want an @l to pair with @h or @ha to generate a 32-bit constant. Thus @l should only produce a 16-bit value, I think. So we need some more relocations to handle e_li it seems, or as I do in this patch, modify the behaviour of existing relocations when applied to e_li instructions. include/ * opcode/ppc.h (E_OPCODE_MASK, E_LI_MASK, E_LI_INSN): Define. bfd/ * elf32-ppc.c (ppc_elf_howto_raw <R_PPC_VLE_ADDR20>): Correct mask and shift value. (ppc_elf_vle_split16): Use E_OPCODE_MASK. Handle e_li specially. gas/ * config/tc-ppc.c (md_assemble): Adjust relocs for VLE before TLS tweaks. Handle e_li. Warn on unexpected operand field for lo16/hi16/ha16 relocs. |
||
---|---|---|
.. | ||
atof-ieee.c | ||
atof-vax.c | ||
bfin-aux.h | ||
bfin-defs.h | ||
bfin-lex-wrapper.c | ||
bfin-lex.l | ||
bfin-parse.y | ||
e-crisaout.c | ||
e-criself.c | ||
e-i386aout.c | ||
e-i386coff.c | ||
e-i386elf.c | ||
e-mipself.c | ||
itbl-mips.h | ||
m68k-parse.h | ||
m68k-parse.y | ||
obj-aout.c | ||
obj-aout.h | ||
obj-coff-seh.c | ||
obj-coff-seh.h | ||
obj-coff.c | ||
obj-coff.h | ||
obj-ecoff.c | ||
obj-ecoff.h | ||
obj-elf.c | ||
obj-elf.h | ||
obj-evax.c | ||
obj-evax.h | ||
obj-fdpicelf.c | ||
obj-fdpicelf.h | ||
obj-macho.c | ||
obj-macho.h | ||
obj-multi.c | ||
obj-multi.h | ||
obj-som.c | ||
obj-som.h | ||
rl78-defs.h | ||
rl78-parse.y | ||
rx-defs.h | ||
rx-parse.y | ||
tc-aarch64.c | ||
tc-aarch64.h | ||
tc-alpha.c | ||
tc-alpha.h | ||
tc-arc.c | ||
tc-arc.h | ||
tc-arm.c | ||
tc-arm.h | ||
tc-avr.c | ||
tc-avr.h | ||
tc-bfin.c | ||
tc-bfin.h | ||
tc-cr16.c | ||
tc-cr16.h | ||
tc-cris.c | ||
tc-cris.h | ||
tc-crx.c | ||
tc-crx.h | ||
tc-csky.c | ||
tc-csky.h | ||
tc-d10v.c | ||
tc-d10v.h | ||
tc-d30v.c | ||
tc-d30v.h | ||
tc-dlx.c | ||
tc-dlx.h | ||
tc-epiphany.c | ||
tc-epiphany.h | ||
tc-fr30.c | ||
tc-fr30.h | ||
tc-frv.c | ||
tc-frv.h | ||
tc-ft32.c | ||
tc-ft32.h | ||
tc-generic.c | ||
tc-generic.h | ||
tc-h8300.c | ||
tc-h8300.h | ||
tc-hppa.c | ||
tc-hppa.h | ||
tc-i386-intel.c | ||
tc-i386.c | ||
tc-i386.h | ||
tc-ia64.c | ||
tc-ia64.h | ||
tc-ip2k.c | ||
tc-ip2k.h | ||
tc-iq2000.c | ||
tc-iq2000.h | ||
tc-lm32.c | ||
tc-lm32.h | ||
tc-m32c.c | ||
tc-m32c.h | ||
tc-m32r.c | ||
tc-m32r.h | ||
tc-m68hc11.c | ||
tc-m68hc11.h | ||
tc-m68k.c | ||
tc-m68k.h | ||
tc-m68851.h | ||
tc-mcore.c | ||
tc-mcore.h | ||
tc-mep.c | ||
tc-mep.h | ||
tc-metag.c | ||
tc-metag.h | ||
tc-microblaze.c | ||
tc-microblaze.h | ||
tc-mips.c | ||
tc-mips.h | ||
tc-mmix.c | ||
tc-mmix.h | ||
tc-mn10200.c | ||
tc-mn10200.h | ||
tc-mn10300.c | ||
tc-mn10300.h | ||
tc-moxie.c | ||
tc-moxie.h | ||
tc-msp430.c | ||
tc-msp430.h | ||
tc-mt.c | ||
tc-mt.h | ||
tc-nds32.c | ||
tc-nds32.h | ||
tc-nios2.c | ||
tc-nios2.h | ||
tc-ns32k.c | ||
tc-ns32k.h | ||
tc-or1k.c | ||
tc-or1k.h | ||
tc-pdp11.c | ||
tc-pdp11.h | ||
tc-pj.c | ||
tc-pj.h | ||
tc-ppc.c | ||
tc-ppc.h | ||
tc-pru.c | ||
tc-pru.h | ||
tc-riscv.c | ||
tc-riscv.h | ||
tc-rl78.c | ||
tc-rl78.h | ||
tc-rx.c | ||
tc-rx.h | ||
tc-s12z.c | ||
tc-s12z.h | ||
tc-s390.c | ||
tc-s390.h | ||
tc-score7.c | ||
tc-score.c | ||
tc-score.h | ||
tc-sh.c | ||
tc-sh.h | ||
tc-sparc.c | ||
tc-sparc.h | ||
tc-spu.c | ||
tc-spu.h | ||
tc-tic4x.c | ||
tc-tic4x.h | ||
tc-tic6x.c | ||
tc-tic6x.h | ||
tc-tic30.c | ||
tc-tic30.h | ||
tc-tic54x.c | ||
tc-tic54x.h | ||
tc-tilegx.c | ||
tc-tilegx.h | ||
tc-tilepro.c | ||
tc-tilepro.h | ||
tc-v850.c | ||
tc-v850.h | ||
tc-vax.c | ||
tc-vax.h | ||
tc-visium.c | ||
tc-visium.h | ||
tc-wasm32.c | ||
tc-wasm32.h | ||
tc-xc16x.c | ||
tc-xc16x.h | ||
tc-xgate.c | ||
tc-xgate.h | ||
tc-xstormy16.c | ||
tc-xstormy16.h | ||
tc-xtensa.c | ||
tc-xtensa.h | ||
tc-z8k.c | ||
tc-z8k.h | ||
tc-z80.c | ||
tc-z80.h | ||
te-386bsd.h | ||
te-aix5.h | ||
te-aix.h | ||
te-armeabi.h | ||
te-armfbsdeabi.h | ||
te-armfbsdvfp.h | ||
te-armlinuxeabi.h | ||
te-csky_abiv1_linux.h | ||
te-csky_abiv1.h | ||
te-csky_abiv2_linux.h | ||
te-csky_abiv2.h | ||
te-dragonfly.h | ||
te-freebsd.h | ||
te-generic.h | ||
te-gnu.h | ||
te-go32.h | ||
te-hppa64.h | ||
te-hppa.h | ||
te-hppalinux64.h | ||
te-hpux.h | ||
te-ia64aix.h | ||
te-interix.h | ||
te-irix.h | ||
te-linux.h | ||
te-lynx.h | ||
te-macos.h | ||
te-nacl.h | ||
te-nbsd532.h | ||
te-nbsd.h | ||
te-pc532mach.h | ||
te-pe.h | ||
te-pep.h | ||
te-solaris.h | ||
te-svr4.h | ||
te-symbian.h | ||
te-tmips.h | ||
te-uclinux.h | ||
te-vms.c | ||
te-vms.h | ||
te-vxworks.h | ||
te-wince-pe.h | ||
vax-inst.h | ||
xtensa-istack.h | ||
xtensa-relax.c | ||
xtensa-relax.h |