binutils-gdb/gas/config
Richard Sandiford f2ae14a1cc include/opcode/
* mips.h (M_ACLR_OB, M_ASET_OB, M_CACHE_OB, M_CACHEE_OB, M_L_DOB)
	(M_LB_A, M_LBE_OB, M_LBU_A, M_LBUE_OB, M_LD_A, M_LD_OB, M_LDC2_OB)
	(M_LDL_OB, M_LDM_OB, M_LDP_OB, M_LDR_OB, M_LH_A, M_LHE_OB, M_LHU_A)
	(M_LHUE_OB, M_LL_OB, M_LLD_OB, M_LLE_OB, M_LS_A, M_LW_A, M_LWE_OB)
	(M_LWC0_A, M_LWC1_A, M_LWC2_A, M_LWC2_OB, M_LWC3_A, M_LWL_A, M_LWL_OB)
	(M_LWLE_OB, M_LWM_OB, M_LWP_OB, M_LWR_A, M_LWR_OB, M_LWRE_OB, M_LWU_OB)
	(M_PREF_OB, M_PREFE_OB, M_S_DOB, M_SAA_OB, M_SAAD_OB, M_SC_OB)
	(M_SCD_OB, M_SCE_OB, M_SD_A, M_SD_OB, M_SDC2_OB, M_SDL_OB, M_SDM_OB)
	(M_SDP_OB, M_SDR_OB, M_SB_A, M_SBE_OB, M_SH_A, M_SHE_OB, M_SW_A)
	(M_SWE_OB, M_SWC0_A, M_SWC1_A, M_SWC2_A, M_SWC2_OB, M_SWC3_A, M_SWL_A)
	(M_SWL_OB, M_SWLE_OB, M_SWM_OB, M_SWP_OB, M_SWR_A, M_SWR_OB, M_SWRE_OB)
	(M_ULD, M_ULH, M_ULHU, M_ULW, M_USH, M_USW, M_USD): Delete.
	(M_ULD_A, M_ULH_A, M_ULHU_A, M_ULW_A, M_USH_A, M_USW_A, M_USD_A):
	Rename to...
	(M_ULD_AB, M_ULH_AB, M_ULHU_AB, M_ULW_AB, M_USH_AB, M_USW_AB)
	(M_USD_AB): ...these.

opcodes/
	* mips-opc.c (mips_builtin_opcodes): Remove o(b) macros.  Move LD
	and SD A(B) macros up.
	* micromips-opc.c (micromips_opcodes): Likewise.

gas/
	* config/tc-mips.c (gprel16_reloc_p): New function.
	(macro_read_relocs): Assume BFD_RELOC_LO16 if all relocs are
	BFD_RELOC_UNUSED.
	(offset_high_part, small_offset_p): New functions.
	(nacro): Use them.  Remove *_OB and *_DOB cases.  For single-
	register load and store macros, handle the 16-bit offset case first.
	If a 16-bit offset is not suitable for the instruction we're
	generating, load it into the temporary register using
	ADDRESS_ADDI_INSN.  Make the M_LI_DD code fall through into the
	M_L_DAB code once the address has been constructed.  For double load
	and store macros, again handle the 16-bit offset case first.
	If the second register cannot be accessed from the same high
	part as the first, load it into AT using ADDRESS_ADDI_INSN.
	Fix the handling of LD in cases where the first register is the
	same as the base.  Also handle the case where the offset is
	not 16 bits and the second register cannot be accessed from the
	same high part as the first.  For unaligned loads and stores,
	fuse the offbits == 12 and old "ab" handling.  Apply this handling
	whenever the second offset needs a different high part from the first.
	Construct the offset using ADDRESS_ADDI_INSN where possible,
	for offbits == 16 as well as offbits == 12.  Use offset_reloc
	when constructing the individual loads and stores.
	(mips_ip): Set up imm_expr, imm2_expr, offset_expr, imm_reloc
	and offset_reloc before matching against a particular opcode.
	Handle elided 'A' constants.  Allow 'A' constants to use
	relocation operators.

gas/testsuite/
	* gas/mips/ldstla-32.d: Avoid "lui at,0x0" sequences for
	truncated constants.
	* gas/mips/ldstla-32-shared.d: Likewise.
	* gas/mips/mcu.d: Use ADDIU in preference to LI+ADDU when adding
	16-bit constants to the base.
	* gas/mips/micromips@mcu.d: Likewise.
	* gas/mips/micromips@cache.d: Likewise.
	* gas/mips/micromips@pref.d: Likewise.
	* gas/mips/micromips.d, gas/mips/micromips-insn32.d,
	gas/mips/micromips-noinsn32.d, gas/mips/micromips-trap.d: Likewise.
	Allow the full 16-bit offset range to be used for SB, LB and LBU in
	USH and ULH sequences.  Fix the expected output for LD and SD when
	the two LW and SW offsets need different high parts.
	* gas/mips/eva.s: Test PREFE with relocation operators.
	* gas/mips/eva.d: Use ADDIU in preference to LI+ADDU for 16-bit
	constants.  Update after eva.s change.
	* gas/mips/micromips@eva.d: Likewise.
	* gas/mips/ld-reloc.s, gas/mips/ld-reloc.d, gas/mips/l_d-reloc.s,
	gas/mips/l_d-reloc.d, gas/mips/ulw-reloc.s, gas/mips/ulw-reloc.d,
	gas/mips/micromips@ulw-reloc.d, gas/mips/ulh-reloc.s,
	gas/mips/ulh-reloc.d: New tests.
	* gas/mips/mips.exp: Run them.
2013-07-07 11:32:32 +00:00
..
aout_gnu.h
atof-ieee.c Remove trailing redundant `;' 2012-11-09 08:29:34 +00:00
atof-vax.c Remove trailing redundant `;' 2012-11-09 08:29:34 +00:00
bfin-aux.h
bfin-defs.h
bfin-lex-wrapper.c Add copyright notices 2012-12-17 16:56:12 +00:00
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 * config/obj-coff.c: Add include of struc-symbol.h header. 2012-10-18 17:00:56 +00:00
obj-coff.h
obj-ecoff.c
obj-ecoff.h
obj-elf.c 2013-02-06 Sandra Loosemore <sandra@codesourcery.com> 2013-02-06 23:22:26 +00:00
obj-elf.h * read.h (s_vendor_attribute): Move to... 2012-11-09 18:07:10 +00:00
obj-evax.c
obj-evax.h
obj-fdpicelf.c Add copyright notices 2012-12-17 16:56:12 +00:00
obj-fdpicelf.h Add copyright notices 2012-12-17 16:56:12 +00:00
obj-macho.c
obj-macho.h
obj-multi.c
obj-multi.h
obj-som.c
obj-som.h
rl78-defs.h
rl78-parse.y * rl78-decode.opc: Fix encoding of DIVWU insn. 2013-02-25 18:41:06 +00:00
rx-defs.h
rx-parse.y
tc-aarch64.c [PATCH, COMMITTED] [AArch64] Replace the :got_prel19: address modifier with :got: 2013-07-03 17:26:36 +00:00
tc-aarch64.h [AArch64, ILP32] 2/6 Parametrize elfnn-aarch64.c and add basic support in ld 2013-06-26 10:41:42 +00:00
tc-alpha.c
tc-alpha.h
tc-arc.c
tc-arc.h
tc-arm.c gas/ 2013-06-24 23:13:00 +00:00
tc-arm.h gas/ 2012-11-20 17:53:46 +00:00
tc-avr.c * gas/config/tc-avr.c: Change ISA for devices with USB support to 2013-06-01 07:14:44 +00:00
tc-avr.h PR gas/14255 2013-02-05 23:02:54 +00:00
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-d10v.c Remove trailing redundant `;' 2012-11-09 08:29:34 +00:00
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-generic.c
tc-generic.h
tc-h8300.c * elf32-h8300 (h8_relax_section): Add new relaxation of mov 2013-03-21 16:08:07 +00:00
tc-h8300.h * elf32-h8300 (h8_relax_section): Add new relaxation of mov 2013-03-21 16:08:07 +00:00
tc-hppa.c * config/tc-hppa.c (pa_get_number): New. 2012-10-14 23:59:39 +00:00
tc-hppa.h
tc-i370.c
tc-i370.h
tc-i386-intel.c Remove trailing redundant `;' 2012-11-09 08:29:34 +00:00
tc-i386.c Don't align text/data/bss sections for ELF 2013-05-31 17:27:28 +00:00
tc-i386.h Add AMD btver1 and btver2 support 2012-08-17 17:12:36 +00:00
tc-i860.c
tc-i860.h
tc-i960.c
tc-i960.h * write.c (fixup_segment): Return void. Delete seg_reloc_count 2013-02-04 12:34:17 +00:00
tc-ia64.c gas/ 2013-03-26 09:13:17 +00:00
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 2012-11-07 James Murray <jsm@jsm-net.demon.co.uk> 2012-11-07 20:36:33 +00:00
tc-m68hc11.h
tc-m68k.c PR gas/15602 2013-06-13 08:53:35 +00:00
tc-m68k.h PR gas/15602 2013-06-13 08:53:35 +00:00
tc-m68851.h
tc-mcore.c
tc-mcore.h
tc-mep.c
tc-mep.h
tc-metag.c * config/tc-metag.c: Make SWAP instruction less permissive with its operands. 2013-01-30 13:21:01 +00:00
tc-metag.h * common.h: Fix case of "Meta". 2013-01-10 09:49:22 +00:00
tc-microblaze.c Microblaze: Add support for handling TLS symbol suffixes and generating 2012-12-11 16:56:53 +00:00
tc-microblaze.h Add microblazeel target support to bfd, gas and ld. 2012-11-09 16:25:12 +00:00
tc-mips.c include/opcode/ 2013-07-07 11:32:32 +00:00
tc-mips.h gas/ 2012-09-23 11:14:27 +00:00
tc-mmix.c * config/tc-mmix.c (loc_asserts): New variable. 2012-08-14 02:29:01 +00:00
tc-mmix.h PR gas/14521 2012-09-01 18:10:50 +00:00
tc-mn10200.c
tc-mn10200.h
tc-mn10300.c
tc-mn10300.h
tc-moxie.c Bi-endian patches for moxie 2012-09-13 22:24:51 +00:00
tc-moxie.h Bi-endian patches for moxie 2012-09-13 22:24:51 +00:00
tc-msp430.c * config/tc-msp430.c (msp430_srcoperand): Do not allow the use of 2013-06-25 08:21:43 +00:00
tc-msp430.h * archures.c: Add some more MSP430 machine numbers. 2013-05-02 21:06:15 +00:00
tc-mt.c
tc-mt.h
tc-nios2.c 2013-06-12 Sandra Loosemore <sandra@codesourcery.com> 2013-06-12 23:11:57 +00:00
tc-nios2.h 2013-02-06 Sandra Loosemore <sandra@codesourcery.com> 2013-02-06 23:22:26 +00:00
tc-ns32k.c
tc-ns32k.h
tc-openrisc.c
tc-openrisc.h
tc-or32.c
tc-or32.h
tc-pdp11.c
tc-pdp11.h
tc-pj.c
tc-pj.h
tc-ppc.c bfd/ 2013-07-02 00:25:08 +00:00
tc-ppc.h bfd/ 2012-11-06 05:18:03 +00:00
tc-rl78.c * reloc.c (BFD_RELOC_RL78_CODE): Add. 2013-02-27 21:39:20 +00:00
tc-rl78.h
tc-rx.c 2012-11-09 Nick Clifton <nickc@redhat.com> 2012-11-09 17:00:44 +00:00
tc-rx.h
tc-s390.c 2013-07-05 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> 2013-07-05 09:45:44 +00:00
tc-s390.h
tc-score7.c
tc-score.c
tc-score.h
tc-sh64.c
tc-sh64.h
tc-sh.c gas/ 2013-04-15 10:30:23 +00:00
tc-sh.h
tc-sparc.c Fix sparc bitness overrides in GAS. Noticed by Eric Botcazou. 2012-11-20 08:37:52 +00:00
tc-sparc.h PR gas/15178 2013-03-26 13:49:12 +00:00
tc-spu.c
tc-spu.h
tc-tic4x.c bfd/ 2012-11-06 05:51:18 +00:00
tc-tic4x.h
tc-tic6x.c PR binutils/15068 2013-03-27 11:43:37 +00:00
tc-tic6x.h
tc-tic30.c
tc-tic30.h
tc-tic54x.c
tc-tic54x.h
tc-tilegx.c Add support for constructing pc-relative addresses to the plt, by 2012-08-28 02:43:22 +00:00
tc-tilegx.h
tc-tilepro.c
tc-tilepro.h
tc-v850.c oops - omitted from previous delta 2013-04-04 07:24:08 +00:00
tc-v850.h 2012-11-09 Nick Clifton <nickc@redhat.com> 2012-11-09 17:36:19 +00:00
tc-vax.c
tc-vax.h
tc-xc16x.c
tc-xc16x.h
tc-xgate.c * config/tc-xgate.c (md_begin): Fix mistake made when going from 2013-01-11 21:12:34 +00:00
tc-xgate.h gas/config/ 2012-06-28 21:36:35 +00:00
tc-xstormy16.c
tc-xstormy16.h
tc-xtensa.c Remove trailing redundant `;' 2012-11-09 08:29:34 +00:00
tc-xtensa.h
tc-z8k.c * config/tc-z8k.c (md_parse_option): Set z8k_target_from_cmdline 2013-04-26 19:21:25 +00:00
tc-z8k.h
tc-z80.c
tc-z80.h
te-386bsd.h
te-aix5.h
te-armeabi.h
te-armlinuxeabi.h
te-dragonfly.h
te-dynix.h
te-epoc-pe.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-i386aix.h
te-ia64aix.h
te-interix.h
te-irix.h
te-linux.h
te-lynx.h
te-mach.h
te-macos.h
te-nacl.h
te-nbsd532.h
te-nbsd.h
te-netware.h
te-pc532mach.h
te-pe.h
te-pep.h
te-psos.h
te-riscix.h
te-solaris.h
te-sparcaout.h
te-sun3.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