binutils-gdb/gas/config
Alan Modra bb6bf75e7a PowerPC @l, @h and @ha warnings, plus VLE e_li
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.
2018-12-06 23:01:03 +10:30
..
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 PR23938, should not free memory alloced in obstack by free() 2018-12-01 15:18:04 +10:30
obj-coff.h
obj-ecoff.c
obj-ecoff.h
obj-elf.c PR23938, should not free memory alloced in obstack by free() 2018-12-01 15:18:04 +10:30
obj-elf.h
obj-evax.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
obj-evax.h
obj-fdpicelf.c
obj-fdpicelf.h
obj-macho.c
obj-macho.h
obj-multi.c
obj-multi.h
obj-som.c PR23938, should not free memory alloced in obstack by free() 2018-12-01 15:18:04 +10:30
obj-som.h
rl78-defs.h
rl78-parse.y
rx-defs.h
rx-parse.y
tc-aarch64.c [aarch64] Add support for pointer authentication B key 2018-12-05 18:30:08 +00:00
tc-aarch64.h AArch64: Close sequences at the end of sections 2018-10-03 18:50:40 +01:00
tc-alpha.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-alpha.h
tc-arc.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-arc.h
tc-arm.c [ARM] Improve indentation of ARM architecture declarations 2018-11-13 12:19:28 +00:00
tc-arm.h
tc-avr.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-avr.h
tc-bfin.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-bfin.h
tc-cr16.c
tc-cr16.h
tc-cris.c
tc-cris.h
tc-crx.c
tc-crx.h
tc-csky.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-csky.h csky: Support PC relative diff relocation 2018-09-14 21:04:47 +08:00
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 PR23837, Segmentation fault in resolve_symbol_value 2018-10-28 16:05:51 +10:30
tc-hppa.h
tc-i386-intel.c x86: fold RegEip/RegRip and RegEiz/RegRiz 2018-08-06 08:34:36 +02:00
tc-i386.c x86: adjust {,E}VEX.W handling outside of 64-bit mode 2018-11-06 11:42:54 +01:00
tc-i386.h x86: Extend assembler to generate GNU property notes 2018-08-31 04:31:20 -07:00
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 GAS/MIPS: Add `-mfix-r5900' option for the R5900 short loop erratum 2018-11-30 18:32:36 +00:00
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 Tighten the constraints for warning about NOPs for the MSP 430 ISA, so NOPs are only inserted/warned about when needed. Specifically: 430 and 430x ISA require a NOP after DINT. Only the 430x ISA requires NOP before EINT. Only the 430x ISA requires NOP after every EINT. CPU42 errata. 2018-11-27 12:25:09 +00:00
tc-msp430.h
tc-mt.c
tc-mt.h
tc-nds32.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-nds32.h Andes Technology has good news for you, we plan to update the nds32 port of binutils on upstream! 2018-09-20 13:32:58 +01:00
tc-nios2.c
tc-nios2.h
tc-ns32k.c Fix compile time warning problem with gcc 8 and the NS32K assembler sources. 2018-08-01 14:36:50 +01:00
tc-ns32k.h
tc-or1k.c or1k: Add the l.adrp insn and supporting relocations 2018-10-05 11:41:41 +09:00
tc-or1k.h
tc-pdp11.c Correct the parsing of derferred register addressing in the PDP11 assembler. 2018-08-07 08:34:08 +01:00
tc-pdp11.h
tc-pj.c
tc-pj.h
tc-ppc.c PowerPC @l, @h and @ha warnings, plus VLE e_li 2018-12-06 23:01:03 +10:30
tc-ppc.h PowerPC64 higher REL16 relocations 2018-08-31 22:15:05 +09:30
tc-pru.c Update PRU assembler to corect hardware register numbering for DWARF. 2018-08-03 10:02:39 +01:00
tc-pru.h Update PRU assembler to corect hardware register numbering for DWARF. 2018-08-03 10:02:39 +01:00
tc-riscv.c RISC-V: Accept version, supervisor ext and more than one NSE for -march. 2018-12-03 14:05:17 -08:00
tc-riscv.h opcodes/riscv: Hide '.L0 ' fake symbols 2018-12-06 09:40:56 +00:00
tc-rl78.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-rl78.h
tc-rx.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-rx.h rx: Add target rx-*-linux. 2018-11-07 17:18:05 +09:00
tc-s12z.c S12Z: Add alias instructions BHS and BLO. 2018-11-21 21:31:10 +01:00
tc-s12z.h
tc-s390.c S/390: Fix optional operand handling after memory addresses 2018-11-09 11:01:01 +01:00
tc-s390.h
tc-score7.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-score.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-score.h
tc-sh.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-sh.h
tc-sparc.c gas, sparc: Allow non-fpop2 instructions before floating point branches 2018-09-04 06:25:52 -07:00
tc-sparc.h
tc-spu.c PR23800, .eqv doesn't always defer expression evaluation 2018-10-20 19:46:43 +10:30
tc-spu.h
tc-tic4x.c
tc-tic4x.h
tc-tic6x.c
tc-tic6x.h
tc-tic30.c
tc-tic30.h
tc-tic54x.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-tic54x.h
tc-tilegx.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-tilegx.h
tc-tilepro.c Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
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 Move struc-symbol.h to symbols.c 2018-10-29 18:20:48 +10:30
tc-xtensa.h
tc-z8k.c
tc-z8k.h
tc-z80.c Fix handling of undocumented SLL instruction for the Z80 target. 2018-08-21 15:50:49 +01:00
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 Add support for the C_SKY series of processors. 2018-07-30 12:24:14 +01:00
te-csky_abiv1.h Add support for the C_SKY series of processors. 2018-07-30 12:24:14 +01:00
te-csky_abiv2_linux.h Add support for the C_SKY series of processors. 2018-07-30 12:24:14 +01:00
te-csky_abiv2.h Add support for the C_SKY series of processors. 2018-07-30 12:24:14 +01:00
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