2011-01-15 15:48:02 +00:00
|
|
|
|
2011-01-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-i386.c (disallow_64bit_disp): New.
|
|
|
|
|
(x86_elf_abi): Replace X86_64_LP64_ABI/X86_64_ILP32_ABI with
|
|
|
|
|
X86_64_ABI/X86_64_X32_ABI.
|
|
|
|
|
(md_assemble): Don't allow movabs with relocation in x32 mode.
|
|
|
|
|
(i386_target_format): Updated.
|
|
|
|
|
|
2011-01-14 23:07:11 +00:00
|
|
|
|
2011-01-14 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-i386.c (OPTION_N32): Renamed to ...
|
|
|
|
|
(OPTION_X32): This.
|
|
|
|
|
(md_longopts): Replace n32 with x32.
|
|
|
|
|
(md_parse_option): Updated.
|
|
|
|
|
(md_show_usage): Likewise.
|
|
|
|
|
|
|
|
|
|
* doc/c-i386.texi: Replace n32 with x32.
|
|
|
|
|
|
2011-01-11 07:22:09 +00:00
|
|
|
|
2011-01-11 Mingjie Xing <mingjie.xing@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-mips.c (mips_ip): Update error messages. Take an
|
|
|
|
|
unadjusted offset for "+c" argument.
|
|
|
|
|
|
2011-01-10 10:10:06 +00:00
|
|
|
|
2011-01-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-i386.c (x86_elf_abi): Only define for targets that use
|
|
|
|
|
it.
|
|
|
|
|
|
2011-01-10 09:50:02 +00:00
|
|
|
|
2011-01-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-arm.c (s_arm_tls_desceq): Move code into ELF-only
|
|
|
|
|
part of the file.
|
|
|
|
|
|
bfd/
* reloc.c (BFD_RELOC_ARM_TLS_GOTDESC, BFD_RELOC_ARM_TLS_CALL,
BFD_RELOC_ARM_THM_TLS_CALL, BFD_RELOC_ARM_TLS_DESCSEQ,
BFD_RELOC_ARM_THM_TLS_DESCSEQ, BFD_RELOC_ARM_TLS_DESC): New
relocations.
* libbfd.h: Rebuilt.
* bfd-in2.h: Rebuilt.
* elf32-arm.c (elf32_arm_howto_table_1): Add new relocations.
(elf32_arm_reloc_map): Likewise.
(tls_trampoline, dl_tlsdesc_lazy_trampoline): New PLT templates.
(elf32_arm_stub_long_branch_any_tls_pic,
elf32_arm_stub_long_branch_v4t_thumb_tls_pic): New stub templates.
(DEF_STUBS): Add new stubs.
(struct_elf_arm_obj_data): Add local_tlsdesc_gotent field.
(elf32_arm_local_tlsdesc_gotent): New.
(GOT_TLS_GDESC): New mask.
(GOT_TLS_GD_ANY): Define.
(struct elf32_arm_link_hash_entry): Add tlsdesc_got field.
(elf32_arm_compute_jump_table_size): New.
(struct elf32_arm_link_hash_table): Add next_tls_desc_index,
num_tls_desc, dt_tlsdesc_plt, dt_tlsdesc_got, tls_trampoline,
sgotplt_jump_table_size fields.
(elf32_arm_link_hash_newfunc): Initialize tlsdesc_got field.
(elf32_arm_link_hash_table_create): Initialize new fields.
(arm_type_of_stub): Check TLS desc relocs too.
(elf32_arm_stub_name): TLS desc relocs can be shared.
(elf32_arm_tls_transition): Determine relaxation.
(arm_stub_required_alignment): Add tls stubs.
(elf32_arm_size_stubs): Likewise.
(elf32_arm_tls_relax): Perform TLS relaxing.
(elf32_arm_final_link_relocate): Process TLS DESC relocations.
(IS_ARM_TLS_GNU_RELOC): New.
(IS_ARM_TLS_RELOC): Use it.
(elf32_arm_relocate_section): Perform TLS relaxing.
(elf32_arm_check_relocs): Anticipate TLS relaxing, process tls
desc relocations.
(allocate_dynrelocs): Allocate tls desc relcoations.
(elf32_arm_output_arch_local_syms): Emit tls trampoline mapping
symbols.
(elf32_arm_size_dynamic_sections): Allocate tls trampolines and
got slots.
(elf32_arm_always_size_sections): New. Create _TLS_MODULE_BASE
symbol.
(elf32_arm_finish_dynamic_symbol): Adjust.
(arm_put_trampoline): New.
(elf32_arm_finish_dynamic_sections): Emit new dynamic tags and tls
trampolines.
(elf_backend_always_size_sections): Define.
include/elf/
* arm.h (R_ARM_TLS_DESC, R_ARM_TLS_GOTDESC, R_ARM_TLS_CALL,
R_ARM_TLS_DESCSEQ, T_ARM_THM_TLS_CALL, R_ARM_THM_TLS_DESCSEQ): New
relocations.
gas/
* doc/c-arm.texi: Document TLSDESC and TLSCALL relocations, and
.tlsdescseq directive.
* config/tc-arm.c (arm_typed_reg_parse): Check for potential reloc
following a symbol.
(s_arm_tls_descseq): New directive.
(md_pseudo_table): Add it.
(encode_branch): Allow TLS_CALL relocs too.
(do_t_blx, do_t_branch23): Use encode_branch.
(reloc_names): Add tlsdesc and tlscall.
(md_apply_fix): Process tls desc relocations.
(tc_gen_reloc): Likewise.
(arm_fix_adjustable): Likewise.
gas/testsuite/
* gas/arm/tls.s: Add tlsdesc tests.
* gas/arm/tls.d: Adjust.
ld/testsuite/
* ld-arm/arm-elf.exp: Added tests for new TLS handling
relocations.
* ld-arm/tls-descrelax-be32.d: New.
* ld-arm/tls-descrelax-be32.s: New.
* ld-arm/tls-descrelax-be8.d: New.
* ld-arm/tls-descrelax-be8.s: New.
* ld-arm/tls-descrelax-v7.d: New.
* ld-arm/tls-descrelax-v7.s: New.
* ld-arm/tls-descrelax.d: New.
* ld-arm/tls-descrelax.s: New.
* ld-arm/tls-descseq.d: New.
* ld-arm/tls-descseq.r: New.
* ld-arm/tls-descseq.s: New.
* ld-arm/tls-gdesc-got.d: New.
* ld-arm/tls-gdesc-got.s: New.
* ld-arm/tls-gdesc-nlazy.g: New.
* ld-arm/tls-gdesc-nlazy.s: New.
* ld-arm/tls-gdesc.d: New.
* ld-arm/tls-gdesc.r: New.
* ld-arm/tls-gdesc.s: New.
* ld-arm/tls-gdierelax.d: New.
* ld-arm/tls-gdierelax.s: New.
* ld-arm/tls-gdierelax2.d: New.
* ld-arm/tls-gdierelax2.s: New.
* ld-arm/tls-gdlerelax.d: New.
* ld-arm/tls-gdlerelax.s: New.
* ld-arm/tls-lib-loc.d: New.
* ld-arm/tls-lib-loc.r: New.
* ld-arm/tls-lib-loc.s: New.
* ld-arm/tls-longplt-lib.d: New.
* ld-arm/tls-longplt-lib.s: New.
* ld-arm/tls-longplt.d: New.
* ld-arm/tls-longplt.s: New.
* ld-arm/tls-mixed.r: New.
* ld-arm/tls-mixed.s: New.
* ld-arm/tls-thumb1.d: New.
* ld-arm/tls-thumb1.s: New.
* ld-arm/arm-elf.exp: New.
2011-01-10 08:40:19 +00:00
|
|
|
|
2011-01-10 Nathan Sidwell <nathan@codesourcery.com>
|
|
|
|
|
Glauber de Oliveira Costa <glommer@gmail.com>
|
|
|
|
|
|
|
|
|
|
* doc/c-arm.texi: Document TLSDESC and TLSCALL relocations, and
|
|
|
|
|
.tlsdescseq directive.
|
|
|
|
|
* config/tc-arm.c (arm_typed_reg_parse): Check for potential reloc
|
|
|
|
|
following a symbol.
|
|
|
|
|
(s_arm_tls_descseq): New directive.
|
|
|
|
|
(md_pseudo_table): Add it.
|
|
|
|
|
(encode_branch): Allow TLS_CALL relocs too.
|
|
|
|
|
(do_t_blx, do_t_branch23): Use encode_branch.
|
|
|
|
|
(reloc_names): Add tlsdesc and tlscall.
|
|
|
|
|
(md_apply_fix): Process tls desc relocations.
|
|
|
|
|
(tc_gen_reloc): Likewise.
|
|
|
|
|
(arm_fix_adjustable): Likewise.
|
|
|
|
|
|
2011-01-07 17:44:30 +00:00
|
|
|
|
2011-01-07 Quentin Neill <quentin.neill@amd.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-i386.c (cpu_arch): Add CPU_BMI_FLAGS.
|
|
|
|
|
|
|
|
|
|
* doc/c-i386.texi (i386-BMI): New section.
|
|
|
|
|
|
2011-01-06 16:41:35 +00:00
|
|
|
|
2011-01-06 Paul Koning <ni1d@arrl.net>
|
|
|
|
|
|
|
|
|
|
* config/tc-pdp11.c (parse_op_no_deferred): Allow PC-relative
|
|
|
|
|
references to absolute addresses.
|
|
|
|
|
|
2011-01-05 22:04:09 +00:00
|
|
|
|
2011-01-05 DJ Delorie <dj@redhat.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-rx.c (tc_gen_reloc): Emit an RX_OP_NEG expression
|
|
|
|
|
instead of an RH_NEG32 one.
|
|
|
|
|
|
2011-01-05 21:35:08 +00:00
|
|
|
|
2011-01-05 Jonathan Wakely <jwakely.gcc@gmail.com>
|
|
|
|
|
|
|
|
|
|
* doc/c-i386.texi: Clarify --n32.
|
|
|
|
|
|
2011-01-05 00:16:57 +00:00
|
|
|
|
2011-01-04 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-i386.c (build_modrm_byte): Allow encoding 32/64bit
|
|
|
|
|
integer registers in VEX.vvvv. Check register-only source
|
|
|
|
|
operand when two source operands are swapped. Properly update
|
|
|
|
|
destination when two source operands are swapped.
|
|
|
|
|
|
2011-01-01 20:55:48 +00:00
|
|
|
|
2011-01-01 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* gas.c (parse_args): Update copyright to 2011.
|
|
|
|
|
|
2011-01-01 16:44:48 +00:00
|
|
|
|
For older changes see ChangeLog-2010
|
2002-01-07 12:12:47 +00:00
|
|
|
|
|
|
|
|
|
Local Variables:
|
|
|
|
|
mode: change-log
|
|
|
|
|
left-margin: 8
|
|
|
|
|
fill-column: 74
|
|
|
|
|
version-control: never
|
|
|
|
|
End:
|