From bab4becb122e95e9cd17cb8046d9d3cf49d351f4 Mon Sep 17 00:00:00 2001 From: Nick Clifton Date: Wed, 2 Jan 2013 13:13:36 +0000 Subject: [PATCH] opcodes/ChangeLog * cr16-dis.c (match_opcode,make_instruction: Remove static declaration. (dwordU,wordU): Moved typedefs to opcode/cr16.h (cr16_words,cr16_allWords,cr16_currInsn): Added prefix 'cr16_' bfd/Changelog * config.bfd (cr16*-*-uclinux*): New target support. include/opcode/ChangeLog * cr16.h (dwordU,wordU): Moved typedefs from cr16-dis.c (make_instruction,match_opcode): Added function prototypes. (cr16_words,cr16_allWords,cr16_currInsn): Declare as extern. --- bfd/ChangeLog | 3288 +------------------------------------ bfd/ChangeLog-2012 | 3299 ++++++++++++++++++++++++++++++++++++++ bfd/config.bfd | 4 +- include/opcode/ChangeLog | 6 + include/opcode/cr16.h | 371 ++--- opcodes/ChangeLog | 1059 +----------- opcodes/ChangeLog-2012 | 1066 ++++++++++++ opcodes/cr16-dis.c | 126 +- 8 files changed, 4643 insertions(+), 4576 deletions(-) create mode 100644 bfd/ChangeLog-2012 create mode 100644 opcodes/ChangeLog-2012 diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 9be65bfdbba..88dfe1b97a1 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3291 +1,11 @@ -2012-12-23 Mike Frysinger +2013-01-02 Kaushik Phatak - * config.bfd (i[3-7]86-*-linux-*): Add x86_64pei_vec to - targ64_selvecs. + * config.bfd (cr16*-*-uclinux*): New target support. -2012-12-21 H.J. Lu - * elf64-x86-64.c (elf_x86_64_relocate_section): Check - R_X86_64_standard instead of R_X86_64_max for unrecognized - relocation. - -2012-12-21 H.J. Lu - - PR ld/14980 - * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Properly - adjust h->plt.refcount. - * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. - -2012-12-19 H.J. Lu - - * elf32-i386.c (elf_i386_relocate_section): Replace - bfd_elf32_swap_reloc_out with elf_append_rel. - (elf_i386_finish_dynamic_symbol): Likewise. - - * elflink.c (elf_append_rel): Call swap_reloc_out instead of - swap_reloca_out. - -2012-12-18 H.J. Lu - - * elf32-i386.c (elf_i386_finish_dynamic_symbol): Reindent. - -2012-12-18 Edgar E. Iglesias - - PR ld/14736 - * elf32-microblaze.c (calc_fixup): Add end range. - -2012-12-18 Alan Modra - - * elf.c (swap_out_syms): Set shndx to SHN_ABS when not one of - the special MAP_* values. - -2012-12-17 Roland McGrath - Alan Modra - - * elf32-arm.c (elf32_arm_size_stubs): Skip input BFDs that are - not ARM ELF. - -2012-12-17 Nick Clifton - - * MAINTAINERS: Add copyright notice. - * Makefile.am: Likewise. - * PORTING: Likewise. - * README: Likewise. - * TODO: Likewise. - * acinclude.m4: Likewise. - * bfd.m4: Likewise. - * config.bfd: Likewise. - * configure.com: Likewise. - * configure.host: Likewise. - * configure.in: Likewise. - * makefile.vms: Likewise. - * warning.m4: Likewise. - * elf64-hppa.c: Fix copyright notice. - * Makefile.in: Regenerate. - -2012-12-16 H.J. Lu - - * elf32-i386.c (elf_i386_check_relocs): Don't check IFUNC - relocations here. - * elf64-x86-64.c (elf_x86_64_check_relocs): Likewise. - -2012-12-16 H.J. Lu - - PR ld/14968 - * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Also check - local IFUNC references. - * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. - -2012-12-14 Tom Tromey - - * elf.c (elfcore_grok_note) : New case. - -2012-12-13 H.J. Lu - - PR ld/14956 - * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Check local - IFUNC calls. - * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. - -2012-12-10 Edgar E. Iglesias - - * reloc.c (MICROBLAZE): Document new relocations - * bfd-in2.h: Regenerated - * libbfd.h: Regenerated - * elf32-microblaze.c (microblaze_elf_howto_raw): Add TLS relocations - (microblaze_elf_reloc_type_lookup): Likewise - (elf32_mb_link_hash_entry): define TLS reference types - (elf32_mb_link_hash_table): add TLS Local dynamic GOT entry - #define has_tls_reloc if section has TLS relocs - (dtprel_base), (check_unique_offset): New - (microblaze_elf_output_dynamic_relocation): output simple - dynamic relocation into SRELOC. - (microblaze_elf_relocate_section): Accommodate TLS relocations. - (microblaze_elf_check_relocs): Likewise - (update_local_sym_info): New - (microblaze_elf_copy_indirect_symbol): Add tls_mask. - (allocate_dynrelocs): Handle TLS symbol - (microblaze_elf_size_dynamic_sections): Set size and offset - (microblaze_elf_finish_dynamic_symbol): Use - microblaze_elf_output_dynamic_relocation - -2012-12-09 H.J. Lu - - PR binutils/14933 - * archive.c (bsd_write_armap): Properly check indicies bigger - than 4Gb. - -2012-12-07 Alan Modra - - PR ld/14926 - * elf.c (_bfd_elf_map_sections_to_segments): Include elf header - size when determining phdr_in_segment. - -2012-12-06 Yufeng Zhang - - * elf64-aarch64.c (elf64_aarch64_grok_prstatus): New function. - (elf_backend_grok_prstatus): Define to elf64_aarch64_grok_prstatus. - -2012-12-06 Alan Modra - - * elfxx-mips.c (allocate_dynrelocs): Correct test for symbol - defined in a regular file to include common symbols. - -2012-12-05 Leif Ekblad - - * config.bfd: Add x86_64-*-rdos. - -2012-12-05 Alan Modra - - * elf64-ppc.c (build_plt_stub): Fix off by one error in branch - to glink. - -2012-12-03 Maciej W. Rozycki - - PR ld/10629 - * elfxx-mips.c (mips_elf_link_hash_table): Update comment for - use_rld_obj_head. - (_bfd_mips_elf_create_dynamic_sections): Always create a - .rld_map section if no __rld_obj_head symbol has been seen. - -2012-12-03 Maciej W. Rozycki - - * elf32-mips.c (mips_elf32_object_p): Return right away when the - ABI is not compatible. - * elfn32-mips.c (mips_elf_n32_object_p): Likewise. - -2012-12-03 Maciej W. Rozycki - - * elf32-tilepro.c (tilepro_elf_mkobject): New function. - (bfd_elf32_mkobject): New macro. - -2012-12-03 Maciej W. Rozycki - - * elf32-mips.c (bfd_elf32_mkobject): New macro. - * elf64-mips.c (bfd_elf64_mkobject): Likewise. - * elfn32-mips.c (bfd_elf32_mkobject): Likewise. - * elfxx-mips.h (_bfd_mips_elf_mkobject): New prototype. - * elfxx-mips.c (mips_elf_obj_tdata): New struct. - (mips_elf_tdata): New macro. - (_bfd_mips_elf_mkobject): New function. - (mips_elf_merge_obj_attributes): Report the originating input BFD - on attribute conflicts. - -2012-12-03 Maciej W. Rozycki - - * elfxx-mips.c (mips_elf_merge_obj_attributes): Correct messages - for the -mdouble-float and -msingle-float cases throughout; make - all the messages report the output file consistently on the - left-hand side. - -2012-11-29 Roland McGrath - - * elf-nacl.c (segment_eligible_for_headers): Disallow writable segments. - -2012-11-26 Roland McGrath - - * elf-nacl.c (nacl_modify_segment_map): Don't crash when INFO is null. - -2012-11-21 H.J. Lu - - PR binutils/14493 - * elf.c (copy_elf_program_header): When rewriting program - header, set the output maxpagesize to the maximum alignment - of input PT_LOAD segments. - -2012-11-21 Roland McGrath - - * elf-nacl.c (segment_nonexecutable_and_has_contents): Renamed to ... - (segment_eligible_for_headers): ... this. Take new arguments - MAXPAGESIZE and SIZEOF_HEADERS. Return false if the first section's - start address doesn't leave space for the headers. - (nacl_modify_segment_map): Update caller. - -2012-11-20 H.J. Lu - - PR ld/14862 - * elf-bfd.h (elf_link_hash_entry): Remove ref_dynamic_nonweak - added by accident. - (elf_link_add_object_symbols): Don't set nor check - ref_dynamic_nonweak. - -2012-11-20 Alan Modra - - * elf32-rx.c (rx_elf_print_private_bfd_data): Warning fix. - -2012-11-16 Joey Ye - - * elf32-arm.c (elf32_arm_final_link_relocate - ): Align address of - the place being relocated. - (elf32_arm_final_link_relocate, case R_ARM_THM_PC8): Align address - of the place being relocated and truncate addend. - (Pa): New macro. - -2012-11-14 Roland McGrath - - * elf32-arm.c (elf32_arm_nacl_plt0_entry): Use bic rather than bfc - instruction for data sandboxing. - -2012-11-14 Tristan Gingold - - * mach-o.c (bfd_mach_o_read_main) - (bfd_mach_o_read_source_version): New functions. - (bfd_mach_o_read_command): Handle BFD_MACH_O_LC_DATA_IN_CODE, - BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS, BFD_MACH_O_LC_MAIN, - BFD_MACH_O_LC_SOURCE_VERSION. - * mach-o.h (bfd_mach_o_main_command) - (bfd_mach_o_source_version_command): New types. - (bfd_mach_o_load_command): Add fields for these new types. - -2012-11-14 Tristan Gingold - - * mach-o.c (bfd_mach_o_canonicalize_one_reloc): Add a special - handling for non-scattered pairs. Update comments. - -2012-11-13 Joe Seymour - - * elf.c (rewrite_elf_program_header): Allocate elf_segment_map - with bfd_zalloc, instead of bfd_alloc. - -2012-11-09 Nick Clifton - - * Makefile.am (ALL_MACHINES): Add cpu-v850-rh850.lo. - (ALL_MACHINES_CFILES): Add cpu-v850-rh850.c. - * archures.c (bfd_arch_info): Add bfd_v850_rh850_arch. - * config.bfd: Likewise. - * configure.in: Add bfd_elf32_v850_rh850_vec. - * cpu-v850.c: Update printed description. - * cpu-v850_rh850.c: New file. - * elf32-v850.c (v850_elf_check_relocs): Add support for RH850 ABI - relocs. - (v850_elf_perform_relocation): Likewise. - (v850_elf_final_link_relocate): Likewise. - (v850_elf_relocate_section): Likewise. - (v850_elf_relax_section): Likewise. - (v800_elf_howto_table): New. - (v850_elf_object_p): Add support for RH850 ABI values. - (v850_elf_final_write_processing): Likewise. - (v850_elf_merge_private_bfd_data): Likewise. - (v850_elf_print_private_bfd_data): Likewise. - (v800_elf_reloc_map): New. - (v800_elf_reloc_type_lookup): New. - (v800_elf_reloc_name_lookup): New. - (v800_elf_info_to_howto): New. - (bfd_elf32_v850_rh850_vec): New. - (bfd_arch_v850_rh850): New. - * targets.c (_bfd_targets): Add bfd_elf32_v850_rh850_vec. - * Makefile.in: Regenerate. - * bfd-in2.h: Regenerate. - * configure: Regenerate. - - * elf32-rx.c (describe_flags): New function. Returns a buffer - containing a description of the E_FLAG_RX_... values set. - (rx_elf_merge_private_bfd_data): Use it. - (rx_elf_print_private_bfd_data): Likewise. - (elf32_rx_machine): Skip EF_RX_CPU_RX check. - (elf32_rx_special_sections): Define. - (elf_backend_special_sections): Define. - -2012-11-09 Edgar E. Iglesias - - * config.bfd: Add microblazeel-*-* - * configure.in: Likewise. - * configure: Regenerate. - * elf32-microblaze.c (microblaze_elf_relocate_section): Add endian awareness. - (microblaze_elf_merge_private_bfd_data): New. - (microblaze_bfd_write_imm_value_32): New. - (microblaze_bfd_write_imm_value_64): New. - (microblaze_elf_relax_section): Add endian awareness. - (microblaze_elf_add_symbol_hook): Define TARGET_LITTLE_NAME, - TARGET_LITTLE_SYM and bfd_elf32_bfd_merge_private_bfd_data. - * targets.c: Add bfd target bfd_elf32_microblazeel_vec. - -2012-11-09 H.J. Lu - - * aout-tic30.c (MY_final_link_callback): Remove trailing - redundant `;'. - * coff-h8500.c (extra_case): Likewise. - (bfd_coff_reloc16_get_value): Likewise. - * dwarf2.c (_bfd_dwarf2_cleanup_debug_info): Likewise. - * elf.c (_bfd_elf_slurp_version_tables): Likewise. - * elf32-frv.c (elf32_frv_relocate_section): Likewise. - * elf32-v850.c (v850_elf_perform_relocation): Likewise. - * opncls.c (bfd_calc_gnu_debuglink_crc32): Likewise. - * plugin.c (add_symbols): Likewise. - * reloc.c (bfd_check_overflow): Likewise. - * vms-lib.c (_bfd_vms_lib_archive_p): Likewise. - -2012-11-08 Tom Tromey - - * elf.c (elfcore_grok_note) : New case; make - pseudosection. - -2012-11-08 Alan Modra - - * aclocal.m4: Regenerate. - * Makefile.in: Regenerate. - * po/SRC-POTFILES.in: Regenerate. - -2012-11-07 H.J. Lu - - * section.c (bfd_get_section_contents): Replace memcpy - with memmove. - -2012-11-07 Hans-Peter Nilsson - - PR binutils/14481 - * aout-target.h (MY_close_and_cleanup): Make local function - instead of alias of MY_bfd_free_cached_info. Also call - _bfd_generic_close_and_cleanup. - -2012-11-06 H.J. Lu - - PR binutils/14813 - * bfdio.c (bfd_iovec): Change return type of bclose to - bfd_boolean. - (memory_bclose): Change return type to bfd_boolean. - * cache.c (cache_bclose): Likewise. - * opncls.c (opncls_bclose): Likewise. Return TRUE on success. - * vms-lib.c (vms_lib_bclose): Likewise. Return TRUE. - * libbfd.h: Regenerated. - -2012-11-06 Tristan Gingold - - * coff-x86_64.c (_bfd_generic_find_nearest_line_discriminator): - Define as coff_find_nearest_line_discriminator. - -2012-11-06 Alan Modra - - PR binutils/14567 - * opncls.c (opncls_iovec): Forward declare. - (_bfd_new_bfd_contained_in): If using opncls_iovec, copy iostream - to new bfd. - -2012-11-06 Alan Modra - - * mach-o.c (bfd_mach_o_close_and_cleanup): Don't call - _bfd_generic_close_and_cleanup for mach_o_fat archives. - -2012-11-06 Alan Modra - - * coff-tic4x.c (tic4x_coff0_vec, tic4x_coff0_beh_vec, - tic4x_coff1_vec, tic4x_coff1_beh_vec, tic4x_coff2_vec, - tic4x_coff2_beh_vec): Allow SEC_CODE and SEC_READONLY in - section flags. - * coff-ppc.c (TARGET_LITTLE_SYM): Likewise. - (TARGET_BIG_SYM): Likewise. - -2012-11-06 Alan Modra - - * elf64-ppc.c (struct ppc_link_hash_table): Add dot_toc_dot. - (ppc64_elf_size_stubs): Lookup ".TOC.". - (ppc64_elf_relocate_section): Resolve special symbol ".TOC.". - -2012-11-06 Alan Modra - - * elf64-ppc.c (maybe_strip_output): Heed SEC_KEEP. - -2012-11-05 Andreas Krebbel - - PR target/14788 - * elf32-s390.c (elf_s390_relocate_section): Set elf.dynobj for - local ifunc symbols. - * elf64-s390.c (elf_s390_relocate_section): Likewise. - -2012-11-05 Alan Modra - - * configure.in: Apply 2012-09-10 change to config.in here. - -2012-11-05 Alan Modra - - * elf64-ppc.c (ppc64_elf_edit_toc): Clear "repeat" inside - loop. Really mark toc entry referring to another toc entry - only if the first is used. - -2012-10-30 H.J. Lu - - * configure.in: Also handle --enable-64-bit-bfd when setting - CORE_HEADER for 'i[3-7]86-*-linux-*'. - -2012-10-30 Steve McIntyre - - * elf32-arm.c (elf32_arm_print_private_bfd_data): Recognise and - display the new ARM hard-float/soft-float ABI flags for EABI_VER5 - (elf32_arm_post_process_headers): Add the hard-float/soft-float - ABI flag as appropriate for ET_DYN/ET_EXEC in EABI_VER5. - -2012-10-30 Yao Qi - H.J. Lu - - * configure.in: Set CORE_HEADER to hosts/x86-64linux.h for - 'i[3-7]86-*-linux-*' if x86_64-*linux is enabled. - * configure: Regenerated. - - * elf64-x86-64.c (elf_x86_64_write_core_note): Replace type - 'prpsinfo_t' and 'prstatus_t' with 'prpsinfo64_t' and - 'prstatus64_t' respectively. - - * hosts/x86-64linux.h (a8_uint64_t): New. - (user_regsx32_struct): Renamed to ... - (user_regs64_struct): This. Replace uint64_t with a8_uint64_t. - (elf_gregx32_t): Renamed to ... - (elf_greg64_t): This. Replace uint64_t with a8_uint64_t. - (ELF_NGREGX32): Removed. - (ELF_NGREG64): New. - (elf_gregx32_t): Removed. - (elf_greg64_t): New. - (struct prstatus64_timeval): New. - (elf_prstatusx32): Replace elf_gregsetx32_t with elf_gregset64_t. - (elf_prstatus64): New. - (elf_prpsinfo64): New. - (prstatus64_t, prpsinfo64_t): New typedef. - -2012-10-29 Sean Keys - - * elf32-xgate.c(elf_xgate_howto_table): Fix src and dest mask for - R_XGATE_16 - -2012-10-29 Alan Modra - - * elf32-ppc.c (ppc_elf_howto_raw): Correct dst_mask in - R_PPC_VLE_LO16A, R_PPC_VLE_HI16A, R_PPC_VLE_HA16A, - R_PPC_VLE_SDAREL_LO16A, R_PPC_VLE_SDAREL_HI16A, - R_PPC_VLE_SDAREL_HA16A reloc howtos. - -2012-10-26 Nick Clifton - - * po/uk.po: Updated Ukranian translation. - -2012-10-26 Alan Modra - - PR target/14758 - * elf32-ppc.c (ppc_elf_reloc_type_lookup): Decode ppc64 _DS - bfd_reloc values. Map to corresponding D-form relocs. - (is_insn_ds_form, is_insn_qs_form): New functions. - (ppc_elf_relocate_section): Validate insn with DS-form or DQ-form - fields using D-form reloc. - -2012-10-25 H.J. Lu - - * elf32-i386.c (elf_i386_size_dynamic_sections): Replace - _GLOBAL_OFFSET_TABLE_ lookup with htab->elf.hgot. - * elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Likewise. - -2012-10-24 H.J. Lu - - * compress.c (bfd_is_section_compressed): Don't decompress the - section. - -2012-10-23 Nathan Sidwell - - * bfd-in.h (bfd_elf_stack_segment_size): Declare. - * bfd-in2.h: Rebuilt. - * elfxx-target.h (elf_backend_stack_align): New. - (elfNN_bed): Add it. - * elf-bfd.h (struct elf_backend_data): Add stack_align field. - * elf.c (bfd_elf_map_sections_to_segments): Pay attention to - stack_align and stacksize for PT_GNU_STACK segment. - (assign_file_positions_for_non_load_sections): Set p_memsz for - PT_GNU_STACK segment. - (copy_elf_program_header): Copy PT_GNU_STACK size. - * elflink.c (bfd_elf_stack_segment_size): New function, taken from - uclinux backends. - (bfd_elf_size_dynamic_sections): Determine - PT_GNU_STACK requirements after calling backend. Pay attention to - stacksize. - * elf32-bfin.c (elf32_bfinfdpic_always_size_sections): Call - bfd_elf_stack_segment_size. - (elf32_bfinfdpic_modify_program_headers): Delete. - (elf32_bfingfdpic_copy_private_bfd_data): Don't copy PT_GNU_STACK - here. - (elf_backend_stack_align): Override. - (elf_backend_modify_program_headers): Don't override. - * elf32-frv.c (frvfdpic_always_size_sections): Call - bfd_elf_stack_segment_size. - (elf32_frvfdpic_modify_program_headers): Delete. - (elf32_frvfdpic_copy_private_bfd_data): Don't copy PT_GNU_STACK - here. - (elf_backend_stack_align): Override. - (elf_backend_modify_program_headers): Don't override. - * elf32-lm32.c (lm32_elf_always_size_sections): Leave - PT_GNU_STACK creation to underlying elf support. Check - __stacksize here for backwards compatibility, and set it if - needed. - (lm32_elf_modify_segment_map): Delete. - (lm32_elf_modify_program_headers): Delete. - (elf_backend_stack_align): Override. - (elf_backend_modify_segment_map): Don't override. - (elf_backend_modify_program_headers): Don't override. - * elf32-sh.c (sh_elf_always_size_sections): Call - bfd_elf_stack_segment_size. - (sh_elf_modify_program_headers): Delete. - (sh_elf_copy_private_data): Don't copy PT_GNU_STACK - here. - (elf_backend_stack_align): Override. - (elf_backend_modify_program_headers): Don't override. - * elf32-tic6x.c (elf32_tic6x_always_size_sections): Call - bfd_elf_stack_segment_size. - (elf32_tic6x_modify_program_headers): Delete. - (elf32_tic6x_copy_private_data): Delete. - (elf_backend_stack_align): Override. - (bfd_elf32_bfd_copy_private_bfd_data): Don't override. - (elf_backend_modify_program_headers): Don't override. - -2012-10-22 Alan Modra - - * cache.c (cache_bmmap): Don't use void* arithmetic. - -2012-10-21 Alan Modra - - * compress.c (bfd_cache_section_contents): New function. - * bfd-in2.h: Regenerate. - -2012-10-21 Hans-Peter Nilsson - - * linker.c (_bfd_generic_link_output_symbols): Handle a - no-longer-global symbol entered through a plugin. - -2012-10-20 Alan Modra - - * compress.c: Reinstate 2012-10-19 change. - (bfd_get_full_section_contents): Don't free unless we alloc. - Use proper decompress size. Delete some vars, rename others. - -2012-10-19 Tom Tromey - - * compress.c: Revert previous patch. - -2012-10-19 Tom Tromey - - * compress.c (bfd_get_full_section_contents): Don't cache - decompressed contents. - -2012-10-18 Kai Tietz - - PR binutils/14067 - * coff-i386.c (bfd_target): Add section flag SEC_EXCLUDE. - Allow BFD_COMPRESS and BFD_DECOMPRESS flags. - * coff-x86_64.c: Likewise. - * coffcode.h (DOT_ZDEBUG): New define. - (sec_to_styp_flags): Check for .zdebug. - (styp_to_sec_flags): Likewise. - * coffgen.c (make_a_section): Handle .debug_* section - compression/decompression flags. - * cofflink.c (mark_relocs): Ignore relocations - for a section, which isn't marked as used. - (_bfd_coff_link_input_bfd): Add support of compressed - debug sections. - * compress.c (decompress_contents): Loop as long - as there is input available and there is room for - output. - * bfd/pe-arm.c: Add .zdebug_ partial match entry. - * pe-i386.c: Likewise. - * pe-x86_64.c: Likewise. - * peXXigen.c (_bfd_XXi_swap_aouthdr_out): Don't clear all - data-directories as this might destroy content. - - * coff-i386.c (_bfd_generic_find_nearest_line_discriminator): - define as coff_find_nearest_line_discriminator. - * libcoff-in.h (coff_find_nearest_line_discriminator): New - * libcoff.h: Regenerated. - * coff-x86_64.c: Likewise. - * coffgen.c (coff_find_nearest_line_discriminator): New function. - prototype. - -2012-10-16 Joel Brobecker - - * coff64-rs6000.c (rs6000coff64_vec): Set _close_and_cleanup - field to _bfd_archive_close_and_cleanup. - (aix5coff64_vec): Likewise. - -2012-10-16 Joel Brobecker - - * coff-rs6000.c (rs6000coff_vec): Set _close_and_cleanup - field to _bfd_archive_close_and_cleanup. - (pmac_xcoff_vec): Likewise. - -2012-10-16 Sofiane Naci - - * elf64-aarch64.c (elf64_aarch64_tls_howto_table): Fix shift value for - R_AARCH64_TLSIE_LD_GOTTPREL_PREL19, R_AARCH64_TLSLE_MOVW_TPREL_G2, - R_AARCH64_TLSLE_MOVW_TPREL_G1, R_AARCH64_TLSLE_MOVW_TPREL_G1_NC, - R_AARCH64_TLSLE_ADD_TPREL_HI12. - (elf64_aarch64_tlsdesc_howto_table): Fix shift value for - R_AARCH64_TLSDESC_LD64_PREL19 and R_AARCH64_TLSDESC_OFF_G1. - (elf64_aarch64_final_link_relocate): Add signed_addend when resolving - AARCH64_TLSLE_*_TPREL_* relocations. - -2012-10-16 Alan Modra - - * elf32-xtensa.c (free_section_cache): Renamed from - clear_section_cache. Don't zero cache. - (section_cache_section): Remove ineffectual zero of cache. - Call init_section_cache instead. - -2012-10-15 Doug Evans - - * elf.c (special_sections_d): Add comment. - -2012-10-13 H.J. Lu - - * Makefile.am (LIBDL): Replace -ldl with @lt_cv_dlopen_libs@. - * configure.in (lt_cv_dlopen_libs): AC_SUBST. - * Makefile.in: Regenerated. - * configure: Likewise. - -2012-10-08 Alan Modra - - PR binutils/14662 - * elf.c (_bfd_elf_make_section_from_shdr): Treat .gdb_index as - SEC_DEBUGGING. - -2012-09-20 Walter Lee - - * elf32-tilepro.c (tilepro_elf_relocate_section): Adjust got - relocations with value of hgot. - * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. - -2012-09-19 Steve Ellcey - - * config.bfd: Add mips*-mti-elf* target. - -2012-09-18 H.J. Lu - - PR ld/14591 - * elf-bfd.h (_bfd_elf_merge_symbol): Add an argument to return - if the old symbol is weak. - - * elf32-sh-symbian.c (sh_symbian_relocate_section): Update - _bfd_elf_merge_symbol call. - - * elflink.c (_bfd_elf_merge_symbol): Add an argument to return - if the old symbol is weak. - (_bfd_elf_add_default_symbol): Update _bfd_elf_merge_symbol - call. - (elf_link_add_object_symbols): Don't update symbol type from a - weak definition. Update symbol type from a common symbol when - overriding a weak symbol. - -2012-09-17 H.J. Lu - - * elf32-i386.c (elf_i386_convert_mov_to_lea): Ignore discarded - section. - * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. - -2012-09-17 H.J. Lu - - * elf32-i386.c (elf_i386_finish_dynamic_symbol): Replace return - FALSE with abort. - * elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Likewise. - -2012-09-17 Walter Lee - - * elf32-tilepro.c (tilepro_elf_relocate_section): Remove unused - got_base variable. - * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. - -2012-09-17 Walter Lee - - * elf32-tilepro.c (tilepro_elf_relocate_section): Fix computation - of got relocations for when .got.plt section is merged with .got. - * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. - -2012-09-14 David Edelsohn - - * configure: Regenerate. - -2012-09-13 Anthony Green - - * targets.c (bfd_elf32_bigmoxie_vec, bfd_elf32_littlemoxie_vec): - Define. - (bfd_elf32_moxie_vec): Remove. - * config.bfd, configure.in: Add bi-endian support for moxie. - * configure: Rebuilt. - * elf32-moxie.c (TARGET_LITTLE_NAME, TARGET_LITTLE_SYM): Define. - (TARGET_BIG_NAME, TARGET_BIG_SYM): Update for bi-endian support. - -2012-09-12 Doug Kwan - - * elf64-ppc.c (ppc64_elf_relocate_section): Use pre-adjusted - relocation for stub lookup. - -2012-09-12 Chris Schlumberger-Socha - - * bfd-in2.h: Regenerated. - * elf64-aarch64.c - (elf64_aarch64_howto_table): Add R_AARCH64_GOT_LD_PREL19 reloc to HOWTO. - (elf64_aarch64_reloc_map): Add reloc entry. - (aarch64_resolve_relocation): Likewise. - (bfd_elf_aarch64_put_addend): Likewise. - (aarch64_reloc_got_type): Likewise. - (elf64_aarch64_final_link_relocate): Likewise. - (lf64_aarch64_check_relocs): Likewise. - (elf64_aarch64_check_relocs): New case for R_AARCH64_ADR_PREL_LO21 - reloc. - * libbfd.h: Regenerated. - * reloc.c (R_AARCH64_GOT_LD_PREL19): New reloc. - -2012-09-10 Matthias Klose - - * config.in: Disable sanity check for kfreebsd. - -2012-09-10 H.J. Lu - - * configure: Regenerated. - -2012-09-04 Sergey A. Guriev - - * cpu-ia64-opc.c (ins_cnt6a): New function. - (ext_cnt6a): Ditto. - (ins_strd5b): Ditto. - (ext_strd5b): Ditto. - (elf64_ia64_operands): Add new operand types. - -2012-09-04 H.J. Lu - - PR binutils/14493 - * elf.c (ignore_section_sym): Also ignore section symbols without - a BFD section. - -2012-09-03 Andreas Krebbel - - * elf32-s390.c (elf_s390_relocate_section): Handle PLTOFF for - local and global ifunc symbols. - * elf64-s390.c (elf_s390_relocate_section): Likewise. - -2012-09-02 H.J. Lu - - * elf-bfd.h (elf_link_hash_table): Add hdynamic for the - _DYNAMIC symbol. - - * elflink.c (_bfd_elf_link_create_dynamic_sections): Set - hdynamic. - - * elf-m10300.c (_bfd_mn10300_elf_finish_dynamic_symbol): Check - hdynamic instead of "_DYNAMIC". - * elf32-arm.c (elf32_arm_finish_dynamic_symbol): Likewise. - * elf32-cr16.c (elf32_arm_finish_dynamic_symbol): Likewise. - * elf32-cris.c (elf_cris_finish_dynamic_symbol): Likewise. - * elf32-hppa.c (elf32_hppa_finish_dynamic_symbol): Likewise. - * elf32-i386.c (elf_i386_convert_mov_to_lea): Likewise. - * elf32-lm32.c (lm32_elf_finish_dynamic_symbol): Likewise. - * elf32-m32r.c (m32r_elf_finish_dynamic_symbol): Likewise. - * elf32-s390.c (elf_s390_finish_dynamic_symbol): Likewise. - * elf32-sh.c (sh_elf_finish_dynamic_symbol): Likewise. - * elf32-tic6x.c (elf32_tic6x_finish_dynamic_symbol): Likewise. - * elf32-tilepro.c (tilepro_elf_finish_dynamic_symbol): Likewise. - * elf32-vax.c (elf_vax_finish_dynamic_symbol): Likewise. - * elf32-xtensa.c (elf_xtensa_finish_dynamic_symbol): Likewise. - * elf64-aarch64.c elf64_aarch64_finish_dynamic_symbol(): Likewise. - * elf64-alpha.c (elf64_alpha_finish_dynamic_symbol): Likewise. - * elf64-ia64-vms.c (elf64_ia64_finish_dynamic_symbol): Likewise. - * elf64-s390.c (elf_s390_finish_dynamic_symbol): Likewise. - * elf64-sh64.c (sh64_elf64_finish_dynamic_symbol): Likewise. - * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. - * elfnn-ia64.c (elfNN_ia64_finish_dynamic_symbol): Likewise. - * elfxx-mips.c (_bfd_mips_elf_finish_dynamic_symbol): Likewise. - * elfxx-sparc.c (_bfd_sparc_elf_finish_dynamic_symbol): Likewise. - * elfxx-tilegx.c (tilegx_elf_finish_dynamic_symbol): Likewise. - - * elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol): Check - hdynamic, hgot, hplt instead of _DYNAMIC, _GLOBAL_OFFSET_TABLE_, - _PROCEDURE_LINKAGE_TABLE_. - * elf32-score.c (s3_bfd_score_elf_finish_dynamic_symbol): Likewise. - * elf32-score7.c (s7_bfd_score_elf_finish_dynamic_symbol): Likewise. - -2012-08-31 H.J. Lu - - * elf32-i386.c (elf_i386_convert_mov_to_lea): Don't optimize - _DYNAMIC. - * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. - -2012-08-31 H.J. Lu - - * elf32-i386.c (elf_i386_convert_mov_to_lea): New. - (elf_i386_size_dynamic_sections): Use it on input sections. - (elf_i386_relocate_section): Don't convert - "mov foo@GOT(%reg), %reg" to "lea foo@GOTOFF(%reg), %reg" - for local symbols here. - - * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): New. - (elf_x86_64_size_dynamic_sections): Use it on input sections. - (elf_x86_64_relocate_section): Don't convert - "mov foo@GOTPCREL(%rip), %reg" to "lea foo(%rip), %reg" - for local symbols here. - -2012-08-30 H.J. Lu - - * elf32-i386.c (elf_i386_relocate_section): Convert - "mov foo@GOT(%reg), %reg" to "lea foo@GOTOFF(%reg), %reg" - for local symbols. - - * elf64-x86-64.c (elf_x86_64_relocate_section): Convert - "mov foo@GOTPCREL(%rip), %reg" to "lea foo(%rip), %reg" - for local symbols. - -2012-08-31 Alan Modra - - PR ld/14464 - * elf64-ppc.c (ppc64_elf_relocate_section): Map symbols defined - by a linker script in .opd to corresponding input .opd section. - -2012-08-28 Maciej W. Rozycki - - * elf32-ppc.c (ppc_elf_relocate_section): Assert that dynindx is - not minus one. - * elf64-ppc.c (ppc64_elf_relocate_section): Likewise. - -2012-08-28 Maciej W. Rozycki - - * elflink.c (_bfd_elf_merge_symbol): Also override the version - a dynamic symbol defaulted to if preempted with a hidden or - internal definition. - -2012-08-28 Walter Lee - - * elf32-tilepro.c (allocate_dynrelocs): Use PLT_ENTRY_SIZE as size - of header. - (tilepro_plt_entry_build): Account for new header size. - (tilepro_elf_finish_dynamic_sections): Ditto. - (tilepro_elf_plt_sym_val): Ditto. - * elfxx-tilegx.c (allocate_dynrelocs): Use PLT_ENTRY_SIZE as size - of header + tail. - (tilegx_elf_finish_dynamic_sections): Account for new padding. - -2012-08-27 Walter Lee - - * reloc.c (Add BFD_RELOC_TILEGX_IMM16_X0_HW0_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW0_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW1_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW1_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW2_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW2_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW3_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW3_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_PLT_PCREL, - BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_PLT_PCREL): new relocations. - * elfxx-tilegx.c (tilegx_elf_howto_table): Handle new relocations. - (tilegx_reloc_map): Ditto. - (reloc_to_create_func): Ditto. - (tilegx_elf_check_relocs): Ditto. - (tilegx_elf_gc_sweep_hook): Ditto. - (tilegx_elf_relocate_section): Ditto. - * libbfd.h: Regenerate. - * bfd-in2.h: Regenerate. - -2012-08-24 Matthew Gretton-Dann - - * elf32-arm.c (v8): New array. - (tag_cpu_arch_combine): Add support for ARMv8 attributes. - (elf32_arm_merge_eabi_attributes): Likewise. - (VFP_VERSION_COUNT): New define. - -2012-08-20 Tom Tromey - - * vms-lib.c (_bfd_vms_lib_get_module): Use bfd_zmalloc for - areltdata. - * opncls.c (_bfd_delete_bfd): Free arelt_data. - * mach-o.c (bfd_mach_o_fat_member_init): Use bfd_zmalloc for - areltdata. - * ecoff.c (_bfd_ecoff_slurp_armap): Use free for mapdata. - * coff-rs6000.c (_bfd_xcoff_read_ar_hdr): Use bfd_zmalloc for - areltdata. - (xcoff_write_archive_contents_old): Likewise. - (xcoff_write_archive_contents_big): Likewise. - * archive64.c (bfd_elf64_archive_slurp_armap): Use free for - areltdata. - * archive.c (_bfd_generic_read_ar_hdr_mag): Use bfd_zmalloc and - free for areltdata. - (_bfd_get_elt_at_filepos): Likewise. Clear n_nfd->arelt_data on - failure. - (do_slurp_bsd_armap): Use bfd_zmalloc and free for areltdata. - (do_slurp_coff_armap): Likewise. - (_bfd_slurp_extended_name_table): Likewise. - (bfd_slurp_bsd_armap_f2): Likewise. Don't leak 'mapdata'. - -2012-08-17 Nick Clifton - - * po/vi.po: Updated Vietnamese translation. - -2012-08-17 Yuri Chornoivan - - * elf-bfd.h, * elf32-ppc.c, * elf64-ia64-vms.c, * elfnn-ia64.c, - * elfxx-mips.c, * vms-alpha.c: Typo fixes. - -2012-08-17 Alan Modra - - PR binutils/14475: - * archive.c (bfd_ar_hdr_from_filesystem): Revert last change. - Instead malloc areltdata. - -2012-08-16 Tom Tromey - - PR binutils/14475: - * archive.c (bfd_ar_hdr_from_filesystem): Allocate areltdata on - 'member' BFD. Don't try to free 'ared'. - -2012-08-14 Nick Clifton - - * po/uk.po: Updated Ukranian translation. - -2012-08-13 Maciej W. Rozycki - - * elfxx-mips.c (_bfd_mips_elf_size_dynamic_sections): Look up - the options section in the output rather than input BFD to - decide if to add a DT_MIPS_OPTIONS tag. - -2012-08-13 Maciej W. Rozycki - - * config.bfd: Wrap mips*el-*-linux* and mips*-*-linux* into - #ifdef BFD64. - -2012-08-13 Ian Bolton - Laurent Desnogues - Jim MacArthur - Marcus Shawcroft - Nigel Stephens - Ramana Radhakrishnan - Richard Earnshaw - Sofiane Naci - Tejas Belagod - Yufeng Zhang - - * Makefile.am: Add AArch64 files. - * Makefile.in: Regenerate. - * archures.c (bfd_aarch64_arch): New declaration. - (bfd_archures_list): Use bfd_archures_list. - * bfd-in.h (bfd_elf64_aarch64_init_maps): New declaration. - (bfd_aarch64_process_before_allocation): New declaration. - (bfd_elf64_aarch64_process_before_allocation): New declaration. - (bfd_elf64_aarch64_set_options): New declaration. - (bfd_elf64_aarch64_add_glue_sections_to_bfd): New declaration. - (BFD_AARCH64_SPECIAL_SYM_TYPE_MAP): New definition. - (BFD_AARCH64_SPECIAL_SYM_TYPE_TAG): New definition. - (BFD_AARCH64_SPECIAL_SYM_TYPE_OTHER): New definition. - (BFD_AARCH64_SPECIAL_SYM_TYPE_ANY): New definition. - (bfd_is_aarch64_special_symbol_name): New declaration. - (bfd_aarch64_merge_machines): New declaration. - (bfd_aarch64_update_notes): New declaration. - (int bfd_aarch64_get_mach_from_notes): New declaration. - (elf64_aarch64_setup_section_lists): New declaration. - (elf64_aarch64_next_input_section): New declaration. - (elf64_aarch64_size_stubs): New declaration. - (elf64_aarch64_build_stubs): New declaration. - * config.bfd: Add AArch64. - * configure.in: Add AArch64. - * configure: Regenerate. - * cpu-aarch64.c: New file. - * elf-bfd.h: Add AArch64. - * bfd-in2.h: Regenerate. - * libbfd.h: Regenerate. - * elf64-aarch64.c: New file. - * reloc.c: Add AArch64 relocations. - * targets.c: Add AArch64. - * po/SRC-POTFILES.in: Regenerate. - -2012-08-13 Maciej W. Rozycki - - * elfxx-mips.c (mips_elf_calculate_relocation): Fix the handling - of protected symbols. - -2012-08-10 Alan Modra - - PR binutils/14444 - * elf.c (IS_VALID_GROUP_SECTION_HEADER) Add minsize param. - (setup_group): Adjust uses. - (bfd_section_from_shdr): Allow SHT_GROUP sections with just a flag - word. - -2012-08-09 Nick Clifton - - * po/vi.po: Updated Vietnamese translation. - -2012-08-09 Maciej W. Rozycki - - * elfxx-mips.c (LA25_LUI_MICROMIPS_1, LA25_LUI_MICROMIPS_2): - Remove macros, folding them into... - (LA25_LUI_MICROMIPS): ... this new macro. - (LA25_J_MICROMIPS_1, LA25_J_MICROMIPS_2): Likewise into... - (LA25_J_MICROMIPS): ... this new macro. - (LA25_ADDIU_MICROMIPS_1, LA25_ADDIU_MICROMIPS_2): Likewise - into... - (LA25_ADDIU_MICROMIPS): ... this new macro. - (bfd_put_micromips_32, bfd_get_micromips_32): New functions. - (mips_elf_create_la25_stub): Use them. - (check_br32_dslot, check_br32, check_relocated_bzc): Likewise. - (_bfd_mips_elf_relax_section): Likewise. - -2012-08-09 Alan Modra - Tom Tromey - - * archive.c (SECTION Archives): Update documentation. - (_bfd_delete_archive_data): Remove. - (_bfd_add_bfd_to_archive_cache): Set 'parent_cache' and 'key'. - (archive_close_worker, _bfd_archive_close_and_cleanup): New - functions. - * libbfd-in.h (struct areltdata ): New fields. - (_bfd_delete_archive_data): Don't declare. - (_bfd_archive_close_and_cleanup): Declare. - (_bfd_generic_close_and_cleanup): Redefine. - * libbfd.h: Rebuild. - * opncls.c (_bfd_delete_bfd): Don't call _bfd_delete_archive_data. - (bfd_close): Don't close nested thin archives here. - -2012-08-07 Tom Tromey - - * archive.c (_bfd_delete_archive_data): New function. - * libbfd-in.h (_bfd_delete_archive_data): Declare. - * libbfd.h: Rebuild. - * opncls.c (_bfd_delete_bfd): Call _bfd_delete_archive_data. - -2012-08-07 Nick Clifton - - * po/uk.po: Updated Ukranian translation. - -2012-08-06 Maciej W. Rozycki - - * elflink.c (bfd_elf_record_link_assignment): Remove --defsym - symbols special case. - -2012-08-05 Maciej W. Rozycki - - * elf32-vax.c (elf_vax_adjust_dynamic_symbol): Don't allocate - PLT slots for local symbols. - -2012-08-03 Maciej W. Rozycki - - * elf64-mips.c (mips16_elf64_howto_table_rela): Correct src_mask - field initializers throughout. - * elfn32-mips.c (elf_mips16_howto_table_rela): Likewise. - -2012-08-03 Maciej W. Rozycki - - * elfxx-mips.c (mips_elf_perform_relocation): Update the - cross-mode jump message. - -2012-08-03 Maciej W. Rozycki - - * elfxx-mips.c (_bfd_mips_elf_size_dynamic_sections): Update the - comment on DT_MIPS_RLD_MAP. - -2012-08-03 Tom Tromey - - * opncls.c (_bfd_delete_bfd): Now static. - * libbfd-in.h (_bfd_delete_bfd): Don't declare. - * libbfd.h: Rebuild. - -2012-08-02 Sean Keys - - * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Modified - conditional statment to allow suppression of mismatched bank - warning. - -2012-08-01 Alan Modra - - * dwarf2.c (struct dwarf2_debug): Add close_on_cleanup. - (_bfd_dwarf2_slurp_debug_info): Set close_on_cleanup if we open - gnu_debuglink bfd. - (_bfd_dwarf2_cleanup_debug_info): Act on close_on_cleanup. - -2012-07-30 Nick Clifton - - * po/bfd.pot: Updated template. - * po/es.po: Updated Spanish translation. - * po/fi.po: Updated Finnish translation. - * po/fr.po: Updated French translation. - * po/ru.po: Updated Russian translation. - * po/uk.po: Updated Ukranian translation. - -2012-07-27 Mike Frysinger - - * configure.in (AC_INIT): Call with the args bfd and 2.22.52. - (AM_INIT_AUTOMAKE): Remove args. - * configure: Regenerate. - -2012-07-27 Andreas Krebbel - - * cpu-s390.c (bfd_s390_64_arch, bfd_s390_arch): Pick the default - arch depending on the target size. - -2012-07-27 Tristan Gingold - - * configure.in: Bump version to 2.23.51 - * configure: Regenerate. - -2012-07-26 Teresa Johnson - - * bfd/dwarf2.c (find_line): Initialize discriminator_ptr - if it is non-NULL. - -2012-07-26 Meador Inge - Nick Clifton - - PR ld/14397 - * elf32-arm.c (elf32_arm_finish_dynamic_sections): Report an error - if a required section is missing from the linker script. - -2012-07-24 Jan Waclawek - PR 13899 - * elf32-avr.c (elf32_avr_relax_delete_bytes): Call - _bfd_elf_link_read_relocs with keep_memory as TRUE. - -2012-07-24 Teresa Johnson - - * bfd.c (bfd_find_nearest_line_discriminator): New macro. - * coff-rs6000.c: Init _bfd_find_nearest_line_discriminator. - * coff64-rs6000.c: Likewise. - * dwarf2.c (struct line_info): Add discriminator field. - (add_line_info): Fill in new discriminator field. - (decode_line_info): Record discriminator information instead - of ignoring it. - (lookup_address_in_line_info_table): Return discriminator field if - requested. - (comp_unit_find_nearest_line): Add discriminator argument. - (find_line): Likewise. - (_bfd_dwarf2_find_nearest_line): Likewise. - (_bfd_dwarf2_find_line): Likewise. - * elf-bfd.h (_bfd_elf_find_nearest_line_discriminator): New. - (_bfd_elf_find_line_discriminator): Likewise. - (_bfd_generic_find_nearest_line_discriminator): Likewise. Defined. - * elf.c (_bfd_elf_find_nearest_line): Change to a wrapper - that invokes _bfd_elf_find_nearest_line_discriminator with correct - arguments. - (_bfd_elf_find_nearest_line_discriminator): New. - (_bfd_elf_find_line): Change to a wrapper - that invokes _bfd_elf_find_line_discriminator with correct - arguments. - (_bfd_elf_find_line_discriminator): New. - * coffgen.c (coff_find_nearest_line_with_names): Handle - new discriminator argument. - * elf32-arm.c (elf32_arm_find_nearest_line): Likewise. - * elf64-alpha.c (elf64_alpha_find_nearest_line): Likewise. - * elfxx-mips.c (_bfd_mips_elf_find_nearest_line): Likewise. - * mach-o.c (bfd_mach_o_find_nearest_line): Likewise. - * libbfd-in.h (_bfd_dwarf2_find_nearest_line): Add discriminator - argument. - (_bfd_dwarf2_find_line): Likewise. - (_bfd_generic_find_nearest_line_discriminator): New. - * libbfd.c (_bfd_generic_find_nearest_line_discriminator): New. - * bfd-in2.h: Regenerated. - * libbfd.h: Likewise. - * targets.c (BFD_JUMP_TABLE_SYMBOLS): Initialize - _bfd_find_nearest_line_discriminator with - _bfd_generic_find_nearest_line_discriminator. - (bfd_target): Add _bfd_find_nearest_line_discriminator. - -2012-07-24 Sean Keys - - * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Added code - that enables the linker to offset addresses, when linking against - symbols from the XGATE processor and vice versa. - -2012-07-23 Nick Clifton - - * cisco-core.c (cisco_core_file_failing_command): Make static. - (cisco_core_file_failing_signal): Make static. - -2012-07-18 H.J. Lu - - * bfd-in2.h: Regenerated. - -2012-07-18 Nicolàs Alejandro Di Risio - - PR binutils/14335 - * section.c: Fix a typo in comments. - -2012-07-13 Andreas Krebbel - - * elf64-s390.c: Include elf-s390-common.c. - (R_390_IRELATIVE): New reloc. - (elf_s390_reloc_type_lookup): Support R_390_IRELATIVE. - (RELA_ENTRY_SIZE): New macro. - (elf_s390_link_hash_entry): New fields ifunc_resolver_address and - *ifunc_resolver_section. - (struct plt_entry): New struct. - (struct elf_s390_obj_tdata): New field local_plt. - (elf_s390_local_plt): New macro. - (struct elf_s390_link_hash_table): New field irelifunc. - (ELF64): New macro. - (link_hash_newfunc): Initialize new fields. - (elf_s390_check_relocs): Handle IFUNC symbols. - (elf_s390_adjust_dynamic_symbol): Don't do anything for IFUNC - symbols. - (allocate_dynrelocs): Call s390_elf_allocate_ifunc_dyn_relocs for - IFUNC symbols. - (elf_s390_size_dynamic_sections): Handle IFUNC symbols. - (elf_s390_relocate_section): Likewise. - (elf_s390_finish_dynamic_symbol): Likewise. - (elf_s390_finish_dynamic_sections): Handle local IFUNC symbols. - (elf_s390_finish_ifunc_symbol): New function. - (elf_s390_gc_sweep_hook): Handle local plt entries. - (elf_backend_add_symbol_hook): Define. - * elf32-s390.c: See elf64-s390.c changes. - * elf-s390-common.c: New file. - * bfd-in2.h (BFD_RELOC_390_IRELATIVE): New enum field. - * libbfd.h (BFD_RELOC_390_IRELATIVE): New entry for - BFD_RELOC_390_IRELATIVE. - * reloc.c (BFD_RELOC_390_IRELATIVE): Document new relocation. - -2012-07-13 Nick Clifton - - * aix386-core.c: Remove use of PTR and PARAMS macros. - * archive.c: Likewise. - * cache.c: Likewise. - * cisco-core.c: Likewise. - * coff-alpha.c: Likewise. - * coff-apollo.c: Likewise. - * coff-aux.c: Likewise. - * coff-h8300.c: Likewise. - * coff-h8500.c: Likewise. - * coff-i386.c: Likewise. - * coff-i960.c: Likewise. - * coff-ia64.c: Likewise. - * coff-m68k.c: Likewise. - * coff-m88k.c: Likewise. - * coff-mcore.c: Likewise. - * coff-mips.c: Likewise. - * coff-or32.c: Likewise. - * coff-ppc.c: Likewise. - * coff-rs6000.c: Likewise. - * coff-sh.c: Likewise. - * coff-sparc.c: Likewise. - * coff-stgo32.c: Likewise. - * coff-tic30.c: Likewise. - * coff-tic4x.c: Likewise. - * coff-tic54x.c: Likewise. - * coff-tic80.c: Likewise. - * coff-w65.c: Likewise. - * cofflink.c: Likewise. - * cpu-arc.c: Likewise. - * cpu-cris.c: Likewise. - * cpu-h8500.c: Likewise. - * cpu-i960.c: Likewise. - * cpu-msp430.c: Likewise. - * cpu-ns32k.c: Likewise. - * cpu-powerpc.c: Likewise. - * cpu-rs6000.c: Likewise. - * cpu-tic4x.c: Likewise. - * cpu-w65.c: Likewise. - * ecoff.c: Likewise. - * ecofflink.c: Likewise. - * elf-m10200.c: Likewise. - * elf32-bfin.c: Likewise. - * elf32-cris.c: Likewise. - * elf32-crx.c: Likewise. - * elf32-fr30.c: Likewise. - * elf32-frv.c: Likewise. - * elf32-h8300.c: Likewise. - * elf32-i960.c: Likewise. - * elf32-m32c.c: Likewise. - * elf32-m68hc11.c: Likewise. - * elf32-m68hc12.c: Likewise. - * elf32-m68hc1x.c: Likewise. - * elf32-m68k.c: Likewise. - * elf32-mcore.c: Likewise. - * elf32-rl78.c: Likewise. - * elf32-rx.c: Likewise. - * elf32-s390.c: Likewise. - * elf32-vax.c: Likewise. - * elf64-alpha.c: Likewise. - * elf64-mmix.c: Likewise. - * elf64-s390.c: Likewise. - * elf64-sparc.c: Likewise. - * elfnn-ia64.c: Likewise. - * elfxx-mips.c: Likewise. - * elfxx-sparc.c: Likewise. - * hash.c: Likewise. - * hp300hpux.c: Likewise. - * hppabsd-core.c: Likewise. - * hpux-core.c: Likewise. - * i386dynix.c: Likewise. - * i386linux.c: Likewise. - * i386lynx.c: Likewise. - * i386mach3.c: Likewise. - * i386msdos.c: Likewise. - * i386os9k.c: Likewise. - * irix-core.c: Likewise. - * lynx-core.c: Likewise. - * m68klinux.c: Likewise. - * mach-o.h: Likewise. - * mipsbsd.c: Likewise. - * netbsd-core.c: Likewise. - * nlm32-i386.c: Likewise. - * osf-core.c: Likewise. - * pc532-mach.c: Likewise. - * pef.c: Likewise. - * ppcboot.c: Likewise. - * ptrace-core.c: Likewise. - * reloc16.c: Likewise. - * sco5-core.c: Likewise. - * som.h: Likewise. - * sparclinux.c: Likewise. - * sparclynx.c: Likewise. - * ticoff.h: Likewise. - * trad-core.c: Likewise. - * vms-lib.c: Likewise. - * xsym.h: Likewise. - -2012-07-09 Alan Modra - - PR ld/14323 - * elflink.c (elf_sort_symbol): Sort by size too. - (elf_link_add_object_symbols ): Simplify binary search. - Do not depend on ordering of symbol aliases. Match largest size. - -2012-07-03 H.J. Lu - - * elf.c (assign_section_numbers): Check if number of sections - >= SHN_LORESERVE. - * elfcode.h (elf_object_p): Likewise. - -2012-07-03 Nick Clifton - - * archive.c (bsd_write_armap): Catch attempts to create an archive - with indicies bigger than 4Gb. - (coff_write_armap): Likewise. - -2012-07-03 H.J. Lu - - PR binutils/14319 - * elf.c (_bfd_elf_make_section_from_shdr): Don't compress empty - debug section. - -2012-07-03 H.J. Lu - - PR ld/3351 - * elflink.c (_bfd_elf_update_dynamic_flags): New. - (_bfd_elf_merge_symbol): Update both real and indirect symbol - dynamic flags. - (_bfd_elf_add_default_symbol): Make the real symbol dynamic if - the indirect symbol is defined in a shared library. - (elf_link_add_object_symbols): Likewise. If the indirect - symbol has been forced local, don't make the real symbol - dynamic. - (elf_link_check_versioned_symbol): Check indirect symbol. - (elf_link_output_extsym): Use real symbol definition when - reporting indirect symbol error. Check version info for - dynamic versioned symbol. - -2012-07-03 Alan Modra - - PR ld/14207 - * elf.c (assign_file_positions_for_load_sections): Remove assertions - that only PT_LOAD headers include file header and section headers. - (assign_file_positions_for_non_load_sections): Similarly don't - assert PT_GNU_RELRO header does not include file and section headers. - Compare first section vma rather than PT_LOAD p_vaddr against - relro_start when looking for PT_LOAD covering PT_GNU_RELRO. Replace - abort with assertion. - -2012-07-02 Alan Modra - - * elf32-m32c.c (m32c_elf_check_relocs): Use bfd_make_section - "anyway" variant when creating .plt. - (m32c_elf_relax_plt_section): Remove redundant test and unused param. - (m32c_elf_relax_section): Test SEC_LINKER_CREATED before calling - m32c_elf_relax_plt_section. - * elfxx-mips.c (mips_elf_create_got_section): Use make anyway variant - when creating .got and .got.plt. - (_bfd_mips_elf_final_link): Likewise for .rtproc, and use - bfd_get_linker_section. - * sunos.c: Similarly throughout. - -2012-07-01 Andreas Schwab - - * elf.c (_bfd_elf_make_section_from_shdr): Fix typo in error - message. - -2012-06-29 H.J. Lu - - * elf64-x86-64.c (elf_x86_64_relocate_section): Return FALSE - on unresolvable relocation. - -2012-06-29 H.J. Lu - - * archive.c (_bfd_compute_and_write_armap): Simplify global - symbol handling. - -2012-06-29 Nick Clifton - - PR ld/14189 - * elf32-arm.c (elf32_arm_check_relocs): Do not increment refcount - for locally bound symbols. - -2012-06-29 Alan Modra - - * section.c (bfd_get_linker_section): New function. - * elf32-arm.c: When retrieving SEC_LINKER_CREATED sections, use - the above throughout rather than bfd_get_section_by_name. Use - bfd_make_section_anyway rather than bfd_make_section when creating - them. - * elf32-bfin.c: Likewise. - * elf32-cr16.c: Likewise. - * elf32-cris.c: Likewise. - * elf32-frv.c: Likewise. - * elf32-hppa.c: Likewise. - * elf32-i370.c: Likewise. - * elf32-i386.c: Likewise. - * elf32-lm32.c: Likewise. - * elf32-m32c.c: Likewise. - * elf32-m32r.c: Likewise. - * elf32-m68k.c: Likewise. - * elf32-microblaze.c: Likewise. - * elf32-ppc.c: Likewise. - * elf32-rl78.c: Likewise. - * elf32-s390.c: Likewise. - * elf32-score.c: Likewise. - * elf32-score7.c: Likewise. - * elf32-sh.c: Likewise. - * elf32-tic6x.c: Likewise. - * elf32-tilepro.c: Likewise. - * elf32-vax.c: Likewise. - * elf32-xstormy16.c: Likewise. - * elf32-xtensa.c: Likewise. - * elf64-alpha.c: Likewise. - * elf64-hppa.c: Likewise. - * elf64-ia64-vms.c: Likewise. - * elf64-ppc.c: Likewise. - * elf64-s390.c: Likewise. - * elf64-sh64.c: Likewise. - * elf64-sparc.c: Likewise. - * elf64-x86-64.c: Likewise. - * elfnn-ia64.c: Likewise. - * elfxx-mips.c: Likewise. - * elfxx-sparc.c: Likewise. - * elfxx-tilegx.c: Likewise. - * elflink.c: Likewise. - * elf-vxworks.c: Likewise. - * elf-m10300.c: Likewise. Also make use of htab plt, got and - gotplt shortcuts. - * bfd-in2.h: Regenerate. - * elf32-lm32.c (lm32_elf_check_relocs): Use the correct bfd when - calling create_rofixup_section. - * elflink.c (bfd_elf_final_link): Simplify test for .dynstr. - -2012-06-29 Alan Modra - - * elf32-sh.c (sh_elf_create_dynamic_sections): Don't create .rela - section for bss type sections, except for .rela.bss. - * elf-m10300.c (_bfd_mn10300_elf_create_dynamic_sections): Likewise. - * elf32-cr16.c (_bfd_cr16_elf_create_dynamic_sections): Likewise. - * elf32-lm32.c (lm32_elf_create_dynamic_sections): Likewise. - * elf32-m32r.c (m32r_elf_create_dynamic_sections): Likewise. - * elf64-sh64.c (sh64_elf64_create_dynamic_sections): Likewise. - -2012-06-28 Roland McGrath - - * elf32-arm.c (elf32_arm_populate_plt_entry): Use int32_t for - displacement calculation in nacl_p case. - -2012-06-28 Nick Clifton - - * po/uk.po: New Ukranian translation. - * configure.in (ALL_LINGUAS): Add uk. - * configure: Regenerate. - -2012-06-26 Alan Modra - - * elf64-ppc.c (ppc64_elf_next_toc_section): Don't error if input - file has multiple .got/.toc sections and all don't fit in - current toc group. - -2012-06-22 Roland McGrath - - * elf.c (assign_file_positions_for_non_load_sections): Define - __ehdr_start symbol if it's referenced and there's a PT_LOAD - segment that covers both the file and program headers. - -2012-06-22 Andreas Schwab - - * elf32-m68k.c (elf_m68k_finish_dynamic_symbol): Don't make - _GLOBAL_OFFSET_TABLE_ and _DYNAMIC absolute. - -2012-06-22 Alan Modra - - * elf64-ppc.c (ppc64_elf_func_desc_adjust): Don't emit out-of-line - save/restore functions when relocatable. Make "funcs" static. - -2012-06-18 Hans-Peter Nilsson - - * elf32-cris.c (cris_elf_plt_sym_val): Rewrite to work in presence - of merged .got and .got.plt entries. - -2012-06-18 John Szakmeister - - * elf32-arm.c (elf32_arm_final_link_relocate): Correct return value. - -2012-06-17 Hans-Peter Nilsson - - * elf32-cris.c (cris_elf_relocate_section): - : Handle references to - thread common symbols. - -2012-06-13 Nick Clifton - - * elf32-arm.c (bfd_arm_get_mach_from_attributes): New function. - (elf32_arm_object_p): If the machine number could not be deduced - from the notes, call bfd_arm_get_mach_from_attributes to get the - number from the attributes. - -2012-06-12 H.J. Lu - - PR bfd/14207 - * elf.c (assign_file_positions_for_non_load_sections): Abort if - PT_GNU_RELRO segment doesn't fit in PT_LOAD segment. - -2012-06-12 Alan Modra - - PR ld/14207 - * elf.c (_bfd_elf_map_sections_to_segments): Disregard bss type - sections at end of PT_LOAD segment when searching for segment - that contains end of relro extent. - -2012-06-11 H.J. Lu - - * elf.c (assign_file_positions_for_non_load_sections): Reindent. - -2012-06-11 H.J. Lu - - * elf.c (_bfd_elf_map_sections_to_segments): Reindent. - -2012-06-06 Alan Modra - - * elflink.c (elf_link_input_bfd): Provide a file symbol for - each input file with local syms, if the input lacks such. - (bfd_elf_final_link): Add a file symbol to mark end of locals - for which we can associate with input files. - (struct elf_final_link_info): Add filesym_count field. - (struct elf_outext_info): Add need_second_pass and second_pass. - (elf_link_output_extsym): Detect symbols defined in the output - file, emit them on second pass over locals. - -2012-06-04 Jan Kratochvil - - * bfd-in.h (bfd_elf_bfd_from_remote_memory): Make LEN argument - of target_read_memory as bfd_size_type. - * bfd-in2.h: Regenerate. - * elf-bfd.h (elf_backend_bfd_from_remote_memory): Make LEN - argument of target_read_memory as bfd_size_type. - (_bfd_elf32_bfd_from_remote_memory): Likewise. - (_bfd_elf64_bfd_from_remote_memory): Likewise. - * elf.c (bfd_elf_bfd_from_remote_memory): Likewise. - * elfcode.h (NAME(_bfd_elf,bfd_from_remote_memory)): Likewise. - -2012-06-03 Alan Modra - - PR binutils/13897 - * elf.c (elf_find_function): Cache last function sym info. - (_bfd_elf_maybe_function_sym): Return function size, pass in - section of interest. - * elf-bfd.h (struct elf_backend_data ): Likewise. - (_bfd_elf_maybe_function_sym): Likewise. - * elf64-ppc.c (ppc64_elf_maybe_function_sym): Likewise. - (opd_entry_value): Add in_code_sec param. Revert caching code. - Return -1 if in_code_sec and function found in wrong section. - Update all calls. - -2012-06-01 Siddhesh Poyarekar - - * bfd-in.h (bfd_elf_bfd_from_remote_memory): Make LEN argument - of target_read_memory as size_t. - * bfd-in2.h: Regenerate. - * elf-bfd.h (elf_backend_bfd_from_remote_memory): Make LEN - argument of target_read_memory as size_t. - (_bfd_elf32_bfd_from_remote_memory): Likewise. - (_bfd_elf64_bfd_from_remote_memory): Likewise. - * elf.c (bfd_elf_bfd_from_remote_memory): Likewise. - * elfcode.h (NAME(_bfd_elf,bfd_from_remote_memory)): Likewise. - -2012-06-01 Alan Modra - - PR binutils/13897 - * elf64-ppc.c (opd_entry_value): Rewrite cache code. - -2012-05-29 Tom Tromey - - * opncls.c (bfd_fopen): Always close fd on failure. - (bfd_fdopenr): Likewise. - -2012-05-27 Alan Modra - - PR ld/14170 - * elflink.c (_bfd_elf_merge_symbol): When a symbol defined in - a dynamic library finds a new instance with non-default - visibility in a regular object, correctly handle symbols - already on the undefs list and undo dynamic symbol state when - the new symbol is hidden or internal. - -2012-05-25 H.J. Lu - - * elf32-i386.c (elf_i386_create_dynamic_sections): Don't use - dynamic_sec_flags to create PLT .eh_frame section. - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. - -2012-05-25 Alan Modra - - PR ld/13909 - * elf-eh-frame.c (_bfd_elf_eh_frame_present): New function. - (_bfd_elf_maybe_strip_eh_frame_hdr): Use it here. - * elf-bfd.h (_bfd_elf_eh_frame_present): Declare. - * elflink.c (bfd_elf_size_dynamic_sections): Let the backend - size dynamic sections before stripping eh_frame_hdr. - (bfd_elf_gc_sections): Handle multiple .eh_frame sections. - * elf32-ppc.c (ppc_elf_size_dynamic_sections): Drop glink_eh_frame - if no other .eh_frame sections exist. - * elf64-ppc.c (ppc64_elf_size_stubs): Likewise. - * elf32-i386.c (elf_i386_create_dynamic_sections): Don't size - or alloc plt_eh_frame here.. - (elf_i386_size_dynamic_sections): ..do it here instead. Don't - specially keep sgotplt, iplt, tgotplt, sdynbss for symbols. - (elf_i386_finish_dynamic_sections): Check plt_eh_frame->contents - before writing plt offset. - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Don't size - or alloc plt_eh_frame here.. - (elf_x86_64_size_dynamic_sections): ..do it here instead. - (elf_x86_64_finish_dynamic_sections): Check plt_eh_frame->contents - before writing plt offset. - -2012-05-24 Alan Modra - - PR ld/14158 - * elf64-ppc.c (ppc64_elf_size_stubs): Round up glink_eh_frame - size to output section alignment. - (ppc64_elf_build_stubs): Likewise, and extend last FDE to cover. - -2012-05-23 Alan Modra - - * elf-eh-frame.c (_bfd_elf_maybe_strip_eh_frame_hdr): Handle - BFDs with multiple .eh_frame sections. - -2012-05-23 Alan Modra - - PR ld/13909 - * elflink.c (bfd_elf_discard_info): Don't ignore dynamic BFDs. - -2012-05-22 H.J. Lu - - PR ld/13909 - * elf32-i386.c (elf_i386_create_dynamic_sections): Revert the - last change. - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. - -2012-05-22 Alan Modra - - * elflink.c (bfd_elf_discard_info): Look for next .eh_frame if - first one is zero size or discarded. - * elf32-ppc.c (ppc_elf_size_dynamic_sections): Set most of - glink_eh_frame contents here.. - (ppc_elf_finish_dynamic_sections): ..rather than here. Just set - offset to .glink. - -2012-05-22 H.J. Lu - - PR ld/13909 - * elf32-i386.c (elf_i386_create_dynamic_sections): Create PLT - eh_frame section if there is an input .eh_frame section. - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. - -2012-05-22 H.J. Lu - - PR ld/14105 - * elf32-i386.c (elf_i386_create_dynamic_sections): Always - create PLT eh_frame section with SEC_LINKER_CREATED. - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. - -2012-05-22 Alan Modra - - * elflink.c (bfd_elf_discard_info): Handle multiple .eh_frame - sections attached to a BFD. - * section.c (bfd_get_section_by_name): Rewrite description. - (bfd_get_next_section_by_name): New function. - * bfd-in2.h: Regenerate. - -2012-05-21 Andreas Schwab - - * elf32-m68k.c (elf_m68k_grok_prstatus): New function. - (elf_m68k_grok_psinfo): New function. - (elf_backend_grok_prstatus): Define. - (elf_backend_grok_psinfo): Define. - -2012-05-19 Maciej W. Rozycki - - * elf64-mips.c (elf_backend_got_header_size): Correct definition. - * elfxx-mips.c (_bfd_mips_elf_adjust_dynamic_symbol): Use the ELF - backend's GOT header size instead of hardcoding it. - -2012-05-19 Maciej W. Rozycki - - * elf32-vax.c (elf_vax_relocate_section) - : Don't check if info->shared again. - -2012-05-19 Maciej W. Rozycki - - * elf32-vax.c (elf_vax_relocate_section) - : Use section flags rather than - its name as the check for text sections. - -2012-05-19 Maciej W. Rozycki - - * elf64-mips.c (mips_elf64_be_swap_reloc_out): Also make sure - the third reloc offset is the same as the first. - -2012-05-19 Alan Modra - - * elf32-ppc.h (has_vle_insns, is_ppc_vle): Delete. - (has_tls_reloc, has_tls_get_addr_call): Move back to.. - * elf32-ppc.c: ..here. - (ppc_elf_section_flags, elf_backend_section_flags): Delete. - (ppc_elf_modify_segment_map): Use ELF sh_flags to detect VLE sections. - -2012-05-18 H.J. Lu - - * elf32-i386.c (elf_i386_finish_dynamic_symbol): Don't make - _DYNAMIC nor _GLOBAL_OFFSET_TABLE_ absolute. - * elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Likewise. - -2012-05-18 Roland McGrath - - * archive.c (_bfd_generic_read_ar_hdr_mag): Fix last change so as - not to clobber the ar_fmag field stored in ARED->arch_header. - -2012-05-18 Pedro Alves - - * mach-o.h: Don't include sysdep.h. - -2012-05-18 Nick Clifton - - PR 14072 - * bfd-in.h: Check for PACKAGE or PACKAGE_VERSION before - complaining about config.h not having been included. - * bfd-in2.h: Regenerate. - -2012-05-18 Andreas Schwab - - * aclocal.m4: Regenerate. - * Makefile.in: Regenerate. - -2012-05-17 Daniel Richard G. - Nick Clifton - - PR 14072 - * configure.in: Add check that sysdep.h has been included before - any system header files. - * configure: Regenerate. - * config.in: Regenerate. - * aclocal.m4: Regenerate. - * bfd-in.h: Generate an error if included before config.h. - * sysdep.h: Likewise. - * bfd-in2.h: Regenerate. - * compress.c: Remove #include "config.h". - * plugin.c: Likewise. - * elf32-m68hc1x.c: Include sysdep.h before alloca-conf.h. - * elf64-hppa.c: Likewise. - * som.c: Likewise. - * xsymc.c: Likewise. - -2012-05-17 Maciej W. Rozycki - Alan Modra - - * elf.c (ignore_section_sym): Correct comment. Don't return - true for absolute section. - (elf_map_symbols): Move stray comment. Adjust for above change. - Don't discard global section symbols. - -2012-05-17 Alan Modra - - * elf32-ppc.c (ppc_elf_finish_dynamic_symbol): Don't make _DYNAMIC, - _GLOBAL_OFFSET_TABLE_ or _PROCEDURE_LINKAGE_TABLE_ absolute. - * elf64-ppc.c (ppc64_elf_finish_dynamic_symbol): Don't make _DYNAMIC - absolute. - -2012-05-17 Alan Modra - - * elf32-ppc.c (has_tls_reloc, has_tls_get_addr_call, has_vle_insns, - is_ppc_vle): Move to.. - * elf32-ppc.h: ..here, making is_ppc_vle a macro. - -2012-05-16 Sergio Durigan Junior - - * bfd-in.h (bfd_get_section_name, bfd_get_section_vma, - bfd_get_section_lma, bfd_get_section_alignment, - bfd_get_section_flags, bfd_get_section_userdata): Rewrite macros - in order to use the `bfd' argument. - * bfd-in2.h: Regenerate. - * elf-vxworks.c (elf_vxworks_finish_dynamic_entry): Pass proper `bfd' - as the first argument for `bfd_get_section_alignment'. - * elf32-arm.c (create_ifunc_sections): Likewise, for - `bfd_set_section_alignment'. - * elf32-m32r.c (m32r_elf_relocate_section): Likewise, for - `bfd_get_section_name'. - * elf32-microblaze.c (microblaze_elf_relocate_section): Likewise. - * elf32-ppc.c (ppc_elf_size_dynamic_sections): Likewise. - (ppc_elf_relocate_section): Likewise. - * elf64-mmix.c (mmix_final_link_relocate): Likewise, for - `bfd_get_section_vma'. - * elf64-ppc.c (create_linkage_sections): Likewise, for - `bfd_set_section_alignment'. - -2012-05-16 Georg-Johann Lay - - PR target/13503 - * reloc.c: Rename BFD_RELOC_AVR_8_HHI to BFD_RELOC_AVR_8_HLO. - * bfd-in2.h: Regenerate. - * libbfd.h: Regenerate. - * elf32-avr.c (elf_avr_howto_table): Rename R_AVR_8_HHI8 to - R_AVR_8_HLO8. - (avr_reloc_map): Likewise. - -2012-05-16 Daniel Richard G. - - PR binutils/13558 - * bfd/aout-cris.c: Include sysdep.h before bfd.h. - * bfd/aout-ns32k.c: Likewise. - * bfd/aout-sparcle.c: Likewise. - * bfd/aout0.c: Likewise. - * bfd/bfd-in2.h: Likewise. - * bfd/coff-stgo32.c: Likewise. - * bfd/cpu-lm32.c: Likewise. - * bfd/cpu-microblaze.c: Likewise. - * bfd/cpu-score.c: Likewise. - * bfd/cpu-tilegx.c: Likewise. - * bfd/cpu-tilepro.c: Likewise. - * bfd/elf32-lm32.c: Likewise. - * bfd/elf32-microblaze.c: Likewise. - * bfd/elf32-score7.c: Likewise. - * bfd/elf32-tilepro.c: Likewise. - * bfd/elfxx-tilegx.c: Likewise. - * bfd/mach-o.h: Likewise. - * bfd/nlm32-ppc.c: Likewise. - * bfd/ns32knetbsd.c: Likewise. - * bfd/pef.h: Likewise. - * bfd/plugin.c: Likewise. - * bfd/stab-syms.c: Likewise. - * bfd/sunos.c: Likewise. - * bfd/syms.c: Likewise. - * bfd/xsym.h: Likewise. - -2012-05-16 Alan Modra - - * elflink.c: Rename flaginfo to flinfo throughout, except.. - (bfd_elf_lookup_section_flags): ..here, rename finfo to flaginfo. - Formatting, style. Simplify flag match. - -2012-05-16 Alan Modra - - * dwarf2.c: Formatting. - (arange_add): Pass in unit rather than bfd. Update callers. - Ignore empty ranges. Don't ask for cleared memory. - (parse_comp_unit): Only set unit->base_address if processing - DW_TAG_compile_unit. - (find_debug_info): Optimise section lookup. - (place_sections): Use bfd_alloc for stash->adjusted_sections. - (find_line): Match previously parsed comp unit addresses as we - do for newly parsed comp units. - -2012-05-16 Alan Modra - - * archive.c (_bfd_generic_read_ar_hdr_mag): Ensure sscanf - stops at end of ar_size field. - -2012-05-16 Alan Modra - - PR ld/13962 - PR ld/7023 - * elf.c (bfd_section_from_shdr): Fail when .dynsym sh_info is - out of range. As a special case, fix sh_info for zero sh_size. - Do the same for .symtab. - -2012-05-15 James Murray - Stephane Carrez - - * archures.c: Add bfd_arch_m9s12x and bfd_arch_m9s12xg. - * config.bfd: Likewise. - * cpu-m9s12x.c: New. - * cpu-m9s12xg.c: New. - * elf32-m68hc12.c: Add S12X and XGATE co-processor support. - Add option to offset S12 addresses into XGATE memory space. - Fix carry bug in IMM16 (IMM8 low/high) relocate. - * Makefile.am (ALL_MACHINES): Add cpu-m9s12x and cpu-m9s12xg. - (ALL_MACHINES_CFILES): Likewise. - * reloc.c: Add S12X relocs. - * Makefile.in: Regenerate. - * bfd-in2.h: Regenerate. - * libbfd.h: Regenerate. - -2012-05-14 James Lemke - Catherine Moore - - * bfd.c (bfd_lookup_section_flags): Add section parm. - * ecoff.c (bfd_debug_section): Remove flag_info initializer. - * elf-bfd.h (bfd_elf_section_data): Move in section_flag_info. - (bfd_elf_lookup_section_flags): Add section parm. - * elf32-ppc.c (is_ppc_vle): New function. - (ppc_elf_modify_segment_map): New function. - (elf_backend_modify_segment_map): Define. - (has_vle_insns): New define. - * elf32-ppc.h (ppc_elf_modify_segment_map): Declare. - * elflink.c (bfd_elf_lookup_section_flags): Add return value & parm. - Move in logic to omit / include a section. - * libbfd-in.h (bfd_link_info): Add section parm. - (bfd_generic_lookup_section_flags): Likewise. - * reloc.c (bfd_generic_lookup_section_flags): Likewise. - * section.c (bfd_section): Move out section_flag_info. - (BFD_FAKE_SECTION): Remove flag_info initializer. - * targets.c (_bfd_lookup_section_flags): Add section parm. - -2012-05-14 Catherine Moore - - * archures.c (bfd_mach_ppc_vle): New. - * bfd-in2.h: Regenerated. - * cpu-powerpc.c (bfd_powerpc_archs): New entry for vle. - * elf32-ppc.c (split16_format_type): New enumeration. - (ppc_elf_vle_split16): New function. - (HOWTO): Add entries for R_PPC_VLE relocations. - (ppc_elf_reloc_type_lookup): Handle PPC_VLE relocations. - (ppc_elf_section_flags): New function. - (ppc_elf_lookup_section_flags): New function. - (ppc_elf_section_processing): New function. - (ppc_elf_check_relocs): Handle PPC_VLE relocations. - (ppc_elf_relocation_section): Likewise. - (elf_backend_lookup_section_flags_hook): Define. - (elf_backend_section_flags): Define. - (elf_backend_section_processing): Define. - * elf32-ppc.h (ppc_elf_section_processing): Declare. - * libbfd.h: Regenerated. - * reloc.c (BFD_RELOC_PPC_VLE_REL8, BFD_RELOC_PPC_VLE_REL15, - BFD_RELOC_PPC_VLE_REL24, BFD_RELOC_PPC_VLE_LO16A, - BFD_RELOC_PPC_VLE_LO16D, BFD_RELOC_PPC_VLE_HI16A, - BFD_RELOC_PPC_VLE_HI16D, BFD_RELOC_PPC_VLE_HA16A, - BFD_RELOC_PPC_VLE_HA16D, BFD_RELOC_PPC_VLE_SDA21, - BFD_RELOC_PPC_VLE_SDA21_LO, BFD_RELOC_PPC_VLE_SDAREL_LO16A, - BFD_RELOC_PPC_VLE_SDAREL_LO16D, BFD_RELOC_PPC_VLE_SDAREL_HI16A, - BFD_RELOC_PPC_VLE_SDAREL_HI16D, BFD_RELOC_PPC_VLE_SDAREL_HA16A, - BFD_RELOC_PPC_VLE_SDAREL_HA16D): New bfd relocations. - -2012-05-11 Georg-Johann Lay - - PR target/13503 - * reloc.c: Add new ENUM for BFD_RELOC_AVR_8_LO, - BFD_RELOC_AVR_8_HI, BFD_RELOC_AVR_8_HHI. - * bfd-in2.h: Regenerate. - * libbfd.h: Regenerate. - * elf32-avr.c (elf_avr_howto_table): Add entries for - R_AVR_8_LO8, R_AVR_8_HI8, R_AVR_8_HHI8. - (avr_reloc_map): Add RELOC mappings for R_AVR_8_LO8, R_AVR_8_HI8, - R_AVR_8_HHI8. - -2012-05-10 H.J. Lu - - * elf64-x86-64.c (elf_x86_64_relocate_section): Use int in x32 - addend overflow check. - -2012-05-10 DJ Delorie - - * elf32-rx.c (rx_elf_object_p): Ignore empty segments. - -2012-05-10 H.J. Lu - - * elf64-x86-64.c (elf_x86_64_relocate_section): Display signed - hex number in x32 addend overflow check. - -2012-05-10 H.J. Lu - - * elf64-x86-64.c (elf_x86_64_reloc_type_class): Handle - R_X86_64_RELATIVE64. - -2012-05-09 H.J. Lu - - * elf64-x86-64.c (elf_x86_64_relocate_section): Check addend - overflow for R_X86_64_RELATIVE64. - -2012-05-08 Ben Cheng - - * elf.c: Preserve the original p_align and p_flags if they are - valid. - -2012-05-07 Alan Modra - - * elf64-ia64-vms.c (elf64_ia64_relocate_section): Update - RELOC_AGAINST_DISCARDED_SECTION invocation. - -2012-05-07 Hans-Peter Nilsson - - * elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Declare and use - local variable i_ instead of assuming and using a variable i. - -2012-05-07 Maciej W. Rozycki - - * elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Handle compound - relocations. - * elfxx-mips.c (mips_reloc_against_discarded_section): New - function. - (_bfd_mips_elf_relocate_section): Call it, in place of - RELOC_AGAINST_DISCARDED_SECTION. - * elf-m10200.c (mn10200_elf_relocate_section): Update arguments - to RELOC_AGAINST_DISCARDED_SECTION. - * elf-m10300.c (mn10300_elf_relocate_section): Likewise. - * elf32-arm.c (elf32_arm_relocate_section): Likewise. - * elf32-avr.c (elf32_avr_relocate_section): Likewise. - * elf32-bfin.c (bfin_relocate_section): Likewise. - (bfinfdpic_relocate_section): Likewise. - * elf32-cr16.c (elf32_cr16_relocate_section): Likewise. - * elf32-cr16c.c (elf32_cr16c_relocate_section): Likewise. - * elf32-cris.c (cris_elf_relocate_section): Likewise. - * elf32-crx.c (elf32_crx_relocate_section): Likewise. - * elf32-d10v.c (elf32_d10v_relocate_section): Likewise. - * elf32-epiphany.c (epiphany_elf_relocate_section): Likewise. - * elf32-fr30.c (fr30_elf_relocate_section): Likewise. - * elf32-frv.c (elf32_frv_relocate_section): Likewise. - * elf32-h8300.c (elf32_h8_relocate_section): Likewise. - * elf32-hppa.c (elf32_hppa_relocate_section): Likewise. - * elf32-i370.c (i370_elf_relocate_section): Likewise. - * elf32-i386.c (elf_i386_relocate_section): Likewise. - * elf32-i860.c (elf32_i860_relocate_section): Likewise. - * elf32-ip2k.c (ip2k_elf_relocate_section): Likewise. - * elf32-iq2000.c (iq2000_elf_relocate_section): Likewise. - * elf32-lm32.c (lm32_elf_relocate_section): Likewise. - * elf32-m32c.c (m32c_elf_relocate_section): Likewise. - * elf32-m32r.c (m32r_elf_relocate_section): Likewise. - * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Likewise. - * elf32-m68k.c (elf_m68k_relocate_section): Likewise. - * elf32-mcore.c (mcore_elf_relocate_section): Likewise. - * elf32-mep.c (mep_elf_relocate_section): Likewise. - * elf32-moxie.c (moxie_elf_relocate_section): Likewise. - * elf32-msp430.c (elf32_msp430_relocate_section): Likewise. - * elf32-mt.c (mt_elf_relocate_section): Likewise. - * elf32-openrisc.c (openrisc_elf_relocate_section): Likewise. - * elf32-ppc.c (ppc_elf_relocate_section): Likewise. - * elf32-rl78.c (rl78_elf_relocate_section): Likewise. - * elf32-rx.c (rx_elf_relocate_section): Likewise. - * elf32-s390.c (elf_s390_relocate_section): Likewise. - * elf32-score.c (s3_bfd_score_elf_relocate_section): Likewise. - * elf32-score7.c (s7_bfd_score_elf_relocate_section): Likewise. - * elf32-sh.c (sh_elf_relocate_section): Likewise. - * elf32-spu.c (spu_elf_relocate_section): Likewise. - * elf32-tic6x.c (elf32_tic6x_relocate_section): Likewise. - * elf32-tilepro.c (tilepro_elf_relocate_section): Likewise. - * elf32-v850.c (v850_elf_relocate_section): Likewise. - * elf32-vax.c (elf_vax_relocate_section): Likewise. - * elf32-xc16x.c (elf32_xc16x_relocate_section): Likewise. - * elf32-xstormy16.c (xstormy16_elf_relocate_section): Likewise. - * elf32-xtensa.c (elf_xtensa_relocate_section): Likewise. - * elf64-alpha.c (elf64_alpha_relocate_section_r): Likewise. - (elf64_alpha_relocate_section): Likewise. - * elf64-hppa.c (elf64_hppa_relocate_section): Likewise. - * elf64-mmix.c (mmix_elf_relocate_section): Likewise. - * elf64-ppc.c (ppc64_elf_relocate_section): Likewise. - * elf64-s390.c (elf_s390_relocate_section): Likewise. - * elf64-sh64.c (sh_elf64_relocate_section): Likewise. - * elf64-x86-64.c (elf_x86_64_relocate_section): Likewise. - * elfnn-ia64.c (elfNN_ia64_relocate_section): Likewise. - * elfxx-sparc.c (_bfd_sparc_elf_relocate_section): Likewise. - * elfxx-tilegx.c (tilegx_elf_relocate_section): Likewise. - -2012-05-05 Alan Modra - - PR ld/14052 - PR ld/13621 - * linker.c (_bfd_nearby_section): Revert 2012-02-13 change. - -2012-05-05 Alan Modra - - * aout-arm.c: Replace all uses of bfd_abs_section, bfd_com_section, - bfd_und_section and bfd_ind_section with their _ptr variants, or - use corresponding bfd_is_* macros. - * aout-ns32k.c: Likewise. - * aout-tic30.c: Likewise. - * coff-arm.c: Likewise. - * coff-tic54x.c: Likewise. - * cpu-ns32k.c: Likewise. - * elf-attrs.c: Likewise. - * elfcode.h: Likewise. - * peicode.h: Likewise. - * reloc.c: Likewise. - * riscix.c: Likewise. - * versados.c: Likewise. - * section.c: Likewise. - (bfd_abs_section, bfd_ind_section, bfd_com_section, - bfd_ind_section): Delete. - (std_section): New array replacing above. - (bfd_abs_section_ptr, bfd_ind_section_ptr, bfd_com_section_ptr, - bfd_ind_section_ptr, STD_SECTION): Update. - (BFD_FAKE_SECTION, GLOBAL_SYM_INIT): Remove unnecessary casts. - * bfd-in2.h: Regenerate. - -2012-05-03 Sean Keys - - * cpu-xgate.c: New file. Added XGATE support. - * archures.c (bfd_architecture): Add XGATE architecture. - (bfd_archures_list): Add reference to XGATE architecture info. - * elf-bfd.h (prep_headers): Handle bfd_arch_xgate. - * reloc.c: Add various XGATE relocation enums. - * targets.c (bfd_elf32_xgate_vec): Declare and add to target vector - list. - * Makefile.am: Add support for XGATE elf. - * configure.in: Ditto. - * config.bfd: Ditto. - * Makefile.in: Regenerate. - * configure: Ditto. - * bfd-in2.h: Ditto. - * libbfd.h: Ditto. - Added files for XGATE relocations. - * elf32-xgate.c: Created minimal relocation file. - * elf32-xgate.h: Created minimal header file for elf32-xgate. - -2012-05-03 Tristan Gingold - - * dwarf2.c (decode_line_info): Ignore - DW_LNE_HP_source_file_correlation. - -2012-05-01 Nick Clifton - - PR binutils/13121 - * aoutx.h: Rename 'finfo' to 'flaginfo' to avoid conflicts with - AIX system headers. - * coff-ppc.c: Likewise. - * cofflink.c: Likewise. - * elf32-arm.c: Likewise. - * elf64-sparc.c: Likewise. - * elflink.c: Likewise. - * pdp11.c: Likewise. - * rescoff.c: Likewise. - -2012-04-26 Mark Wielaard - - * dwarf2.c (scan_unit_for_symbols): Account for DW_AT_high_pc - possibly being relative to DW_AT_low_pc. - (parse_comp_unit): Likewise. - -2012-04-26 Andreas Schwab - - * elf32-m68k.c (elf_m68k_check_relocs): Mark non-GOT references - also when generating PIE. - (elf_m68k_discard_copies): Mark undefined weak symbols referenced - by relocations as dynamic. - -2012-04-26 Hans-Peter Nilsson - - Provide a way for programs to recognize BFD_ASSERT calls. - * bfd.c (bfd_assert_handler_type): New API type. - (bfd_set_assert_handler, bfd_get_assert_handler): New API functions. - (_bfd_assert_handler): New variable. - (_bfd_default_assert_handler): New function. - (bfd_assert): Call _bfd_assert_handler, not _bfd_error_handler. - * libbfd-in.h (_bfd_assert_handler): Declare. - * libbfd.h, bfd-in2.h: Regenerate. - -2012-04-24 Hans-Peter Nilsson - - PR ld/13990 - * elf32-arm.c (elf32_arm_gc_sweep_hook): Handle a forced-local - symbol, where PLT refcount is set to -1. - -2012-04-24 Alan Modra - - PR ld/13991 - * elf-bfd.h (_bfd_elf_link_just_syms): Define as - _bfd_generic_link_just_syms. - * elflink.c (_bfd_elf_link_just_syms): Delete. - * linker.c (_bfd_generic_link_just_syms): Set sec_info_type. - - * bfd-in.h (discarded_section): Renamed from elf_discarded_section. - * section.c (SEC_INFO_TYPE_NONE, SEC_INFO_TYPE_STABS, - SEC_INFO_TYPE_MERGE, SEC_INFO_TYPE_EH_FRAME, - SEC_INFO_TYPE_JUST_SYMS): Renamed from corresponding ELF_INFO_TYPE. - * elf-eh-frame.c, * elf-m10200.c, * elf-m10300.c, - * elf.c, * elf32-arm.c, * elf32-avr.c, * elf32-bfin.c, - * elf32-cr16.c, * elf32-cr16c.c, * elf32-cris.c, - * elf32-crx.c, * elf32-d10v.c, * elf32-epiphany.c, - * elf32-fr30.c, * elf32-frv.c, * elf32-h8300.c, - * elf32-hppa.c, * elf32-i370.c, * elf32-i386.c, - * elf32-i860.c, * elf32-ip2k.c, * elf32-iq2000.c, - * elf32-lm32.c, * elf32-m32c.c, * elf32-m32r.c, - * elf32-m68hc1x.c, * elf32-m68k.c, * elf32-mcore.c, - * elf32-mep.c, * elf32-moxie.c, * elf32-msp430.c, - * elf32-mt.c, * elf32-openrisc.c, * elf32-ppc.c, - * elf32-rl78.c, * elf32-rx.c, * elf32-s390.c, - * elf32-score.c, * elf32-score7.c, * elf32-sh.c, - * elf32-spu.c, * elf32-tic6x.c, * elf32-tilepro.c, - * elf32-v850.c, * elf32-vax.c, * elf32-xc16x.c, - * elf32-xstormy16.c, * elf32-xtensa.c, * elf64-alpha.c, - * elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mmix.c, - * elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, - * elf64-x86-64.c, * elflink.c, * elfnn-ia64.c, - * elfxx-mips.c, * elfxx-sparc.c, * elfxx-tilegx.c, - * reloc.c: Update all references. - * bfd-in2.h: Regenerate. - -2012-04-20 Andreas Krebbel - - * elf32-s390.c (ELF_DYNAMIC_INTERPRETER): Set to the GCC default. - * elf64-s390.c (ELF_DYNAMIC_INTERPRETER): Set to the GCC default. - -2012-04-19 Thomas Schwinge - - * elf32-sh.c (elf_sh_link_hash_entry): Specify an enum identifier for - got_type. - (allocate_dynrelocs, sh_elf_relocate_section, sh_elf_check_relocs): Use - it. - -2012-04-17 Kaz Kojima - - * elf32-sh.c (allocate_dynrelocs): Don't allocate dynamic - relocations when LE conversion happens on the IE tls symbol. - -2012-04-17 Roland McGrath - - * elf64-x86-64.c (elf_x86_64_nacl_plt0_entry): Fix nop padding - so that 32-byte boundary is a proper instruction boundary. - -2012-04-17 Tristan Gingold - - * vms-lib.c (_bfd_vms_lib_get_module): Append .obj extension to - member of an object archive.< - -2012-04-17 Tristan Gingold - - * vms-lib.c (MAX_EKEYLEN): Define. - (MAX_KEYLEN): Fix value. - (vms_write_index): Add comments and fix indentation. - Adjust comparaison. Add assertions. Free kbn_blk. - (_bfd_vms_lib_write_archive_contents): Use MAX_EKEYLEN. - Compense MAX_KEYLEN adjustment. - -2012-04-16 Maciej W. Rozycki - - * elfxx-mips.c (mips16_stub_symndx): Handle n64 compound relocs. - (_bfd_mips_elf_check_relocs): Update accordingly. - -2012-04-13 Alan Modra - - PR ld/13947 - * elflink.c (bfd_elf_final_link): Set reloc_count to 0 for - reloc sections. - -2012-04-12 David S. Miller - - * reloc.c (BFD_RELOC_SPARC_H34, BFD_RELOC_SPARC_SIZE32, - BFD_RELOC_SPARC_SIZE64, BFD_RELOC_SPARC_WDISP10): New relocs. - * libbfd.h: Regenerate. - * bfd-in2.h: Likewise. - * elfxx-sparc.c (sparc_elf_wdisp10_reloc): New function. - (_bfd_sparc_elf_howto_table): Add entries for R_SPARC_H34, - R_SPARC_SIZE32, R_SPARC_64, and R_SPARC_WDISP10. - (_bfd_sparc_elf_reloc_type_lookup): Handle new relocs. - (_bfd_sparc_elf_check_relocs): Likewise. - (_bfd_sparc_elf_gc_sweep_hook): Likewise. - (_bfd_sparc_elf_relocate_section): Likewise. - -2012-04-12 Roland McGrath - - * elf32-arm.c (elf32_arm_nacl_plt0_entry, elf32_arm_nacl_plt_entry): - New variables. - (struct elf32_arm_link_hash_table): New member `nacl_p'. - (elf32_arm_link_hash_table_create): Initialize it. - (elf32_arm_nacl_link_hash_table_create): New function. - (arm_movw_immediate, arm_movt_immediate): New functions. - (elf32_arm_populate_plt_entry): Test HTAB->nacl_p. - (elf32_arm_finish_dynamic_sections): Likewise. - (elf32_arm_output_plt_map_1): Likewise. - (bfd_elf32_littlearm_nacl_vec, bfd_elf32_bigarm_nacl_vec): - New backend vector stanza. - (elf32_arm_nacl_modify_segment_map): New function. - * config.bfd: Handle arm-*-nacl*, armeb-*-nacl*. - * targets.c: Support bfd_elf32_{big,little}_nacl_vec. - * configure.in: Likewise. - (bfd_elf32_bigarm_nacl_vec): Add elf-nacl.lo here. - (bfd_elf32_littlearm_nacl_vec): Likewise. - (bfd_elf32_bigarm_vec, bfd_elf32_littlearm_vec): Likewise. - (bfd_elf32_bigarm_symbian_vec): Likewise. - (bfd_elf32_littlearm_symbian_vec): Likewise. - (bfd_elf32_bigarm_vxworks_vec): Likewise. - (bfd_elf32_littlearm_vxworks_vec): Likewise. - * configure: Regenerated. - -2012-04-12 Tristan Gingold - - * elflink.c (elf_link_output_extsym): Add a guard. - (bfd_elf_final_link): Remove assertion. - (bfd_elf_final_link): Add a guard. - * elfnn-ia64.c (INCLUDE_IA64_VMS): Removed. - (elfNN_vms_section_from_shdr, elfNN_vms_object_p) - (elfNN_vms_post_process_headers, elfNN_vms_section_processing) - (elfNN_vms_final_write_processing, elfNN_vms_close_and_cleanup): - Remove. - (elfNN-ia64-vms target): Move to ... - * elf64-ia64-vms.c: New file. - * configure.in (bfd_elf64_ia64_vms_vec): Add elf64-ia64-vms.lo - * Makefile.am (BFD64_BACKENDS): Add elf64-ia64-vms.lo. - (BFD64_BACKENDS_CFILES): Ad elf64-ia64-vms.c. - * configure: Regenerate. - * Makefile.in: Regenerate. - -2012-04-11 Nick Clifton - - PR binutils/13897 - * elf64-ppc.c (opd_entry_value): When dealing with sections - without relocs, keep the last section loaded in order to avoid - unnecessary reloads. - -2012-04-09 Roland McGrath - - * elf.c (_bfd_elf_map_sections_to_segments): Set INFO->user_phdrs. - * elf-nacl.c (nacl_modify_segment_map): Do nothing if INFO->user_phdrs. - (nacl_modify_program_headers): Likewise. - -2012-04-03 Roland McGrath - - * elf-nacl.c: New file. - * elf-nacl.h: New file. - * elf32-i386.c (elf_backend_modify_segment_map): Define for - bfd_elf32_i386_nacl_vec. - (elf_backend_modify_program_headers): Likewise. - * elf64-x86-64.c (elf_backend_modify_segment_map): Define for - bfd_elf64_x86_64_nacl_vec and bfd_elf32_x86_64_nacl_vec. - (elf_backend_modify_program_headers): Likewise. - * Makefile.am (BFD32_BACKENDS, BFD64_BACKENDS): Add elf-nacl.lo here. - (BFD32_BACKENDS_CFILES, BFD64_BACKENDS_CFILES): Add elf-nacl.c here. - * Makefile.in: Regenerated. - * configure.in (bfd_elf64_x86_64_nacl_vec): Add elf-nacl.o to tb here. - (bfd_elf32_x86_64_nacl_vec): Likewise. - (bfd_elf64_x86_64_vec, bfd_elf32_x86_64_vec): Likewise. - (bfd_elf64_x86_64_freebsd_vec, bfd_elf64_x86_64_sol2_vec): Likewise. - (bfd_elf64_l1om_vec, bfd_elf64_l1om_freebsd_vec): Likewise. - (bfd_elf64_k1om_vec, bfd_elf64_k1om_freebsd_vec): Likewise. - (bfd_elf32_i386_nacl_vec): Likewise. - (bfd_elf32_i386_sol2_vec, bfd_elf32_i386_freebsd_vec): Likewise. - (bfd_elf32_i386_vxworks_vec, bfd_elf32_i386_vec): Likewise. - * configure: Regenerated. - -2012-03-31 Andreas Schwab - - * elf32-m68k.c (elf_m68k_relocate_section): Allow - R_68K_TLS_LE{8,16,32} for PIE. - -2012-03-30 Andreas Krebbel - - * elf64-s390.c: Fix several comments regarding PLT entry - description. - * elf32-s390.c: Likewise. - -2012-03-30 Andreas Krebbel - - * elf64-s390.c: Use the section pointer shortcuts in - elf_link_hash_table and remove them from the target specific - variant. - * elf32-s390.c: Likewise. - -2012-03-30 Andreas Krebbel - - * elf64-s390.c (elf_s390x_plt_entry, elf_s390x_first_plt_entry): - New definitions. - (PLT_PIC_ENTRY_WORD*, PLT_PIC12_ENTRY_WORD*): Remove. - (elf_s390_finish_dynamic_symbol): Use memcpy instead of bfd_put_32. - (elf_s390_finish_dynamic_sections): Likewise. - * elf32-s390.c (elf_s390_plt_entry, elf_s390_plt_pic_entry) - (elf_s390_plt_pic12_entry, elf_s390_plt_pic16_entry) - (elf_s390_plt_first_entry, elf_s390_plt_pic_first_entry): New definitions. - (PLT_PIC16_ENTRY_WORD*, PLT_ENTRY_WORD*) - (PLT_PIC_FIRST_ENTRY_WORD*, PLT_FIRST_ENTRY_WORD*): Remove. - -2012-03-30 Andreas Krebbel - - * elf32-s390.c (struct elf_s390_dyn_relocs): Remove. - Rename all occurrences in the file to elf_dyn_relocs. - * elf64-s390.c: Likewise. - -2012-03-30 Alan Modra - - * elflink.c (_bfd_elf_gc_mark_reloc): Don't delve into dynamic - libraries. - -2012-03-29 Alan Modra - - * bfd-in.h (bfd_get_arch_size, bfd_get_sign_extend_vma): Delete. - * bfd-in2.h: Regenerate. - -2012-03-23 Alan Modra - - * elf.c (assign_file_positions_for_non_load_sections): Don't warn - on empty alloc sections. - -2012-03-23 Alan Modra - - * linker.c (_bfd_nearby_section): New function, split out from.. - (fix_syms): ..here. - * bfd-in.h (_bfd_nearby_section): Declare. - * bfd-in2.h: Regenerate. - * elflink.c (elf_link_input_bfd): Don't use text_index_section or - data_index_section with ld -q or ld -r output relocs against - stripped output sections. Instead use _bfd_nearby_section. - -2012-03-23 Alan Modra - - PR binutils/13894 - * elf64-ppc.c (opd_entry_value): Read full symbol table when - sym hashes unavailable. - -2012-03-21 Eliot Dresselhaus - - * elf32-tic6x.c (elf32_tic6x_merge_private_bfd_data): Return TRUE - for non-C6X objects. - -2012-03-20 Kai Tietz - - PR ld/12742 - * configure.in (AC_CHECK_HEADERS): Test for windows.h and dlfcn.h. - * plugin.c: Guard include of dlfcn.h if HAVE_DLFCN_H is defined. - Add windows.h header include if HAVE_WINDOWS_H is defined. - (dlerror): New static function if windows variant is used instead - of dlfcn.h. - (dlclose): Likewise. - (dlopen): Likewise. - (dlsym): Likewise. - * configure: Regenerated. - * config.in: Regenerated. - -2012-03-20 H.J. Lu - - PR ld/13880 - * elf32-i386.c (elf_i386_relocate_section): Don't issue an error - for R_386_GOTOFF relocation against protected function if - SYMBOLIC_BIND is true. - - * elf64-x86-64.c (elf_x86_64_relocate_section): Don't issue an - error for R_X86_64_GOTOFF64 relocation against protected function - when building executable or SYMBOLIC_BIND is true. - -2012-03-16 Roland McGrath - - * config.bfd: Handle x86_64-*-nacl*. - * elf64-x86-64.c (bfd_elf64_x86_64_nacl_vec): New backend vector stanza. - (bfd_elf32_x86_64_nacl_vec): Likewise. - * targets.c: Support them. - * configure.in: Likewise. - * configure: Regenerated. - -2012-03-16 Matthew Gretton-Dann - - * elf32-arm.c (elf32_arm_attributes_accept_div): New function. - (elf32_arm_attributes_forbid_div): Likewise. - (elf32_arm_merge_eabi_attributes): Correct handling of - Tag_DIV_use. - -2012-03-15 Roland McGrath - - * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Use - elf_x86_64_backend_data parameters for plt_eh_frame. - - * elf64-x86-64.c (struct elf_x86_64_backend_data): New type. - (get_elf_x86_64_backend_data, GET_PLT_ENTRY_SIZE): New macros. - (elf_x86_64_arch_bed): New variable. - (elf_backend_arch_data): New macro. - (elf_x86_64_adjust_dynamic_symbol): Use GET_PLT_ENTRY_SIZE. - (elf_x86_64_allocate_dynrelocs): Likewise. - (elf_x86_64_relocate_section): Likewise. - (elf_x86_64_plt_sym_val): Likewise. - (elf_x86_64_finish_dynamic_symbol): Use elf_x86_64_backend_data - parameters for PLT details. - (elf_x86_64_finish_dynamic_sections): Likewise. - -2012-03-14 Roland McGrath - - * elf32-i386.c (elf_i386_nacl_pic_plt0_entry): Initialize up - to the full size, padding out with nop instructions. - -2012-03-12 Alan Modra - - * elf-m10300.c (_bfd_mn10300_elf_adjust_dynamic_symbol): Don't warn - on zero size dynbss symbol. - * elf32-arm.c (elf32_arm_adjust_dynamic_symbol): Likewise. - * elf32-cr16.c (_bfd_cr16_elf_adjust_dynamic_symbol): Likewise. - * elf32-cris.c (elf_cris_adjust_dynamic_symbol): Likewise. - * elf32-hppa.c (elf32_hppa_adjust_dynamic_symbol): Likewise. - * elf32-i370.c (i370_elf_adjust_dynamic_symbol): Likewise. - * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Likewise. - * elf32-lm32.c (lm32_elf_adjust_dynamic_symbol): Likewise. - * elf32-m32r.c (m32r_elf_adjust_dynamic_symbol): Likewise. - * elf32-m68k.c (elf_m68k_adjust_dynamic_symbol): Likewise. - * elf32-ppc.c (ppc_elf_adjust_dynamic_symbol): Likewise. - * elf32-s390.c (elf_s390_adjust_dynamic_symbol): Likewise. - * elf32-sh.c (sh_elf_adjust_dynamic_symbol): Likewise. - * elf32-tic6x.c (elf32_tic6x_adjust_dynamic_symbol): Likewise. - * elf32-tilepro.c (tilepro_elf_adjust_dynamic_symbol): Likewise. - * elf32-vax.c (elf_vax_adjust_dynamic_symbol): Likewise. - * elf64-ppc.c (ppc64_elf_adjust_dynamic_symbol): Likewise. - * elf64-s390.c (elf_s390_adjust_dynamic_symbol): Likewise. - * elf64-sh64.c (sh64_elf64_adjust_dynamic_symbol): Likewise. - * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. - * elfxx-sparc.c (_bfd_sparc_elf_adjust_dynamic_symbol): Likewise. - * elfxx-tilegx.c (tilegx_elf_adjust_dynamic_symbol): Likewise. - -2012-03-10 Edmar Wienskoski - - * archures.c: Add bfd_mach_ppc_e5500 and bfd_mach_ppc_e6500. - * bfd-in2.h: Regenerate. - * cpu-powerpc.c (bfd_powerpc_archs): Add entries for - bfd_mach_ppc_e5500 and bfd_mach_ppc_e6500. - -2012-03-09 H.J. Lu - - PR ld/13817 - * elf32-i386.c (elf_i386_relocate_section): Restore - R_386_IRELATIVE. - - * elf64-x86-64.c (elf_x86_64_relocate_section): Restore - R_X86_64_IRELATIVE. - -2012-03-08 Tristan Gingold - - * vms-lib.c (_bfd_vms_lib_write_archive_contents): Set maximum - keylen according to archive kind. Set nextvbn and nextrfa lhd - fields. Add comments. - -2012-03-07 Nick Clifton - - * elf-m10300.c (elf32_mn10300_link_hash_entry): Add tls_type - field. - (elf32_mn10300_link_hash_table): Add tls_ldm_got entry; - (elf_mn10300_tdata): Define. - (elf_mn10300_local_got_tls_type): Define. - (elf_mn10300_howto_table): Add entries for R_MN10300_TLS_GD, - R_MN10300_TLS_LD, R_MN10300_TLS_LDO, R_MN10300_TLS_GOTIE, - R_MN10300_TLS_IE, R_MN10300_TLS_LE, R_MN10300_TLS_DPTMOD, - R_MN10300_TLS_DTPOFF, R_MN10300_TLS_TPOFF relocs. - (mn10300_reloc_map): Likewise. - (elf_mn10300_tls_transition): New function. - (dtpoff, tpoff, mn10300_do_tls_transition): New functions. - (mn10300_elf_check_relocs): Add TLS support. - (mn10300_elf_final_link_relocate): Likewise. - (mn10300_elf_relocate_section): Likewise. - (mn10300_elf_relax_section): Likewise. - (elf32_mn10300_link_hash_newfunc): Initialise new field. - (_bfd_mn10300_copy_indirect_symbol): New function. - (elf32_mn10300_link_hash_table_create): Initialise new fields. - (_bfd_mn10300_elf_size_dynamic_sections): Add TLS support. - (_bfd_mn10300_elf_finish_dynamic_symbol): Likewise. - (_bfd_mn10300_elf_reloc_type_class): Allocate an - elf_mn10300_obj_tdata structure. - (elf_backend_copy_indirect_symbol): Define. - * reloc.c (BFD_MN10300_TLS_GD, BFD_MN10300_TLS_LD, - BFD_MN10300_TLS_LDO, BFD_MN10300_TLS_GOTIE, BFD_MN10300_TLS_IE, - BFD_MN10300_TLS_LE, BFD_MN10300_TLS_DPTMOD, - BFD_MN10300_TLS_DTPOFF, BFD_MN10300_TLS_TPOFF): New relocations. - (BFD_RELOC_MN10300_32_PCREL, BFD_RELOC_MN10300_16_PCREL): Move to - alongside other MN10300 relocations. - * bfd-in2.h: Regenerate. - * libbfd.h: Regenerate. - -2012-03-06 Jakub Jelinek - - * elf64-x86-64.c (elf_x86_64_relocate_section): For R_X86_64_RELATIVE - set relocate to TRUE. - -2012-03-05 Rainer Orth - - PR ld/12152 - * elfxx-sparc.c (_bfd_sparc_elf_relocate_section): Also ignore - overflows for R_SPARC_UA32 in .stab sections. - -2012-03-01 Alan Modra - - * elfxx-tilegx.c (tilegx_elf_relocate_section): Silence bogus warning. - -2012-02-27 Alan Modra - - * elf32-sh.c (sh_elf_osec_to_segment): Check for elf flavour bfd - before calling elf specific function. - (sh_elf_osec_readonly_p): Test for error return from above. - -2012-02-27 Alan Modra - - * elf32-spu.c (build_stub): Fix malloc under-allocation. - -2012-02-25 Walter Lee - * reloc.c: Add BFD_RELOC_TILEPRO_TLS_GD_CALL, - BFD_RELOC_TILEPRO_IMM8_X0_TLS_GD_ADD, - BFD_RELOC_TILEPRO_IMM8_X1_TLS_GD_ADD, - BFD_RELOC_TILEPRO_IMM8_Y0_TLS_GD_ADD, - BFD_RELOC_TILEPRO_IMM8_Y1_TLS_GD_ADD, - BFD_RELOC_TILEPRO_TLS_IE_LOAD, BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE, - BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE, - BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_LO, - BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_LO, - BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HI, - BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HI, - BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HA, - BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HA, - BFD_RELOC_TILEGX_IMM16_X0_HW0_TLS_LE, - BFD_RELOC_TILEGX_IMM16_X1_HW0_TLS_LE, - BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_TLS_LE, - BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_TLS_LE, - BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_TLS_LE, - BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_TLS_LE, - BFD_RELOC_TILEGX_TLS_GD_CALL, BFD_RELOC_TILEGX_IMM8_X0_TLS_GD_ADD, - BFD_RELOC_TILEGX_IMM8_X1_TLS_GD_ADD, - BFD_RELOC_TILEGX_IMM8_Y0_TLS_GD_ADD, - BFD_RELOC_TILEGX_IMM8_Y1_TLS_GD_ADD, BFD_RELOC_TILEGX_TLS_IE_LOAD, - BFD_RELOC_TILEGX_IMM8_X0_TLS_ADD, - BFD_RELOC_TILEGX_IMM8_X1_TLS_ADD, - BFD_RELOC_TILEGX_IMM8_Y0_TLS_ADD, BFD_RELOC_TILEGX_IMM8_Y1_TLS_ADD. - Delete BFD_RELOC_TILEGX_IMM16_X0_HW1_GOT, - BFD_RELOC_TILEGX_IMM16_X1_HW1_GOT, - BFD_RELOC_TILEGX_IMM16_X0_HW2_GOT, - BFD_RELOC_TILEGX_IMM16_X1_HW2_GOT, - BFD_RELOC_TILEGX_IMM16_X0_HW3_GOT, - BFD_RELOC_TILEGX_IMM16_X1_HW3_GOT, - BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_GOT, - BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_GOT, - BFD_RELOC_TILEGX_IMM16_X0_HW1_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X1_HW1_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X0_HW2_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X1_HW2_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X0_HW3_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X1_HW3_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_TLS_GD, - BFD_RELOC_TILEGX_IMM16_X0_HW1_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X1_HW1_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X0_HW2_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X1_HW2_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X0_HW3_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X1_HW3_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_TLS_IE, - BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_TLS_IE. - * elf32-tilepro.c (tilepro_elf_howto_table): Update tilepro - relocations. - (tilepro_reloc_map): Ditto. - (tilepro_info_to_howto_rela): Ditto. - (reloc_to_create_func): Ditto. - (tilepro_tls_translate_to_le): New. - (tilepro_tls_translate_to_ie): New. - (tilepro_elf_tls_transition): New. - (tilepro_elf_check_relocs): Handle new tls relocations. - (tilepro_elf_gc_sweep_hook): Ditto. - (allocate_dynrelocs): Ditto. - (tilepro_elf_relocate_section): Ditto. - (tilepro_replace_insn): New. - (insn_mask_X1): New. - (insn_mask_X0_no_dest_no_srca): New - (insn_mask_X1_no_dest_no_srca): New - (insn_mask_Y0_no_dest_no_srca): New - (insn_mask_Y1_no_dest_no_srca): New - (srca_mask_X0): New - (srca_mask_X1): New - (insn_tls_le_move_X1): New - (insn_tls_le_move_zero_X0X1): New - (insn_tls_ie_lw_X1): New - (insn_tls_ie_add_X0X1): New - (insn_tls_ie_add_Y0Y1): New - (insn_tls_gd_add_X0X1): New - (insn_tls_gd_add_Y0Y1): New - * elfxx-tilegx.c (tilegx_elf_howto_table): Update tilegx - relocations. - (tilegx_reloc_map): Ditto. - (tilegx_info_to_howto_rela): Ditto. - (reloc_to_create_func): Ditto. - (tilegx_elf_link_hash_table): New field disable_le_transition. - (tilegx_tls_translate_to_le): New. - (tilegx_tls_translate_to_ie): New. - (tilegx_elf_tls_transition): New. - (tilegx_elf_check_relocs): Handle new tls relocations. - (tilegx_elf_gc_sweep_hook): Ditto. - (allocate_dynrelocs): Ditto. - (tilegx_elf_relocate_section): Ditto. - (tilegx_copy_bits): New. - (tilegx_replace_insn): New. - (insn_mask_X1): New. - (insn_mask_X0_no_dest_no_srca): New. - (insn_mask_X1_no_dest_no_srca): New. - (insn_mask_Y0_no_dest_no_srca): New. - (insn_mask_Y1_no_dest_no_srca): New. - (insn_mask_X0_no_operand): New. - (insn_mask_X1_no_operand): New. - (insn_mask_Y0_no_operand): New. - (insn_mask_Y1_no_operand): New. - (insn_tls_ie_ld_X1): New. - (insn_tls_ie_ld4s_X1): New. - (insn_tls_ie_add_X0X1): New. - (insn_tls_ie_add_Y0Y1): New. - (insn_tls_ie_addx_X0X1): New. - (insn_tls_ie_addx_Y0Y1): New. - (insn_tls_gd_add_X0X1): New. - (insn_tls_gd_add_Y0Y1): New. - (insn_move_X0X1): New. - (insn_move_Y0Y1): New. - (insn_add_X0X1): New. - (insn_add_Y0Y1): New. - (insn_addx_X0X1): New. - (insn_addx_Y0Y1): New. - * libbfd.h: Regenerate. - * bfd-in2.h: Regenerate. - -2012-02-25 Walter Lee - - * config.bfd (tilegx-*-*): rename little endian vector; add big - endian vector. - (tilegxbe-*-*): New case. - * configure.in (bfd_elf32_tilegx_vec): Rename... - (bfd_elf32_tilegx_le_vec): ... to this. - (bfd_elf32_tilegx_be_vec): New vector. - (bfd_elf64_tilegx_vec): Rename... - (bfd_elf64_tilegx_le_vec): ... to this. - (bfd_elf64_tilegx_be_vec): New vector. - * configure: Regenerate. - * elf32-tilegx.c (TARGET_LITTLE_SYM): Rename. - (TARGET_LITTLE_NAME): Ditto. - (TARGET_BIG_SYM): Define. - (TARGET_BIG_NAME): Define. - * elf64-tilegx.c (TARGET_LITTLE_SYM): Rename. - (TARGET_LITTLE_NAME): Ditto. - (TARGET_BIG_SYM): Define. - (TARGET_BIG_NAME): Define. - * targets.c (bfd_elf32_tilegx_vec): Rename... - (bfd_elf32_tilegx_le_vec): ... to this. - (bfd_elf32_tilegx_be_vec): Declare. - (bfd_elf64_tilegx_vec): Rename... - (bfd_elf64_tilegx_le_vec): ... to this. - (bfd_elf64_tilegx_be_vec): Declare. - (_bfd_target_vector): Add / rename above vectors. - * arctures.c (bfd_architecture): Define bfd_mach_tilegx32. - * bfd-in2.h: Regenerate. - * cpu-tilegx.c (bfd_tilegx32_arch): define. - (bfd_tilegx_arch): link to bfd_tilegx32_arch. - -2012-02-24 Nick Clifton - - PR ld/13730 - * reloc.c (bfd_generic_get_relocated_section_contents): Issue an - error message instead of aborting, when an outofrange reloc is - encountered. - -2012-02-23 Iain Sandoe - - * mach-o.c (bfd_mach_o_swap_in_non_scattered_reloc): New. - (bfd_mach_o_canonicalize_one_reloc): Swap non-scattered reloc - bit-fields when target and host differ in endian-ness. When - PAIRs are non-scattered find the 'symbol' from the preceding - reloc. Add FIXME re. reloc symbols on section boundaries. - (bfd_mach_o_swap_out_non_scattered_reloc): New. - (bfd_mach_o_write_relocs): Use bfd_mach_o_encode_non_scattered_reloc. - -2012-02-17 Iain Sandoe - - * mach-o-i386.c (i386_howto_table): Add support for 16 bit - sect-diffs. - (bfd_mach_o_i386_swap_reloc_in): Handle 16bit sect-diffs. - (bfd_mach_o_i386_swap_reloc_out): Likewise. - -2012-02-17 Tristan Gingold - - * reloc.c (BFD_RELOC_MACH_O_LOCAL_SECTDIFF): - * libbfd.h: Regenerated. - * bfd-in2.h: Likewise. - * mach-o-i386.c (i386_howto_table): Include local sectdiff. - (bfd_mach_o_i386_swap_reloc_in): Update for local sectdiff. - (bfd_mach_o_i386_swap_reloc_out): Likewise. - -2012-02-17 Andreas Krebbel - - * elf32-s390.c (elf_s390_relocate_section): Support basr in the - GD->LE and LD->LE optimizations. - -2012-02-16 Alan Modra - - PR binutils/13355 - * elf32-rx.c (elf32_rx_relax_section): Correct width check. - -2012-02-13 Richard Henderson - - PR ld/13621 - * linker.c (fix_syms): Force symbols outside any section into - bfd_abs_section_ptr. - -2012-02-13 Alan Modra - - * elf32-m68hc1x.c (elf32_m68hc11_merge_symbol_attribute): New function. - * elf32-m68hc1x.h (elf32_m68hc11_merge_symbol_attribute): Declare. - * elf32-m68hc11.c (elf_backend_merge_symbol_attribute): Define. - * elf32-m68hc12.c (elf_backend_merge_symbol_attribute): Define. - -2012-02-11 Jan Kratochvil - Nick Clifton - - * oasys.c (oasys_write_header): Fix compilation warning on zero-sized - memset. - -2012-02-10 Iain Sandoe - - * mach-o.c (bfd_mach_o_build_seg_command): Count zerofill section - vma additions in their logical, rather than physical order. - -2012-02-10 Iain Sandoe - - * mach-o.c (mach_o_section_name_xlat): Correct eh-frame section - parameters. - * mach-o-x86-64.c (text_section_names_xlat): New. - (mach_o_x86_64_segsec_names_xlat): New. - (bfd_mach_o_tgt_seg_table): Define to mach_o_x86_64_segsec_names_xlat. - * mach-o-i386.c (text_section_names_xlat): Correct section parameters. - -2012-02-10 Tristan Gingold - - * elfnn-ia64.c (elfNN_vms_object_p): Change comparison operator - to avoid infinite loop. Add comments. - -2012-02-09 H.J. Lu - - PR ld/13675 - * cpu-i386.c (bfd_arch_i386_fill): Updated to support multi byte - nop instructions. - (bfd_arch_i386_short_nop_fill): New. - (bfd_arch_i386_long_nop_fill): Likewise. - Use bfd_arch_i386_short_nop_fill in 32bit bfd_arch_info - initializers. Use bfd_arch_i386_long_nop_fill on 64bit - bfd_arch_info initializers. - - * cpu-k1om.c (bfd_arch_i386_fill): Renamed to ... - (bfd_arch_i386_short_nop_fill): This. - Update bfd_arch_info initializers. - * cpu-l1om.c: Likewise. - -2012-02-08 Alan Modra - - * elflink.c (_bfd_elf_gc_mark_rsec): Mark weakdef syms too. - (_bfd_elf_fix_symbol_flags): When a weakdef is def_regular, clear - the correct h->u.weakdef. - -2012-02-07 Alan Modra - - * elf.c (elf_find_function): Don't use internal_elf_sym. - (_bfd_elf_maybe_function_sym): Likewise. Replace elf_symbol_type - parameter with asymbol. - * elf64-ppc.c (ppc64_elf_maybe_function_sym): Likewise. - * elf-bfd.h (_bfd_elf_maybe_function_sym): Update prototype. - (struct elf_backend_data ): Likewise. - -2012-02-02 Vidya Praveen (vidya.praveen@atmel.com) - - PR bfd/13410 - * elf32-avr.c (elf32_avr_relax_section): Correct the - condition that qualifies the candidates for relaxation. - -2012-02-02 Tristan Gingold - - * bfdio.c (real_fopen): Remove unused vms_modes variable. - -2012-02-02 Tristan Gingold - - * mach-o.c (bfd_mach_o_read_header): Silent uninitialized - variable warning. - -2012-02-02 Tristan Gingold - - * archive.c (bfd_slurp_armap): Fix thinko in cast. - -2012-01-31 H.J. Lu - - PR ld/13616 - * archures.c (bfd_arch_info): Add fill. - (bfd_default_arch_struct): Add bfd_arch_default_fill. - (bfd_arch_default_fill): New. - - * configure.in: Set bfd version to 2.22.52. - * configure: Regenerated. - - * cpu-alpha.c: Add bfd_arch_default_fill to bfd_arch_info - initializer. - * cpu-arc.c: Likewise. - * cpu-arm.c: Likewise. - * cpu-avr.c: Likewise. - * cpu-bfin.c: Likewise. - * cpu-cr16.c: Likewise. - * cpu-cr16c.c: Likewise. - * cpu-cris.c: Likewise. - * cpu-crx.c: Likewise. - * cpu-d10v.c: Likewise. - * cpu-d30v.c: Likewise. - * cpu-dlx.c: Likewise. - * cpu-epiphany.c: Likewise. - * cpu-fr30.c: Likewise. - * cpu-frv.c: Likewise. - * cpu-h8300.c: Likewise. - * cpu-h8500.c: Likewise. - * cpu-hppa.c: Likewise. - * cpu-i370.c: Likewise. - * cpu-i860.c: Likewise. - * cpu-i960.c: Likewise. - * cpu-ia64.c: Likewise. - * cpu-ip2k.c: Likewise. - * cpu-iq2000.c: Likewise. - * cpu-lm32.c: Likewise. - * cpu-m10200.c: Likewise. - * cpu-m10300.c: Likewise. - * cpu-m32c.c: Likewise. - * cpu-m32r.c: Likewise. - * cpu-m68hc11.c: Likewise. - * cpu-m68hc12.c: Likewise. - * cpu-m68k.c: Likewise. - * cpu-m88k.c: Likewise. - * cpu-mcore.c: Likewise. - * cpu-mep.c: Likewise. - * cpu-microblaze.c: Likewise. - * cpu-mips.c: Likewise. - * cpu-mmix.c: Likewise. - * cpu-moxie.c: Likewise. - * cpu-msp430.c: Likewise. - * cpu-mt.c: Likewise. - * cpu-ns32k.c: Likewise. - * cpu-openrisc.c: Likewise. - * cpu-or32.c: Likewise. - * cpu-pdp11.c: Likewise. - * cpu-pj.c: Likewise. - * cpu-plugin.c: Likewise. - * cpu-powerpc.c: Likewise. - * cpu-rl78.c: Likewise. - * cpu-rs6000.c: Likewise. - * cpu-rx.c: Likewise. - * cpu-s390.c: Likewise. - * cpu-score.c: Likewise. - * cpu-sh.c: Likewise. - * cpu-sparc.c: Likewise. - * cpu-spu.c: Likewise. - * cpu-tic30.c: Likewise. - * cpu-tic4x.c: Likewise. - * cpu-tic54x.c: Likewise. - * cpu-tic6x.c: Likewise. - * cpu-tic80.c: Likewise. - * cpu-tilegx.c: Likewise. - * cpu-tilepro.c: Likewise. - * cpu-v850.c: Likewise. - * cpu-vax.c: Likewise. - * cpu-w65.c: Likewise. - * cpu-we32k.c: Likewise. - * cpu-xc16x.c: Likewise. - * cpu-xstormy16.c: Likewise. - * cpu-xtensa.c: Likewise. - * cpu-z80.c: Likewise. - * cpu-z8k.c: Likewise. - - * cpu-i386.c: Include "libiberty.h". - (bfd_arch_i386_fill): New. - Add bfd_arch_i386_fill to bfd_arch_info initializer. - - * cpu-k1om.c: Add bfd_arch_i386_fill to bfd_arch_info initializer. - * cpu-l1om.c: Likewise. - - * linker.c (default_data_link_order): Call abfd->arch_info->fill - if fill size is 0. - - * bfd-in2.h: Regenerated. - -2012-01-27 Michael Eager - - * elf32-microblaze.c (create_got_section): - Reuse existing .rela.got section. - -2012-01-23 Alan Modra - - * elf-bfd.h: Formatting. - (struct elf_backend_data): Add "maybe_function_sym". - (_bfd_elf_maybe_function_sym): Declare. - * elfxx-target.h (elf_backend_maybe_function_sym): Define. - (elfNN_bed): Init new field. - * elf.c (elf_find_function): Use maybe_function_sym. - (_bfd_elf_maybe_function_sym): New function. - * elf64-ppc.c (elf_backend_maybe_function_sym): Define. - (ppc64_elf_maybe_function_sym): New function. - -2012-01-20 Francois Gouget - - PR binutils/13534 - * archive.c (_bfd_ar_sizepad): New function. Correctly install and - pad the size field in an archive header. - (_bfd_generic_read_ar_hdr_mag): Use the correct type and scan - function for the archive size field. - (bfd_generic_openr_next_archived_file): Likewise. - (do_slurp_coff_armap): Likewise. - (_bfd_write_archive_contents): Likewise. - (_bfd_bsd44_write_ar_hdr): Use the new function. - (bfd_ar_hdr_from_filesystem): Likewise. - (_bfd_write_archive_contents): Likewise. - (bsd_write_armap): Likewise. - (coff_write_armap): Likewise. - * archive64.c (bfd_elf64_archive_write_armap): Likewise. - * bfdio.c (bfd_bread): Use correct type for archive element - sizes. - * ar.c (open_inarch): Likewise. - (extract_file): Likewise. - * libbfd-in.h (struct areltdata): Use correct types for - parsed_size and extra_size fields. - Prototype _bfd_ar_sizepad function. - * libbfd.h: Regenerate. - -2012-01-20 Ulrich Weigand - - * elf.c (elfcore_write_prpsinfo): Provide unconditionally. - Return NULL if core file generation is unsupported. - (elfcore_write_prstatus): Likewise. - * elf32-arm.c (elf32_arm_nabi_write_core_note): New function. - (elf_backend_write_core_note): Define. - -2012-01-19 Tristan Gingold - - * pef.c: Add a comment. - * xsym.c: Likewise. - -2012-01-17 Alan Modra - - * elf32-ppc.c (ppc_elf_write_core_note ): Don't leave - trailing garbage in the note. - * elf64-ppc.c (ppc64_elf_write_core_note ): Likewise. - -2012-01-16 Daniel Green - - PR ld/13491 - * coff-i386.c (coff_i386_rtype_to_howto ): Test - h->root.type not h->type. - * coff-x86_64.c (coff_amd64_rtype_to_howto ): Likewise. - -2012-01-13 Iain Sandoe - - * mach-o.c (bfd_mach_o_build_dysymtab_command): Handle absolute - indirect symbols. - -2012-01-13 Iain Sandoe - - * mach-o.c (bfd_mach_o_write_relocs): Move computation of relocs file - position from here... to (bfd_mach_o_build_seg_command): Here. - -2012-01-12 Iain Sandoe - - * mach-o.c (bfd_mach_o_count_indirect_symbols): New. - (bfd_mach_o_build_dysymtab_command): Populate indirect symbol table. - * mach-o.h (bfd_mach_o_asymbol): Move declaration to start of the - file. (bfd_mach_o_section): Add indirect_syms field. - -2012-01-11 Iain Sandoe - - * mach-o.c (bfd_mach_o_build_seg_command): Separate computation of - vmsize from filesize. Don't compute offsets or file sizes for - zerofill sections. - -2012-01-11 Iain Sandoe - - * mach-o.c (bfd_mach_o_build_commands): Make the building of each - command type independent. - -2012-01-11 Alan Modra - - * elf64-ppc.c: Define more insns used in plt call stubs. - (ppc64_elf_brtaken_reloc): Assume isa version 2 or above. - (ppc64_elf_relocate_section): Likewise. - (enum ppc_stub_type): Add ppc_stub_plt_call_r2save. - (struct ppc_link_hash_table): Increase size of stub_count array. - Add plt_stub_align and plt_thread_safe. - (ALWAYS_USE_FAKE_DEP, ALWAYS_EMIT_R2SAVE): Define. - (plt_stub_size, plt_stub_pad): New functions. - (build_plt_stub): Emit barriers for power7 thread safety. Don't - emit needless save of r2. - (build_tls_get_addr_stub): Adjust params. - (ppc_build_one_stub): Handle ppc_stub_plt_call_r2save and aligning - plt stubs. Adjust build_*plt_stub calls. - (ppc_size_one_stub): Similarly. - (ppc64_elf_size_stubs): Accept plt_thread_safe and plt_stub_align - params. Choose default for plt_thread_safe based on existence of - calls to thread creation functions. Modify plt_call to - plt_call_r2save when no tocsave reloc found. Align tail of stub - sections. - (ppc64_elf_build_stubs): Align tail of stub sections. Adjust - output of stub statistics. - (ppc64_elf_relocate_section): Handle ppc_stub_plt_call_r2save. - * elf64-ppc.h (ppc64_elf_size_stubs): Update prototype. - -2012-01-10 H.J. Lu - - PR ld/13581 - * elf64-x86-64.c (elf_x86_64_relocate_section): Remove ABI_64_P - check on R_X86_64_PCXX. - -2012-01-10 Tristan Gingold - - * mach-o.c (bfd_mach_o_build_commands): Avoid uninitialized false - warning. - -2012-01-10 Tristan Gingold - - * bfdio.c (bfd_tell): Handle nested archives. - (bfd_seek): Ditto. - * cache.c (bfd_cache_lookup_worker): Ditto. - * archive.c (_bfd_get_elt_at_filepos): Remove code dealing with - nested archives. - (bfd_generic_openr_next_archived_file): Likewise. - -2012-01-09 Iain Sandoe - - * mach-o.c (bfd_mach_o_bfd_copy_private_symbol_data): Implement. - (bfd_mach_o_write_symtab): Remove handling for indirect syms. - (bfd_mach_o_primary_symbol_sort_key): Likewise. - (bfd_mach_o_cf_symbols): Likewise. - (bfd_mach_o_sort_symbol_table): Remove. - (bfd_mach_o_mangle_symbols): Adjust arguments, remove handling - for indirect and dysymtab counts. Do the symbol sorting here. - (bfd_mach_o_build_dysymtab_command): Count the symbol types here. - Make the indirect symbols a TODO. - (bfd_mach_o_build_commands): Adjust call to bfd_mach_o_mangle_symbols. - (bfd_mach_o_make_empty_symbol): Specifically flag unset symbols with - a non-zero value. - (bfd_mach_o_read_symtab_symbol): Record the symbol index. - (bfd_mach_o_read_symtab_symbol): Adjust recording of global status. - * mach-o.h (mach_o_data_struct): Remove indirect and dysymtab entries. - (IS_MACHO_INDIRECT): Remove. - (SYM_MACHO_FIELDS_UNSET, SYM_MACHO_FIELDS_NOT_VALIDATED): New. - -2012-01-06 Nick Clifton - - PR binutils/13121 - * reloc.c (bfd_generic_lookup_section_flags): Rename 'finfo' to - 'flaginfo' to avoid conflicts with AIX system headers. - -2012-01-06 Tristan Gingold - - * bfdio.c (bfd_bread): Use arelt_size macro. - -2012-01-06 Tristan Gingold - - * config.bfd (i[3-7]86-*-darwin*): Define targ64_selvecs. - -2012-01-05 Nick Clifton - - PR ld/12161 - * elf32-avr.c (elf32_avr_relax_delete_bytes): Read in relocs if - necessary. - -2012-01-05 Jan Kratochvil - - Fix zero registers core files when built by gcc-4.7. - * elf64-x86-64.c (elf_x86_64_write_core_note): Remove variables p and - size. Call elfcore_write_note for the local variables. Remove the - final elfcore_write_note call. Add NOTREACHED comments. - -2012-01-04 Tristan Gingold - - * mach-o.c (bfd_mach_o_fat_stat_arch_elt): New function. - (bfd_mach_o_generic_stat_arch_elt): Adjust. - -2012-01-04 Tristan Gingold - - * mach-o.c (bfd_mach_o_fat_member_init): New function. - (bfd_mach_o_openr_next_archived_file): Reindent. - Adjust to call bfd_mach_o_fat_member_init. - (bfd_mach_o_fat_extract): Adjust to call bfd_mach_o_fat_member_init. - -2012-01-04 Tristan Gingold - - * mach-o-x86-64.c (bfd_mach_o_x86_64_swap_reloc_out): Handle - BFD_RELOC_32, BFD_RELOC_MACH_O_X86_64_PCREL32_1, - BFD_RELOC_MACH_O_X86_64_PCREL32_2, - BFD_RELOC_MACH_O_X86_64_PCREL32_4, - BFD_RELOC_MACH_O_X86_64_BRANCH32, - BFD_RELOC_MACH_O_X86_64_SUBTRACTOR32, - BFD_RELOC_MACH_O_X86_64_GOT. - -2012-01-04 Tristan Gingold - - * mach-o.h (bfd_mach_o_fvmlib_command): New structure. - (bfd_mach_o_load_command): Add fvmlib field. - - * mach-o.c (bfd_mach_o_read_fvmlib): New function. - (bfd_mach_o_read_command): Handle fvmlib. - -2012-01-04 Tristan Gingold - - * mach-o.c (bfd_mach_o_convert_architecture): Reindent. - Decode msubtype for ARM. - -2012-01-04 Tristan Gingold - - * mach-o.c (bfd_mach_o_get_synthetic_symtab): Add comments. - -2012-01-04 Tristan Gingold - - * mach-o.h: Reindent header. - (bfd_mach_o_encryption_info_command): New structure. - (bfd_mach_o_load_command): Add encryption_info field. - - * mach-o.c (bfd_mach_o_read_encryption_info): New function. - (bfd_mach_o_read_command): Handle BFD_MACH_O_LC_ENCRYPTION_INFO. - (bfd_mach_o_read_command): Adjust error message. - -2012-01-04 Shinichiro Hamaji - - * dwarf2.c (_bfd_dwarf2_slurp_debug_info): Factor out the part - which reads DWARF2 and stores in stash from find_line. - (find_line) Call _bfd_dwarf2_slurp_debug_info. - * libbfd-in.h (_bfd_dwarf2_slurp_debug_info): Add declaration. - * libbfd.h (_bfd_dwarf2_slurp_debug_info): Regenerate. - * mach-o.c (dsym_subdir): The name of subdir where debug - information may be stored. - (bfd_mach_o_lookup_uuid_command): New. Lookup a load command whose - type is UUID. - (bfd_mach_o_dsym_for_uuid_p): New. Check if the specified BFD is - corresponding to the executable. - (bfd_mach_o_find_dsym): New. Find a debug information BFD in the - specified binary file. - (bfd_mach_o_follow_dsym): New. Find a debug information BFD for - the original BFD. - (bfd_mach_o_find_nearest_line): Check dSYM files for Mach-O - executables, dylibs, and bundles. - (bfd_mach_o_close_and_cleanup): Clean up BFDs for the dSYM file. - * mach-o.h (dsym_bfd): The BFD of the dSYM file. - -2012-01-03 Iain Sandoe - - * mach-o.c (bfd_mach_o_mangle_symbols): Put in the section index - for stabd symbols. - (bfd_mach_o_primary_symbol_sort_key): Adjust for stabs. - (bfd_mach_o_cf_symbols): Likewise. - -2012-01-03 Iain Sandoe - - * mach-o.c (bfd_mach_o_mangle_symbols): Correct typo. - -2012-01-03 Iain Sandoe - - * mach-o.c (bfd_mach_o_write_symtab): Fill in the string table index - as the value of an indirect symbol. Keep the string table index in - non-indirect syms for reference. - (bfd_mach_o_write_dysymtab): New. - (bfd_mach_o_primary_symbol_sort_key): New. - (bfd_mach_o_cf_symbols): New. - (bfd_mach_o_sort_symbol_table): New. - (bfd_mach_o_mangle_symbols): Return early if no symbols. Sort symbols. - If we are emitting a dysymtab, process indirect symbols and count the - number of each other kind. - (bfd_mach_o_mangle_sections): New. - (bfd_mach_o_write_contents): Split out some pre-requisite code into - the command builder. Write dysymtab if the command is present. - (bfd_mach_o_count_sections_for_seg): New. - (bfd_mach_o_build_seg_command): New. - (bfd_mach_o_build_dysymtab_command): New. - (bfd_mach_o_build_commands): Reorganize to support the fact that some - commands are optional and should not be emitted if there are no - sections or symbols. - (bfd_mach_o_set_section_contents): Amend comment. - * mach-o.h: Amend and add to comments. - (mach_o_data_struct): Add fields for dysymtab symbols counts and a - pointer to the indirects, when present. - (bfd_mach_o_should_emit_dysymtab): New macro. - (IS_MACHO_INDIRECT): Likewise. - -For older changes see ChangeLog-2011 +For older changes see ChangeLog-2012 -Copyright (C) 2012 Free Software Foundation, Inc. +Copyright (C) 2013 Free Software Foundation, Inc. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright diff --git a/bfd/ChangeLog-2012 b/bfd/ChangeLog-2012 new file mode 100644 index 00000000000..9be65bfdbba --- /dev/null +++ b/bfd/ChangeLog-2012 @@ -0,0 +1,3299 @@ +2012-12-23 Mike Frysinger + + * config.bfd (i[3-7]86-*-linux-*): Add x86_64pei_vec to + targ64_selvecs. + +2012-12-21 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_relocate_section): Check + R_X86_64_standard instead of R_X86_64_max for unrecognized + relocation. + +2012-12-21 H.J. Lu + + PR ld/14980 + * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Properly + adjust h->plt.refcount. + * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. + +2012-12-19 H.J. Lu + + * elf32-i386.c (elf_i386_relocate_section): Replace + bfd_elf32_swap_reloc_out with elf_append_rel. + (elf_i386_finish_dynamic_symbol): Likewise. + + * elflink.c (elf_append_rel): Call swap_reloc_out instead of + swap_reloca_out. + +2012-12-18 H.J. Lu + + * elf32-i386.c (elf_i386_finish_dynamic_symbol): Reindent. + +2012-12-18 Edgar E. Iglesias + + PR ld/14736 + * elf32-microblaze.c (calc_fixup): Add end range. + +2012-12-18 Alan Modra + + * elf.c (swap_out_syms): Set shndx to SHN_ABS when not one of + the special MAP_* values. + +2012-12-17 Roland McGrath + Alan Modra + + * elf32-arm.c (elf32_arm_size_stubs): Skip input BFDs that are + not ARM ELF. + +2012-12-17 Nick Clifton + + * MAINTAINERS: Add copyright notice. + * Makefile.am: Likewise. + * PORTING: Likewise. + * README: Likewise. + * TODO: Likewise. + * acinclude.m4: Likewise. + * bfd.m4: Likewise. + * config.bfd: Likewise. + * configure.com: Likewise. + * configure.host: Likewise. + * configure.in: Likewise. + * makefile.vms: Likewise. + * warning.m4: Likewise. + * elf64-hppa.c: Fix copyright notice. + * Makefile.in: Regenerate. + +2012-12-16 H.J. Lu + + * elf32-i386.c (elf_i386_check_relocs): Don't check IFUNC + relocations here. + * elf64-x86-64.c (elf_x86_64_check_relocs): Likewise. + +2012-12-16 H.J. Lu + + PR ld/14968 + * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Also check + local IFUNC references. + * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. + +2012-12-14 Tom Tromey + + * elf.c (elfcore_grok_note) : New case. + +2012-12-13 H.J. Lu + + PR ld/14956 + * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Check local + IFUNC calls. + * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. + +2012-12-10 Edgar E. Iglesias + + * reloc.c (MICROBLAZE): Document new relocations + * bfd-in2.h: Regenerated + * libbfd.h: Regenerated + * elf32-microblaze.c (microblaze_elf_howto_raw): Add TLS relocations + (microblaze_elf_reloc_type_lookup): Likewise + (elf32_mb_link_hash_entry): define TLS reference types + (elf32_mb_link_hash_table): add TLS Local dynamic GOT entry + #define has_tls_reloc if section has TLS relocs + (dtprel_base), (check_unique_offset): New + (microblaze_elf_output_dynamic_relocation): output simple + dynamic relocation into SRELOC. + (microblaze_elf_relocate_section): Accommodate TLS relocations. + (microblaze_elf_check_relocs): Likewise + (update_local_sym_info): New + (microblaze_elf_copy_indirect_symbol): Add tls_mask. + (allocate_dynrelocs): Handle TLS symbol + (microblaze_elf_size_dynamic_sections): Set size and offset + (microblaze_elf_finish_dynamic_symbol): Use + microblaze_elf_output_dynamic_relocation + +2012-12-09 H.J. Lu + + PR binutils/14933 + * archive.c (bsd_write_armap): Properly check indicies bigger + than 4Gb. + +2012-12-07 Alan Modra + + PR ld/14926 + * elf.c (_bfd_elf_map_sections_to_segments): Include elf header + size when determining phdr_in_segment. + +2012-12-06 Yufeng Zhang + + * elf64-aarch64.c (elf64_aarch64_grok_prstatus): New function. + (elf_backend_grok_prstatus): Define to elf64_aarch64_grok_prstatus. + +2012-12-06 Alan Modra + + * elfxx-mips.c (allocate_dynrelocs): Correct test for symbol + defined in a regular file to include common symbols. + +2012-12-05 Leif Ekblad + + * config.bfd: Add x86_64-*-rdos. + +2012-12-05 Alan Modra + + * elf64-ppc.c (build_plt_stub): Fix off by one error in branch + to glink. + +2012-12-03 Maciej W. Rozycki + + PR ld/10629 + * elfxx-mips.c (mips_elf_link_hash_table): Update comment for + use_rld_obj_head. + (_bfd_mips_elf_create_dynamic_sections): Always create a + .rld_map section if no __rld_obj_head symbol has been seen. + +2012-12-03 Maciej W. Rozycki + + * elf32-mips.c (mips_elf32_object_p): Return right away when the + ABI is not compatible. + * elfn32-mips.c (mips_elf_n32_object_p): Likewise. + +2012-12-03 Maciej W. Rozycki + + * elf32-tilepro.c (tilepro_elf_mkobject): New function. + (bfd_elf32_mkobject): New macro. + +2012-12-03 Maciej W. Rozycki + + * elf32-mips.c (bfd_elf32_mkobject): New macro. + * elf64-mips.c (bfd_elf64_mkobject): Likewise. + * elfn32-mips.c (bfd_elf32_mkobject): Likewise. + * elfxx-mips.h (_bfd_mips_elf_mkobject): New prototype. + * elfxx-mips.c (mips_elf_obj_tdata): New struct. + (mips_elf_tdata): New macro. + (_bfd_mips_elf_mkobject): New function. + (mips_elf_merge_obj_attributes): Report the originating input BFD + on attribute conflicts. + +2012-12-03 Maciej W. Rozycki + + * elfxx-mips.c (mips_elf_merge_obj_attributes): Correct messages + for the -mdouble-float and -msingle-float cases throughout; make + all the messages report the output file consistently on the + left-hand side. + +2012-11-29 Roland McGrath + + * elf-nacl.c (segment_eligible_for_headers): Disallow writable segments. + +2012-11-26 Roland McGrath + + * elf-nacl.c (nacl_modify_segment_map): Don't crash when INFO is null. + +2012-11-21 H.J. Lu + + PR binutils/14493 + * elf.c (copy_elf_program_header): When rewriting program + header, set the output maxpagesize to the maximum alignment + of input PT_LOAD segments. + +2012-11-21 Roland McGrath + + * elf-nacl.c (segment_nonexecutable_and_has_contents): Renamed to ... + (segment_eligible_for_headers): ... this. Take new arguments + MAXPAGESIZE and SIZEOF_HEADERS. Return false if the first section's + start address doesn't leave space for the headers. + (nacl_modify_segment_map): Update caller. + +2012-11-20 H.J. Lu + + PR ld/14862 + * elf-bfd.h (elf_link_hash_entry): Remove ref_dynamic_nonweak + added by accident. + (elf_link_add_object_symbols): Don't set nor check + ref_dynamic_nonweak. + +2012-11-20 Alan Modra + + * elf32-rx.c (rx_elf_print_private_bfd_data): Warning fix. + +2012-11-16 Joey Ye + + * elf32-arm.c (elf32_arm_final_link_relocate + ): Align address of + the place being relocated. + (elf32_arm_final_link_relocate, case R_ARM_THM_PC8): Align address + of the place being relocated and truncate addend. + (Pa): New macro. + +2012-11-14 Roland McGrath + + * elf32-arm.c (elf32_arm_nacl_plt0_entry): Use bic rather than bfc + instruction for data sandboxing. + +2012-11-14 Tristan Gingold + + * mach-o.c (bfd_mach_o_read_main) + (bfd_mach_o_read_source_version): New functions. + (bfd_mach_o_read_command): Handle BFD_MACH_O_LC_DATA_IN_CODE, + BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS, BFD_MACH_O_LC_MAIN, + BFD_MACH_O_LC_SOURCE_VERSION. + * mach-o.h (bfd_mach_o_main_command) + (bfd_mach_o_source_version_command): New types. + (bfd_mach_o_load_command): Add fields for these new types. + +2012-11-14 Tristan Gingold + + * mach-o.c (bfd_mach_o_canonicalize_one_reloc): Add a special + handling for non-scattered pairs. Update comments. + +2012-11-13 Joe Seymour + + * elf.c (rewrite_elf_program_header): Allocate elf_segment_map + with bfd_zalloc, instead of bfd_alloc. + +2012-11-09 Nick Clifton + + * Makefile.am (ALL_MACHINES): Add cpu-v850-rh850.lo. + (ALL_MACHINES_CFILES): Add cpu-v850-rh850.c. + * archures.c (bfd_arch_info): Add bfd_v850_rh850_arch. + * config.bfd: Likewise. + * configure.in: Add bfd_elf32_v850_rh850_vec. + * cpu-v850.c: Update printed description. + * cpu-v850_rh850.c: New file. + * elf32-v850.c (v850_elf_check_relocs): Add support for RH850 ABI + relocs. + (v850_elf_perform_relocation): Likewise. + (v850_elf_final_link_relocate): Likewise. + (v850_elf_relocate_section): Likewise. + (v850_elf_relax_section): Likewise. + (v800_elf_howto_table): New. + (v850_elf_object_p): Add support for RH850 ABI values. + (v850_elf_final_write_processing): Likewise. + (v850_elf_merge_private_bfd_data): Likewise. + (v850_elf_print_private_bfd_data): Likewise. + (v800_elf_reloc_map): New. + (v800_elf_reloc_type_lookup): New. + (v800_elf_reloc_name_lookup): New. + (v800_elf_info_to_howto): New. + (bfd_elf32_v850_rh850_vec): New. + (bfd_arch_v850_rh850): New. + * targets.c (_bfd_targets): Add bfd_elf32_v850_rh850_vec. + * Makefile.in: Regenerate. + * bfd-in2.h: Regenerate. + * configure: Regenerate. + + * elf32-rx.c (describe_flags): New function. Returns a buffer + containing a description of the E_FLAG_RX_... values set. + (rx_elf_merge_private_bfd_data): Use it. + (rx_elf_print_private_bfd_data): Likewise. + (elf32_rx_machine): Skip EF_RX_CPU_RX check. + (elf32_rx_special_sections): Define. + (elf_backend_special_sections): Define. + +2012-11-09 Edgar E. Iglesias + + * config.bfd: Add microblazeel-*-* + * configure.in: Likewise. + * configure: Regenerate. + * elf32-microblaze.c (microblaze_elf_relocate_section): Add endian awareness. + (microblaze_elf_merge_private_bfd_data): New. + (microblaze_bfd_write_imm_value_32): New. + (microblaze_bfd_write_imm_value_64): New. + (microblaze_elf_relax_section): Add endian awareness. + (microblaze_elf_add_symbol_hook): Define TARGET_LITTLE_NAME, + TARGET_LITTLE_SYM and bfd_elf32_bfd_merge_private_bfd_data. + * targets.c: Add bfd target bfd_elf32_microblazeel_vec. + +2012-11-09 H.J. Lu + + * aout-tic30.c (MY_final_link_callback): Remove trailing + redundant `;'. + * coff-h8500.c (extra_case): Likewise. + (bfd_coff_reloc16_get_value): Likewise. + * dwarf2.c (_bfd_dwarf2_cleanup_debug_info): Likewise. + * elf.c (_bfd_elf_slurp_version_tables): Likewise. + * elf32-frv.c (elf32_frv_relocate_section): Likewise. + * elf32-v850.c (v850_elf_perform_relocation): Likewise. + * opncls.c (bfd_calc_gnu_debuglink_crc32): Likewise. + * plugin.c (add_symbols): Likewise. + * reloc.c (bfd_check_overflow): Likewise. + * vms-lib.c (_bfd_vms_lib_archive_p): Likewise. + +2012-11-08 Tom Tromey + + * elf.c (elfcore_grok_note) : New case; make + pseudosection. + +2012-11-08 Alan Modra + + * aclocal.m4: Regenerate. + * Makefile.in: Regenerate. + * po/SRC-POTFILES.in: Regenerate. + +2012-11-07 H.J. Lu + + * section.c (bfd_get_section_contents): Replace memcpy + with memmove. + +2012-11-07 Hans-Peter Nilsson + + PR binutils/14481 + * aout-target.h (MY_close_and_cleanup): Make local function + instead of alias of MY_bfd_free_cached_info. Also call + _bfd_generic_close_and_cleanup. + +2012-11-06 H.J. Lu + + PR binutils/14813 + * bfdio.c (bfd_iovec): Change return type of bclose to + bfd_boolean. + (memory_bclose): Change return type to bfd_boolean. + * cache.c (cache_bclose): Likewise. + * opncls.c (opncls_bclose): Likewise. Return TRUE on success. + * vms-lib.c (vms_lib_bclose): Likewise. Return TRUE. + * libbfd.h: Regenerated. + +2012-11-06 Tristan Gingold + + * coff-x86_64.c (_bfd_generic_find_nearest_line_discriminator): + Define as coff_find_nearest_line_discriminator. + +2012-11-06 Alan Modra + + PR binutils/14567 + * opncls.c (opncls_iovec): Forward declare. + (_bfd_new_bfd_contained_in): If using opncls_iovec, copy iostream + to new bfd. + +2012-11-06 Alan Modra + + * mach-o.c (bfd_mach_o_close_and_cleanup): Don't call + _bfd_generic_close_and_cleanup for mach_o_fat archives. + +2012-11-06 Alan Modra + + * coff-tic4x.c (tic4x_coff0_vec, tic4x_coff0_beh_vec, + tic4x_coff1_vec, tic4x_coff1_beh_vec, tic4x_coff2_vec, + tic4x_coff2_beh_vec): Allow SEC_CODE and SEC_READONLY in + section flags. + * coff-ppc.c (TARGET_LITTLE_SYM): Likewise. + (TARGET_BIG_SYM): Likewise. + +2012-11-06 Alan Modra + + * elf64-ppc.c (struct ppc_link_hash_table): Add dot_toc_dot. + (ppc64_elf_size_stubs): Lookup ".TOC.". + (ppc64_elf_relocate_section): Resolve special symbol ".TOC.". + +2012-11-06 Alan Modra + + * elf64-ppc.c (maybe_strip_output): Heed SEC_KEEP. + +2012-11-05 Andreas Krebbel + + PR target/14788 + * elf32-s390.c (elf_s390_relocate_section): Set elf.dynobj for + local ifunc symbols. + * elf64-s390.c (elf_s390_relocate_section): Likewise. + +2012-11-05 Alan Modra + + * configure.in: Apply 2012-09-10 change to config.in here. + +2012-11-05 Alan Modra + + * elf64-ppc.c (ppc64_elf_edit_toc): Clear "repeat" inside + loop. Really mark toc entry referring to another toc entry + only if the first is used. + +2012-10-30 H.J. Lu + + * configure.in: Also handle --enable-64-bit-bfd when setting + CORE_HEADER for 'i[3-7]86-*-linux-*'. + +2012-10-30 Steve McIntyre + + * elf32-arm.c (elf32_arm_print_private_bfd_data): Recognise and + display the new ARM hard-float/soft-float ABI flags for EABI_VER5 + (elf32_arm_post_process_headers): Add the hard-float/soft-float + ABI flag as appropriate for ET_DYN/ET_EXEC in EABI_VER5. + +2012-10-30 Yao Qi + H.J. Lu + + * configure.in: Set CORE_HEADER to hosts/x86-64linux.h for + 'i[3-7]86-*-linux-*' if x86_64-*linux is enabled. + * configure: Regenerated. + + * elf64-x86-64.c (elf_x86_64_write_core_note): Replace type + 'prpsinfo_t' and 'prstatus_t' with 'prpsinfo64_t' and + 'prstatus64_t' respectively. + + * hosts/x86-64linux.h (a8_uint64_t): New. + (user_regsx32_struct): Renamed to ... + (user_regs64_struct): This. Replace uint64_t with a8_uint64_t. + (elf_gregx32_t): Renamed to ... + (elf_greg64_t): This. Replace uint64_t with a8_uint64_t. + (ELF_NGREGX32): Removed. + (ELF_NGREG64): New. + (elf_gregx32_t): Removed. + (elf_greg64_t): New. + (struct prstatus64_timeval): New. + (elf_prstatusx32): Replace elf_gregsetx32_t with elf_gregset64_t. + (elf_prstatus64): New. + (elf_prpsinfo64): New. + (prstatus64_t, prpsinfo64_t): New typedef. + +2012-10-29 Sean Keys + + * elf32-xgate.c(elf_xgate_howto_table): Fix src and dest mask for + R_XGATE_16 + +2012-10-29 Alan Modra + + * elf32-ppc.c (ppc_elf_howto_raw): Correct dst_mask in + R_PPC_VLE_LO16A, R_PPC_VLE_HI16A, R_PPC_VLE_HA16A, + R_PPC_VLE_SDAREL_LO16A, R_PPC_VLE_SDAREL_HI16A, + R_PPC_VLE_SDAREL_HA16A reloc howtos. + +2012-10-26 Nick Clifton + + * po/uk.po: Updated Ukranian translation. + +2012-10-26 Alan Modra + + PR target/14758 + * elf32-ppc.c (ppc_elf_reloc_type_lookup): Decode ppc64 _DS + bfd_reloc values. Map to corresponding D-form relocs. + (is_insn_ds_form, is_insn_qs_form): New functions. + (ppc_elf_relocate_section): Validate insn with DS-form or DQ-form + fields using D-form reloc. + +2012-10-25 H.J. Lu + + * elf32-i386.c (elf_i386_size_dynamic_sections): Replace + _GLOBAL_OFFSET_TABLE_ lookup with htab->elf.hgot. + * elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Likewise. + +2012-10-24 H.J. Lu + + * compress.c (bfd_is_section_compressed): Don't decompress the + section. + +2012-10-23 Nathan Sidwell + + * bfd-in.h (bfd_elf_stack_segment_size): Declare. + * bfd-in2.h: Rebuilt. + * elfxx-target.h (elf_backend_stack_align): New. + (elfNN_bed): Add it. + * elf-bfd.h (struct elf_backend_data): Add stack_align field. + * elf.c (bfd_elf_map_sections_to_segments): Pay attention to + stack_align and stacksize for PT_GNU_STACK segment. + (assign_file_positions_for_non_load_sections): Set p_memsz for + PT_GNU_STACK segment. + (copy_elf_program_header): Copy PT_GNU_STACK size. + * elflink.c (bfd_elf_stack_segment_size): New function, taken from + uclinux backends. + (bfd_elf_size_dynamic_sections): Determine + PT_GNU_STACK requirements after calling backend. Pay attention to + stacksize. + * elf32-bfin.c (elf32_bfinfdpic_always_size_sections): Call + bfd_elf_stack_segment_size. + (elf32_bfinfdpic_modify_program_headers): Delete. + (elf32_bfingfdpic_copy_private_bfd_data): Don't copy PT_GNU_STACK + here. + (elf_backend_stack_align): Override. + (elf_backend_modify_program_headers): Don't override. + * elf32-frv.c (frvfdpic_always_size_sections): Call + bfd_elf_stack_segment_size. + (elf32_frvfdpic_modify_program_headers): Delete. + (elf32_frvfdpic_copy_private_bfd_data): Don't copy PT_GNU_STACK + here. + (elf_backend_stack_align): Override. + (elf_backend_modify_program_headers): Don't override. + * elf32-lm32.c (lm32_elf_always_size_sections): Leave + PT_GNU_STACK creation to underlying elf support. Check + __stacksize here for backwards compatibility, and set it if + needed. + (lm32_elf_modify_segment_map): Delete. + (lm32_elf_modify_program_headers): Delete. + (elf_backend_stack_align): Override. + (elf_backend_modify_segment_map): Don't override. + (elf_backend_modify_program_headers): Don't override. + * elf32-sh.c (sh_elf_always_size_sections): Call + bfd_elf_stack_segment_size. + (sh_elf_modify_program_headers): Delete. + (sh_elf_copy_private_data): Don't copy PT_GNU_STACK + here. + (elf_backend_stack_align): Override. + (elf_backend_modify_program_headers): Don't override. + * elf32-tic6x.c (elf32_tic6x_always_size_sections): Call + bfd_elf_stack_segment_size. + (elf32_tic6x_modify_program_headers): Delete. + (elf32_tic6x_copy_private_data): Delete. + (elf_backend_stack_align): Override. + (bfd_elf32_bfd_copy_private_bfd_data): Don't override. + (elf_backend_modify_program_headers): Don't override. + +2012-10-22 Alan Modra + + * cache.c (cache_bmmap): Don't use void* arithmetic. + +2012-10-21 Alan Modra + + * compress.c (bfd_cache_section_contents): New function. + * bfd-in2.h: Regenerate. + +2012-10-21 Hans-Peter Nilsson + + * linker.c (_bfd_generic_link_output_symbols): Handle a + no-longer-global symbol entered through a plugin. + +2012-10-20 Alan Modra + + * compress.c: Reinstate 2012-10-19 change. + (bfd_get_full_section_contents): Don't free unless we alloc. + Use proper decompress size. Delete some vars, rename others. + +2012-10-19 Tom Tromey + + * compress.c: Revert previous patch. + +2012-10-19 Tom Tromey + + * compress.c (bfd_get_full_section_contents): Don't cache + decompressed contents. + +2012-10-18 Kai Tietz + + PR binutils/14067 + * coff-i386.c (bfd_target): Add section flag SEC_EXCLUDE. + Allow BFD_COMPRESS and BFD_DECOMPRESS flags. + * coff-x86_64.c: Likewise. + * coffcode.h (DOT_ZDEBUG): New define. + (sec_to_styp_flags): Check for .zdebug. + (styp_to_sec_flags): Likewise. + * coffgen.c (make_a_section): Handle .debug_* section + compression/decompression flags. + * cofflink.c (mark_relocs): Ignore relocations + for a section, which isn't marked as used. + (_bfd_coff_link_input_bfd): Add support of compressed + debug sections. + * compress.c (decompress_contents): Loop as long + as there is input available and there is room for + output. + * bfd/pe-arm.c: Add .zdebug_ partial match entry. + * pe-i386.c: Likewise. + * pe-x86_64.c: Likewise. + * peXXigen.c (_bfd_XXi_swap_aouthdr_out): Don't clear all + data-directories as this might destroy content. + + * coff-i386.c (_bfd_generic_find_nearest_line_discriminator): + define as coff_find_nearest_line_discriminator. + * libcoff-in.h (coff_find_nearest_line_discriminator): New + * libcoff.h: Regenerated. + * coff-x86_64.c: Likewise. + * coffgen.c (coff_find_nearest_line_discriminator): New function. + prototype. + +2012-10-16 Joel Brobecker + + * coff64-rs6000.c (rs6000coff64_vec): Set _close_and_cleanup + field to _bfd_archive_close_and_cleanup. + (aix5coff64_vec): Likewise. + +2012-10-16 Joel Brobecker + + * coff-rs6000.c (rs6000coff_vec): Set _close_and_cleanup + field to _bfd_archive_close_and_cleanup. + (pmac_xcoff_vec): Likewise. + +2012-10-16 Sofiane Naci + + * elf64-aarch64.c (elf64_aarch64_tls_howto_table): Fix shift value for + R_AARCH64_TLSIE_LD_GOTTPREL_PREL19, R_AARCH64_TLSLE_MOVW_TPREL_G2, + R_AARCH64_TLSLE_MOVW_TPREL_G1, R_AARCH64_TLSLE_MOVW_TPREL_G1_NC, + R_AARCH64_TLSLE_ADD_TPREL_HI12. + (elf64_aarch64_tlsdesc_howto_table): Fix shift value for + R_AARCH64_TLSDESC_LD64_PREL19 and R_AARCH64_TLSDESC_OFF_G1. + (elf64_aarch64_final_link_relocate): Add signed_addend when resolving + AARCH64_TLSLE_*_TPREL_* relocations. + +2012-10-16 Alan Modra + + * elf32-xtensa.c (free_section_cache): Renamed from + clear_section_cache. Don't zero cache. + (section_cache_section): Remove ineffectual zero of cache. + Call init_section_cache instead. + +2012-10-15 Doug Evans + + * elf.c (special_sections_d): Add comment. + +2012-10-13 H.J. Lu + + * Makefile.am (LIBDL): Replace -ldl with @lt_cv_dlopen_libs@. + * configure.in (lt_cv_dlopen_libs): AC_SUBST. + * Makefile.in: Regenerated. + * configure: Likewise. + +2012-10-08 Alan Modra + + PR binutils/14662 + * elf.c (_bfd_elf_make_section_from_shdr): Treat .gdb_index as + SEC_DEBUGGING. + +2012-09-20 Walter Lee + + * elf32-tilepro.c (tilepro_elf_relocate_section): Adjust got + relocations with value of hgot. + * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. + +2012-09-19 Steve Ellcey + + * config.bfd: Add mips*-mti-elf* target. + +2012-09-18 H.J. Lu + + PR ld/14591 + * elf-bfd.h (_bfd_elf_merge_symbol): Add an argument to return + if the old symbol is weak. + + * elf32-sh-symbian.c (sh_symbian_relocate_section): Update + _bfd_elf_merge_symbol call. + + * elflink.c (_bfd_elf_merge_symbol): Add an argument to return + if the old symbol is weak. + (_bfd_elf_add_default_symbol): Update _bfd_elf_merge_symbol + call. + (elf_link_add_object_symbols): Don't update symbol type from a + weak definition. Update symbol type from a common symbol when + overriding a weak symbol. + +2012-09-17 H.J. Lu + + * elf32-i386.c (elf_i386_convert_mov_to_lea): Ignore discarded + section. + * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. + +2012-09-17 H.J. Lu + + * elf32-i386.c (elf_i386_finish_dynamic_symbol): Replace return + FALSE with abort. + * elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Likewise. + +2012-09-17 Walter Lee + + * elf32-tilepro.c (tilepro_elf_relocate_section): Remove unused + got_base variable. + * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. + +2012-09-17 Walter Lee + + * elf32-tilepro.c (tilepro_elf_relocate_section): Fix computation + of got relocations for when .got.plt section is merged with .got. + * elfxx-tilegx.c (tilegx_elf_relocate_section): Ditto. + +2012-09-14 David Edelsohn + + * configure: Regenerate. + +2012-09-13 Anthony Green + + * targets.c (bfd_elf32_bigmoxie_vec, bfd_elf32_littlemoxie_vec): + Define. + (bfd_elf32_moxie_vec): Remove. + * config.bfd, configure.in: Add bi-endian support for moxie. + * configure: Rebuilt. + * elf32-moxie.c (TARGET_LITTLE_NAME, TARGET_LITTLE_SYM): Define. + (TARGET_BIG_NAME, TARGET_BIG_SYM): Update for bi-endian support. + +2012-09-12 Doug Kwan + + * elf64-ppc.c (ppc64_elf_relocate_section): Use pre-adjusted + relocation for stub lookup. + +2012-09-12 Chris Schlumberger-Socha + + * bfd-in2.h: Regenerated. + * elf64-aarch64.c + (elf64_aarch64_howto_table): Add R_AARCH64_GOT_LD_PREL19 reloc to HOWTO. + (elf64_aarch64_reloc_map): Add reloc entry. + (aarch64_resolve_relocation): Likewise. + (bfd_elf_aarch64_put_addend): Likewise. + (aarch64_reloc_got_type): Likewise. + (elf64_aarch64_final_link_relocate): Likewise. + (lf64_aarch64_check_relocs): Likewise. + (elf64_aarch64_check_relocs): New case for R_AARCH64_ADR_PREL_LO21 + reloc. + * libbfd.h: Regenerated. + * reloc.c (R_AARCH64_GOT_LD_PREL19): New reloc. + +2012-09-10 Matthias Klose + + * config.in: Disable sanity check for kfreebsd. + +2012-09-10 H.J. Lu + + * configure: Regenerated. + +2012-09-04 Sergey A. Guriev + + * cpu-ia64-opc.c (ins_cnt6a): New function. + (ext_cnt6a): Ditto. + (ins_strd5b): Ditto. + (ext_strd5b): Ditto. + (elf64_ia64_operands): Add new operand types. + +2012-09-04 H.J. Lu + + PR binutils/14493 + * elf.c (ignore_section_sym): Also ignore section symbols without + a BFD section. + +2012-09-03 Andreas Krebbel + + * elf32-s390.c (elf_s390_relocate_section): Handle PLTOFF for + local and global ifunc symbols. + * elf64-s390.c (elf_s390_relocate_section): Likewise. + +2012-09-02 H.J. Lu + + * elf-bfd.h (elf_link_hash_table): Add hdynamic for the + _DYNAMIC symbol. + + * elflink.c (_bfd_elf_link_create_dynamic_sections): Set + hdynamic. + + * elf-m10300.c (_bfd_mn10300_elf_finish_dynamic_symbol): Check + hdynamic instead of "_DYNAMIC". + * elf32-arm.c (elf32_arm_finish_dynamic_symbol): Likewise. + * elf32-cr16.c (elf32_arm_finish_dynamic_symbol): Likewise. + * elf32-cris.c (elf_cris_finish_dynamic_symbol): Likewise. + * elf32-hppa.c (elf32_hppa_finish_dynamic_symbol): Likewise. + * elf32-i386.c (elf_i386_convert_mov_to_lea): Likewise. + * elf32-lm32.c (lm32_elf_finish_dynamic_symbol): Likewise. + * elf32-m32r.c (m32r_elf_finish_dynamic_symbol): Likewise. + * elf32-s390.c (elf_s390_finish_dynamic_symbol): Likewise. + * elf32-sh.c (sh_elf_finish_dynamic_symbol): Likewise. + * elf32-tic6x.c (elf32_tic6x_finish_dynamic_symbol): Likewise. + * elf32-tilepro.c (tilepro_elf_finish_dynamic_symbol): Likewise. + * elf32-vax.c (elf_vax_finish_dynamic_symbol): Likewise. + * elf32-xtensa.c (elf_xtensa_finish_dynamic_symbol): Likewise. + * elf64-aarch64.c elf64_aarch64_finish_dynamic_symbol(): Likewise. + * elf64-alpha.c (elf64_alpha_finish_dynamic_symbol): Likewise. + * elf64-ia64-vms.c (elf64_ia64_finish_dynamic_symbol): Likewise. + * elf64-s390.c (elf_s390_finish_dynamic_symbol): Likewise. + * elf64-sh64.c (sh64_elf64_finish_dynamic_symbol): Likewise. + * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. + * elfnn-ia64.c (elfNN_ia64_finish_dynamic_symbol): Likewise. + * elfxx-mips.c (_bfd_mips_elf_finish_dynamic_symbol): Likewise. + * elfxx-sparc.c (_bfd_sparc_elf_finish_dynamic_symbol): Likewise. + * elfxx-tilegx.c (tilegx_elf_finish_dynamic_symbol): Likewise. + + * elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol): Check + hdynamic, hgot, hplt instead of _DYNAMIC, _GLOBAL_OFFSET_TABLE_, + _PROCEDURE_LINKAGE_TABLE_. + * elf32-score.c (s3_bfd_score_elf_finish_dynamic_symbol): Likewise. + * elf32-score7.c (s7_bfd_score_elf_finish_dynamic_symbol): Likewise. + +2012-08-31 H.J. Lu + + * elf32-i386.c (elf_i386_convert_mov_to_lea): Don't optimize + _DYNAMIC. + * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): Likewise. + +2012-08-31 H.J. Lu + + * elf32-i386.c (elf_i386_convert_mov_to_lea): New. + (elf_i386_size_dynamic_sections): Use it on input sections. + (elf_i386_relocate_section): Don't convert + "mov foo@GOT(%reg), %reg" to "lea foo@GOTOFF(%reg), %reg" + for local symbols here. + + * elf64-x86-64.c (elf_x86_64_convert_mov_to_lea): New. + (elf_x86_64_size_dynamic_sections): Use it on input sections. + (elf_x86_64_relocate_section): Don't convert + "mov foo@GOTPCREL(%rip), %reg" to "lea foo(%rip), %reg" + for local symbols here. + +2012-08-30 H.J. Lu + + * elf32-i386.c (elf_i386_relocate_section): Convert + "mov foo@GOT(%reg), %reg" to "lea foo@GOTOFF(%reg), %reg" + for local symbols. + + * elf64-x86-64.c (elf_x86_64_relocate_section): Convert + "mov foo@GOTPCREL(%rip), %reg" to "lea foo(%rip), %reg" + for local symbols. + +2012-08-31 Alan Modra + + PR ld/14464 + * elf64-ppc.c (ppc64_elf_relocate_section): Map symbols defined + by a linker script in .opd to corresponding input .opd section. + +2012-08-28 Maciej W. Rozycki + + * elf32-ppc.c (ppc_elf_relocate_section): Assert that dynindx is + not minus one. + * elf64-ppc.c (ppc64_elf_relocate_section): Likewise. + +2012-08-28 Maciej W. Rozycki + + * elflink.c (_bfd_elf_merge_symbol): Also override the version + a dynamic symbol defaulted to if preempted with a hidden or + internal definition. + +2012-08-28 Walter Lee + + * elf32-tilepro.c (allocate_dynrelocs): Use PLT_ENTRY_SIZE as size + of header. + (tilepro_plt_entry_build): Account for new header size. + (tilepro_elf_finish_dynamic_sections): Ditto. + (tilepro_elf_plt_sym_val): Ditto. + * elfxx-tilegx.c (allocate_dynrelocs): Use PLT_ENTRY_SIZE as size + of header + tail. + (tilegx_elf_finish_dynamic_sections): Account for new padding. + +2012-08-27 Walter Lee + + * reloc.c (Add BFD_RELOC_TILEGX_IMM16_X0_HW0_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW0_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW1_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW1_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW2_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW2_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW3_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW3_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_PLT_PCREL, + BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_PLT_PCREL): new relocations. + * elfxx-tilegx.c (tilegx_elf_howto_table): Handle new relocations. + (tilegx_reloc_map): Ditto. + (reloc_to_create_func): Ditto. + (tilegx_elf_check_relocs): Ditto. + (tilegx_elf_gc_sweep_hook): Ditto. + (tilegx_elf_relocate_section): Ditto. + * libbfd.h: Regenerate. + * bfd-in2.h: Regenerate. + +2012-08-24 Matthew Gretton-Dann + + * elf32-arm.c (v8): New array. + (tag_cpu_arch_combine): Add support for ARMv8 attributes. + (elf32_arm_merge_eabi_attributes): Likewise. + (VFP_VERSION_COUNT): New define. + +2012-08-20 Tom Tromey + + * vms-lib.c (_bfd_vms_lib_get_module): Use bfd_zmalloc for + areltdata. + * opncls.c (_bfd_delete_bfd): Free arelt_data. + * mach-o.c (bfd_mach_o_fat_member_init): Use bfd_zmalloc for + areltdata. + * ecoff.c (_bfd_ecoff_slurp_armap): Use free for mapdata. + * coff-rs6000.c (_bfd_xcoff_read_ar_hdr): Use bfd_zmalloc for + areltdata. + (xcoff_write_archive_contents_old): Likewise. + (xcoff_write_archive_contents_big): Likewise. + * archive64.c (bfd_elf64_archive_slurp_armap): Use free for + areltdata. + * archive.c (_bfd_generic_read_ar_hdr_mag): Use bfd_zmalloc and + free for areltdata. + (_bfd_get_elt_at_filepos): Likewise. Clear n_nfd->arelt_data on + failure. + (do_slurp_bsd_armap): Use bfd_zmalloc and free for areltdata. + (do_slurp_coff_armap): Likewise. + (_bfd_slurp_extended_name_table): Likewise. + (bfd_slurp_bsd_armap_f2): Likewise. Don't leak 'mapdata'. + +2012-08-17 Nick Clifton + + * po/vi.po: Updated Vietnamese translation. + +2012-08-17 Yuri Chornoivan + + * elf-bfd.h, * elf32-ppc.c, * elf64-ia64-vms.c, * elfnn-ia64.c, + * elfxx-mips.c, * vms-alpha.c: Typo fixes. + +2012-08-17 Alan Modra + + PR binutils/14475: + * archive.c (bfd_ar_hdr_from_filesystem): Revert last change. + Instead malloc areltdata. + +2012-08-16 Tom Tromey + + PR binutils/14475: + * archive.c (bfd_ar_hdr_from_filesystem): Allocate areltdata on + 'member' BFD. Don't try to free 'ared'. + +2012-08-14 Nick Clifton + + * po/uk.po: Updated Ukranian translation. + +2012-08-13 Maciej W. Rozycki + + * elfxx-mips.c (_bfd_mips_elf_size_dynamic_sections): Look up + the options section in the output rather than input BFD to + decide if to add a DT_MIPS_OPTIONS tag. + +2012-08-13 Maciej W. Rozycki + + * config.bfd: Wrap mips*el-*-linux* and mips*-*-linux* into + #ifdef BFD64. + +2012-08-13 Ian Bolton + Laurent Desnogues + Jim MacArthur + Marcus Shawcroft + Nigel Stephens + Ramana Radhakrishnan + Richard Earnshaw + Sofiane Naci + Tejas Belagod + Yufeng Zhang + + * Makefile.am: Add AArch64 files. + * Makefile.in: Regenerate. + * archures.c (bfd_aarch64_arch): New declaration. + (bfd_archures_list): Use bfd_archures_list. + * bfd-in.h (bfd_elf64_aarch64_init_maps): New declaration. + (bfd_aarch64_process_before_allocation): New declaration. + (bfd_elf64_aarch64_process_before_allocation): New declaration. + (bfd_elf64_aarch64_set_options): New declaration. + (bfd_elf64_aarch64_add_glue_sections_to_bfd): New declaration. + (BFD_AARCH64_SPECIAL_SYM_TYPE_MAP): New definition. + (BFD_AARCH64_SPECIAL_SYM_TYPE_TAG): New definition. + (BFD_AARCH64_SPECIAL_SYM_TYPE_OTHER): New definition. + (BFD_AARCH64_SPECIAL_SYM_TYPE_ANY): New definition. + (bfd_is_aarch64_special_symbol_name): New declaration. + (bfd_aarch64_merge_machines): New declaration. + (bfd_aarch64_update_notes): New declaration. + (int bfd_aarch64_get_mach_from_notes): New declaration. + (elf64_aarch64_setup_section_lists): New declaration. + (elf64_aarch64_next_input_section): New declaration. + (elf64_aarch64_size_stubs): New declaration. + (elf64_aarch64_build_stubs): New declaration. + * config.bfd: Add AArch64. + * configure.in: Add AArch64. + * configure: Regenerate. + * cpu-aarch64.c: New file. + * elf-bfd.h: Add AArch64. + * bfd-in2.h: Regenerate. + * libbfd.h: Regenerate. + * elf64-aarch64.c: New file. + * reloc.c: Add AArch64 relocations. + * targets.c: Add AArch64. + * po/SRC-POTFILES.in: Regenerate. + +2012-08-13 Maciej W. Rozycki + + * elfxx-mips.c (mips_elf_calculate_relocation): Fix the handling + of protected symbols. + +2012-08-10 Alan Modra + + PR binutils/14444 + * elf.c (IS_VALID_GROUP_SECTION_HEADER) Add minsize param. + (setup_group): Adjust uses. + (bfd_section_from_shdr): Allow SHT_GROUP sections with just a flag + word. + +2012-08-09 Nick Clifton + + * po/vi.po: Updated Vietnamese translation. + +2012-08-09 Maciej W. Rozycki + + * elfxx-mips.c (LA25_LUI_MICROMIPS_1, LA25_LUI_MICROMIPS_2): + Remove macros, folding them into... + (LA25_LUI_MICROMIPS): ... this new macro. + (LA25_J_MICROMIPS_1, LA25_J_MICROMIPS_2): Likewise into... + (LA25_J_MICROMIPS): ... this new macro. + (LA25_ADDIU_MICROMIPS_1, LA25_ADDIU_MICROMIPS_2): Likewise + into... + (LA25_ADDIU_MICROMIPS): ... this new macro. + (bfd_put_micromips_32, bfd_get_micromips_32): New functions. + (mips_elf_create_la25_stub): Use them. + (check_br32_dslot, check_br32, check_relocated_bzc): Likewise. + (_bfd_mips_elf_relax_section): Likewise. + +2012-08-09 Alan Modra + Tom Tromey + + * archive.c (SECTION Archives): Update documentation. + (_bfd_delete_archive_data): Remove. + (_bfd_add_bfd_to_archive_cache): Set 'parent_cache' and 'key'. + (archive_close_worker, _bfd_archive_close_and_cleanup): New + functions. + * libbfd-in.h (struct areltdata ): New fields. + (_bfd_delete_archive_data): Don't declare. + (_bfd_archive_close_and_cleanup): Declare. + (_bfd_generic_close_and_cleanup): Redefine. + * libbfd.h: Rebuild. + * opncls.c (_bfd_delete_bfd): Don't call _bfd_delete_archive_data. + (bfd_close): Don't close nested thin archives here. + +2012-08-07 Tom Tromey + + * archive.c (_bfd_delete_archive_data): New function. + * libbfd-in.h (_bfd_delete_archive_data): Declare. + * libbfd.h: Rebuild. + * opncls.c (_bfd_delete_bfd): Call _bfd_delete_archive_data. + +2012-08-07 Nick Clifton + + * po/uk.po: Updated Ukranian translation. + +2012-08-06 Maciej W. Rozycki + + * elflink.c (bfd_elf_record_link_assignment): Remove --defsym + symbols special case. + +2012-08-05 Maciej W. Rozycki + + * elf32-vax.c (elf_vax_adjust_dynamic_symbol): Don't allocate + PLT slots for local symbols. + +2012-08-03 Maciej W. Rozycki + + * elf64-mips.c (mips16_elf64_howto_table_rela): Correct src_mask + field initializers throughout. + * elfn32-mips.c (elf_mips16_howto_table_rela): Likewise. + +2012-08-03 Maciej W. Rozycki + + * elfxx-mips.c (mips_elf_perform_relocation): Update the + cross-mode jump message. + +2012-08-03 Maciej W. Rozycki + + * elfxx-mips.c (_bfd_mips_elf_size_dynamic_sections): Update the + comment on DT_MIPS_RLD_MAP. + +2012-08-03 Tom Tromey + + * opncls.c (_bfd_delete_bfd): Now static. + * libbfd-in.h (_bfd_delete_bfd): Don't declare. + * libbfd.h: Rebuild. + +2012-08-02 Sean Keys + + * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Modified + conditional statment to allow suppression of mismatched bank + warning. + +2012-08-01 Alan Modra + + * dwarf2.c (struct dwarf2_debug): Add close_on_cleanup. + (_bfd_dwarf2_slurp_debug_info): Set close_on_cleanup if we open + gnu_debuglink bfd. + (_bfd_dwarf2_cleanup_debug_info): Act on close_on_cleanup. + +2012-07-30 Nick Clifton + + * po/bfd.pot: Updated template. + * po/es.po: Updated Spanish translation. + * po/fi.po: Updated Finnish translation. + * po/fr.po: Updated French translation. + * po/ru.po: Updated Russian translation. + * po/uk.po: Updated Ukranian translation. + +2012-07-27 Mike Frysinger + + * configure.in (AC_INIT): Call with the args bfd and 2.22.52. + (AM_INIT_AUTOMAKE): Remove args. + * configure: Regenerate. + +2012-07-27 Andreas Krebbel + + * cpu-s390.c (bfd_s390_64_arch, bfd_s390_arch): Pick the default + arch depending on the target size. + +2012-07-27 Tristan Gingold + + * configure.in: Bump version to 2.23.51 + * configure: Regenerate. + +2012-07-26 Teresa Johnson + + * bfd/dwarf2.c (find_line): Initialize discriminator_ptr + if it is non-NULL. + +2012-07-26 Meador Inge + Nick Clifton + + PR ld/14397 + * elf32-arm.c (elf32_arm_finish_dynamic_sections): Report an error + if a required section is missing from the linker script. + +2012-07-24 Jan Waclawek + PR 13899 + * elf32-avr.c (elf32_avr_relax_delete_bytes): Call + _bfd_elf_link_read_relocs with keep_memory as TRUE. + +2012-07-24 Teresa Johnson + + * bfd.c (bfd_find_nearest_line_discriminator): New macro. + * coff-rs6000.c: Init _bfd_find_nearest_line_discriminator. + * coff64-rs6000.c: Likewise. + * dwarf2.c (struct line_info): Add discriminator field. + (add_line_info): Fill in new discriminator field. + (decode_line_info): Record discriminator information instead + of ignoring it. + (lookup_address_in_line_info_table): Return discriminator field if + requested. + (comp_unit_find_nearest_line): Add discriminator argument. + (find_line): Likewise. + (_bfd_dwarf2_find_nearest_line): Likewise. + (_bfd_dwarf2_find_line): Likewise. + * elf-bfd.h (_bfd_elf_find_nearest_line_discriminator): New. + (_bfd_elf_find_line_discriminator): Likewise. + (_bfd_generic_find_nearest_line_discriminator): Likewise. Defined. + * elf.c (_bfd_elf_find_nearest_line): Change to a wrapper + that invokes _bfd_elf_find_nearest_line_discriminator with correct + arguments. + (_bfd_elf_find_nearest_line_discriminator): New. + (_bfd_elf_find_line): Change to a wrapper + that invokes _bfd_elf_find_line_discriminator with correct + arguments. + (_bfd_elf_find_line_discriminator): New. + * coffgen.c (coff_find_nearest_line_with_names): Handle + new discriminator argument. + * elf32-arm.c (elf32_arm_find_nearest_line): Likewise. + * elf64-alpha.c (elf64_alpha_find_nearest_line): Likewise. + * elfxx-mips.c (_bfd_mips_elf_find_nearest_line): Likewise. + * mach-o.c (bfd_mach_o_find_nearest_line): Likewise. + * libbfd-in.h (_bfd_dwarf2_find_nearest_line): Add discriminator + argument. + (_bfd_dwarf2_find_line): Likewise. + (_bfd_generic_find_nearest_line_discriminator): New. + * libbfd.c (_bfd_generic_find_nearest_line_discriminator): New. + * bfd-in2.h: Regenerated. + * libbfd.h: Likewise. + * targets.c (BFD_JUMP_TABLE_SYMBOLS): Initialize + _bfd_find_nearest_line_discriminator with + _bfd_generic_find_nearest_line_discriminator. + (bfd_target): Add _bfd_find_nearest_line_discriminator. + +2012-07-24 Sean Keys + + * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Added code + that enables the linker to offset addresses, when linking against + symbols from the XGATE processor and vice versa. + +2012-07-23 Nick Clifton + + * cisco-core.c (cisco_core_file_failing_command): Make static. + (cisco_core_file_failing_signal): Make static. + +2012-07-18 H.J. Lu + + * bfd-in2.h: Regenerated. + +2012-07-18 Nicolàs Alejandro Di Risio + + PR binutils/14335 + * section.c: Fix a typo in comments. + +2012-07-13 Andreas Krebbel + + * elf64-s390.c: Include elf-s390-common.c. + (R_390_IRELATIVE): New reloc. + (elf_s390_reloc_type_lookup): Support R_390_IRELATIVE. + (RELA_ENTRY_SIZE): New macro. + (elf_s390_link_hash_entry): New fields ifunc_resolver_address and + *ifunc_resolver_section. + (struct plt_entry): New struct. + (struct elf_s390_obj_tdata): New field local_plt. + (elf_s390_local_plt): New macro. + (struct elf_s390_link_hash_table): New field irelifunc. + (ELF64): New macro. + (link_hash_newfunc): Initialize new fields. + (elf_s390_check_relocs): Handle IFUNC symbols. + (elf_s390_adjust_dynamic_symbol): Don't do anything for IFUNC + symbols. + (allocate_dynrelocs): Call s390_elf_allocate_ifunc_dyn_relocs for + IFUNC symbols. + (elf_s390_size_dynamic_sections): Handle IFUNC symbols. + (elf_s390_relocate_section): Likewise. + (elf_s390_finish_dynamic_symbol): Likewise. + (elf_s390_finish_dynamic_sections): Handle local IFUNC symbols. + (elf_s390_finish_ifunc_symbol): New function. + (elf_s390_gc_sweep_hook): Handle local plt entries. + (elf_backend_add_symbol_hook): Define. + * elf32-s390.c: See elf64-s390.c changes. + * elf-s390-common.c: New file. + * bfd-in2.h (BFD_RELOC_390_IRELATIVE): New enum field. + * libbfd.h (BFD_RELOC_390_IRELATIVE): New entry for + BFD_RELOC_390_IRELATIVE. + * reloc.c (BFD_RELOC_390_IRELATIVE): Document new relocation. + +2012-07-13 Nick Clifton + + * aix386-core.c: Remove use of PTR and PARAMS macros. + * archive.c: Likewise. + * cache.c: Likewise. + * cisco-core.c: Likewise. + * coff-alpha.c: Likewise. + * coff-apollo.c: Likewise. + * coff-aux.c: Likewise. + * coff-h8300.c: Likewise. + * coff-h8500.c: Likewise. + * coff-i386.c: Likewise. + * coff-i960.c: Likewise. + * coff-ia64.c: Likewise. + * coff-m68k.c: Likewise. + * coff-m88k.c: Likewise. + * coff-mcore.c: Likewise. + * coff-mips.c: Likewise. + * coff-or32.c: Likewise. + * coff-ppc.c: Likewise. + * coff-rs6000.c: Likewise. + * coff-sh.c: Likewise. + * coff-sparc.c: Likewise. + * coff-stgo32.c: Likewise. + * coff-tic30.c: Likewise. + * coff-tic4x.c: Likewise. + * coff-tic54x.c: Likewise. + * coff-tic80.c: Likewise. + * coff-w65.c: Likewise. + * cofflink.c: Likewise. + * cpu-arc.c: Likewise. + * cpu-cris.c: Likewise. + * cpu-h8500.c: Likewise. + * cpu-i960.c: Likewise. + * cpu-msp430.c: Likewise. + * cpu-ns32k.c: Likewise. + * cpu-powerpc.c: Likewise. + * cpu-rs6000.c: Likewise. + * cpu-tic4x.c: Likewise. + * cpu-w65.c: Likewise. + * ecoff.c: Likewise. + * ecofflink.c: Likewise. + * elf-m10200.c: Likewise. + * elf32-bfin.c: Likewise. + * elf32-cris.c: Likewise. + * elf32-crx.c: Likewise. + * elf32-fr30.c: Likewise. + * elf32-frv.c: Likewise. + * elf32-h8300.c: Likewise. + * elf32-i960.c: Likewise. + * elf32-m32c.c: Likewise. + * elf32-m68hc11.c: Likewise. + * elf32-m68hc12.c: Likewise. + * elf32-m68hc1x.c: Likewise. + * elf32-m68k.c: Likewise. + * elf32-mcore.c: Likewise. + * elf32-rl78.c: Likewise. + * elf32-rx.c: Likewise. + * elf32-s390.c: Likewise. + * elf32-vax.c: Likewise. + * elf64-alpha.c: Likewise. + * elf64-mmix.c: Likewise. + * elf64-s390.c: Likewise. + * elf64-sparc.c: Likewise. + * elfnn-ia64.c: Likewise. + * elfxx-mips.c: Likewise. + * elfxx-sparc.c: Likewise. + * hash.c: Likewise. + * hp300hpux.c: Likewise. + * hppabsd-core.c: Likewise. + * hpux-core.c: Likewise. + * i386dynix.c: Likewise. + * i386linux.c: Likewise. + * i386lynx.c: Likewise. + * i386mach3.c: Likewise. + * i386msdos.c: Likewise. + * i386os9k.c: Likewise. + * irix-core.c: Likewise. + * lynx-core.c: Likewise. + * m68klinux.c: Likewise. + * mach-o.h: Likewise. + * mipsbsd.c: Likewise. + * netbsd-core.c: Likewise. + * nlm32-i386.c: Likewise. + * osf-core.c: Likewise. + * pc532-mach.c: Likewise. + * pef.c: Likewise. + * ppcboot.c: Likewise. + * ptrace-core.c: Likewise. + * reloc16.c: Likewise. + * sco5-core.c: Likewise. + * som.h: Likewise. + * sparclinux.c: Likewise. + * sparclynx.c: Likewise. + * ticoff.h: Likewise. + * trad-core.c: Likewise. + * vms-lib.c: Likewise. + * xsym.h: Likewise. + +2012-07-09 Alan Modra + + PR ld/14323 + * elflink.c (elf_sort_symbol): Sort by size too. + (elf_link_add_object_symbols ): Simplify binary search. + Do not depend on ordering of symbol aliases. Match largest size. + +2012-07-03 H.J. Lu + + * elf.c (assign_section_numbers): Check if number of sections + >= SHN_LORESERVE. + * elfcode.h (elf_object_p): Likewise. + +2012-07-03 Nick Clifton + + * archive.c (bsd_write_armap): Catch attempts to create an archive + with indicies bigger than 4Gb. + (coff_write_armap): Likewise. + +2012-07-03 H.J. Lu + + PR binutils/14319 + * elf.c (_bfd_elf_make_section_from_shdr): Don't compress empty + debug section. + +2012-07-03 H.J. Lu + + PR ld/3351 + * elflink.c (_bfd_elf_update_dynamic_flags): New. + (_bfd_elf_merge_symbol): Update both real and indirect symbol + dynamic flags. + (_bfd_elf_add_default_symbol): Make the real symbol dynamic if + the indirect symbol is defined in a shared library. + (elf_link_add_object_symbols): Likewise. If the indirect + symbol has been forced local, don't make the real symbol + dynamic. + (elf_link_check_versioned_symbol): Check indirect symbol. + (elf_link_output_extsym): Use real symbol definition when + reporting indirect symbol error. Check version info for + dynamic versioned symbol. + +2012-07-03 Alan Modra + + PR ld/14207 + * elf.c (assign_file_positions_for_load_sections): Remove assertions + that only PT_LOAD headers include file header and section headers. + (assign_file_positions_for_non_load_sections): Similarly don't + assert PT_GNU_RELRO header does not include file and section headers. + Compare first section vma rather than PT_LOAD p_vaddr against + relro_start when looking for PT_LOAD covering PT_GNU_RELRO. Replace + abort with assertion. + +2012-07-02 Alan Modra + + * elf32-m32c.c (m32c_elf_check_relocs): Use bfd_make_section + "anyway" variant when creating .plt. + (m32c_elf_relax_plt_section): Remove redundant test and unused param. + (m32c_elf_relax_section): Test SEC_LINKER_CREATED before calling + m32c_elf_relax_plt_section. + * elfxx-mips.c (mips_elf_create_got_section): Use make anyway variant + when creating .got and .got.plt. + (_bfd_mips_elf_final_link): Likewise for .rtproc, and use + bfd_get_linker_section. + * sunos.c: Similarly throughout. + +2012-07-01 Andreas Schwab + + * elf.c (_bfd_elf_make_section_from_shdr): Fix typo in error + message. + +2012-06-29 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_relocate_section): Return FALSE + on unresolvable relocation. + +2012-06-29 H.J. Lu + + * archive.c (_bfd_compute_and_write_armap): Simplify global + symbol handling. + +2012-06-29 Nick Clifton + + PR ld/14189 + * elf32-arm.c (elf32_arm_check_relocs): Do not increment refcount + for locally bound symbols. + +2012-06-29 Alan Modra + + * section.c (bfd_get_linker_section): New function. + * elf32-arm.c: When retrieving SEC_LINKER_CREATED sections, use + the above throughout rather than bfd_get_section_by_name. Use + bfd_make_section_anyway rather than bfd_make_section when creating + them. + * elf32-bfin.c: Likewise. + * elf32-cr16.c: Likewise. + * elf32-cris.c: Likewise. + * elf32-frv.c: Likewise. + * elf32-hppa.c: Likewise. + * elf32-i370.c: Likewise. + * elf32-i386.c: Likewise. + * elf32-lm32.c: Likewise. + * elf32-m32c.c: Likewise. + * elf32-m32r.c: Likewise. + * elf32-m68k.c: Likewise. + * elf32-microblaze.c: Likewise. + * elf32-ppc.c: Likewise. + * elf32-rl78.c: Likewise. + * elf32-s390.c: Likewise. + * elf32-score.c: Likewise. + * elf32-score7.c: Likewise. + * elf32-sh.c: Likewise. + * elf32-tic6x.c: Likewise. + * elf32-tilepro.c: Likewise. + * elf32-vax.c: Likewise. + * elf32-xstormy16.c: Likewise. + * elf32-xtensa.c: Likewise. + * elf64-alpha.c: Likewise. + * elf64-hppa.c: Likewise. + * elf64-ia64-vms.c: Likewise. + * elf64-ppc.c: Likewise. + * elf64-s390.c: Likewise. + * elf64-sh64.c: Likewise. + * elf64-sparc.c: Likewise. + * elf64-x86-64.c: Likewise. + * elfnn-ia64.c: Likewise. + * elfxx-mips.c: Likewise. + * elfxx-sparc.c: Likewise. + * elfxx-tilegx.c: Likewise. + * elflink.c: Likewise. + * elf-vxworks.c: Likewise. + * elf-m10300.c: Likewise. Also make use of htab plt, got and + gotplt shortcuts. + * bfd-in2.h: Regenerate. + * elf32-lm32.c (lm32_elf_check_relocs): Use the correct bfd when + calling create_rofixup_section. + * elflink.c (bfd_elf_final_link): Simplify test for .dynstr. + +2012-06-29 Alan Modra + + * elf32-sh.c (sh_elf_create_dynamic_sections): Don't create .rela + section for bss type sections, except for .rela.bss. + * elf-m10300.c (_bfd_mn10300_elf_create_dynamic_sections): Likewise. + * elf32-cr16.c (_bfd_cr16_elf_create_dynamic_sections): Likewise. + * elf32-lm32.c (lm32_elf_create_dynamic_sections): Likewise. + * elf32-m32r.c (m32r_elf_create_dynamic_sections): Likewise. + * elf64-sh64.c (sh64_elf64_create_dynamic_sections): Likewise. + +2012-06-28 Roland McGrath + + * elf32-arm.c (elf32_arm_populate_plt_entry): Use int32_t for + displacement calculation in nacl_p case. + +2012-06-28 Nick Clifton + + * po/uk.po: New Ukranian translation. + * configure.in (ALL_LINGUAS): Add uk. + * configure: Regenerate. + +2012-06-26 Alan Modra + + * elf64-ppc.c (ppc64_elf_next_toc_section): Don't error if input + file has multiple .got/.toc sections and all don't fit in + current toc group. + +2012-06-22 Roland McGrath + + * elf.c (assign_file_positions_for_non_load_sections): Define + __ehdr_start symbol if it's referenced and there's a PT_LOAD + segment that covers both the file and program headers. + +2012-06-22 Andreas Schwab + + * elf32-m68k.c (elf_m68k_finish_dynamic_symbol): Don't make + _GLOBAL_OFFSET_TABLE_ and _DYNAMIC absolute. + +2012-06-22 Alan Modra + + * elf64-ppc.c (ppc64_elf_func_desc_adjust): Don't emit out-of-line + save/restore functions when relocatable. Make "funcs" static. + +2012-06-18 Hans-Peter Nilsson + + * elf32-cris.c (cris_elf_plt_sym_val): Rewrite to work in presence + of merged .got and .got.plt entries. + +2012-06-18 John Szakmeister + + * elf32-arm.c (elf32_arm_final_link_relocate): Correct return value. + +2012-06-17 Hans-Peter Nilsson + + * elf32-cris.c (cris_elf_relocate_section): + : Handle references to + thread common symbols. + +2012-06-13 Nick Clifton + + * elf32-arm.c (bfd_arm_get_mach_from_attributes): New function. + (elf32_arm_object_p): If the machine number could not be deduced + from the notes, call bfd_arm_get_mach_from_attributes to get the + number from the attributes. + +2012-06-12 H.J. Lu + + PR bfd/14207 + * elf.c (assign_file_positions_for_non_load_sections): Abort if + PT_GNU_RELRO segment doesn't fit in PT_LOAD segment. + +2012-06-12 Alan Modra + + PR ld/14207 + * elf.c (_bfd_elf_map_sections_to_segments): Disregard bss type + sections at end of PT_LOAD segment when searching for segment + that contains end of relro extent. + +2012-06-11 H.J. Lu + + * elf.c (assign_file_positions_for_non_load_sections): Reindent. + +2012-06-11 H.J. Lu + + * elf.c (_bfd_elf_map_sections_to_segments): Reindent. + +2012-06-06 Alan Modra + + * elflink.c (elf_link_input_bfd): Provide a file symbol for + each input file with local syms, if the input lacks such. + (bfd_elf_final_link): Add a file symbol to mark end of locals + for which we can associate with input files. + (struct elf_final_link_info): Add filesym_count field. + (struct elf_outext_info): Add need_second_pass and second_pass. + (elf_link_output_extsym): Detect symbols defined in the output + file, emit them on second pass over locals. + +2012-06-04 Jan Kratochvil + + * bfd-in.h (bfd_elf_bfd_from_remote_memory): Make LEN argument + of target_read_memory as bfd_size_type. + * bfd-in2.h: Regenerate. + * elf-bfd.h (elf_backend_bfd_from_remote_memory): Make LEN + argument of target_read_memory as bfd_size_type. + (_bfd_elf32_bfd_from_remote_memory): Likewise. + (_bfd_elf64_bfd_from_remote_memory): Likewise. + * elf.c (bfd_elf_bfd_from_remote_memory): Likewise. + * elfcode.h (NAME(_bfd_elf,bfd_from_remote_memory)): Likewise. + +2012-06-03 Alan Modra + + PR binutils/13897 + * elf.c (elf_find_function): Cache last function sym info. + (_bfd_elf_maybe_function_sym): Return function size, pass in + section of interest. + * elf-bfd.h (struct elf_backend_data ): Likewise. + (_bfd_elf_maybe_function_sym): Likewise. + * elf64-ppc.c (ppc64_elf_maybe_function_sym): Likewise. + (opd_entry_value): Add in_code_sec param. Revert caching code. + Return -1 if in_code_sec and function found in wrong section. + Update all calls. + +2012-06-01 Siddhesh Poyarekar + + * bfd-in.h (bfd_elf_bfd_from_remote_memory): Make LEN argument + of target_read_memory as size_t. + * bfd-in2.h: Regenerate. + * elf-bfd.h (elf_backend_bfd_from_remote_memory): Make LEN + argument of target_read_memory as size_t. + (_bfd_elf32_bfd_from_remote_memory): Likewise. + (_bfd_elf64_bfd_from_remote_memory): Likewise. + * elf.c (bfd_elf_bfd_from_remote_memory): Likewise. + * elfcode.h (NAME(_bfd_elf,bfd_from_remote_memory)): Likewise. + +2012-06-01 Alan Modra + + PR binutils/13897 + * elf64-ppc.c (opd_entry_value): Rewrite cache code. + +2012-05-29 Tom Tromey + + * opncls.c (bfd_fopen): Always close fd on failure. + (bfd_fdopenr): Likewise. + +2012-05-27 Alan Modra + + PR ld/14170 + * elflink.c (_bfd_elf_merge_symbol): When a symbol defined in + a dynamic library finds a new instance with non-default + visibility in a regular object, correctly handle symbols + already on the undefs list and undo dynamic symbol state when + the new symbol is hidden or internal. + +2012-05-25 H.J. Lu + + * elf32-i386.c (elf_i386_create_dynamic_sections): Don't use + dynamic_sec_flags to create PLT .eh_frame section. + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. + +2012-05-25 Alan Modra + + PR ld/13909 + * elf-eh-frame.c (_bfd_elf_eh_frame_present): New function. + (_bfd_elf_maybe_strip_eh_frame_hdr): Use it here. + * elf-bfd.h (_bfd_elf_eh_frame_present): Declare. + * elflink.c (bfd_elf_size_dynamic_sections): Let the backend + size dynamic sections before stripping eh_frame_hdr. + (bfd_elf_gc_sections): Handle multiple .eh_frame sections. + * elf32-ppc.c (ppc_elf_size_dynamic_sections): Drop glink_eh_frame + if no other .eh_frame sections exist. + * elf64-ppc.c (ppc64_elf_size_stubs): Likewise. + * elf32-i386.c (elf_i386_create_dynamic_sections): Don't size + or alloc plt_eh_frame here.. + (elf_i386_size_dynamic_sections): ..do it here instead. Don't + specially keep sgotplt, iplt, tgotplt, sdynbss for symbols. + (elf_i386_finish_dynamic_sections): Check plt_eh_frame->contents + before writing plt offset. + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Don't size + or alloc plt_eh_frame here.. + (elf_x86_64_size_dynamic_sections): ..do it here instead. + (elf_x86_64_finish_dynamic_sections): Check plt_eh_frame->contents + before writing plt offset. + +2012-05-24 Alan Modra + + PR ld/14158 + * elf64-ppc.c (ppc64_elf_size_stubs): Round up glink_eh_frame + size to output section alignment. + (ppc64_elf_build_stubs): Likewise, and extend last FDE to cover. + +2012-05-23 Alan Modra + + * elf-eh-frame.c (_bfd_elf_maybe_strip_eh_frame_hdr): Handle + BFDs with multiple .eh_frame sections. + +2012-05-23 Alan Modra + + PR ld/13909 + * elflink.c (bfd_elf_discard_info): Don't ignore dynamic BFDs. + +2012-05-22 H.J. Lu + + PR ld/13909 + * elf32-i386.c (elf_i386_create_dynamic_sections): Revert the + last change. + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. + +2012-05-22 Alan Modra + + * elflink.c (bfd_elf_discard_info): Look for next .eh_frame if + first one is zero size or discarded. + * elf32-ppc.c (ppc_elf_size_dynamic_sections): Set most of + glink_eh_frame contents here.. + (ppc_elf_finish_dynamic_sections): ..rather than here. Just set + offset to .glink. + +2012-05-22 H.J. Lu + + PR ld/13909 + * elf32-i386.c (elf_i386_create_dynamic_sections): Create PLT + eh_frame section if there is an input .eh_frame section. + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. + +2012-05-22 H.J. Lu + + PR ld/14105 + * elf32-i386.c (elf_i386_create_dynamic_sections): Always + create PLT eh_frame section with SEC_LINKER_CREATED. + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Likewise. + +2012-05-22 Alan Modra + + * elflink.c (bfd_elf_discard_info): Handle multiple .eh_frame + sections attached to a BFD. + * section.c (bfd_get_section_by_name): Rewrite description. + (bfd_get_next_section_by_name): New function. + * bfd-in2.h: Regenerate. + +2012-05-21 Andreas Schwab + + * elf32-m68k.c (elf_m68k_grok_prstatus): New function. + (elf_m68k_grok_psinfo): New function. + (elf_backend_grok_prstatus): Define. + (elf_backend_grok_psinfo): Define. + +2012-05-19 Maciej W. Rozycki + + * elf64-mips.c (elf_backend_got_header_size): Correct definition. + * elfxx-mips.c (_bfd_mips_elf_adjust_dynamic_symbol): Use the ELF + backend's GOT header size instead of hardcoding it. + +2012-05-19 Maciej W. Rozycki + + * elf32-vax.c (elf_vax_relocate_section) + : Don't check if info->shared again. + +2012-05-19 Maciej W. Rozycki + + * elf32-vax.c (elf_vax_relocate_section) + : Use section flags rather than + its name as the check for text sections. + +2012-05-19 Maciej W. Rozycki + + * elf64-mips.c (mips_elf64_be_swap_reloc_out): Also make sure + the third reloc offset is the same as the first. + +2012-05-19 Alan Modra + + * elf32-ppc.h (has_vle_insns, is_ppc_vle): Delete. + (has_tls_reloc, has_tls_get_addr_call): Move back to.. + * elf32-ppc.c: ..here. + (ppc_elf_section_flags, elf_backend_section_flags): Delete. + (ppc_elf_modify_segment_map): Use ELF sh_flags to detect VLE sections. + +2012-05-18 H.J. Lu + + * elf32-i386.c (elf_i386_finish_dynamic_symbol): Don't make + _DYNAMIC nor _GLOBAL_OFFSET_TABLE_ absolute. + * elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Likewise. + +2012-05-18 Roland McGrath + + * archive.c (_bfd_generic_read_ar_hdr_mag): Fix last change so as + not to clobber the ar_fmag field stored in ARED->arch_header. + +2012-05-18 Pedro Alves + + * mach-o.h: Don't include sysdep.h. + +2012-05-18 Nick Clifton + + PR 14072 + * bfd-in.h: Check for PACKAGE or PACKAGE_VERSION before + complaining about config.h not having been included. + * bfd-in2.h: Regenerate. + +2012-05-18 Andreas Schwab + + * aclocal.m4: Regenerate. + * Makefile.in: Regenerate. + +2012-05-17 Daniel Richard G. + Nick Clifton + + PR 14072 + * configure.in: Add check that sysdep.h has been included before + any system header files. + * configure: Regenerate. + * config.in: Regenerate. + * aclocal.m4: Regenerate. + * bfd-in.h: Generate an error if included before config.h. + * sysdep.h: Likewise. + * bfd-in2.h: Regenerate. + * compress.c: Remove #include "config.h". + * plugin.c: Likewise. + * elf32-m68hc1x.c: Include sysdep.h before alloca-conf.h. + * elf64-hppa.c: Likewise. + * som.c: Likewise. + * xsymc.c: Likewise. + +2012-05-17 Maciej W. Rozycki + Alan Modra + + * elf.c (ignore_section_sym): Correct comment. Don't return + true for absolute section. + (elf_map_symbols): Move stray comment. Adjust for above change. + Don't discard global section symbols. + +2012-05-17 Alan Modra + + * elf32-ppc.c (ppc_elf_finish_dynamic_symbol): Don't make _DYNAMIC, + _GLOBAL_OFFSET_TABLE_ or _PROCEDURE_LINKAGE_TABLE_ absolute. + * elf64-ppc.c (ppc64_elf_finish_dynamic_symbol): Don't make _DYNAMIC + absolute. + +2012-05-17 Alan Modra + + * elf32-ppc.c (has_tls_reloc, has_tls_get_addr_call, has_vle_insns, + is_ppc_vle): Move to.. + * elf32-ppc.h: ..here, making is_ppc_vle a macro. + +2012-05-16 Sergio Durigan Junior + + * bfd-in.h (bfd_get_section_name, bfd_get_section_vma, + bfd_get_section_lma, bfd_get_section_alignment, + bfd_get_section_flags, bfd_get_section_userdata): Rewrite macros + in order to use the `bfd' argument. + * bfd-in2.h: Regenerate. + * elf-vxworks.c (elf_vxworks_finish_dynamic_entry): Pass proper `bfd' + as the first argument for `bfd_get_section_alignment'. + * elf32-arm.c (create_ifunc_sections): Likewise, for + `bfd_set_section_alignment'. + * elf32-m32r.c (m32r_elf_relocate_section): Likewise, for + `bfd_get_section_name'. + * elf32-microblaze.c (microblaze_elf_relocate_section): Likewise. + * elf32-ppc.c (ppc_elf_size_dynamic_sections): Likewise. + (ppc_elf_relocate_section): Likewise. + * elf64-mmix.c (mmix_final_link_relocate): Likewise, for + `bfd_get_section_vma'. + * elf64-ppc.c (create_linkage_sections): Likewise, for + `bfd_set_section_alignment'. + +2012-05-16 Georg-Johann Lay + + PR target/13503 + * reloc.c: Rename BFD_RELOC_AVR_8_HHI to BFD_RELOC_AVR_8_HLO. + * bfd-in2.h: Regenerate. + * libbfd.h: Regenerate. + * elf32-avr.c (elf_avr_howto_table): Rename R_AVR_8_HHI8 to + R_AVR_8_HLO8. + (avr_reloc_map): Likewise. + +2012-05-16 Daniel Richard G. + + PR binutils/13558 + * bfd/aout-cris.c: Include sysdep.h before bfd.h. + * bfd/aout-ns32k.c: Likewise. + * bfd/aout-sparcle.c: Likewise. + * bfd/aout0.c: Likewise. + * bfd/bfd-in2.h: Likewise. + * bfd/coff-stgo32.c: Likewise. + * bfd/cpu-lm32.c: Likewise. + * bfd/cpu-microblaze.c: Likewise. + * bfd/cpu-score.c: Likewise. + * bfd/cpu-tilegx.c: Likewise. + * bfd/cpu-tilepro.c: Likewise. + * bfd/elf32-lm32.c: Likewise. + * bfd/elf32-microblaze.c: Likewise. + * bfd/elf32-score7.c: Likewise. + * bfd/elf32-tilepro.c: Likewise. + * bfd/elfxx-tilegx.c: Likewise. + * bfd/mach-o.h: Likewise. + * bfd/nlm32-ppc.c: Likewise. + * bfd/ns32knetbsd.c: Likewise. + * bfd/pef.h: Likewise. + * bfd/plugin.c: Likewise. + * bfd/stab-syms.c: Likewise. + * bfd/sunos.c: Likewise. + * bfd/syms.c: Likewise. + * bfd/xsym.h: Likewise. + +2012-05-16 Alan Modra + + * elflink.c: Rename flaginfo to flinfo throughout, except.. + (bfd_elf_lookup_section_flags): ..here, rename finfo to flaginfo. + Formatting, style. Simplify flag match. + +2012-05-16 Alan Modra + + * dwarf2.c: Formatting. + (arange_add): Pass in unit rather than bfd. Update callers. + Ignore empty ranges. Don't ask for cleared memory. + (parse_comp_unit): Only set unit->base_address if processing + DW_TAG_compile_unit. + (find_debug_info): Optimise section lookup. + (place_sections): Use bfd_alloc for stash->adjusted_sections. + (find_line): Match previously parsed comp unit addresses as we + do for newly parsed comp units. + +2012-05-16 Alan Modra + + * archive.c (_bfd_generic_read_ar_hdr_mag): Ensure sscanf + stops at end of ar_size field. + +2012-05-16 Alan Modra + + PR ld/13962 + PR ld/7023 + * elf.c (bfd_section_from_shdr): Fail when .dynsym sh_info is + out of range. As a special case, fix sh_info for zero sh_size. + Do the same for .symtab. + +2012-05-15 James Murray + Stephane Carrez + + * archures.c: Add bfd_arch_m9s12x and bfd_arch_m9s12xg. + * config.bfd: Likewise. + * cpu-m9s12x.c: New. + * cpu-m9s12xg.c: New. + * elf32-m68hc12.c: Add S12X and XGATE co-processor support. + Add option to offset S12 addresses into XGATE memory space. + Fix carry bug in IMM16 (IMM8 low/high) relocate. + * Makefile.am (ALL_MACHINES): Add cpu-m9s12x and cpu-m9s12xg. + (ALL_MACHINES_CFILES): Likewise. + * reloc.c: Add S12X relocs. + * Makefile.in: Regenerate. + * bfd-in2.h: Regenerate. + * libbfd.h: Regenerate. + +2012-05-14 James Lemke + Catherine Moore + + * bfd.c (bfd_lookup_section_flags): Add section parm. + * ecoff.c (bfd_debug_section): Remove flag_info initializer. + * elf-bfd.h (bfd_elf_section_data): Move in section_flag_info. + (bfd_elf_lookup_section_flags): Add section parm. + * elf32-ppc.c (is_ppc_vle): New function. + (ppc_elf_modify_segment_map): New function. + (elf_backend_modify_segment_map): Define. + (has_vle_insns): New define. + * elf32-ppc.h (ppc_elf_modify_segment_map): Declare. + * elflink.c (bfd_elf_lookup_section_flags): Add return value & parm. + Move in logic to omit / include a section. + * libbfd-in.h (bfd_link_info): Add section parm. + (bfd_generic_lookup_section_flags): Likewise. + * reloc.c (bfd_generic_lookup_section_flags): Likewise. + * section.c (bfd_section): Move out section_flag_info. + (BFD_FAKE_SECTION): Remove flag_info initializer. + * targets.c (_bfd_lookup_section_flags): Add section parm. + +2012-05-14 Catherine Moore + + * archures.c (bfd_mach_ppc_vle): New. + * bfd-in2.h: Regenerated. + * cpu-powerpc.c (bfd_powerpc_archs): New entry for vle. + * elf32-ppc.c (split16_format_type): New enumeration. + (ppc_elf_vle_split16): New function. + (HOWTO): Add entries for R_PPC_VLE relocations. + (ppc_elf_reloc_type_lookup): Handle PPC_VLE relocations. + (ppc_elf_section_flags): New function. + (ppc_elf_lookup_section_flags): New function. + (ppc_elf_section_processing): New function. + (ppc_elf_check_relocs): Handle PPC_VLE relocations. + (ppc_elf_relocation_section): Likewise. + (elf_backend_lookup_section_flags_hook): Define. + (elf_backend_section_flags): Define. + (elf_backend_section_processing): Define. + * elf32-ppc.h (ppc_elf_section_processing): Declare. + * libbfd.h: Regenerated. + * reloc.c (BFD_RELOC_PPC_VLE_REL8, BFD_RELOC_PPC_VLE_REL15, + BFD_RELOC_PPC_VLE_REL24, BFD_RELOC_PPC_VLE_LO16A, + BFD_RELOC_PPC_VLE_LO16D, BFD_RELOC_PPC_VLE_HI16A, + BFD_RELOC_PPC_VLE_HI16D, BFD_RELOC_PPC_VLE_HA16A, + BFD_RELOC_PPC_VLE_HA16D, BFD_RELOC_PPC_VLE_SDA21, + BFD_RELOC_PPC_VLE_SDA21_LO, BFD_RELOC_PPC_VLE_SDAREL_LO16A, + BFD_RELOC_PPC_VLE_SDAREL_LO16D, BFD_RELOC_PPC_VLE_SDAREL_HI16A, + BFD_RELOC_PPC_VLE_SDAREL_HI16D, BFD_RELOC_PPC_VLE_SDAREL_HA16A, + BFD_RELOC_PPC_VLE_SDAREL_HA16D): New bfd relocations. + +2012-05-11 Georg-Johann Lay + + PR target/13503 + * reloc.c: Add new ENUM for BFD_RELOC_AVR_8_LO, + BFD_RELOC_AVR_8_HI, BFD_RELOC_AVR_8_HHI. + * bfd-in2.h: Regenerate. + * libbfd.h: Regenerate. + * elf32-avr.c (elf_avr_howto_table): Add entries for + R_AVR_8_LO8, R_AVR_8_HI8, R_AVR_8_HHI8. + (avr_reloc_map): Add RELOC mappings for R_AVR_8_LO8, R_AVR_8_HI8, + R_AVR_8_HHI8. + +2012-05-10 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_relocate_section): Use int in x32 + addend overflow check. + +2012-05-10 DJ Delorie + + * elf32-rx.c (rx_elf_object_p): Ignore empty segments. + +2012-05-10 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_relocate_section): Display signed + hex number in x32 addend overflow check. + +2012-05-10 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_reloc_type_class): Handle + R_X86_64_RELATIVE64. + +2012-05-09 H.J. Lu + + * elf64-x86-64.c (elf_x86_64_relocate_section): Check addend + overflow for R_X86_64_RELATIVE64. + +2012-05-08 Ben Cheng + + * elf.c: Preserve the original p_align and p_flags if they are + valid. + +2012-05-07 Alan Modra + + * elf64-ia64-vms.c (elf64_ia64_relocate_section): Update + RELOC_AGAINST_DISCARDED_SECTION invocation. + +2012-05-07 Hans-Peter Nilsson + + * elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Declare and use + local variable i_ instead of assuming and using a variable i. + +2012-05-07 Maciej W. Rozycki + + * elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Handle compound + relocations. + * elfxx-mips.c (mips_reloc_against_discarded_section): New + function. + (_bfd_mips_elf_relocate_section): Call it, in place of + RELOC_AGAINST_DISCARDED_SECTION. + * elf-m10200.c (mn10200_elf_relocate_section): Update arguments + to RELOC_AGAINST_DISCARDED_SECTION. + * elf-m10300.c (mn10300_elf_relocate_section): Likewise. + * elf32-arm.c (elf32_arm_relocate_section): Likewise. + * elf32-avr.c (elf32_avr_relocate_section): Likewise. + * elf32-bfin.c (bfin_relocate_section): Likewise. + (bfinfdpic_relocate_section): Likewise. + * elf32-cr16.c (elf32_cr16_relocate_section): Likewise. + * elf32-cr16c.c (elf32_cr16c_relocate_section): Likewise. + * elf32-cris.c (cris_elf_relocate_section): Likewise. + * elf32-crx.c (elf32_crx_relocate_section): Likewise. + * elf32-d10v.c (elf32_d10v_relocate_section): Likewise. + * elf32-epiphany.c (epiphany_elf_relocate_section): Likewise. + * elf32-fr30.c (fr30_elf_relocate_section): Likewise. + * elf32-frv.c (elf32_frv_relocate_section): Likewise. + * elf32-h8300.c (elf32_h8_relocate_section): Likewise. + * elf32-hppa.c (elf32_hppa_relocate_section): Likewise. + * elf32-i370.c (i370_elf_relocate_section): Likewise. + * elf32-i386.c (elf_i386_relocate_section): Likewise. + * elf32-i860.c (elf32_i860_relocate_section): Likewise. + * elf32-ip2k.c (ip2k_elf_relocate_section): Likewise. + * elf32-iq2000.c (iq2000_elf_relocate_section): Likewise. + * elf32-lm32.c (lm32_elf_relocate_section): Likewise. + * elf32-m32c.c (m32c_elf_relocate_section): Likewise. + * elf32-m32r.c (m32r_elf_relocate_section): Likewise. + * elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Likewise. + * elf32-m68k.c (elf_m68k_relocate_section): Likewise. + * elf32-mcore.c (mcore_elf_relocate_section): Likewise. + * elf32-mep.c (mep_elf_relocate_section): Likewise. + * elf32-moxie.c (moxie_elf_relocate_section): Likewise. + * elf32-msp430.c (elf32_msp430_relocate_section): Likewise. + * elf32-mt.c (mt_elf_relocate_section): Likewise. + * elf32-openrisc.c (openrisc_elf_relocate_section): Likewise. + * elf32-ppc.c (ppc_elf_relocate_section): Likewise. + * elf32-rl78.c (rl78_elf_relocate_section): Likewise. + * elf32-rx.c (rx_elf_relocate_section): Likewise. + * elf32-s390.c (elf_s390_relocate_section): Likewise. + * elf32-score.c (s3_bfd_score_elf_relocate_section): Likewise. + * elf32-score7.c (s7_bfd_score_elf_relocate_section): Likewise. + * elf32-sh.c (sh_elf_relocate_section): Likewise. + * elf32-spu.c (spu_elf_relocate_section): Likewise. + * elf32-tic6x.c (elf32_tic6x_relocate_section): Likewise. + * elf32-tilepro.c (tilepro_elf_relocate_section): Likewise. + * elf32-v850.c (v850_elf_relocate_section): Likewise. + * elf32-vax.c (elf_vax_relocate_section): Likewise. + * elf32-xc16x.c (elf32_xc16x_relocate_section): Likewise. + * elf32-xstormy16.c (xstormy16_elf_relocate_section): Likewise. + * elf32-xtensa.c (elf_xtensa_relocate_section): Likewise. + * elf64-alpha.c (elf64_alpha_relocate_section_r): Likewise. + (elf64_alpha_relocate_section): Likewise. + * elf64-hppa.c (elf64_hppa_relocate_section): Likewise. + * elf64-mmix.c (mmix_elf_relocate_section): Likewise. + * elf64-ppc.c (ppc64_elf_relocate_section): Likewise. + * elf64-s390.c (elf_s390_relocate_section): Likewise. + * elf64-sh64.c (sh_elf64_relocate_section): Likewise. + * elf64-x86-64.c (elf_x86_64_relocate_section): Likewise. + * elfnn-ia64.c (elfNN_ia64_relocate_section): Likewise. + * elfxx-sparc.c (_bfd_sparc_elf_relocate_section): Likewise. + * elfxx-tilegx.c (tilegx_elf_relocate_section): Likewise. + +2012-05-05 Alan Modra + + PR ld/14052 + PR ld/13621 + * linker.c (_bfd_nearby_section): Revert 2012-02-13 change. + +2012-05-05 Alan Modra + + * aout-arm.c: Replace all uses of bfd_abs_section, bfd_com_section, + bfd_und_section and bfd_ind_section with their _ptr variants, or + use corresponding bfd_is_* macros. + * aout-ns32k.c: Likewise. + * aout-tic30.c: Likewise. + * coff-arm.c: Likewise. + * coff-tic54x.c: Likewise. + * cpu-ns32k.c: Likewise. + * elf-attrs.c: Likewise. + * elfcode.h: Likewise. + * peicode.h: Likewise. + * reloc.c: Likewise. + * riscix.c: Likewise. + * versados.c: Likewise. + * section.c: Likewise. + (bfd_abs_section, bfd_ind_section, bfd_com_section, + bfd_ind_section): Delete. + (std_section): New array replacing above. + (bfd_abs_section_ptr, bfd_ind_section_ptr, bfd_com_section_ptr, + bfd_ind_section_ptr, STD_SECTION): Update. + (BFD_FAKE_SECTION, GLOBAL_SYM_INIT): Remove unnecessary casts. + * bfd-in2.h: Regenerate. + +2012-05-03 Sean Keys + + * cpu-xgate.c: New file. Added XGATE support. + * archures.c (bfd_architecture): Add XGATE architecture. + (bfd_archures_list): Add reference to XGATE architecture info. + * elf-bfd.h (prep_headers): Handle bfd_arch_xgate. + * reloc.c: Add various XGATE relocation enums. + * targets.c (bfd_elf32_xgate_vec): Declare and add to target vector + list. + * Makefile.am: Add support for XGATE elf. + * configure.in: Ditto. + * config.bfd: Ditto. + * Makefile.in: Regenerate. + * configure: Ditto. + * bfd-in2.h: Ditto. + * libbfd.h: Ditto. + Added files for XGATE relocations. + * elf32-xgate.c: Created minimal relocation file. + * elf32-xgate.h: Created minimal header file for elf32-xgate. + +2012-05-03 Tristan Gingold + + * dwarf2.c (decode_line_info): Ignore + DW_LNE_HP_source_file_correlation. + +2012-05-01 Nick Clifton + + PR binutils/13121 + * aoutx.h: Rename 'finfo' to 'flaginfo' to avoid conflicts with + AIX system headers. + * coff-ppc.c: Likewise. + * cofflink.c: Likewise. + * elf32-arm.c: Likewise. + * elf64-sparc.c: Likewise. + * elflink.c: Likewise. + * pdp11.c: Likewise. + * rescoff.c: Likewise. + +2012-04-26 Mark Wielaard + + * dwarf2.c (scan_unit_for_symbols): Account for DW_AT_high_pc + possibly being relative to DW_AT_low_pc. + (parse_comp_unit): Likewise. + +2012-04-26 Andreas Schwab + + * elf32-m68k.c (elf_m68k_check_relocs): Mark non-GOT references + also when generating PIE. + (elf_m68k_discard_copies): Mark undefined weak symbols referenced + by relocations as dynamic. + +2012-04-26 Hans-Peter Nilsson + + Provide a way for programs to recognize BFD_ASSERT calls. + * bfd.c (bfd_assert_handler_type): New API type. + (bfd_set_assert_handler, bfd_get_assert_handler): New API functions. + (_bfd_assert_handler): New variable. + (_bfd_default_assert_handler): New function. + (bfd_assert): Call _bfd_assert_handler, not _bfd_error_handler. + * libbfd-in.h (_bfd_assert_handler): Declare. + * libbfd.h, bfd-in2.h: Regenerate. + +2012-04-24 Hans-Peter Nilsson + + PR ld/13990 + * elf32-arm.c (elf32_arm_gc_sweep_hook): Handle a forced-local + symbol, where PLT refcount is set to -1. + +2012-04-24 Alan Modra + + PR ld/13991 + * elf-bfd.h (_bfd_elf_link_just_syms): Define as + _bfd_generic_link_just_syms. + * elflink.c (_bfd_elf_link_just_syms): Delete. + * linker.c (_bfd_generic_link_just_syms): Set sec_info_type. + + * bfd-in.h (discarded_section): Renamed from elf_discarded_section. + * section.c (SEC_INFO_TYPE_NONE, SEC_INFO_TYPE_STABS, + SEC_INFO_TYPE_MERGE, SEC_INFO_TYPE_EH_FRAME, + SEC_INFO_TYPE_JUST_SYMS): Renamed from corresponding ELF_INFO_TYPE. + * elf-eh-frame.c, * elf-m10200.c, * elf-m10300.c, + * elf.c, * elf32-arm.c, * elf32-avr.c, * elf32-bfin.c, + * elf32-cr16.c, * elf32-cr16c.c, * elf32-cris.c, + * elf32-crx.c, * elf32-d10v.c, * elf32-epiphany.c, + * elf32-fr30.c, * elf32-frv.c, * elf32-h8300.c, + * elf32-hppa.c, * elf32-i370.c, * elf32-i386.c, + * elf32-i860.c, * elf32-ip2k.c, * elf32-iq2000.c, + * elf32-lm32.c, * elf32-m32c.c, * elf32-m32r.c, + * elf32-m68hc1x.c, * elf32-m68k.c, * elf32-mcore.c, + * elf32-mep.c, * elf32-moxie.c, * elf32-msp430.c, + * elf32-mt.c, * elf32-openrisc.c, * elf32-ppc.c, + * elf32-rl78.c, * elf32-rx.c, * elf32-s390.c, + * elf32-score.c, * elf32-score7.c, * elf32-sh.c, + * elf32-spu.c, * elf32-tic6x.c, * elf32-tilepro.c, + * elf32-v850.c, * elf32-vax.c, * elf32-xc16x.c, + * elf32-xstormy16.c, * elf32-xtensa.c, * elf64-alpha.c, + * elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mmix.c, + * elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, + * elf64-x86-64.c, * elflink.c, * elfnn-ia64.c, + * elfxx-mips.c, * elfxx-sparc.c, * elfxx-tilegx.c, + * reloc.c: Update all references. + * bfd-in2.h: Regenerate. + +2012-04-20 Andreas Krebbel + + * elf32-s390.c (ELF_DYNAMIC_INTERPRETER): Set to the GCC default. + * elf64-s390.c (ELF_DYNAMIC_INTERPRETER): Set to the GCC default. + +2012-04-19 Thomas Schwinge + + * elf32-sh.c (elf_sh_link_hash_entry): Specify an enum identifier for + got_type. + (allocate_dynrelocs, sh_elf_relocate_section, sh_elf_check_relocs): Use + it. + +2012-04-17 Kaz Kojima + + * elf32-sh.c (allocate_dynrelocs): Don't allocate dynamic + relocations when LE conversion happens on the IE tls symbol. + +2012-04-17 Roland McGrath + + * elf64-x86-64.c (elf_x86_64_nacl_plt0_entry): Fix nop padding + so that 32-byte boundary is a proper instruction boundary. + +2012-04-17 Tristan Gingold + + * vms-lib.c (_bfd_vms_lib_get_module): Append .obj extension to + member of an object archive.< + +2012-04-17 Tristan Gingold + + * vms-lib.c (MAX_EKEYLEN): Define. + (MAX_KEYLEN): Fix value. + (vms_write_index): Add comments and fix indentation. + Adjust comparaison. Add assertions. Free kbn_blk. + (_bfd_vms_lib_write_archive_contents): Use MAX_EKEYLEN. + Compense MAX_KEYLEN adjustment. + +2012-04-16 Maciej W. Rozycki + + * elfxx-mips.c (mips16_stub_symndx): Handle n64 compound relocs. + (_bfd_mips_elf_check_relocs): Update accordingly. + +2012-04-13 Alan Modra + + PR ld/13947 + * elflink.c (bfd_elf_final_link): Set reloc_count to 0 for + reloc sections. + +2012-04-12 David S. Miller + + * reloc.c (BFD_RELOC_SPARC_H34, BFD_RELOC_SPARC_SIZE32, + BFD_RELOC_SPARC_SIZE64, BFD_RELOC_SPARC_WDISP10): New relocs. + * libbfd.h: Regenerate. + * bfd-in2.h: Likewise. + * elfxx-sparc.c (sparc_elf_wdisp10_reloc): New function. + (_bfd_sparc_elf_howto_table): Add entries for R_SPARC_H34, + R_SPARC_SIZE32, R_SPARC_64, and R_SPARC_WDISP10. + (_bfd_sparc_elf_reloc_type_lookup): Handle new relocs. + (_bfd_sparc_elf_check_relocs): Likewise. + (_bfd_sparc_elf_gc_sweep_hook): Likewise. + (_bfd_sparc_elf_relocate_section): Likewise. + +2012-04-12 Roland McGrath + + * elf32-arm.c (elf32_arm_nacl_plt0_entry, elf32_arm_nacl_plt_entry): + New variables. + (struct elf32_arm_link_hash_table): New member `nacl_p'. + (elf32_arm_link_hash_table_create): Initialize it. + (elf32_arm_nacl_link_hash_table_create): New function. + (arm_movw_immediate, arm_movt_immediate): New functions. + (elf32_arm_populate_plt_entry): Test HTAB->nacl_p. + (elf32_arm_finish_dynamic_sections): Likewise. + (elf32_arm_output_plt_map_1): Likewise. + (bfd_elf32_littlearm_nacl_vec, bfd_elf32_bigarm_nacl_vec): + New backend vector stanza. + (elf32_arm_nacl_modify_segment_map): New function. + * config.bfd: Handle arm-*-nacl*, armeb-*-nacl*. + * targets.c: Support bfd_elf32_{big,little}_nacl_vec. + * configure.in: Likewise. + (bfd_elf32_bigarm_nacl_vec): Add elf-nacl.lo here. + (bfd_elf32_littlearm_nacl_vec): Likewise. + (bfd_elf32_bigarm_vec, bfd_elf32_littlearm_vec): Likewise. + (bfd_elf32_bigarm_symbian_vec): Likewise. + (bfd_elf32_littlearm_symbian_vec): Likewise. + (bfd_elf32_bigarm_vxworks_vec): Likewise. + (bfd_elf32_littlearm_vxworks_vec): Likewise. + * configure: Regenerated. + +2012-04-12 Tristan Gingold + + * elflink.c (elf_link_output_extsym): Add a guard. + (bfd_elf_final_link): Remove assertion. + (bfd_elf_final_link): Add a guard. + * elfnn-ia64.c (INCLUDE_IA64_VMS): Removed. + (elfNN_vms_section_from_shdr, elfNN_vms_object_p) + (elfNN_vms_post_process_headers, elfNN_vms_section_processing) + (elfNN_vms_final_write_processing, elfNN_vms_close_and_cleanup): + Remove. + (elfNN-ia64-vms target): Move to ... + * elf64-ia64-vms.c: New file. + * configure.in (bfd_elf64_ia64_vms_vec): Add elf64-ia64-vms.lo + * Makefile.am (BFD64_BACKENDS): Add elf64-ia64-vms.lo. + (BFD64_BACKENDS_CFILES): Ad elf64-ia64-vms.c. + * configure: Regenerate. + * Makefile.in: Regenerate. + +2012-04-11 Nick Clifton + + PR binutils/13897 + * elf64-ppc.c (opd_entry_value): When dealing with sections + without relocs, keep the last section loaded in order to avoid + unnecessary reloads. + +2012-04-09 Roland McGrath + + * elf.c (_bfd_elf_map_sections_to_segments): Set INFO->user_phdrs. + * elf-nacl.c (nacl_modify_segment_map): Do nothing if INFO->user_phdrs. + (nacl_modify_program_headers): Likewise. + +2012-04-03 Roland McGrath + + * elf-nacl.c: New file. + * elf-nacl.h: New file. + * elf32-i386.c (elf_backend_modify_segment_map): Define for + bfd_elf32_i386_nacl_vec. + (elf_backend_modify_program_headers): Likewise. + * elf64-x86-64.c (elf_backend_modify_segment_map): Define for + bfd_elf64_x86_64_nacl_vec and bfd_elf32_x86_64_nacl_vec. + (elf_backend_modify_program_headers): Likewise. + * Makefile.am (BFD32_BACKENDS, BFD64_BACKENDS): Add elf-nacl.lo here. + (BFD32_BACKENDS_CFILES, BFD64_BACKENDS_CFILES): Add elf-nacl.c here. + * Makefile.in: Regenerated. + * configure.in (bfd_elf64_x86_64_nacl_vec): Add elf-nacl.o to tb here. + (bfd_elf32_x86_64_nacl_vec): Likewise. + (bfd_elf64_x86_64_vec, bfd_elf32_x86_64_vec): Likewise. + (bfd_elf64_x86_64_freebsd_vec, bfd_elf64_x86_64_sol2_vec): Likewise. + (bfd_elf64_l1om_vec, bfd_elf64_l1om_freebsd_vec): Likewise. + (bfd_elf64_k1om_vec, bfd_elf64_k1om_freebsd_vec): Likewise. + (bfd_elf32_i386_nacl_vec): Likewise. + (bfd_elf32_i386_sol2_vec, bfd_elf32_i386_freebsd_vec): Likewise. + (bfd_elf32_i386_vxworks_vec, bfd_elf32_i386_vec): Likewise. + * configure: Regenerated. + +2012-03-31 Andreas Schwab + + * elf32-m68k.c (elf_m68k_relocate_section): Allow + R_68K_TLS_LE{8,16,32} for PIE. + +2012-03-30 Andreas Krebbel + + * elf64-s390.c: Fix several comments regarding PLT entry + description. + * elf32-s390.c: Likewise. + +2012-03-30 Andreas Krebbel + + * elf64-s390.c: Use the section pointer shortcuts in + elf_link_hash_table and remove them from the target specific + variant. + * elf32-s390.c: Likewise. + +2012-03-30 Andreas Krebbel + + * elf64-s390.c (elf_s390x_plt_entry, elf_s390x_first_plt_entry): + New definitions. + (PLT_PIC_ENTRY_WORD*, PLT_PIC12_ENTRY_WORD*): Remove. + (elf_s390_finish_dynamic_symbol): Use memcpy instead of bfd_put_32. + (elf_s390_finish_dynamic_sections): Likewise. + * elf32-s390.c (elf_s390_plt_entry, elf_s390_plt_pic_entry) + (elf_s390_plt_pic12_entry, elf_s390_plt_pic16_entry) + (elf_s390_plt_first_entry, elf_s390_plt_pic_first_entry): New definitions. + (PLT_PIC16_ENTRY_WORD*, PLT_ENTRY_WORD*) + (PLT_PIC_FIRST_ENTRY_WORD*, PLT_FIRST_ENTRY_WORD*): Remove. + +2012-03-30 Andreas Krebbel + + * elf32-s390.c (struct elf_s390_dyn_relocs): Remove. + Rename all occurrences in the file to elf_dyn_relocs. + * elf64-s390.c: Likewise. + +2012-03-30 Alan Modra + + * elflink.c (_bfd_elf_gc_mark_reloc): Don't delve into dynamic + libraries. + +2012-03-29 Alan Modra + + * bfd-in.h (bfd_get_arch_size, bfd_get_sign_extend_vma): Delete. + * bfd-in2.h: Regenerate. + +2012-03-23 Alan Modra + + * elf.c (assign_file_positions_for_non_load_sections): Don't warn + on empty alloc sections. + +2012-03-23 Alan Modra + + * linker.c (_bfd_nearby_section): New function, split out from.. + (fix_syms): ..here. + * bfd-in.h (_bfd_nearby_section): Declare. + * bfd-in2.h: Regenerate. + * elflink.c (elf_link_input_bfd): Don't use text_index_section or + data_index_section with ld -q or ld -r output relocs against + stripped output sections. Instead use _bfd_nearby_section. + +2012-03-23 Alan Modra + + PR binutils/13894 + * elf64-ppc.c (opd_entry_value): Read full symbol table when + sym hashes unavailable. + +2012-03-21 Eliot Dresselhaus + + * elf32-tic6x.c (elf32_tic6x_merge_private_bfd_data): Return TRUE + for non-C6X objects. + +2012-03-20 Kai Tietz + + PR ld/12742 + * configure.in (AC_CHECK_HEADERS): Test for windows.h and dlfcn.h. + * plugin.c: Guard include of dlfcn.h if HAVE_DLFCN_H is defined. + Add windows.h header include if HAVE_WINDOWS_H is defined. + (dlerror): New static function if windows variant is used instead + of dlfcn.h. + (dlclose): Likewise. + (dlopen): Likewise. + (dlsym): Likewise. + * configure: Regenerated. + * config.in: Regenerated. + +2012-03-20 H.J. Lu + + PR ld/13880 + * elf32-i386.c (elf_i386_relocate_section): Don't issue an error + for R_386_GOTOFF relocation against protected function if + SYMBOLIC_BIND is true. + + * elf64-x86-64.c (elf_x86_64_relocate_section): Don't issue an + error for R_X86_64_GOTOFF64 relocation against protected function + when building executable or SYMBOLIC_BIND is true. + +2012-03-16 Roland McGrath + + * config.bfd: Handle x86_64-*-nacl*. + * elf64-x86-64.c (bfd_elf64_x86_64_nacl_vec): New backend vector stanza. + (bfd_elf32_x86_64_nacl_vec): Likewise. + * targets.c: Support them. + * configure.in: Likewise. + * configure: Regenerated. + +2012-03-16 Matthew Gretton-Dann + + * elf32-arm.c (elf32_arm_attributes_accept_div): New function. + (elf32_arm_attributes_forbid_div): Likewise. + (elf32_arm_merge_eabi_attributes): Correct handling of + Tag_DIV_use. + +2012-03-15 Roland McGrath + + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Use + elf_x86_64_backend_data parameters for plt_eh_frame. + + * elf64-x86-64.c (struct elf_x86_64_backend_data): New type. + (get_elf_x86_64_backend_data, GET_PLT_ENTRY_SIZE): New macros. + (elf_x86_64_arch_bed): New variable. + (elf_backend_arch_data): New macro. + (elf_x86_64_adjust_dynamic_symbol): Use GET_PLT_ENTRY_SIZE. + (elf_x86_64_allocate_dynrelocs): Likewise. + (elf_x86_64_relocate_section): Likewise. + (elf_x86_64_plt_sym_val): Likewise. + (elf_x86_64_finish_dynamic_symbol): Use elf_x86_64_backend_data + parameters for PLT details. + (elf_x86_64_finish_dynamic_sections): Likewise. + +2012-03-14 Roland McGrath + + * elf32-i386.c (elf_i386_nacl_pic_plt0_entry): Initialize up + to the full size, padding out with nop instructions. + +2012-03-12 Alan Modra + + * elf-m10300.c (_bfd_mn10300_elf_adjust_dynamic_symbol): Don't warn + on zero size dynbss symbol. + * elf32-arm.c (elf32_arm_adjust_dynamic_symbol): Likewise. + * elf32-cr16.c (_bfd_cr16_elf_adjust_dynamic_symbol): Likewise. + * elf32-cris.c (elf_cris_adjust_dynamic_symbol): Likewise. + * elf32-hppa.c (elf32_hppa_adjust_dynamic_symbol): Likewise. + * elf32-i370.c (i370_elf_adjust_dynamic_symbol): Likewise. + * elf32-i386.c (elf_i386_adjust_dynamic_symbol): Likewise. + * elf32-lm32.c (lm32_elf_adjust_dynamic_symbol): Likewise. + * elf32-m32r.c (m32r_elf_adjust_dynamic_symbol): Likewise. + * elf32-m68k.c (elf_m68k_adjust_dynamic_symbol): Likewise. + * elf32-ppc.c (ppc_elf_adjust_dynamic_symbol): Likewise. + * elf32-s390.c (elf_s390_adjust_dynamic_symbol): Likewise. + * elf32-sh.c (sh_elf_adjust_dynamic_symbol): Likewise. + * elf32-tic6x.c (elf32_tic6x_adjust_dynamic_symbol): Likewise. + * elf32-tilepro.c (tilepro_elf_adjust_dynamic_symbol): Likewise. + * elf32-vax.c (elf_vax_adjust_dynamic_symbol): Likewise. + * elf64-ppc.c (ppc64_elf_adjust_dynamic_symbol): Likewise. + * elf64-s390.c (elf_s390_adjust_dynamic_symbol): Likewise. + * elf64-sh64.c (sh64_elf64_adjust_dynamic_symbol): Likewise. + * elf64-x86-64.c (elf_x86_64_adjust_dynamic_symbol): Likewise. + * elfxx-sparc.c (_bfd_sparc_elf_adjust_dynamic_symbol): Likewise. + * elfxx-tilegx.c (tilegx_elf_adjust_dynamic_symbol): Likewise. + +2012-03-10 Edmar Wienskoski + + * archures.c: Add bfd_mach_ppc_e5500 and bfd_mach_ppc_e6500. + * bfd-in2.h: Regenerate. + * cpu-powerpc.c (bfd_powerpc_archs): Add entries for + bfd_mach_ppc_e5500 and bfd_mach_ppc_e6500. + +2012-03-09 H.J. Lu + + PR ld/13817 + * elf32-i386.c (elf_i386_relocate_section): Restore + R_386_IRELATIVE. + + * elf64-x86-64.c (elf_x86_64_relocate_section): Restore + R_X86_64_IRELATIVE. + +2012-03-08 Tristan Gingold + + * vms-lib.c (_bfd_vms_lib_write_archive_contents): Set maximum + keylen according to archive kind. Set nextvbn and nextrfa lhd + fields. Add comments. + +2012-03-07 Nick Clifton + + * elf-m10300.c (elf32_mn10300_link_hash_entry): Add tls_type + field. + (elf32_mn10300_link_hash_table): Add tls_ldm_got entry; + (elf_mn10300_tdata): Define. + (elf_mn10300_local_got_tls_type): Define. + (elf_mn10300_howto_table): Add entries for R_MN10300_TLS_GD, + R_MN10300_TLS_LD, R_MN10300_TLS_LDO, R_MN10300_TLS_GOTIE, + R_MN10300_TLS_IE, R_MN10300_TLS_LE, R_MN10300_TLS_DPTMOD, + R_MN10300_TLS_DTPOFF, R_MN10300_TLS_TPOFF relocs. + (mn10300_reloc_map): Likewise. + (elf_mn10300_tls_transition): New function. + (dtpoff, tpoff, mn10300_do_tls_transition): New functions. + (mn10300_elf_check_relocs): Add TLS support. + (mn10300_elf_final_link_relocate): Likewise. + (mn10300_elf_relocate_section): Likewise. + (mn10300_elf_relax_section): Likewise. + (elf32_mn10300_link_hash_newfunc): Initialise new field. + (_bfd_mn10300_copy_indirect_symbol): New function. + (elf32_mn10300_link_hash_table_create): Initialise new fields. + (_bfd_mn10300_elf_size_dynamic_sections): Add TLS support. + (_bfd_mn10300_elf_finish_dynamic_symbol): Likewise. + (_bfd_mn10300_elf_reloc_type_class): Allocate an + elf_mn10300_obj_tdata structure. + (elf_backend_copy_indirect_symbol): Define. + * reloc.c (BFD_MN10300_TLS_GD, BFD_MN10300_TLS_LD, + BFD_MN10300_TLS_LDO, BFD_MN10300_TLS_GOTIE, BFD_MN10300_TLS_IE, + BFD_MN10300_TLS_LE, BFD_MN10300_TLS_DPTMOD, + BFD_MN10300_TLS_DTPOFF, BFD_MN10300_TLS_TPOFF): New relocations. + (BFD_RELOC_MN10300_32_PCREL, BFD_RELOC_MN10300_16_PCREL): Move to + alongside other MN10300 relocations. + * bfd-in2.h: Regenerate. + * libbfd.h: Regenerate. + +2012-03-06 Jakub Jelinek + + * elf64-x86-64.c (elf_x86_64_relocate_section): For R_X86_64_RELATIVE + set relocate to TRUE. + +2012-03-05 Rainer Orth + + PR ld/12152 + * elfxx-sparc.c (_bfd_sparc_elf_relocate_section): Also ignore + overflows for R_SPARC_UA32 in .stab sections. + +2012-03-01 Alan Modra + + * elfxx-tilegx.c (tilegx_elf_relocate_section): Silence bogus warning. + +2012-02-27 Alan Modra + + * elf32-sh.c (sh_elf_osec_to_segment): Check for elf flavour bfd + before calling elf specific function. + (sh_elf_osec_readonly_p): Test for error return from above. + +2012-02-27 Alan Modra + + * elf32-spu.c (build_stub): Fix malloc under-allocation. + +2012-02-25 Walter Lee + * reloc.c: Add BFD_RELOC_TILEPRO_TLS_GD_CALL, + BFD_RELOC_TILEPRO_IMM8_X0_TLS_GD_ADD, + BFD_RELOC_TILEPRO_IMM8_X1_TLS_GD_ADD, + BFD_RELOC_TILEPRO_IMM8_Y0_TLS_GD_ADD, + BFD_RELOC_TILEPRO_IMM8_Y1_TLS_GD_ADD, + BFD_RELOC_TILEPRO_TLS_IE_LOAD, BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE, + BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE, + BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_LO, + BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_LO, + BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HI, + BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HI, + BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HA, + BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HA, + BFD_RELOC_TILEGX_IMM16_X0_HW0_TLS_LE, + BFD_RELOC_TILEGX_IMM16_X1_HW0_TLS_LE, + BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_TLS_LE, + BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_TLS_LE, + BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_TLS_LE, + BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_TLS_LE, + BFD_RELOC_TILEGX_TLS_GD_CALL, BFD_RELOC_TILEGX_IMM8_X0_TLS_GD_ADD, + BFD_RELOC_TILEGX_IMM8_X1_TLS_GD_ADD, + BFD_RELOC_TILEGX_IMM8_Y0_TLS_GD_ADD, + BFD_RELOC_TILEGX_IMM8_Y1_TLS_GD_ADD, BFD_RELOC_TILEGX_TLS_IE_LOAD, + BFD_RELOC_TILEGX_IMM8_X0_TLS_ADD, + BFD_RELOC_TILEGX_IMM8_X1_TLS_ADD, + BFD_RELOC_TILEGX_IMM8_Y0_TLS_ADD, BFD_RELOC_TILEGX_IMM8_Y1_TLS_ADD. + Delete BFD_RELOC_TILEGX_IMM16_X0_HW1_GOT, + BFD_RELOC_TILEGX_IMM16_X1_HW1_GOT, + BFD_RELOC_TILEGX_IMM16_X0_HW2_GOT, + BFD_RELOC_TILEGX_IMM16_X1_HW2_GOT, + BFD_RELOC_TILEGX_IMM16_X0_HW3_GOT, + BFD_RELOC_TILEGX_IMM16_X1_HW3_GOT, + BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_GOT, + BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_GOT, + BFD_RELOC_TILEGX_IMM16_X0_HW1_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X1_HW1_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X0_HW2_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X1_HW2_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X0_HW3_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X1_HW3_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_TLS_GD, + BFD_RELOC_TILEGX_IMM16_X0_HW1_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X1_HW1_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X0_HW2_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X1_HW2_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X0_HW3_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X1_HW3_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_TLS_IE, + BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_TLS_IE. + * elf32-tilepro.c (tilepro_elf_howto_table): Update tilepro + relocations. + (tilepro_reloc_map): Ditto. + (tilepro_info_to_howto_rela): Ditto. + (reloc_to_create_func): Ditto. + (tilepro_tls_translate_to_le): New. + (tilepro_tls_translate_to_ie): New. + (tilepro_elf_tls_transition): New. + (tilepro_elf_check_relocs): Handle new tls relocations. + (tilepro_elf_gc_sweep_hook): Ditto. + (allocate_dynrelocs): Ditto. + (tilepro_elf_relocate_section): Ditto. + (tilepro_replace_insn): New. + (insn_mask_X1): New. + (insn_mask_X0_no_dest_no_srca): New + (insn_mask_X1_no_dest_no_srca): New + (insn_mask_Y0_no_dest_no_srca): New + (insn_mask_Y1_no_dest_no_srca): New + (srca_mask_X0): New + (srca_mask_X1): New + (insn_tls_le_move_X1): New + (insn_tls_le_move_zero_X0X1): New + (insn_tls_ie_lw_X1): New + (insn_tls_ie_add_X0X1): New + (insn_tls_ie_add_Y0Y1): New + (insn_tls_gd_add_X0X1): New + (insn_tls_gd_add_Y0Y1): New + * elfxx-tilegx.c (tilegx_elf_howto_table): Update tilegx + relocations. + (tilegx_reloc_map): Ditto. + (tilegx_info_to_howto_rela): Ditto. + (reloc_to_create_func): Ditto. + (tilegx_elf_link_hash_table): New field disable_le_transition. + (tilegx_tls_translate_to_le): New. + (tilegx_tls_translate_to_ie): New. + (tilegx_elf_tls_transition): New. + (tilegx_elf_check_relocs): Handle new tls relocations. + (tilegx_elf_gc_sweep_hook): Ditto. + (allocate_dynrelocs): Ditto. + (tilegx_elf_relocate_section): Ditto. + (tilegx_copy_bits): New. + (tilegx_replace_insn): New. + (insn_mask_X1): New. + (insn_mask_X0_no_dest_no_srca): New. + (insn_mask_X1_no_dest_no_srca): New. + (insn_mask_Y0_no_dest_no_srca): New. + (insn_mask_Y1_no_dest_no_srca): New. + (insn_mask_X0_no_operand): New. + (insn_mask_X1_no_operand): New. + (insn_mask_Y0_no_operand): New. + (insn_mask_Y1_no_operand): New. + (insn_tls_ie_ld_X1): New. + (insn_tls_ie_ld4s_X1): New. + (insn_tls_ie_add_X0X1): New. + (insn_tls_ie_add_Y0Y1): New. + (insn_tls_ie_addx_X0X1): New. + (insn_tls_ie_addx_Y0Y1): New. + (insn_tls_gd_add_X0X1): New. + (insn_tls_gd_add_Y0Y1): New. + (insn_move_X0X1): New. + (insn_move_Y0Y1): New. + (insn_add_X0X1): New. + (insn_add_Y0Y1): New. + (insn_addx_X0X1): New. + (insn_addx_Y0Y1): New. + * libbfd.h: Regenerate. + * bfd-in2.h: Regenerate. + +2012-02-25 Walter Lee + + * config.bfd (tilegx-*-*): rename little endian vector; add big + endian vector. + (tilegxbe-*-*): New case. + * configure.in (bfd_elf32_tilegx_vec): Rename... + (bfd_elf32_tilegx_le_vec): ... to this. + (bfd_elf32_tilegx_be_vec): New vector. + (bfd_elf64_tilegx_vec): Rename... + (bfd_elf64_tilegx_le_vec): ... to this. + (bfd_elf64_tilegx_be_vec): New vector. + * configure: Regenerate. + * elf32-tilegx.c (TARGET_LITTLE_SYM): Rename. + (TARGET_LITTLE_NAME): Ditto. + (TARGET_BIG_SYM): Define. + (TARGET_BIG_NAME): Define. + * elf64-tilegx.c (TARGET_LITTLE_SYM): Rename. + (TARGET_LITTLE_NAME): Ditto. + (TARGET_BIG_SYM): Define. + (TARGET_BIG_NAME): Define. + * targets.c (bfd_elf32_tilegx_vec): Rename... + (bfd_elf32_tilegx_le_vec): ... to this. + (bfd_elf32_tilegx_be_vec): Declare. + (bfd_elf64_tilegx_vec): Rename... + (bfd_elf64_tilegx_le_vec): ... to this. + (bfd_elf64_tilegx_be_vec): Declare. + (_bfd_target_vector): Add / rename above vectors. + * arctures.c (bfd_architecture): Define bfd_mach_tilegx32. + * bfd-in2.h: Regenerate. + * cpu-tilegx.c (bfd_tilegx32_arch): define. + (bfd_tilegx_arch): link to bfd_tilegx32_arch. + +2012-02-24 Nick Clifton + + PR ld/13730 + * reloc.c (bfd_generic_get_relocated_section_contents): Issue an + error message instead of aborting, when an outofrange reloc is + encountered. + +2012-02-23 Iain Sandoe + + * mach-o.c (bfd_mach_o_swap_in_non_scattered_reloc): New. + (bfd_mach_o_canonicalize_one_reloc): Swap non-scattered reloc + bit-fields when target and host differ in endian-ness. When + PAIRs are non-scattered find the 'symbol' from the preceding + reloc. Add FIXME re. reloc symbols on section boundaries. + (bfd_mach_o_swap_out_non_scattered_reloc): New. + (bfd_mach_o_write_relocs): Use bfd_mach_o_encode_non_scattered_reloc. + +2012-02-17 Iain Sandoe + + * mach-o-i386.c (i386_howto_table): Add support for 16 bit + sect-diffs. + (bfd_mach_o_i386_swap_reloc_in): Handle 16bit sect-diffs. + (bfd_mach_o_i386_swap_reloc_out): Likewise. + +2012-02-17 Tristan Gingold + + * reloc.c (BFD_RELOC_MACH_O_LOCAL_SECTDIFF): + * libbfd.h: Regenerated. + * bfd-in2.h: Likewise. + * mach-o-i386.c (i386_howto_table): Include local sectdiff. + (bfd_mach_o_i386_swap_reloc_in): Update for local sectdiff. + (bfd_mach_o_i386_swap_reloc_out): Likewise. + +2012-02-17 Andreas Krebbel + + * elf32-s390.c (elf_s390_relocate_section): Support basr in the + GD->LE and LD->LE optimizations. + +2012-02-16 Alan Modra + + PR binutils/13355 + * elf32-rx.c (elf32_rx_relax_section): Correct width check. + +2012-02-13 Richard Henderson + + PR ld/13621 + * linker.c (fix_syms): Force symbols outside any section into + bfd_abs_section_ptr. + +2012-02-13 Alan Modra + + * elf32-m68hc1x.c (elf32_m68hc11_merge_symbol_attribute): New function. + * elf32-m68hc1x.h (elf32_m68hc11_merge_symbol_attribute): Declare. + * elf32-m68hc11.c (elf_backend_merge_symbol_attribute): Define. + * elf32-m68hc12.c (elf_backend_merge_symbol_attribute): Define. + +2012-02-11 Jan Kratochvil + Nick Clifton + + * oasys.c (oasys_write_header): Fix compilation warning on zero-sized + memset. + +2012-02-10 Iain Sandoe + + * mach-o.c (bfd_mach_o_build_seg_command): Count zerofill section + vma additions in their logical, rather than physical order. + +2012-02-10 Iain Sandoe + + * mach-o.c (mach_o_section_name_xlat): Correct eh-frame section + parameters. + * mach-o-x86-64.c (text_section_names_xlat): New. + (mach_o_x86_64_segsec_names_xlat): New. + (bfd_mach_o_tgt_seg_table): Define to mach_o_x86_64_segsec_names_xlat. + * mach-o-i386.c (text_section_names_xlat): Correct section parameters. + +2012-02-10 Tristan Gingold + + * elfnn-ia64.c (elfNN_vms_object_p): Change comparison operator + to avoid infinite loop. Add comments. + +2012-02-09 H.J. Lu + + PR ld/13675 + * cpu-i386.c (bfd_arch_i386_fill): Updated to support multi byte + nop instructions. + (bfd_arch_i386_short_nop_fill): New. + (bfd_arch_i386_long_nop_fill): Likewise. + Use bfd_arch_i386_short_nop_fill in 32bit bfd_arch_info + initializers. Use bfd_arch_i386_long_nop_fill on 64bit + bfd_arch_info initializers. + + * cpu-k1om.c (bfd_arch_i386_fill): Renamed to ... + (bfd_arch_i386_short_nop_fill): This. + Update bfd_arch_info initializers. + * cpu-l1om.c: Likewise. + +2012-02-08 Alan Modra + + * elflink.c (_bfd_elf_gc_mark_rsec): Mark weakdef syms too. + (_bfd_elf_fix_symbol_flags): When a weakdef is def_regular, clear + the correct h->u.weakdef. + +2012-02-07 Alan Modra + + * elf.c (elf_find_function): Don't use internal_elf_sym. + (_bfd_elf_maybe_function_sym): Likewise. Replace elf_symbol_type + parameter with asymbol. + * elf64-ppc.c (ppc64_elf_maybe_function_sym): Likewise. + * elf-bfd.h (_bfd_elf_maybe_function_sym): Update prototype. + (struct elf_backend_data ): Likewise. + +2012-02-02 Vidya Praveen (vidya.praveen@atmel.com) + + PR bfd/13410 + * elf32-avr.c (elf32_avr_relax_section): Correct the + condition that qualifies the candidates for relaxation. + +2012-02-02 Tristan Gingold + + * bfdio.c (real_fopen): Remove unused vms_modes variable. + +2012-02-02 Tristan Gingold + + * mach-o.c (bfd_mach_o_read_header): Silent uninitialized + variable warning. + +2012-02-02 Tristan Gingold + + * archive.c (bfd_slurp_armap): Fix thinko in cast. + +2012-01-31 H.J. Lu + + PR ld/13616 + * archures.c (bfd_arch_info): Add fill. + (bfd_default_arch_struct): Add bfd_arch_default_fill. + (bfd_arch_default_fill): New. + + * configure.in: Set bfd version to 2.22.52. + * configure: Regenerated. + + * cpu-alpha.c: Add bfd_arch_default_fill to bfd_arch_info + initializer. + * cpu-arc.c: Likewise. + * cpu-arm.c: Likewise. + * cpu-avr.c: Likewise. + * cpu-bfin.c: Likewise. + * cpu-cr16.c: Likewise. + * cpu-cr16c.c: Likewise. + * cpu-cris.c: Likewise. + * cpu-crx.c: Likewise. + * cpu-d10v.c: Likewise. + * cpu-d30v.c: Likewise. + * cpu-dlx.c: Likewise. + * cpu-epiphany.c: Likewise. + * cpu-fr30.c: Likewise. + * cpu-frv.c: Likewise. + * cpu-h8300.c: Likewise. + * cpu-h8500.c: Likewise. + * cpu-hppa.c: Likewise. + * cpu-i370.c: Likewise. + * cpu-i860.c: Likewise. + * cpu-i960.c: Likewise. + * cpu-ia64.c: Likewise. + * cpu-ip2k.c: Likewise. + * cpu-iq2000.c: Likewise. + * cpu-lm32.c: Likewise. + * cpu-m10200.c: Likewise. + * cpu-m10300.c: Likewise. + * cpu-m32c.c: Likewise. + * cpu-m32r.c: Likewise. + * cpu-m68hc11.c: Likewise. + * cpu-m68hc12.c: Likewise. + * cpu-m68k.c: Likewise. + * cpu-m88k.c: Likewise. + * cpu-mcore.c: Likewise. + * cpu-mep.c: Likewise. + * cpu-microblaze.c: Likewise. + * cpu-mips.c: Likewise. + * cpu-mmix.c: Likewise. + * cpu-moxie.c: Likewise. + * cpu-msp430.c: Likewise. + * cpu-mt.c: Likewise. + * cpu-ns32k.c: Likewise. + * cpu-openrisc.c: Likewise. + * cpu-or32.c: Likewise. + * cpu-pdp11.c: Likewise. + * cpu-pj.c: Likewise. + * cpu-plugin.c: Likewise. + * cpu-powerpc.c: Likewise. + * cpu-rl78.c: Likewise. + * cpu-rs6000.c: Likewise. + * cpu-rx.c: Likewise. + * cpu-s390.c: Likewise. + * cpu-score.c: Likewise. + * cpu-sh.c: Likewise. + * cpu-sparc.c: Likewise. + * cpu-spu.c: Likewise. + * cpu-tic30.c: Likewise. + * cpu-tic4x.c: Likewise. + * cpu-tic54x.c: Likewise. + * cpu-tic6x.c: Likewise. + * cpu-tic80.c: Likewise. + * cpu-tilegx.c: Likewise. + * cpu-tilepro.c: Likewise. + * cpu-v850.c: Likewise. + * cpu-vax.c: Likewise. + * cpu-w65.c: Likewise. + * cpu-we32k.c: Likewise. + * cpu-xc16x.c: Likewise. + * cpu-xstormy16.c: Likewise. + * cpu-xtensa.c: Likewise. + * cpu-z80.c: Likewise. + * cpu-z8k.c: Likewise. + + * cpu-i386.c: Include "libiberty.h". + (bfd_arch_i386_fill): New. + Add bfd_arch_i386_fill to bfd_arch_info initializer. + + * cpu-k1om.c: Add bfd_arch_i386_fill to bfd_arch_info initializer. + * cpu-l1om.c: Likewise. + + * linker.c (default_data_link_order): Call abfd->arch_info->fill + if fill size is 0. + + * bfd-in2.h: Regenerated. + +2012-01-27 Michael Eager + + * elf32-microblaze.c (create_got_section): + Reuse existing .rela.got section. + +2012-01-23 Alan Modra + + * elf-bfd.h: Formatting. + (struct elf_backend_data): Add "maybe_function_sym". + (_bfd_elf_maybe_function_sym): Declare. + * elfxx-target.h (elf_backend_maybe_function_sym): Define. + (elfNN_bed): Init new field. + * elf.c (elf_find_function): Use maybe_function_sym. + (_bfd_elf_maybe_function_sym): New function. + * elf64-ppc.c (elf_backend_maybe_function_sym): Define. + (ppc64_elf_maybe_function_sym): New function. + +2012-01-20 Francois Gouget + + PR binutils/13534 + * archive.c (_bfd_ar_sizepad): New function. Correctly install and + pad the size field in an archive header. + (_bfd_generic_read_ar_hdr_mag): Use the correct type and scan + function for the archive size field. + (bfd_generic_openr_next_archived_file): Likewise. + (do_slurp_coff_armap): Likewise. + (_bfd_write_archive_contents): Likewise. + (_bfd_bsd44_write_ar_hdr): Use the new function. + (bfd_ar_hdr_from_filesystem): Likewise. + (_bfd_write_archive_contents): Likewise. + (bsd_write_armap): Likewise. + (coff_write_armap): Likewise. + * archive64.c (bfd_elf64_archive_write_armap): Likewise. + * bfdio.c (bfd_bread): Use correct type for archive element + sizes. + * ar.c (open_inarch): Likewise. + (extract_file): Likewise. + * libbfd-in.h (struct areltdata): Use correct types for + parsed_size and extra_size fields. + Prototype _bfd_ar_sizepad function. + * libbfd.h: Regenerate. + +2012-01-20 Ulrich Weigand + + * elf.c (elfcore_write_prpsinfo): Provide unconditionally. + Return NULL if core file generation is unsupported. + (elfcore_write_prstatus): Likewise. + * elf32-arm.c (elf32_arm_nabi_write_core_note): New function. + (elf_backend_write_core_note): Define. + +2012-01-19 Tristan Gingold + + * pef.c: Add a comment. + * xsym.c: Likewise. + +2012-01-17 Alan Modra + + * elf32-ppc.c (ppc_elf_write_core_note ): Don't leave + trailing garbage in the note. + * elf64-ppc.c (ppc64_elf_write_core_note ): Likewise. + +2012-01-16 Daniel Green + + PR ld/13491 + * coff-i386.c (coff_i386_rtype_to_howto ): Test + h->root.type not h->type. + * coff-x86_64.c (coff_amd64_rtype_to_howto ): Likewise. + +2012-01-13 Iain Sandoe + + * mach-o.c (bfd_mach_o_build_dysymtab_command): Handle absolute + indirect symbols. + +2012-01-13 Iain Sandoe + + * mach-o.c (bfd_mach_o_write_relocs): Move computation of relocs file + position from here... to (bfd_mach_o_build_seg_command): Here. + +2012-01-12 Iain Sandoe + + * mach-o.c (bfd_mach_o_count_indirect_symbols): New. + (bfd_mach_o_build_dysymtab_command): Populate indirect symbol table. + * mach-o.h (bfd_mach_o_asymbol): Move declaration to start of the + file. (bfd_mach_o_section): Add indirect_syms field. + +2012-01-11 Iain Sandoe + + * mach-o.c (bfd_mach_o_build_seg_command): Separate computation of + vmsize from filesize. Don't compute offsets or file sizes for + zerofill sections. + +2012-01-11 Iain Sandoe + + * mach-o.c (bfd_mach_o_build_commands): Make the building of each + command type independent. + +2012-01-11 Alan Modra + + * elf64-ppc.c: Define more insns used in plt call stubs. + (ppc64_elf_brtaken_reloc): Assume isa version 2 or above. + (ppc64_elf_relocate_section): Likewise. + (enum ppc_stub_type): Add ppc_stub_plt_call_r2save. + (struct ppc_link_hash_table): Increase size of stub_count array. + Add plt_stub_align and plt_thread_safe. + (ALWAYS_USE_FAKE_DEP, ALWAYS_EMIT_R2SAVE): Define. + (plt_stub_size, plt_stub_pad): New functions. + (build_plt_stub): Emit barriers for power7 thread safety. Don't + emit needless save of r2. + (build_tls_get_addr_stub): Adjust params. + (ppc_build_one_stub): Handle ppc_stub_plt_call_r2save and aligning + plt stubs. Adjust build_*plt_stub calls. + (ppc_size_one_stub): Similarly. + (ppc64_elf_size_stubs): Accept plt_thread_safe and plt_stub_align + params. Choose default for plt_thread_safe based on existence of + calls to thread creation functions. Modify plt_call to + plt_call_r2save when no tocsave reloc found. Align tail of stub + sections. + (ppc64_elf_build_stubs): Align tail of stub sections. Adjust + output of stub statistics. + (ppc64_elf_relocate_section): Handle ppc_stub_plt_call_r2save. + * elf64-ppc.h (ppc64_elf_size_stubs): Update prototype. + +2012-01-10 H.J. Lu + + PR ld/13581 + * elf64-x86-64.c (elf_x86_64_relocate_section): Remove ABI_64_P + check on R_X86_64_PCXX. + +2012-01-10 Tristan Gingold + + * mach-o.c (bfd_mach_o_build_commands): Avoid uninitialized false + warning. + +2012-01-10 Tristan Gingold + + * bfdio.c (bfd_tell): Handle nested archives. + (bfd_seek): Ditto. + * cache.c (bfd_cache_lookup_worker): Ditto. + * archive.c (_bfd_get_elt_at_filepos): Remove code dealing with + nested archives. + (bfd_generic_openr_next_archived_file): Likewise. + +2012-01-09 Iain Sandoe + + * mach-o.c (bfd_mach_o_bfd_copy_private_symbol_data): Implement. + (bfd_mach_o_write_symtab): Remove handling for indirect syms. + (bfd_mach_o_primary_symbol_sort_key): Likewise. + (bfd_mach_o_cf_symbols): Likewise. + (bfd_mach_o_sort_symbol_table): Remove. + (bfd_mach_o_mangle_symbols): Adjust arguments, remove handling + for indirect and dysymtab counts. Do the symbol sorting here. + (bfd_mach_o_build_dysymtab_command): Count the symbol types here. + Make the indirect symbols a TODO. + (bfd_mach_o_build_commands): Adjust call to bfd_mach_o_mangle_symbols. + (bfd_mach_o_make_empty_symbol): Specifically flag unset symbols with + a non-zero value. + (bfd_mach_o_read_symtab_symbol): Record the symbol index. + (bfd_mach_o_read_symtab_symbol): Adjust recording of global status. + * mach-o.h (mach_o_data_struct): Remove indirect and dysymtab entries. + (IS_MACHO_INDIRECT): Remove. + (SYM_MACHO_FIELDS_UNSET, SYM_MACHO_FIELDS_NOT_VALIDATED): New. + +2012-01-06 Nick Clifton + + PR binutils/13121 + * reloc.c (bfd_generic_lookup_section_flags): Rename 'finfo' to + 'flaginfo' to avoid conflicts with AIX system headers. + +2012-01-06 Tristan Gingold + + * bfdio.c (bfd_bread): Use arelt_size macro. + +2012-01-06 Tristan Gingold + + * config.bfd (i[3-7]86-*-darwin*): Define targ64_selvecs. + +2012-01-05 Nick Clifton + + PR ld/12161 + * elf32-avr.c (elf32_avr_relax_delete_bytes): Read in relocs if + necessary. + +2012-01-05 Jan Kratochvil + + Fix zero registers core files when built by gcc-4.7. + * elf64-x86-64.c (elf_x86_64_write_core_note): Remove variables p and + size. Call elfcore_write_note for the local variables. Remove the + final elfcore_write_note call. Add NOTREACHED comments. + +2012-01-04 Tristan Gingold + + * mach-o.c (bfd_mach_o_fat_stat_arch_elt): New function. + (bfd_mach_o_generic_stat_arch_elt): Adjust. + +2012-01-04 Tristan Gingold + + * mach-o.c (bfd_mach_o_fat_member_init): New function. + (bfd_mach_o_openr_next_archived_file): Reindent. + Adjust to call bfd_mach_o_fat_member_init. + (bfd_mach_o_fat_extract): Adjust to call bfd_mach_o_fat_member_init. + +2012-01-04 Tristan Gingold + + * mach-o-x86-64.c (bfd_mach_o_x86_64_swap_reloc_out): Handle + BFD_RELOC_32, BFD_RELOC_MACH_O_X86_64_PCREL32_1, + BFD_RELOC_MACH_O_X86_64_PCREL32_2, + BFD_RELOC_MACH_O_X86_64_PCREL32_4, + BFD_RELOC_MACH_O_X86_64_BRANCH32, + BFD_RELOC_MACH_O_X86_64_SUBTRACTOR32, + BFD_RELOC_MACH_O_X86_64_GOT. + +2012-01-04 Tristan Gingold + + * mach-o.h (bfd_mach_o_fvmlib_command): New structure. + (bfd_mach_o_load_command): Add fvmlib field. + + * mach-o.c (bfd_mach_o_read_fvmlib): New function. + (bfd_mach_o_read_command): Handle fvmlib. + +2012-01-04 Tristan Gingold + + * mach-o.c (bfd_mach_o_convert_architecture): Reindent. + Decode msubtype for ARM. + +2012-01-04 Tristan Gingold + + * mach-o.c (bfd_mach_o_get_synthetic_symtab): Add comments. + +2012-01-04 Tristan Gingold + + * mach-o.h: Reindent header. + (bfd_mach_o_encryption_info_command): New structure. + (bfd_mach_o_load_command): Add encryption_info field. + + * mach-o.c (bfd_mach_o_read_encryption_info): New function. + (bfd_mach_o_read_command): Handle BFD_MACH_O_LC_ENCRYPTION_INFO. + (bfd_mach_o_read_command): Adjust error message. + +2012-01-04 Shinichiro Hamaji + + * dwarf2.c (_bfd_dwarf2_slurp_debug_info): Factor out the part + which reads DWARF2 and stores in stash from find_line. + (find_line) Call _bfd_dwarf2_slurp_debug_info. + * libbfd-in.h (_bfd_dwarf2_slurp_debug_info): Add declaration. + * libbfd.h (_bfd_dwarf2_slurp_debug_info): Regenerate. + * mach-o.c (dsym_subdir): The name of subdir where debug + information may be stored. + (bfd_mach_o_lookup_uuid_command): New. Lookup a load command whose + type is UUID. + (bfd_mach_o_dsym_for_uuid_p): New. Check if the specified BFD is + corresponding to the executable. + (bfd_mach_o_find_dsym): New. Find a debug information BFD in the + specified binary file. + (bfd_mach_o_follow_dsym): New. Find a debug information BFD for + the original BFD. + (bfd_mach_o_find_nearest_line): Check dSYM files for Mach-O + executables, dylibs, and bundles. + (bfd_mach_o_close_and_cleanup): Clean up BFDs for the dSYM file. + * mach-o.h (dsym_bfd): The BFD of the dSYM file. + +2012-01-03 Iain Sandoe + + * mach-o.c (bfd_mach_o_mangle_symbols): Put in the section index + for stabd symbols. + (bfd_mach_o_primary_symbol_sort_key): Adjust for stabs. + (bfd_mach_o_cf_symbols): Likewise. + +2012-01-03 Iain Sandoe + + * mach-o.c (bfd_mach_o_mangle_symbols): Correct typo. + +2012-01-03 Iain Sandoe + + * mach-o.c (bfd_mach_o_write_symtab): Fill in the string table index + as the value of an indirect symbol. Keep the string table index in + non-indirect syms for reference. + (bfd_mach_o_write_dysymtab): New. + (bfd_mach_o_primary_symbol_sort_key): New. + (bfd_mach_o_cf_symbols): New. + (bfd_mach_o_sort_symbol_table): New. + (bfd_mach_o_mangle_symbols): Return early if no symbols. Sort symbols. + If we are emitting a dysymtab, process indirect symbols and count the + number of each other kind. + (bfd_mach_o_mangle_sections): New. + (bfd_mach_o_write_contents): Split out some pre-requisite code into + the command builder. Write dysymtab if the command is present. + (bfd_mach_o_count_sections_for_seg): New. + (bfd_mach_o_build_seg_command): New. + (bfd_mach_o_build_dysymtab_command): New. + (bfd_mach_o_build_commands): Reorganize to support the fact that some + commands are optional and should not be emitted if there are no + sections or symbols. + (bfd_mach_o_set_section_contents): Amend comment. + * mach-o.h: Amend and add to comments. + (mach_o_data_struct): Add fields for dysymtab symbols counts and a + pointer to the indirects, when present. + (bfd_mach_o_should_emit_dysymtab): New macro. + (IS_MACHO_INDIRECT): Likewise. + +For older changes see ChangeLog-2011 + +Copyright (C) 2012 Free Software Foundation, Inc. + +Copying and distribution of this file, with or without modification, +are permitted in any medium without royalty provided the copyright +notice and this notice are preserved. + +Local Variables: +mode: change-log +left-margin: 8 +fill-column: 74 +version-control: never +End: diff --git a/bfd/config.bfd b/bfd/config.bfd index 43edd4c4014..f72803c0c47 100644 --- a/bfd/config.bfd +++ b/bfd/config.bfd @@ -1,6 +1,6 @@ # config.bfd # -# Copyright 2012 Free Software Foundation +# Copyright 2012, 2013 Free Software Foundation # # This file is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -378,7 +378,7 @@ case "${targ}" in targ_underscore=yes ;; - cr16-*-elf*) + cr16-*-elf* | cr16*-*-uclinux*) targ_defvec=bfd_elf32_cr16_vec targ_underscore=yes ;; diff --git a/include/opcode/ChangeLog b/include/opcode/ChangeLog index 560837ffaee..891a51599fc 100644 --- a/include/opcode/ChangeLog +++ b/include/opcode/ChangeLog @@ -1,3 +1,9 @@ +2013-01-02 Kaushik Phatak + + * cr16.h (dwordU,wordU): Moved typedefs from cr16-dis.c + (make_instruction,match_opcode): Added function prototypes. + (cr16_words,cr16_allWords,cr16_currInsn): Declare as extern. + 2012-11-23 Alan Modra * ppc.h (ppc_parse_cpu): Update prototype. diff --git a/include/opcode/cr16.h b/include/opcode/cr16.h index 2d322882e4c..76ac3a6bc19 100644 --- a/include/opcode/cr16.h +++ b/include/opcode/cr16.h @@ -1,5 +1,5 @@ /* cr16.h -- Header file for CR16 opcode and register tables. - Copyright 2007, 2008, 2010 Free Software Foundation, Inc. + Copyright 2007, 2008, 2010, 2013 Free Software Foundation, Inc. Contributed by M R Swami Reddy This file is part of GAS, GDB and the GNU binutils. @@ -26,21 +26,21 @@ Therefore, order MUST be preserved. */ typedef enum - { - /* 16-bit general purpose registers. */ - r0, r1, r2, r3, - r4, r5, r6, r7, - r8, r9, r10, r11, - r12_L = 12, r13_L = 13, ra = 14, sp_L = 15, - - /* 32-bit general purpose registers. */ - r12 = 12, r13 = 13, r14 = 14, r15 = 15, - era = 14, sp = 15, RA, - - /* Not a register. */ - nullregister, - MAX_REG - } +{ + /* 16-bit general purpose registers. */ + r0, r1, r2, r3, + r4, r5, r6, r7, + r8, r9, r10, r11, + r12_L = 12, r13_L = 13, ra = 14, sp_L = 15, + + /* 32-bit general purpose registers. */ + r12 = 12, r13 = 13, r14 = 14, r15 = 15, + era = 14, sp = 15, RA, + + /* Not a register. */ + nullregister, + MAX_REG +} reg; /* CR16 processor registers and special registers : @@ -48,33 +48,33 @@ reg; (cr16_pregtab). Therefore, order MUST be preserved. */ typedef enum - { - /* processor registers. */ - dbs = MAX_REG, - dsr, dcrl, dcrh, - car0l, car0h, car1l, car1h, - cfg, psr, intbasel, intbaseh, - ispl, isph, uspl, usph, - dcr = dcrl, - car0 = car0l, - car1 = car1l, - intbase = intbasel, - isp = ispl, - usp = uspl, - /* Not a processor register. */ - nullpregister = usph + 1, - MAX_PREG - } +{ + /* processor registers. */ + dbs = MAX_REG, + dsr, dcrl, dcrh, + car0l, car0h, car1l, car1h, + cfg, psr, intbasel, intbaseh, + ispl, isph, uspl, usph, + dcr = dcrl, + car0 = car0l, + car1 = car1l, + intbase = intbasel, + isp = ispl, + usp = uspl, + /* Not a processor register. */ + nullpregister = usph + 1, + MAX_PREG +} preg; /* CR16 Register types. */ typedef enum - { - CR16_R_REGTYPE, /* r */ - CR16_RP_REGTYPE, /* reg pair */ - CR16_P_REGTYPE /* Processor register */ - } +{ + CR16_R_REGTYPE, /* r */ + CR16_RP_REGTYPE, /* reg pair */ + CR16_P_REGTYPE /* Processor register */ +} reg_type; /* CR16 argument types : @@ -89,69 +89,69 @@ reg_type; idxrp - index with register pair rbase - register base rpbase - register pair base - pr - processor register */ + pr - processor register. */ typedef enum - { - arg_r, - arg_c, - arg_cr, - arg_crp, - arg_ic, - arg_icr, - arg_idxr, - arg_idxrp, - arg_rbase, - arg_rpbase, - arg_rp, - arg_pr, - arg_prp, - arg_cc, - arg_ra, - /* Not an argument. */ - nullargs - } +{ + arg_r, + arg_c, + arg_cr, + arg_crp, + arg_ic, + arg_icr, + arg_idxr, + arg_idxrp, + arg_rbase, + arg_rpbase, + arg_rp, + arg_pr, + arg_prp, + arg_cc, + arg_ra, + /* Not an argument. */ + nullargs +} argtype; -/* CR16 operand types:The operand types correspond to instructions operands.*/ +/* CR16 operand types:The operand types correspond to instructions operands. */ typedef enum - { - dummy, - /* N-bit signed immediate. */ - imm3, imm4, imm5, imm6, imm16, imm20, imm32, - /* N-bit unsigned immediate. */ - uimm3, uimm3_1, uimm4, uimm4_1, uimm5, uimm16, uimm20, uimm32, - /* N-bit signed displacement. */ - disps5, disps17, disps25, - /* N-bit unsigned displacement. */ - dispe9, - /* N-bit absolute address. */ - abs20, abs24, - /* Register relative. */ - rra, rbase, rbase_disps20, rbase_dispe20, - /* Register pair relative. */ - rpbase_disps0, rpbase_dispe4, rpbase_disps4, rpbase_disps16, - rpbase_disps20, rpbase_dispe20, - /* Register index. */ - rindex7_abs20, rindex8_abs20, - /* Register pair index. */ - rpindex_disps0, rpindex_disps14, rpindex_disps20, - /* register. */ - regr, - /* register pair. */ - regp, - /* processor register. */ - pregr, - /* processor register 32 bit. */ - pregrp, - /* condition code - 4 bit. */ - cc, - /* Not an operand. */ - nulloperand, - /* Maximum supported operand. */ - MAX_OPRD - } +{ + dummy, + /* N-bit signed immediate. */ + imm3, imm4, imm5, imm6, imm16, imm20, imm32, + /* N-bit unsigned immediate. */ + uimm3, uimm3_1, uimm4, uimm4_1, uimm5, uimm16, uimm20, uimm32, + /* N-bit signed displacement. */ + disps5, disps17, disps25, + /* N-bit unsigned displacement. */ + dispe9, + /* N-bit absolute address. */ + abs20, abs24, + /* Register relative. */ + rra, rbase, rbase_disps20, rbase_dispe20, + /* Register pair relative. */ + rpbase_disps0, rpbase_dispe4, rpbase_disps4, rpbase_disps16, + rpbase_disps20, rpbase_dispe20, + /* Register index. */ + rindex7_abs20, rindex8_abs20, + /* Register pair index. */ + rpindex_disps0, rpindex_disps14, rpindex_disps20, + /* register. */ + regr, + /* register pair. */ + regp, + /* processor register. */ + pregr, + /* processor register 32 bit. */ + pregrp, + /* condition code - 4 bit. */ + cc, + /* Not an operand. */ + nulloperand, + /* Maximum supported operand. */ + MAX_OPRD +} operand_type; /* CR16 instruction types. */ @@ -239,126 +239,126 @@ operand_type; /* Single operand description. */ typedef struct - { - /* Operand type. */ - operand_type op_type; - /* Operand location within the opcode. */ - unsigned int shift; - } +{ + /* Operand type. */ + operand_type op_type; + /* Operand location within the opcode. */ + unsigned int shift; +} operand_desc; /* Instruction data structure used in instruction table. */ typedef struct - { - /* Name. */ - const char *mnemonic; - /* Size (in words). */ - unsigned int size; - /* Constant prefix (matched by the disassembler). */ - unsigned long match; /* ie opcode */ - /* Match size (in bits). */ - /* MASK: if( (i & match_bits) == match ) then match */ - int match_bits; - /* Attributes. */ - unsigned int flags; - /* Operands (always last, so unreferenced operands are initialized). */ - operand_desc operands[MAX_OPERANDS]; - } +{ + /* Name. */ + const char *mnemonic; + /* Size (in words). */ + unsigned int size; + /* Constant prefix (matched by the disassembler). */ + unsigned long match; /* ie opcode */ + /* Match size (in bits). */ + /* MASK: if( (i & match_bits) == match ) then match */ + int match_bits; + /* Attributes. */ + unsigned int flags; + /* Operands (always last, so unreferenced operands are initialized). */ + operand_desc operands[MAX_OPERANDS]; +} inst; /* Data structure for a single instruction's arguments (Operands). */ typedef struct - { - /* Register or base register. */ - reg r; - /* Register pair register. */ - reg rp; - /* Index register. */ - reg i_r; - /* Processor register. */ - preg pr; - /* Processor register. 32 bit */ - preg prp; - /* Constant/immediate/absolute value. */ - long constant; - /* CC code. */ - unsigned int cc; - /* Scaled index mode. */ - unsigned int scale; - /* Argument type. */ - argtype type; - /* Size of the argument (in bits) required to represent. */ - int size; +{ + /* Register or base register. */ + reg r; + /* Register pair register. */ + reg rp; + /* Index register. */ + reg i_r; + /* Processor register. */ + preg pr; + /* Processor register. 32 bit */ + preg prp; + /* Constant/immediate/absolute value. */ + long constant; + /* CC code. */ + unsigned int cc; + /* Scaled index mode. */ + unsigned int scale; + /* Argument type. */ + argtype type; + /* Size of the argument (in bits) required to represent. */ + int size; /* The type of the expression. */ - unsigned char X_op; - } + unsigned char X_op; +} argument; /* Internal structure to hold the various entities corresponding to the current assembling instruction. */ typedef struct - { - /* Number of arguments. */ - int nargs; - /* The argument data structure for storing args (operands). */ - argument arg[MAX_OPERANDS]; +{ + /* Number of arguments. */ + int nargs; + /* The argument data structure for storing args (operands). */ + argument arg[MAX_OPERANDS]; /* The following fields are required only by CR16-assembler. */ #ifdef TC_CR16 - /* Expression used for setting the fixups (if any). */ - expressionS exp; - bfd_reloc_code_real_type rtype; + /* Expression used for setting the fixups (if any). */ + expressionS exp; + bfd_reloc_code_real_type rtype; #endif /* TC_CR16 */ - /* Instruction size (in bytes). */ - int size; - } + /* Instruction size (in bytes). */ + int size; +} ins; /* Structure to hold information about predefined operands. */ typedef struct - { - /* Size (in bits). */ - unsigned int bit_size; - /* Argument type. */ - argtype arg_type; - /* One bit syntax flags. */ - int flags; - } +{ + /* Size (in bits). */ + unsigned int bit_size; + /* Argument type. */ + argtype arg_type; + /* One bit syntax flags. */ + int flags; +} operand_entry; /* Structure to hold trap handler information. */ typedef struct - { - /* Trap name. */ - char *name; - /* Index in dispatch table. */ - unsigned int entry; - } +{ + /* Trap name. */ + char *name; + /* Index in dispatch table. */ + unsigned int entry; +} trap_entry; /* Structure to hold information about predefined registers. */ typedef struct +{ + /* Name (string representation). */ + char *name; + /* Value (enum representation). */ + union { - /* Name (string representation). */ - char *name; - /* Value (enum representation). */ - union - { - /* Register. */ - reg reg_val; - /* processor register. */ - preg preg_val; - } value; - /* Register image. */ - int image; - /* Register type. */ - reg_type type; - } + /* Register. */ + reg reg_val; + /* processor register. */ + preg preg_val; + } value; + /* Register image. */ + int image; + /* Register type. */ + reg_type type; +} reg_entry; /* CR16 opcode table. */ @@ -435,4 +435,17 @@ extern const inst *instruction; typedef long long int LONGLONG; typedef unsigned long long ULONGLONG; +/* Data types for opcode handling. */ +typedef unsigned long dwordU; +typedef unsigned short wordU; + +/* Globals to store opcode data and build the instruction. */ +extern wordU cr16_words[3]; +extern ULONGLONG cr16_allWords; +extern ins cr16_currInsn; + +/* Prototypes for function in cr16-dis.c. */ +extern void make_instruction (void); +extern int match_opcode (void); + #endif /* _CR16_H_ */ diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index f69ea65cae2..a034ca6b96a 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,1058 +1,13 @@ -2012-12-17 Nick Clifton +2013-01-02 Kaushik Phatak - * MAINTAINERS: Add copyright notice. - * Makefile.am: Likewise. - * configure.com: Likewise. - * configure.in: Likewise. - * makefile.vms: Likewise. - * rl78-decode.c: Likewise. - * rl78-decode.opc: Likewise. - * rx-decode.c: Likewise. - * rx-decode.opc: Likewise. - * Makefile.in: Regenerate. + * cr16-dis.c (match_opcode,make_instruction): Remove static + declaration. + (dwordU,wordU): Moved typedefs to opcode/cr16.h + (cr16_words,cr16_allWords,cr16_currInsn): Added prefix 'cr16_'. -2012-12-13 Alan Modra - - PR binutils/14950 - * ppc-opc.c (insert_sci8, extract_sci8): Rewrite. - (insert_sci8n, extract_sci8n): Likewise. - -2012-11-30 Oleg Raikhman - Joern Rennecke - - * epiphany-desc.c, epiphany-desc.h, epiphany-opc.c: Regenerate. - -2012-11-29 Roland McGrath - - * s390-mkopc.c (file_header): Add const. - -2012-11-29 David Holsgrove - - * microblaze-opc.h: Rename INST_TYPE_RD_R1_SPECIAL to - INST_TYPE_R1_R2_SPECIAL - * microblaze-dis.c (print_insn_microblaze): Same. - -2012-11-23 Alan Modra - - * ppc-dis.c (ppc_parse_cpu): Add "sticky" param. Track bits - set from ppc_opts.sticky in it. Delete "retain_mask". - (powerpc_init_dialect): Choose default dialect from info->mach - before parsing -M options. Handle more bfd_mach_ppc variants. - Update common default to power7. - -2012-11-21 David Holsgrove - - * microblaze-opc.h (op_code_struct): Add swapb, swaph Increase MAX_OPCODES. - * microblaze-opcm.h (microblaze_instr): Likewise - -2012-11-21 Edgar E. Iglesias - - * microblaze-opcm.h: Add REG_SLR_MASK, REG_SHR_MASK, REG_SHR and REG_SLR - * microblaze-dis.c (get_field_special): Handle REG_SLR_MASK and REG_SHR_MASK - -2012-11-20 Kirill Yukhin - H.J. Lu - - PR gas/14859 - * i386-opc.tbl: Fix opcode for 64-bit jecxz. - * i386-tbl.h: Regenerated. - -2012-11-20 Andreas Krebbel - - * s390-opc.txt: Fix srstu and strag opcodes. - -2012-11-14 David Holsgrove - - * microblaze-opc.h: Define new instruction type INST_TYPE_IMM5, - update OPCODE_MASK_H13S, add OPCODE_MASK_HN, define MIN_IMM5 / MAX_IMM5, - and increase MAX_OPCODES. - (op_code_struct): add mbar and sleep - * microblaze-opcm.h (microblaze_instr): add mbar - Define IMM_MBAR and IMM5_MBAR_MASK - * microblaze-dis.c: Add get_field_imm5_mbar - (print_insn_microblaze): Add support for INST_TYPE_IMM5 and INST_TYPE_NONE - -2012-11-14 Edgar E. Iglesias - - * microblaze-opc.h: Increase MAX_OPCODES (op_code_struct): add clz insn - * microblaze-opcm.h (microblaze_instr): add clz - -2012-11-14 Edgar E. Iglesias - - * microblaze-opc.h: Increase MAX_OPCODES (op_code_struct): add lbur, - lhur, lwr, sbr, shr, swr - * microblaze-opcm.h (microblaze_instr): add lbur, lhur, lwr, sbr, shr, - swr - -2012-11-09 Nick Clifton - - * configure.in: Add bfd_v850_rh850_arch. - * configure: Regenerate. - * disassemble.c (disassembler): Likewise. - -2012-11-09 H.J. Lu - - * aarch64-opc.h (gen_mask): Remove trailing redundant `;'. - * ia64-gen.c (fetch_insn_class): Likewise. - -2012-11-08 Alan Modra - - * po/POTFILES.in: Regenerate. - -2012-11-05 Alan Modra - - * configure.in: Apply 2012-09-10 change to config.in here. - -2012-10-26 Andreas Krebbel - - * s390-mkopc.c: Accept empty lines in s390-opc.txt. - * s390-opc.c: Add M_20OPT field. New instruction formats RRF_RURR2 - and RRF_RMRR. - * s390-opc.txt: Add new instructions. New instruction type for lptea. - -2012-10-26 Christian Groessler - - * z8kgen.c (struct op): Fix encoding for translate opcodes (trdb, - trdrb, trib, trirb, trtdb, trtdrb, trtib, trtirb). Remove - non-existing opcode trtrb. - * z8k-opc.h: Regenerate. - -2012-10-26 Alan Modra - - * ppc-opc (powerpc_opcodes): "lfdp" and "stfdp" use DS offset. - -2012-10-24 Roland McGrath - - * i386-dis.c (ckprefix): When bailing out for fwait with prefixes, - set rex_used to rex. - -2012-10-22 Peter Bergner - - * ppc-opc.c (powerpc_opcodes) : Fix opcode spelling. - -2012-10-18 Tom Tromey - - * tic54x-dis.c (print_instruction): Don't use K&R style. - (print_parallel_instruction, sprint_dual_address) - (sprint_indirect_address, sprint_direct_address, sprint_mmr) - (sprint_cc2, sprint_condition): Likewise. - -2012-10-18 Kai Tietz - - * aarch64-asm.c (aarch64_ins_ldst_reglist): Initialize - value with a default. - (do_special_encoding): Likewise. - (aarch64_ins_ldst_elemlist): Pre-initialize QSsize, and opcodeh2 - variables with default. - * arc-dis.c (write_comments_): Don't use strncat due - size of state->commentBuffer pointer isn't predictable. - -2012-10-15 Yufeng Zhang - - * aarch64-opc.c (aarch64_sys_regs): Add rmr_el1, rmr_el2 and - rmr_el3; remove daifset and daifclr. - -2012-10-15 Yufeng Zhang - - * aarch64-opc.c (operand_general_constraint_met_p): Change to check - the alignment of addr.offset.imm instead of that of shifter.amount for - operand type AARCH64_OPND_ADDR_UIMM12. - -2012-10-11 Kyrylo Tkachov - - * arm-dis.c: Use preferred form of vrint instruction variants - for disassembly. - -2012-10-09 Nagajyothi Eggone - - * i386-gen.c (cpu_flag_init): Add CPU_BDVER3_FLAGS. - * i386-init.h: Regenerated. - -2012-10-05 Peter Bergner - - * ppc-dis.c (ppc_opts) : Use PPC_OPCODE_ALTIVEC2; - * ppc-opc.c (VBA): New define. - (powerpc_opcodes) : New extended mnemonics. - -2012-10-04 Nick Clifton - - * v850-dis.c (disassemble): Place square parentheses around second - register operand of clr1, not1, set1 and tst1 instructions. - -2012-10-04 Andreas Krebbel - - * s390-mkopc.c: Support new option zEC12. - * s390-opc.c: Add new instruction formats. - * s390-opc.txt: Add new instructions for zEC12. - -2012-09-27 Anthony Green - - * moxie-dis.c (print_insn_moxie): Print 'bad' instructions. - * moxie-opc.c: All 'bad' instructions have the itype MOXIE_BAD. - -2012-09-25 Saravanan Ekanathan - - * i386-gen.c (cpu_flag_init): Add missing Cpu flags in - CPU_BDVER1_FLAGS, CPU_BDVER2_FLAGS, CPU_BTVER1_FLAGS - and CPU_BTVER2_FLAGS. - * i386-init.h: Regenerated. - -2012-09-20 Michael Zolotukhin - - * i386-gen.c (cpu_flag_init): Add CpuCX16 to CPU_NOCONA_FLAGS, - CPU_CORE_FLAGS, CPU_CORE2_FLAGS, CPU_COREI7_FLAGS, - CPU_BDVER1_FLAGS, CPU_BDVER2_FLAGS, CPU_BTVER1_FLAGS, - CPU_BTVER2_FLAGS. Add CPU_CX16_FLAGS. - (cpu_flags): Add CpuCX16. - * i386-opc.h (CpuCX16): New. - (i386_cpu_flags): Add cpucx16. - * i386-opc.tbl: Replace CpuSSE3 with CpuCX16 for cmpxchg16b. - * i386-tbl.h: Regenerate. - * i386-init.h: Likewise. - -2012-09-18 Kyrylo Tkachov - - * arm-dis.c: Changed ldra and strl-form mnemonics - to lda and stl-form. - -2012-09-18 Chao-ying Fu - - * micromips-opc.c (micromips_opcodes): Correct the encoding of - the "swxc1" instruction. - -2012-09-17 Yufeng Zhang - - * aarch64-asm.c (aarch64_ins_imm_half): Remove ATTRIBUTE_UNUSED from - the parameter 'inst'. - (aarch64_ins_addr_simm): Add ATTRIBUTE_UNUSED to the parameter 'inst'. - (convert_mov_to_movewide): Change to assert (0) when - aarch64_wide_constant_p returns FALSE. - -2012-09-14 David Edelsohn - - * configure: Regenerate. - -2012-09-14 Anthony Green - - * moxie-dis.c (print_insn_moxie): Branch targets are relative to - the address after the branch instruction. - -2012-09-13 Anthony Green - - * moxie-dis.c (print_insn_moxie): Handle bi-endian encodings. - -2012-09-10 Matthias Klose - - * config.in: Disable sanity check for kfreebsd. - -2012-09-10 H.J. Lu - - * configure: Regenerated. - -2012-09-04 Sergey A. Guriev - - * ia64-asmtab.h (completer_index): Extend bitfield to full uint. - * ia64-gen.c: Promote completer index type to longlong. - (irf_operand): Add new register recognition. - (in_iclass_mov_x): Add an entry for the new mov_* instruction type. - (lookup_specifier): Add new resource recognition. - (insert_bit_table_ent): Relax abort condition according to the - changed completer index type. - (print_dis_table): Fix printf format for completer index. - * ia64-ic.tbl: Add a new instruction class. - * ia64-opc-i.c (ia64_opcodes_i): Define new I-instructions. - * ia64-opc-m.c (ia64_opcodes_m): Define new M-instructions. - * ia64-opc.h: Define short names for new operand types. - * ia64-raw.tbl: Add new RAW resource for DAHR register. - * ia64-waw.tbl: Add new WAW resource for DAHR register. - * ia64-asmtab.c: Regenerate. - -2012-08-29 Peter Bergner - - * ppc-opc.c (VXASHB_MASK): New define. - (powerpc_opcodes) : Use VXASHB_MASK. - -2012-08-28 Peter Bergner - - * ppc-opc.c (UIMM4, UIMM3, UIMM2, VXVA_MASK, VXVB_MASK, VXVAVB_MASK, - VXVDVA_MASK, VXUIMM4_MASK, VXUIMM3_MASK, VXUIMM2_MASK): New defines. - (powerpc_opcodes) : Use VXVA_MASK. - : Use VXVB_MASK. - : Use VXVAVB_MASK. - : Use VXVDVA_MASK. - : Use VXUIMM4_MASK. - : Use VXUIMM3_MASK. - : Use VXUIMM2_MASK. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (neon_opcodes): Add 2 operand sha instructions. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (neon_opcodes): Add SHA 3-operand instructions. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (neon_opcodes): Handle VMULL.P64. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (neon_opcodes): Add support for AES instructions. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (coprocessor_opcodes): Add support for HP/DP - conversions. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (coprocessor_opcodes): Add VRINT. - (neon_opcodes): Likewise. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (coprocessor_opcodes): Add support for new VCVT - variants. - (neon_opcodes): Likewise. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (coprocessor_opcodes): Add VMAXNM/VMINNM. - (neon_opcodes): Likewise. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (coprocessor_opcodes): Add VSEL. - (print_insn_coprocessor): Add new %<>c bitfield format - specifier. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (arm_opcodes): Add LDRA/STRL instructions. - (thumb32_opcodes): Likewise. - (print_arm_insn): Add support for %<>T formatter. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (arm_opcodes): Add HLT. - (thumb_opcodes): Likewise. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (thumb32_opcodes): Add DCPS instruction. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (arm_opcodes): Add SEVL. - (thumb_opcodes): Likewise. - (thumb32_opcodes): Likewise. - -2012-08-24 Matthew Gretton-Dann - - * arm-dis.c (data_barrier_option): New function. - (print_insn_arm): Use data_barrier_option. - (print_insn_thumb32): Use data_barrier_option. - -2012-08-24 Matthew Gretton-Dann - - * sparc-opc.c (4-argument crypto instructions): Fix encoding using - F3F4 macro. - -2012-08-20 Edmar Wienskoski - - * ppc-opc.c (powerpc_opcodes): Changed opcode for vabsdub, - vabsduh, vabsduw, mviwsplt. - -2012-08-17 Nagajyothi Eggone - - * i386-gen.c (cpu_flag_init): Add CPU_BTVER1_FLAGS and - CPU_BTVER2_FLAGS. - - * i386-opc.h: Update CpuPRFCHW comment. - - * i386-opc.tbl: Enable prefetch instruction for CpuPRFCHW. - * i386-init.h: Regenerated. - * i386-tbl.h: Likewise. - -2012-08-17 Nick Clifton - - * po/uk.po: New Ukranian translation. - * configure.in (ALL_LINGUAS): Add uk. - * configure: Regenerate. - -2012-08-16 Peter Bergner - - * ppc-opc.c (powerpc_opcodes) <"lswx">: Use RAX for the second and - RBX for the third operand. - <"lswi">: Use RAX for second and NBI for the third operand. - -2012-08-15 DJ Delorie - - * rl78-decode.opc (rl78_decode_opcode): Merge %e and %[01] - operands, so that data addresses can be corrected when not - ES-overridden. - * rl78-decode.c: Regenerate. - * rl78-dis.c (print_insn_rl78): Make order of modifiers - irrelevent. When the 'e' specifier is used on an operand and no - ES prefix is provided, adjust address to make it absolute. - -2012-08-15 Peter Bergner - - * ppc-opc.c : Use PPC_OPERAND_GPR. - -2012-08-15 Peter Bergner - - * ppc-opc.c : New extended mnemonics. - -2012-08-14 Maciej W. Rozycki - - * mips-dis.c (print_insn_args): Add GET_OP and GET_OP_S local - macros, use local variables for info struct member accesses, - update the type of the variable used to hold the instruction - word. - (print_insn_mips, print_mips16_insn_arg): Likewise. - (print_insn_mips16): Add GET_OP and GET_OP_S local macros, use - local variables for info struct member accesses. - (print_insn_micromips): Add GET_OP_S local macro. - (_print_insn_mips): Update the type of the variable used to hold - the instruction word. - -2012-08-13 Ian Bolton - Laurent Desnogues - Jim MacArthur - Marcus Shawcroft - Nigel Stephens - Ramana Radhakrishnan - Richard Earnshaw - Sofiane Naci - Tejas Belagod - Yufeng Zhang - - * Makefile.am: Add AArch64. - * Makefile.in: Regenerate. - * aarch64-asm.c: New file. - * aarch64-asm.h: New file. - * aarch64-dis.c: New file. - * aarch64-dis.h: New file. - * aarch64-gen.c: New file. - * aarch64-opc.c: New file. - * aarch64-opc.h: New file. - * aarch64-tbl.h: New file. - * configure.in: Add AArch64. - * configure: Regenerate. - * disassemble.c: Add AArch64. - * aarch64-asm-2.c: New file (automatically generated). - * aarch64-dis-2.c: New file (automatically generated). - * aarch64-opc-2.c: New file (automatically generated). - * po/POTFILES.in: Regenerate. - -2012-08-13 Maciej W. Rozycki - - * micromips-opc.c (micromips_opcodes): Update comment. - * mips-opc.c (mips_builtin_opcodes): Likewise. Mark coprocessor - instructions for IOCT as appropriate. - * mips-dis.c (print_insn_mips): Replace OPCODE_IS_MEMBER with - opcode_is_member. - * configure.in: Substitute NO_WMISSING_FIELD_INITIALIZERS with - the result of a check for the -Wno-missing-field-initializers - GCC option. - * Makefile.am (NO_WMISSING_FIELD_INITIALIZERS): New variable. - (mips-opc.lo): Pass $(NO_WMISSING_FIELD_INITIALIZERS) to - compilation. - (mips16-opc.lo): Likewise. - (micromips-opc.lo): Likewise. - * aclocal.m4: Regenerate. - * configure: Regenerate. - * Makefile.in: Regenerate. - -2012-08-11 Saravanan Ekanathan - - PR gas/14423 - * i386-gen.c (cpu_flag_init): Add CpuFMA in CPU_BDVER2_FLAGS. - * i386-init.h: Regenerated. - -2012-08-09 Nick Clifton - - * po/vi.po: Updated Vietnamese translation. - -2012-08-07 Roland McGrath - - * i386-dis.c (reg_table): Fill out REG_0F0D table with - AMD-reserved cases as "prefetch". - (MOD_0F18_REG_4, MOD_0F18_REG_5): New enum constants. - (MOD_0F18_REG_6, MOD_0F18_REG_7): Likewise. - (reg_table): Use those under REG_0F18. - (mod_table): Add those cases as "nop/reserved". - -2012-08-07 Jan Beulich - - * i386-opc.tbl: Remove "FIXME" comments from SVME instructions. - -2012-08-06 Roland McGrath - - * i386-dis.c (print_insn): Print spaces between multiple excess - prefixes. Return actual number of excess prefixes consumed, - not always one. - - * i386-dis.c (OP_REG): Ignore REX_B for segment register cases. - -2012-08-06 Roland McGrath - Victor Khimenko - H.J. Lu - - * i386-dis.c (OP_sI): In b_T_mode and v_mode, REX_W trumps DFLAG. - (putop): For 'T', 'U', and 'V', treat REX_W like DFLAG. - (intel_operand_size): For stack_v_mode, treat REX_W like DFLAG. - (OP_E_register): Likewise. - (OP_REG): For low 8 whole registers, treat REX_W like DFLAG. - -2012-08-02 Jan-Benedict Glaw - - * configure.in: Formatting. - * configure: Regenerate. - -2012-08-01 Alan Modra - - * h8300-dis.c: Fix printf arg warnings. - * i960-dis.c: Likewise. - * mips-dis.c: Likewise. - * pdp11-dis.c: Likewise. - * sh-dis.c: Likewise. - * v850-dis.c: Likewise. - * configure.in: Formatting. - * configure: Regenerate. - * rl78-decode.c: Regenerate. - * po/POTFILES.in: Regenerate. - -2012-07-31 Chao-Ying Fu - Catherine Moore - Maciej W. Rozycki - - * micromips-opc.c (WR_a, RD_a, MOD_a): New macros. - (DSP_VOLA): Likewise. - (D32, D33): Likewise. - (micromips_opcodes): Add DSP ASE instructions. - * mips-dis.c (print_insn_micromips) <'2', '3'>: New cases. - <'4', '5', '6', '7', '8', '0', '^', '@'>: Likewise. - -2012-07-31 Jan Beulich - - * i386-opc.tbl (vmovntdqa): Move up into 256-bit integer AVX2 - instruction group. Mark as requiring AVX2. - * i386-tbl.h: Re-generate. - -2012-07-30 Nick Clifton - - * po/opcodes.pot: Updated template. - * po/es.po: Updated Spanish translation. - * po/fi.po: Updated Finnish translation. - -2012-07-27 Mike Frysinger - - * configure.in (BFD_VERSION): Run bfd/configure --version and - parse the output of that. - * configure: Regenerate. - -2012-07-25 James Lemke - - * ppc-opc.c (powerpc_opcodes): Add/remove PPCVLE for some 32-bit insns. - -2012-07-24 Stephan McCamant - Dr David Alan Gilbert - - PR binutils/13135 - * arm-dis.c: Add necessary casts for printing integer values. - Use %s when printing string values. - * hppa-dis.c: Likewise. - * m68k-dis.c: Likewise. - * microblaze-dis.c: Likewise. - * mips-dis.c: Likewise. - * sparc-dis.c: Likewise. - -2012-07-19 Michael Zolotukhin - - PR binutils/14355 - * i386-dis.c (VEX_LEN_0FXOP_08_CC): New. - (VEX_LEN_0FXOP_08_CD): Likewise. - (VEX_LEN_0FXOP_08_CE): Likewise. - (VEX_LEN_0FXOP_08_CF): Likewise. - (VEX_LEN_0FXOP_08_EC): Likewise. - (VEX_LEN_0FXOP_08_ED): Likewise. - (VEX_LEN_0FXOP_08_EE): Likewise. - (VEX_LEN_0FXOP_08_EF): Likewise. - (xop_table): Fix entries for vpcomb, vpcomw, vpcomd, vpcomq, - vpcomub, vpcomuw, vpcomud, vpcomuq. - (vex_len_table): Add entries for VEX_LEN_0FXOP_08_CC, - VEX_LEN_0FXOP_08_CD, VEX_LEN_0FXOP_08_CE, VEX_LEN_0FXOP_08_CF, - VEX_LEN_0FXOP_08_EC, VEX_LEN_0FXOP_08_ED, VEX_LEN_0FXOP_08_EE, - VEX_LEN_0FXOP_08_EF. - -2012-07-16 Michael Zolotukhin - - * i386-dis.c (PREFIX_0F38F6): New. - (prefix_table): Add adcx, adox instructions. - (three_byte_table): Use PREFIX_0F38F6. - (mod_table): Add rdseed instruction. - * i386-gen.c (cpu_flag_init): Add CpuADX, CpuRDSEED, CpuPRFCHW. - (cpu_flags): Likewise. - * i386-opc.h: Add CpuADX, CpuRDSEED, CpuPRFCHW. - (i386_cpu_flags): Add fields cpurdseed, cpuadx, cpuprfchw. - * i386-opc.tbl: Add instrcutions adcx, adox, rdseed. Extend - prefetchw. - * i386-tbl.h: Regenerate. - * i386-init.h: Likewise. - -2012-07-05 Thomas Schwinge - - * mips-dis.c: Remove gratuitous newline. - -2012-07-05 Sean Keys - - * xgate-dis.c: Removed an IF statement that will - always be false due to overlapping operand masks. - * xgate-opc.c: Corrected 'com' opcode entry and - fixed spacing. - -2012-07-02 Roland McGrath - - * i386-opc.tbl: Add RepPrefixOk to nop. - * i386-tbl.h: Regenerate. - -2012-06-28 Nick Clifton - - * po/vi.po: Updated Vietnamese translation. - -2012-06-22 Roland McGrath - - * i386-opc.tbl: Add RepPrefixOk to ret. - * i386-tbl.h: Regenerate. - - * i386-opc.h (RepPrefixOk): New enum constant. - (i386_opcode_modifier): New bitfield 'repprefixok'. - * i386-gen.c (opcode_modifiers): Add RepPrefixOk. - * i386-opc.tbl: Add RepPrefixOk to bsf, bsr, and to all - instructions that have IsString. - * i386-tbl.h: Regenerate. - -2012-06-11 Andreas Schwab - - * ppc-opc.c (lvsl, lvebx, isellt, icbt, ldepx, lwepx, lvsr, lvehx) - (iselgt, lvewx, iseleq, isel, dcbst, dcbstep, dcbfl, dcbf, lbepx) - (lvx, dcbfep, dcbtstls, stvebx, dcbtstlse, stdepx, stwepx, dcbtls) - (stvehx, dcbtlse, stvewx, stbepx, icblc, stvx, dcbtstt, dcbtst) - (dcbtst, dcbtstep, dcbtt, dcbt, dcbt, lhepx, eciwx, dcbtep) - (dcread, lxvdsx, lvxl, dcblc, sthepx, ecowx, dcbi, dcread, icbtls) - (stvxl, lxsdx, lfdepx, stxsdx, stfdepx, dcba, dcbal, lxvw4x) - (tlbivax, lfdpx, lxvd2x, tlbsrx., stxvw4x, tlbsx, tlbsx., stfdpx) - (stfqx, stxvd2x, icbi, icbiep, icread, dcbzep): Change RA to RA0. - -2012-05-19 Alan Modra - - * ppc-dis.c: Don't include elf32-ppc.h, do include elf/ppc.h. - (get_powerpc_dialect): Detect VLE sections from ELF sh_flags. - -2012-05-18 Alan Modra - - * ia64-opc.c: Remove #include "ansidecl.h". - * z8kgen.c: Include sysdep.h first. - - * arc-dis.c: Include sysdep.h first, remove some redundant includes. - * bfin-dis.c: Likewise. - * i860-dis.c: Likewise. - * ia64-dis.c: Likewise. - * ia64-gen.c: Likewise. - * m68hc11-dis.c: Likewise. - * mmix-dis.c: Likewise. - * msp430-dis.c: Likewise. - * or32-dis.c: Likewise. - * rl78-dis.c: Likewise. - * rx-dis.c: Likewise. - * tic4x-dis.c: Likewise. - * tilegx-opc.c: Likewise. - * tilepro-opc.c: Likewise. - * rx-decode.c: Regenerate. - -2012-05-17 James Lemke - - * ppc-opc.c (powerpc_macros): Add entries for e_extlwi to e_clrlslwi. - -2012-05-17 James Lemke - - * ppc-opc.c (extract_sprg): Use ALLOW8_SPRG to include VLE. - -2012-05-17 Daniel Richard G. - Nick Clifton - - PR 14072 - * configure.in: Add check that sysdep.h has been included before - any system header files. - * configure: Regenerate. - * config.in: Regenerate. - * sysdep.h: Generate an error if included before config.h. - * alpha-opc.c: Include sysdep.h before any other header file. - * alpha-dis.c: Likewise. - * avr-dis.c: Likewise. - * cgen-opc.c: Likewise. - * cr16-dis.c: Likewise. - * cris-dis.c: Likewise. - * crx-dis.c: Likewise. - * d10v-dis.c: Likewise. - * d10v-opc.c: Likewise. - * d30v-dis.c: Likewise. - * d30v-opc.c: Likewise. - * h8500-dis.c: Likewise. - * i370-dis.c: Likewise. - * i370-opc.c: Likewise. - * m10200-dis.c: Likewise. - * m10300-dis.c: Likewise. - * micromips-opc.c: Likewise. - * mips-opc.c: Likewise. - * mips61-opc.c: Likewise. - * moxie-dis.c: Likewise. - * or32-opc.c: Likewise. - * pj-dis.c: Likewise. - * ppc-dis.c: Likewise. - * ppc-opc.c: Likewise. - * s390-dis.c: Likewise. - * sh-dis.c: Likewise. - * sh64-dis.c: Likewise. - * sparc-dis.c: Likewise. - * sparc-opc.c: Likewise. - * spu-dis.c: Likewise. - * tic30-dis.c: Likewise. - * tic54x-dis.c: Likewise. - * tic80-dis.c: Likewise. - * tic80-opc.c: Likewise. - * tilegx-dis.c: Likewise. - * tilepro-dis.c: Likewise. - * v850-dis.c: Likewise. - * v850-opc.c: Likewise. - * vax-dis.c: Likewise. - * w65-dis.c: Likewise. - * xgate-dis.c: Likewise. - * xtensa-dis.c: Likewise. - * rl78-decode.opc: Likewise. - * rl78-decode.c: Regenerate. - * rx-decode.opc: Likewise. - * rx-decode.c: Regenerate. - -2012-05-17 Alan Modra - - * ppc_dis.c: Don't include elf/ppc.h. - -2012-05-16 Meador Inge - - * arm-dis.c (arm_opcodes): Don't disassemble STMFD/LDMIA sp!, {reg} - to PUSH/POP {reg}. - -2012-05-15 James Murray - Stephane Carrez - - * configure.in: Add S12X and XGATE co-processor support to m68hc11 - target. - * disassemble.c: Likewise. - * configure: Regenerate. - * m68hc11-dis.c: Make objdump output more consistent, use hex - instead of decimal and use 0x prefix for hex. - * m68hc11-opc.c: Add S12X and XGATE opcodes. - -2012-05-14 James Lemke - - * ppc-dis.c (get_powerpc_dialect): Use is_ppc_vle. - (PPC_OPCD_SEGS, VLE_OPCD_SEGS): New defines. - (vle_opcd_indices): New array. - (lookup_vle): New function. - (disassemble_init_powerpc): Revise for second (VLE) opcode table. - (print_insn_powerpc): Likewise. - * ppc-opc.c: Likewise. - -2012-05-14 Catherine Moore - Maciej W. Rozycki - Rhonda Wittels - Nathan Froyd - - * ppc-opc.c (insert_arx, extract_arx): New functions. - (insert_ary, extract_ary): New functions. - (insert_li20, extract_li20): New functions. - (insert_rx, extract_rx): New functions. - (insert_ry, extract_ry): New functions. - (insert_sci8, extract_sci8): New functions. - (insert_sci8n, extract_sci8n): New functions. - (insert_sd4h, extract_sd4h): New functions. - (insert_sd4w, extract_sd4w): New functions. - (insert_vlesi, extract_vlesi): New functions. - (insert_vlensi, extract_vlensi): New functions. - (insert_vleui, extract_vleui): New functions. - (insert_vleil, extract_vleil): New functions. - (BI_MASK, BB_MASK, BT): Use PPC_OPERAND_CR_BIT. - (BI16, BI32, BO32, B8): New. - (B15, B24, CRD32, CRS): New. - (CRD, OBF, BFA, CR, CRFS): Use PPC_OPERAND_CR_REG. - (DB, IMM20, RD, Rx, ARX, RY, RZ): New. - (ARY, SCLSCI8, SCLSCI8N, SE_SD, SE_SDH): New. - (SH6_MASK): Use PPC_OPSHIFT_INV. - (SI8, UI5, OIMM5, UI7, BO16): New. - (VLESIMM, VLENSIMM, VLEUIMM, VLEUIMML): New. - (XT6, XA6, XB6, XB6S, XC6): Use PPC_OPSHIFT_INV. - (ALLOW8_SPRG): New. - (insert_sprg, extract_sprg): Check ALLOW8_SPRG. - (OPVUP, OPVUP_MASK OPVUP): New - (BD8, BD8_MASK, BD8IO, BD8IO_MASK): New. - (EBD8IO, EBD8IO1_MASK, EBD8IO2_MASK, EBD8IO3_MASK): New. - (BD15, BD15_MASK, EBD15, EBD15_MASK, EBD15BI, EBD15BI_MASK): New. - (BD24,BD24_MASK, C_LK, C_LK_MASK, C, C_MASK): New. - (IA16, IA16_MASK, I16A, I16A_MASK, I16L, I16L_MASK): New. - (IM7, IM7_MASK, LI20, LI20_MASK, SCI8, SCI8_MASK): New. - (SCI8BF, SCI8BF_MASK, SD4, SD4_MASK): New. - (SE_IM5, SE_IM5_MASK): New. - (SE_R, SE_R_MASK, SE_RR, SE_RR_MASK): New. - (EX, EX_MASK, BO16F, BO16T, BO32F, BO32T): New. - (BO32DNZ, BO32DZ): New. - (NO371, PPCSPE, PPCISEL, PPCEFS, MULHW): Include PPC_OPCODE_VLE. - (PPCVLE): New. - (powerpc_opcodes): Add new VLE instructions. Update existing - instruction to include PPCVLE if supported. - * ppc-dis.c (ppc_opts): Add vle entry. - (get_powerpc_dialect): New function. - (powerpc_init_dialect): VLE support. - (print_insn_big_powerpc): Call get_powerpc_dialect. - (print_insn_little_powerpc): Likewise. - (operand_value_powerpc): Handle negative shift counts. - (print_insn_powerpc): Handle 2-byte instruction lengths. - -2012-05-11 Daniel Richard G. - - PR binutils/14028 - * configure.in: Invoke ACX_HEADER_STRING. - * configure: Regenerate. - * config.in: Regenerate. - * sysdep.h: If STRINGS_WITH_STRING is defined then include both - string.h and strings.h. - -2012-05-11 Nick Clifton - - PR binutils/14006 - * arm-dis.c (print_insn): Fix detection of instruction mode in - files containing multiple executable sections. - -2012-05-03 Sean Keys - - * Makefile.in, configure: regenerate - * disassemble.c (disassembler): Recognize ARCH_XGATE. - * xgate-dis.c (read_memory, print_insn, print_insn_xgate): - New functions. - * configure.in: Recognize xgate. - * xgate-dis.c, xgate-opc.c: New files for support of xgate - * Makefile.am (CFILES, ALL_MACHINES): New files for disassembly - and opcode generation for xgate. - -2012-04-30 DJ Delorie - - * rx-decode.opc (MOV): Do not sign-extend immediates which are - already the maximum bit size. - * rx-decode.c: Regenerate. - -2012-04-27 David S. Miller - - * sparc-dis.c (v9a_asr_reg_names): Add 'cfr'. - * sparc-opc.c (sparc_opcodes): Add rd/wr cases for %cfr. - - * sparc-opc.c (sparc_opcodes): Add 'wr X, %pause' and 'pause'. - * sparc-dis.c (v9a_asr_reg_names): Add 'pause'. - - * sparc-opc.c (CBCOND): New define. - (CBCOND_XCC): Likewise. - (cbcond): New helper macro. - (sparc_opcodes): Add compare-and-branch instructions. - - * sparc-dis.c (print_insn_sparc): Handle ')'. - * sparc-opc.c (sparc_opcodes): Add crypto instructions. - - * sparc-opc.c (sparc_opcodes): Rework table to put HWCAP values - into new struct sparc_opcode 'hwcaps' field instead of 'flags'. - -2012-04-12 David S. Miller - - * sparc-dis.c (X_DISP10): Define. - (print_insn_sparc): Handle '='. - -2012-04-01 Mike Frysinger - - * bfin-dis.c (fmtconst): Replace decimal handling with a single - sprintf call and the '*' field width. - -2012-03-23 Maxim Kuvyrkov - - * mips-dis.c (mips_arch_choices): Add entry for Broadcom XLP. - -2012-03-16 Alan Modra - - * ppc-dis.c (PPC_OPC_SEGS, PPC_OP_TO_SEG): Delete. - (powerpc_opcd_indices): Bump array size. - (disassemble_init_powerpc): Set powerpc_opcd_indices entries - corresponding to unused opcodes to following entry. - (lookup_powerpc): New function, extracted and optimised from.. - (print_insn_powerpc): ..here. - -2012-03-15 Alan Modra - James Lemke - - * disassemble.c (disassemble_init_for_target): Handle ppc init. - * ppc-dis.c (private): New var. - (powerpc_init_dialect): Don't return calloc failure, instead use - private. - (PPC_OPCD_SEGS, PPC_OP_TO_SEG): Define. - (powerpc_opcd_indices): New array. - (disassemble_init_powerpc): New function. - (print_insn_big_powerpc): Don't init dialect here. - (print_insn_little_powerpc): Likewise. - (print_insn_powerpc): Start search using powerpc_opcd_indices. - -2012-03-10 Edmar Wienskoski - - * ppc-dis.c (ppc_opts): Add entries for "e5500" and "e6500". - * ppc-opc.c (insert_ls, TMR, ESYNC, XSYNCLE_MASK): New. - (PPCVEC2, PPCTMR, E6500): New short names. - (powerpc_opcodes): Add vabsdub, vabsduh, vabsduw, dni, mvidsplt, - mviwsplt, icblq., mftmr, mttmr, dcblq., miso, lvexbx, lvexhx, - lvexwx, stvexbx, stvexhx, stvexwx, lvepx, lvepxl, stvepx, stvepxl, - lvtrx, lvtrxl, lvtlx, lvtlxl, stvfrx, stvfrxl, stvflx, stvflxl, - lvswx, lvswxl, stvswx, stvswxl, lvsm mnemonics. Accept LS, ESYNC - optional operands on sync instruction for E6500 target. - -2012-03-08 Andreas Krebbel - - * s390-opc.txt: Set instruction type of pku to SS_L2RDRD. - -2012-02-27 Alan Modra - - * mt-dis.c: Regenerate. - -2012-02-27 Alan Modra - - * v850-opc.c (extract_v8): Rearrange to make it obvious this - is the inverse of corresponding insert function. - (extract_d22, extract_u9, extract_r4): Likewise. - (extract_d9): Correct sign extension. - (extract_d16_15): Don't assume "long" is 32 bits, and don't - rely on implementation defined behaviour for shift right of - signed types. - (extract_d16_16, extract_d17_16, extract_i9): Likewise. - (extract_d23): Likewise, and correct mask. - -2012-02-27 Alan Modra - - * crx-dis.c (print_arg): Mask constant to 32 bits. - * crx-opc.c (cst4_map): Use int array. - -2012-02-27 Alan Modra - - * arc-dis.c (BITS): Don't use shifts to mask off bits. - (FIELDD): Sign extend with xor,sub. - -2012-02-25 Walter Lee - - * tilegx-opc.c: Handle TILEGX_OPC_LD4S_TLS and TILEGX_OPC_LD_TLS. - * tilepro-opc.c: Handle TILEPRO_OPC_LW_TLS and - TILEPRO_OPC_LW_TLS_SN. - -2012-02-21 H.J. Lu - - * i386-opc.h (HLEPrefixNone): New. - (HLEPrefixLock): Likewise. - (HLEPrefixAny): Likewise. - (HLEPrefixRelease): Likewise. - -2012-02-08 H.J. Lu - - * i386-dis.c (HLE_Fixup1): New. - (HLE_Fixup2): Likewise. - (HLE_Fixup3): Likewise. - (Ebh1): Likewise. - (Evh1): Likewise. - (Ebh2): Likewise. - (Evh2): Likewise. - (Ebh3): Likewise. - (Evh3): Likewise. - (MOD_C6_REG_7): Likewise. - (MOD_C7_REG_7): Likewise. - (RM_C6_REG_7): Likewise. - (RM_C7_REG_7): Likewise. - (XACQUIRE_PREFIX): Likewise. - (XRELEASE_PREFIX): Likewise. - (dis386): Use Ebh1/Evh1 on add, adc, and, btc, btr, bts, - cmpxchg, dec, inc, neg, not, or, sbb, sub, xor and xadd. Use - Ebh2/Evh2 on xchg. Use Ebh3/Evh3 on mov. - (reg_table): Use Ebh1/Evh1 on add, adc, and, dec, inc, neg, - not, or, sbb, sub and xor. Use Ebh3/Evh3 on mov. Use - MOD_C6_REG_7 and MOD_C7_REG_7. - (mod_table): Add MOD_C6_REG_7 and MOD_C7_REG_7. - (rm_table): Add RM_C6_REG_7 and RM_C7_REG_7. Add xend and - xtest. - (prefix_name): Handle XACQUIRE_PREFIX and XRELEASE_PREFIX. - (CMPXCHG8B_Fixup): Handle HLE prefix on cmpxchg8b. - - * i386-gen.c (cpu_flag_init): Add CPU_HLE_FLAGS and - CPU_RTM_FLAGS. - (cpu_flags): Add CpuHLE and CpuRTM. - (opcode_modifiers): Add HLEPrefixOk. - - * i386-opc.h (CpuHLE): New. - (CpuRTM): Likewise. - (HLEPrefixOk): Likewise. - (i386_cpu_flags): Add cpuhle and cpurtm. - (i386_opcode_modifier): Add hleprefixok. - - * i386-opc.tbl: Add HLEPrefixOk=3 to mov. Add HLEPrefixOk to - add, adc, and, btc, btr, bts, cmpxchg, dec, inc, neg, not, or, - sbb, sub, xor and xadd. Add HLEPrefixOk=2 to xchg with memory - operand. Add xacquire, xrelease, xabort, xbegin, xend and - xtest. - * i386-init.h: Regenerated. - * i386-tbl.h: Likewise. - -2012-01-24 DJ Delorie - - * rl78-decode.opc (rl78_decode_opcode): Add NOT1. - * rl78-decode.c: Regenerate. - -2012-01-17 James Murray - - PR binutils/10173 - * cr16-dis.c (print_arg): Test symtab_size not num_symbols. - -2012-01-17 Andreas Schwab - - * m68k-opc.c (m68k_opcodes): Fix entries for pmove with BADx/BACx - register and move them after pmove with PSR/PCSR register. - -2012-01-13 H.J. Lu - - * i386-dis.c (mod_table): Add vmfunc. - - * i386-gen.c (cpu_flag_init): Add CPU_VMFUNC_FLAGS. - (cpu_flags): CpuVMFUNC. - - * i386-opc.h (CpuVMFUNC): New. - (i386_cpu_flags): Add cpuvmfunc. - - * i386-opc.tbl: Add vmfunc. - * i386-init.h: Regenerated. - * i386-tbl.h: Likewise. - -For older changes see ChangeLog-2011 +For older changes see ChangeLog-2012 -Copyright (C) 2012 Free Software Foundation, Inc. +Copyright (C) 2013 Free Software Foundation, Inc. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright diff --git a/opcodes/ChangeLog-2012 b/opcodes/ChangeLog-2012 new file mode 100644 index 00000000000..f69ea65cae2 --- /dev/null +++ b/opcodes/ChangeLog-2012 @@ -0,0 +1,1066 @@ +2012-12-17 Nick Clifton + + * MAINTAINERS: Add copyright notice. + * Makefile.am: Likewise. + * configure.com: Likewise. + * configure.in: Likewise. + * makefile.vms: Likewise. + * rl78-decode.c: Likewise. + * rl78-decode.opc: Likewise. + * rx-decode.c: Likewise. + * rx-decode.opc: Likewise. + * Makefile.in: Regenerate. + +2012-12-13 Alan Modra + + PR binutils/14950 + * ppc-opc.c (insert_sci8, extract_sci8): Rewrite. + (insert_sci8n, extract_sci8n): Likewise. + +2012-11-30 Oleg Raikhman + Joern Rennecke + + * epiphany-desc.c, epiphany-desc.h, epiphany-opc.c: Regenerate. + +2012-11-29 Roland McGrath + + * s390-mkopc.c (file_header): Add const. + +2012-11-29 David Holsgrove + + * microblaze-opc.h: Rename INST_TYPE_RD_R1_SPECIAL to + INST_TYPE_R1_R2_SPECIAL + * microblaze-dis.c (print_insn_microblaze): Same. + +2012-11-23 Alan Modra + + * ppc-dis.c (ppc_parse_cpu): Add "sticky" param. Track bits + set from ppc_opts.sticky in it. Delete "retain_mask". + (powerpc_init_dialect): Choose default dialect from info->mach + before parsing -M options. Handle more bfd_mach_ppc variants. + Update common default to power7. + +2012-11-21 David Holsgrove + + * microblaze-opc.h (op_code_struct): Add swapb, swaph Increase MAX_OPCODES. + * microblaze-opcm.h (microblaze_instr): Likewise + +2012-11-21 Edgar E. Iglesias + + * microblaze-opcm.h: Add REG_SLR_MASK, REG_SHR_MASK, REG_SHR and REG_SLR + * microblaze-dis.c (get_field_special): Handle REG_SLR_MASK and REG_SHR_MASK + +2012-11-20 Kirill Yukhin + H.J. Lu + + PR gas/14859 + * i386-opc.tbl: Fix opcode for 64-bit jecxz. + * i386-tbl.h: Regenerated. + +2012-11-20 Andreas Krebbel + + * s390-opc.txt: Fix srstu and strag opcodes. + +2012-11-14 David Holsgrove + + * microblaze-opc.h: Define new instruction type INST_TYPE_IMM5, + update OPCODE_MASK_H13S, add OPCODE_MASK_HN, define MIN_IMM5 / MAX_IMM5, + and increase MAX_OPCODES. + (op_code_struct): add mbar and sleep + * microblaze-opcm.h (microblaze_instr): add mbar + Define IMM_MBAR and IMM5_MBAR_MASK + * microblaze-dis.c: Add get_field_imm5_mbar + (print_insn_microblaze): Add support for INST_TYPE_IMM5 and INST_TYPE_NONE + +2012-11-14 Edgar E. Iglesias + + * microblaze-opc.h: Increase MAX_OPCODES (op_code_struct): add clz insn + * microblaze-opcm.h (microblaze_instr): add clz + +2012-11-14 Edgar E. Iglesias + + * microblaze-opc.h: Increase MAX_OPCODES (op_code_struct): add lbur, + lhur, lwr, sbr, shr, swr + * microblaze-opcm.h (microblaze_instr): add lbur, lhur, lwr, sbr, shr, + swr + +2012-11-09 Nick Clifton + + * configure.in: Add bfd_v850_rh850_arch. + * configure: Regenerate. + * disassemble.c (disassembler): Likewise. + +2012-11-09 H.J. Lu + + * aarch64-opc.h (gen_mask): Remove trailing redundant `;'. + * ia64-gen.c (fetch_insn_class): Likewise. + +2012-11-08 Alan Modra + + * po/POTFILES.in: Regenerate. + +2012-11-05 Alan Modra + + * configure.in: Apply 2012-09-10 change to config.in here. + +2012-10-26 Andreas Krebbel + + * s390-mkopc.c: Accept empty lines in s390-opc.txt. + * s390-opc.c: Add M_20OPT field. New instruction formats RRF_RURR2 + and RRF_RMRR. + * s390-opc.txt: Add new instructions. New instruction type for lptea. + +2012-10-26 Christian Groessler + + * z8kgen.c (struct op): Fix encoding for translate opcodes (trdb, + trdrb, trib, trirb, trtdb, trtdrb, trtib, trtirb). Remove + non-existing opcode trtrb. + * z8k-opc.h: Regenerate. + +2012-10-26 Alan Modra + + * ppc-opc (powerpc_opcodes): "lfdp" and "stfdp" use DS offset. + +2012-10-24 Roland McGrath + + * i386-dis.c (ckprefix): When bailing out for fwait with prefixes, + set rex_used to rex. + +2012-10-22 Peter Bergner + + * ppc-opc.c (powerpc_opcodes) : Fix opcode spelling. + +2012-10-18 Tom Tromey + + * tic54x-dis.c (print_instruction): Don't use K&R style. + (print_parallel_instruction, sprint_dual_address) + (sprint_indirect_address, sprint_direct_address, sprint_mmr) + (sprint_cc2, sprint_condition): Likewise. + +2012-10-18 Kai Tietz + + * aarch64-asm.c (aarch64_ins_ldst_reglist): Initialize + value with a default. + (do_special_encoding): Likewise. + (aarch64_ins_ldst_elemlist): Pre-initialize QSsize, and opcodeh2 + variables with default. + * arc-dis.c (write_comments_): Don't use strncat due + size of state->commentBuffer pointer isn't predictable. + +2012-10-15 Yufeng Zhang + + * aarch64-opc.c (aarch64_sys_regs): Add rmr_el1, rmr_el2 and + rmr_el3; remove daifset and daifclr. + +2012-10-15 Yufeng Zhang + + * aarch64-opc.c (operand_general_constraint_met_p): Change to check + the alignment of addr.offset.imm instead of that of shifter.amount for + operand type AARCH64_OPND_ADDR_UIMM12. + +2012-10-11 Kyrylo Tkachov + + * arm-dis.c: Use preferred form of vrint instruction variants + for disassembly. + +2012-10-09 Nagajyothi Eggone + + * i386-gen.c (cpu_flag_init): Add CPU_BDVER3_FLAGS. + * i386-init.h: Regenerated. + +2012-10-05 Peter Bergner + + * ppc-dis.c (ppc_opts) : Use PPC_OPCODE_ALTIVEC2; + * ppc-opc.c (VBA): New define. + (powerpc_opcodes) : New extended mnemonics. + +2012-10-04 Nick Clifton + + * v850-dis.c (disassemble): Place square parentheses around second + register operand of clr1, not1, set1 and tst1 instructions. + +2012-10-04 Andreas Krebbel + + * s390-mkopc.c: Support new option zEC12. + * s390-opc.c: Add new instruction formats. + * s390-opc.txt: Add new instructions for zEC12. + +2012-09-27 Anthony Green + + * moxie-dis.c (print_insn_moxie): Print 'bad' instructions. + * moxie-opc.c: All 'bad' instructions have the itype MOXIE_BAD. + +2012-09-25 Saravanan Ekanathan + + * i386-gen.c (cpu_flag_init): Add missing Cpu flags in + CPU_BDVER1_FLAGS, CPU_BDVER2_FLAGS, CPU_BTVER1_FLAGS + and CPU_BTVER2_FLAGS. + * i386-init.h: Regenerated. + +2012-09-20 Michael Zolotukhin + + * i386-gen.c (cpu_flag_init): Add CpuCX16 to CPU_NOCONA_FLAGS, + CPU_CORE_FLAGS, CPU_CORE2_FLAGS, CPU_COREI7_FLAGS, + CPU_BDVER1_FLAGS, CPU_BDVER2_FLAGS, CPU_BTVER1_FLAGS, + CPU_BTVER2_FLAGS. Add CPU_CX16_FLAGS. + (cpu_flags): Add CpuCX16. + * i386-opc.h (CpuCX16): New. + (i386_cpu_flags): Add cpucx16. + * i386-opc.tbl: Replace CpuSSE3 with CpuCX16 for cmpxchg16b. + * i386-tbl.h: Regenerate. + * i386-init.h: Likewise. + +2012-09-18 Kyrylo Tkachov + + * arm-dis.c: Changed ldra and strl-form mnemonics + to lda and stl-form. + +2012-09-18 Chao-ying Fu + + * micromips-opc.c (micromips_opcodes): Correct the encoding of + the "swxc1" instruction. + +2012-09-17 Yufeng Zhang + + * aarch64-asm.c (aarch64_ins_imm_half): Remove ATTRIBUTE_UNUSED from + the parameter 'inst'. + (aarch64_ins_addr_simm): Add ATTRIBUTE_UNUSED to the parameter 'inst'. + (convert_mov_to_movewide): Change to assert (0) when + aarch64_wide_constant_p returns FALSE. + +2012-09-14 David Edelsohn + + * configure: Regenerate. + +2012-09-14 Anthony Green + + * moxie-dis.c (print_insn_moxie): Branch targets are relative to + the address after the branch instruction. + +2012-09-13 Anthony Green + + * moxie-dis.c (print_insn_moxie): Handle bi-endian encodings. + +2012-09-10 Matthias Klose + + * config.in: Disable sanity check for kfreebsd. + +2012-09-10 H.J. Lu + + * configure: Regenerated. + +2012-09-04 Sergey A. Guriev + + * ia64-asmtab.h (completer_index): Extend bitfield to full uint. + * ia64-gen.c: Promote completer index type to longlong. + (irf_operand): Add new register recognition. + (in_iclass_mov_x): Add an entry for the new mov_* instruction type. + (lookup_specifier): Add new resource recognition. + (insert_bit_table_ent): Relax abort condition according to the + changed completer index type. + (print_dis_table): Fix printf format for completer index. + * ia64-ic.tbl: Add a new instruction class. + * ia64-opc-i.c (ia64_opcodes_i): Define new I-instructions. + * ia64-opc-m.c (ia64_opcodes_m): Define new M-instructions. + * ia64-opc.h: Define short names for new operand types. + * ia64-raw.tbl: Add new RAW resource for DAHR register. + * ia64-waw.tbl: Add new WAW resource for DAHR register. + * ia64-asmtab.c: Regenerate. + +2012-08-29 Peter Bergner + + * ppc-opc.c (VXASHB_MASK): New define. + (powerpc_opcodes) : Use VXASHB_MASK. + +2012-08-28 Peter Bergner + + * ppc-opc.c (UIMM4, UIMM3, UIMM2, VXVA_MASK, VXVB_MASK, VXVAVB_MASK, + VXVDVA_MASK, VXUIMM4_MASK, VXUIMM3_MASK, VXUIMM2_MASK): New defines. + (powerpc_opcodes) : Use VXVA_MASK. + : Use VXVB_MASK. + : Use VXVAVB_MASK. + : Use VXVDVA_MASK. + : Use VXUIMM4_MASK. + : Use VXUIMM3_MASK. + : Use VXUIMM2_MASK. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (neon_opcodes): Add 2 operand sha instructions. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (neon_opcodes): Add SHA 3-operand instructions. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (neon_opcodes): Handle VMULL.P64. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (neon_opcodes): Add support for AES instructions. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (coprocessor_opcodes): Add support for HP/DP + conversions. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (coprocessor_opcodes): Add VRINT. + (neon_opcodes): Likewise. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (coprocessor_opcodes): Add support for new VCVT + variants. + (neon_opcodes): Likewise. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (coprocessor_opcodes): Add VMAXNM/VMINNM. + (neon_opcodes): Likewise. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (coprocessor_opcodes): Add VSEL. + (print_insn_coprocessor): Add new %<>c bitfield format + specifier. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (arm_opcodes): Add LDRA/STRL instructions. + (thumb32_opcodes): Likewise. + (print_arm_insn): Add support for %<>T formatter. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (arm_opcodes): Add HLT. + (thumb_opcodes): Likewise. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (thumb32_opcodes): Add DCPS instruction. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (arm_opcodes): Add SEVL. + (thumb_opcodes): Likewise. + (thumb32_opcodes): Likewise. + +2012-08-24 Matthew Gretton-Dann + + * arm-dis.c (data_barrier_option): New function. + (print_insn_arm): Use data_barrier_option. + (print_insn_thumb32): Use data_barrier_option. + +2012-08-24 Matthew Gretton-Dann + + * sparc-opc.c (4-argument crypto instructions): Fix encoding using + F3F4 macro. + +2012-08-20 Edmar Wienskoski + + * ppc-opc.c (powerpc_opcodes): Changed opcode for vabsdub, + vabsduh, vabsduw, mviwsplt. + +2012-08-17 Nagajyothi Eggone + + * i386-gen.c (cpu_flag_init): Add CPU_BTVER1_FLAGS and + CPU_BTVER2_FLAGS. + + * i386-opc.h: Update CpuPRFCHW comment. + + * i386-opc.tbl: Enable prefetch instruction for CpuPRFCHW. + * i386-init.h: Regenerated. + * i386-tbl.h: Likewise. + +2012-08-17 Nick Clifton + + * po/uk.po: New Ukranian translation. + * configure.in (ALL_LINGUAS): Add uk. + * configure: Regenerate. + +2012-08-16 Peter Bergner + + * ppc-opc.c (powerpc_opcodes) <"lswx">: Use RAX for the second and + RBX for the third operand. + <"lswi">: Use RAX for second and NBI for the third operand. + +2012-08-15 DJ Delorie + + * rl78-decode.opc (rl78_decode_opcode): Merge %e and %[01] + operands, so that data addresses can be corrected when not + ES-overridden. + * rl78-decode.c: Regenerate. + * rl78-dis.c (print_insn_rl78): Make order of modifiers + irrelevent. When the 'e' specifier is used on an operand and no + ES prefix is provided, adjust address to make it absolute. + +2012-08-15 Peter Bergner + + * ppc-opc.c : Use PPC_OPERAND_GPR. + +2012-08-15 Peter Bergner + + * ppc-opc.c : New extended mnemonics. + +2012-08-14 Maciej W. Rozycki + + * mips-dis.c (print_insn_args): Add GET_OP and GET_OP_S local + macros, use local variables for info struct member accesses, + update the type of the variable used to hold the instruction + word. + (print_insn_mips, print_mips16_insn_arg): Likewise. + (print_insn_mips16): Add GET_OP and GET_OP_S local macros, use + local variables for info struct member accesses. + (print_insn_micromips): Add GET_OP_S local macro. + (_print_insn_mips): Update the type of the variable used to hold + the instruction word. + +2012-08-13 Ian Bolton + Laurent Desnogues + Jim MacArthur + Marcus Shawcroft + Nigel Stephens + Ramana Radhakrishnan + Richard Earnshaw + Sofiane Naci + Tejas Belagod + Yufeng Zhang + + * Makefile.am: Add AArch64. + * Makefile.in: Regenerate. + * aarch64-asm.c: New file. + * aarch64-asm.h: New file. + * aarch64-dis.c: New file. + * aarch64-dis.h: New file. + * aarch64-gen.c: New file. + * aarch64-opc.c: New file. + * aarch64-opc.h: New file. + * aarch64-tbl.h: New file. + * configure.in: Add AArch64. + * configure: Regenerate. + * disassemble.c: Add AArch64. + * aarch64-asm-2.c: New file (automatically generated). + * aarch64-dis-2.c: New file (automatically generated). + * aarch64-opc-2.c: New file (automatically generated). + * po/POTFILES.in: Regenerate. + +2012-08-13 Maciej W. Rozycki + + * micromips-opc.c (micromips_opcodes): Update comment. + * mips-opc.c (mips_builtin_opcodes): Likewise. Mark coprocessor + instructions for IOCT as appropriate. + * mips-dis.c (print_insn_mips): Replace OPCODE_IS_MEMBER with + opcode_is_member. + * configure.in: Substitute NO_WMISSING_FIELD_INITIALIZERS with + the result of a check for the -Wno-missing-field-initializers + GCC option. + * Makefile.am (NO_WMISSING_FIELD_INITIALIZERS): New variable. + (mips-opc.lo): Pass $(NO_WMISSING_FIELD_INITIALIZERS) to + compilation. + (mips16-opc.lo): Likewise. + (micromips-opc.lo): Likewise. + * aclocal.m4: Regenerate. + * configure: Regenerate. + * Makefile.in: Regenerate. + +2012-08-11 Saravanan Ekanathan + + PR gas/14423 + * i386-gen.c (cpu_flag_init): Add CpuFMA in CPU_BDVER2_FLAGS. + * i386-init.h: Regenerated. + +2012-08-09 Nick Clifton + + * po/vi.po: Updated Vietnamese translation. + +2012-08-07 Roland McGrath + + * i386-dis.c (reg_table): Fill out REG_0F0D table with + AMD-reserved cases as "prefetch". + (MOD_0F18_REG_4, MOD_0F18_REG_5): New enum constants. + (MOD_0F18_REG_6, MOD_0F18_REG_7): Likewise. + (reg_table): Use those under REG_0F18. + (mod_table): Add those cases as "nop/reserved". + +2012-08-07 Jan Beulich + + * i386-opc.tbl: Remove "FIXME" comments from SVME instructions. + +2012-08-06 Roland McGrath + + * i386-dis.c (print_insn): Print spaces between multiple excess + prefixes. Return actual number of excess prefixes consumed, + not always one. + + * i386-dis.c (OP_REG): Ignore REX_B for segment register cases. + +2012-08-06 Roland McGrath + Victor Khimenko + H.J. Lu + + * i386-dis.c (OP_sI): In b_T_mode and v_mode, REX_W trumps DFLAG. + (putop): For 'T', 'U', and 'V', treat REX_W like DFLAG. + (intel_operand_size): For stack_v_mode, treat REX_W like DFLAG. + (OP_E_register): Likewise. + (OP_REG): For low 8 whole registers, treat REX_W like DFLAG. + +2012-08-02 Jan-Benedict Glaw + + * configure.in: Formatting. + * configure: Regenerate. + +2012-08-01 Alan Modra + + * h8300-dis.c: Fix printf arg warnings. + * i960-dis.c: Likewise. + * mips-dis.c: Likewise. + * pdp11-dis.c: Likewise. + * sh-dis.c: Likewise. + * v850-dis.c: Likewise. + * configure.in: Formatting. + * configure: Regenerate. + * rl78-decode.c: Regenerate. + * po/POTFILES.in: Regenerate. + +2012-07-31 Chao-Ying Fu + Catherine Moore + Maciej W. Rozycki + + * micromips-opc.c (WR_a, RD_a, MOD_a): New macros. + (DSP_VOLA): Likewise. + (D32, D33): Likewise. + (micromips_opcodes): Add DSP ASE instructions. + * mips-dis.c (print_insn_micromips) <'2', '3'>: New cases. + <'4', '5', '6', '7', '8', '0', '^', '@'>: Likewise. + +2012-07-31 Jan Beulich + + * i386-opc.tbl (vmovntdqa): Move up into 256-bit integer AVX2 + instruction group. Mark as requiring AVX2. + * i386-tbl.h: Re-generate. + +2012-07-30 Nick Clifton + + * po/opcodes.pot: Updated template. + * po/es.po: Updated Spanish translation. + * po/fi.po: Updated Finnish translation. + +2012-07-27 Mike Frysinger + + * configure.in (BFD_VERSION): Run bfd/configure --version and + parse the output of that. + * configure: Regenerate. + +2012-07-25 James Lemke + + * ppc-opc.c (powerpc_opcodes): Add/remove PPCVLE for some 32-bit insns. + +2012-07-24 Stephan McCamant + Dr David Alan Gilbert + + PR binutils/13135 + * arm-dis.c: Add necessary casts for printing integer values. + Use %s when printing string values. + * hppa-dis.c: Likewise. + * m68k-dis.c: Likewise. + * microblaze-dis.c: Likewise. + * mips-dis.c: Likewise. + * sparc-dis.c: Likewise. + +2012-07-19 Michael Zolotukhin + + PR binutils/14355 + * i386-dis.c (VEX_LEN_0FXOP_08_CC): New. + (VEX_LEN_0FXOP_08_CD): Likewise. + (VEX_LEN_0FXOP_08_CE): Likewise. + (VEX_LEN_0FXOP_08_CF): Likewise. + (VEX_LEN_0FXOP_08_EC): Likewise. + (VEX_LEN_0FXOP_08_ED): Likewise. + (VEX_LEN_0FXOP_08_EE): Likewise. + (VEX_LEN_0FXOP_08_EF): Likewise. + (xop_table): Fix entries for vpcomb, vpcomw, vpcomd, vpcomq, + vpcomub, vpcomuw, vpcomud, vpcomuq. + (vex_len_table): Add entries for VEX_LEN_0FXOP_08_CC, + VEX_LEN_0FXOP_08_CD, VEX_LEN_0FXOP_08_CE, VEX_LEN_0FXOP_08_CF, + VEX_LEN_0FXOP_08_EC, VEX_LEN_0FXOP_08_ED, VEX_LEN_0FXOP_08_EE, + VEX_LEN_0FXOP_08_EF. + +2012-07-16 Michael Zolotukhin + + * i386-dis.c (PREFIX_0F38F6): New. + (prefix_table): Add adcx, adox instructions. + (three_byte_table): Use PREFIX_0F38F6. + (mod_table): Add rdseed instruction. + * i386-gen.c (cpu_flag_init): Add CpuADX, CpuRDSEED, CpuPRFCHW. + (cpu_flags): Likewise. + * i386-opc.h: Add CpuADX, CpuRDSEED, CpuPRFCHW. + (i386_cpu_flags): Add fields cpurdseed, cpuadx, cpuprfchw. + * i386-opc.tbl: Add instrcutions adcx, adox, rdseed. Extend + prefetchw. + * i386-tbl.h: Regenerate. + * i386-init.h: Likewise. + +2012-07-05 Thomas Schwinge + + * mips-dis.c: Remove gratuitous newline. + +2012-07-05 Sean Keys + + * xgate-dis.c: Removed an IF statement that will + always be false due to overlapping operand masks. + * xgate-opc.c: Corrected 'com' opcode entry and + fixed spacing. + +2012-07-02 Roland McGrath + + * i386-opc.tbl: Add RepPrefixOk to nop. + * i386-tbl.h: Regenerate. + +2012-06-28 Nick Clifton + + * po/vi.po: Updated Vietnamese translation. + +2012-06-22 Roland McGrath + + * i386-opc.tbl: Add RepPrefixOk to ret. + * i386-tbl.h: Regenerate. + + * i386-opc.h (RepPrefixOk): New enum constant. + (i386_opcode_modifier): New bitfield 'repprefixok'. + * i386-gen.c (opcode_modifiers): Add RepPrefixOk. + * i386-opc.tbl: Add RepPrefixOk to bsf, bsr, and to all + instructions that have IsString. + * i386-tbl.h: Regenerate. + +2012-06-11 Andreas Schwab + + * ppc-opc.c (lvsl, lvebx, isellt, icbt, ldepx, lwepx, lvsr, lvehx) + (iselgt, lvewx, iseleq, isel, dcbst, dcbstep, dcbfl, dcbf, lbepx) + (lvx, dcbfep, dcbtstls, stvebx, dcbtstlse, stdepx, stwepx, dcbtls) + (stvehx, dcbtlse, stvewx, stbepx, icblc, stvx, dcbtstt, dcbtst) + (dcbtst, dcbtstep, dcbtt, dcbt, dcbt, lhepx, eciwx, dcbtep) + (dcread, lxvdsx, lvxl, dcblc, sthepx, ecowx, dcbi, dcread, icbtls) + (stvxl, lxsdx, lfdepx, stxsdx, stfdepx, dcba, dcbal, lxvw4x) + (tlbivax, lfdpx, lxvd2x, tlbsrx., stxvw4x, tlbsx, tlbsx., stfdpx) + (stfqx, stxvd2x, icbi, icbiep, icread, dcbzep): Change RA to RA0. + +2012-05-19 Alan Modra + + * ppc-dis.c: Don't include elf32-ppc.h, do include elf/ppc.h. + (get_powerpc_dialect): Detect VLE sections from ELF sh_flags. + +2012-05-18 Alan Modra + + * ia64-opc.c: Remove #include "ansidecl.h". + * z8kgen.c: Include sysdep.h first. + + * arc-dis.c: Include sysdep.h first, remove some redundant includes. + * bfin-dis.c: Likewise. + * i860-dis.c: Likewise. + * ia64-dis.c: Likewise. + * ia64-gen.c: Likewise. + * m68hc11-dis.c: Likewise. + * mmix-dis.c: Likewise. + * msp430-dis.c: Likewise. + * or32-dis.c: Likewise. + * rl78-dis.c: Likewise. + * rx-dis.c: Likewise. + * tic4x-dis.c: Likewise. + * tilegx-opc.c: Likewise. + * tilepro-opc.c: Likewise. + * rx-decode.c: Regenerate. + +2012-05-17 James Lemke + + * ppc-opc.c (powerpc_macros): Add entries for e_extlwi to e_clrlslwi. + +2012-05-17 James Lemke + + * ppc-opc.c (extract_sprg): Use ALLOW8_SPRG to include VLE. + +2012-05-17 Daniel Richard G. + Nick Clifton + + PR 14072 + * configure.in: Add check that sysdep.h has been included before + any system header files. + * configure: Regenerate. + * config.in: Regenerate. + * sysdep.h: Generate an error if included before config.h. + * alpha-opc.c: Include sysdep.h before any other header file. + * alpha-dis.c: Likewise. + * avr-dis.c: Likewise. + * cgen-opc.c: Likewise. + * cr16-dis.c: Likewise. + * cris-dis.c: Likewise. + * crx-dis.c: Likewise. + * d10v-dis.c: Likewise. + * d10v-opc.c: Likewise. + * d30v-dis.c: Likewise. + * d30v-opc.c: Likewise. + * h8500-dis.c: Likewise. + * i370-dis.c: Likewise. + * i370-opc.c: Likewise. + * m10200-dis.c: Likewise. + * m10300-dis.c: Likewise. + * micromips-opc.c: Likewise. + * mips-opc.c: Likewise. + * mips61-opc.c: Likewise. + * moxie-dis.c: Likewise. + * or32-opc.c: Likewise. + * pj-dis.c: Likewise. + * ppc-dis.c: Likewise. + * ppc-opc.c: Likewise. + * s390-dis.c: Likewise. + * sh-dis.c: Likewise. + * sh64-dis.c: Likewise. + * sparc-dis.c: Likewise. + * sparc-opc.c: Likewise. + * spu-dis.c: Likewise. + * tic30-dis.c: Likewise. + * tic54x-dis.c: Likewise. + * tic80-dis.c: Likewise. + * tic80-opc.c: Likewise. + * tilegx-dis.c: Likewise. + * tilepro-dis.c: Likewise. + * v850-dis.c: Likewise. + * v850-opc.c: Likewise. + * vax-dis.c: Likewise. + * w65-dis.c: Likewise. + * xgate-dis.c: Likewise. + * xtensa-dis.c: Likewise. + * rl78-decode.opc: Likewise. + * rl78-decode.c: Regenerate. + * rx-decode.opc: Likewise. + * rx-decode.c: Regenerate. + +2012-05-17 Alan Modra + + * ppc_dis.c: Don't include elf/ppc.h. + +2012-05-16 Meador Inge + + * arm-dis.c (arm_opcodes): Don't disassemble STMFD/LDMIA sp!, {reg} + to PUSH/POP {reg}. + +2012-05-15 James Murray + Stephane Carrez + + * configure.in: Add S12X and XGATE co-processor support to m68hc11 + target. + * disassemble.c: Likewise. + * configure: Regenerate. + * m68hc11-dis.c: Make objdump output more consistent, use hex + instead of decimal and use 0x prefix for hex. + * m68hc11-opc.c: Add S12X and XGATE opcodes. + +2012-05-14 James Lemke + + * ppc-dis.c (get_powerpc_dialect): Use is_ppc_vle. + (PPC_OPCD_SEGS, VLE_OPCD_SEGS): New defines. + (vle_opcd_indices): New array. + (lookup_vle): New function. + (disassemble_init_powerpc): Revise for second (VLE) opcode table. + (print_insn_powerpc): Likewise. + * ppc-opc.c: Likewise. + +2012-05-14 Catherine Moore + Maciej W. Rozycki + Rhonda Wittels + Nathan Froyd + + * ppc-opc.c (insert_arx, extract_arx): New functions. + (insert_ary, extract_ary): New functions. + (insert_li20, extract_li20): New functions. + (insert_rx, extract_rx): New functions. + (insert_ry, extract_ry): New functions. + (insert_sci8, extract_sci8): New functions. + (insert_sci8n, extract_sci8n): New functions. + (insert_sd4h, extract_sd4h): New functions. + (insert_sd4w, extract_sd4w): New functions. + (insert_vlesi, extract_vlesi): New functions. + (insert_vlensi, extract_vlensi): New functions. + (insert_vleui, extract_vleui): New functions. + (insert_vleil, extract_vleil): New functions. + (BI_MASK, BB_MASK, BT): Use PPC_OPERAND_CR_BIT. + (BI16, BI32, BO32, B8): New. + (B15, B24, CRD32, CRS): New. + (CRD, OBF, BFA, CR, CRFS): Use PPC_OPERAND_CR_REG. + (DB, IMM20, RD, Rx, ARX, RY, RZ): New. + (ARY, SCLSCI8, SCLSCI8N, SE_SD, SE_SDH): New. + (SH6_MASK): Use PPC_OPSHIFT_INV. + (SI8, UI5, OIMM5, UI7, BO16): New. + (VLESIMM, VLENSIMM, VLEUIMM, VLEUIMML): New. + (XT6, XA6, XB6, XB6S, XC6): Use PPC_OPSHIFT_INV. + (ALLOW8_SPRG): New. + (insert_sprg, extract_sprg): Check ALLOW8_SPRG. + (OPVUP, OPVUP_MASK OPVUP): New + (BD8, BD8_MASK, BD8IO, BD8IO_MASK): New. + (EBD8IO, EBD8IO1_MASK, EBD8IO2_MASK, EBD8IO3_MASK): New. + (BD15, BD15_MASK, EBD15, EBD15_MASK, EBD15BI, EBD15BI_MASK): New. + (BD24,BD24_MASK, C_LK, C_LK_MASK, C, C_MASK): New. + (IA16, IA16_MASK, I16A, I16A_MASK, I16L, I16L_MASK): New. + (IM7, IM7_MASK, LI20, LI20_MASK, SCI8, SCI8_MASK): New. + (SCI8BF, SCI8BF_MASK, SD4, SD4_MASK): New. + (SE_IM5, SE_IM5_MASK): New. + (SE_R, SE_R_MASK, SE_RR, SE_RR_MASK): New. + (EX, EX_MASK, BO16F, BO16T, BO32F, BO32T): New. + (BO32DNZ, BO32DZ): New. + (NO371, PPCSPE, PPCISEL, PPCEFS, MULHW): Include PPC_OPCODE_VLE. + (PPCVLE): New. + (powerpc_opcodes): Add new VLE instructions. Update existing + instruction to include PPCVLE if supported. + * ppc-dis.c (ppc_opts): Add vle entry. + (get_powerpc_dialect): New function. + (powerpc_init_dialect): VLE support. + (print_insn_big_powerpc): Call get_powerpc_dialect. + (print_insn_little_powerpc): Likewise. + (operand_value_powerpc): Handle negative shift counts. + (print_insn_powerpc): Handle 2-byte instruction lengths. + +2012-05-11 Daniel Richard G. + + PR binutils/14028 + * configure.in: Invoke ACX_HEADER_STRING. + * configure: Regenerate. + * config.in: Regenerate. + * sysdep.h: If STRINGS_WITH_STRING is defined then include both + string.h and strings.h. + +2012-05-11 Nick Clifton + + PR binutils/14006 + * arm-dis.c (print_insn): Fix detection of instruction mode in + files containing multiple executable sections. + +2012-05-03 Sean Keys + + * Makefile.in, configure: regenerate + * disassemble.c (disassembler): Recognize ARCH_XGATE. + * xgate-dis.c (read_memory, print_insn, print_insn_xgate): + New functions. + * configure.in: Recognize xgate. + * xgate-dis.c, xgate-opc.c: New files for support of xgate + * Makefile.am (CFILES, ALL_MACHINES): New files for disassembly + and opcode generation for xgate. + +2012-04-30 DJ Delorie + + * rx-decode.opc (MOV): Do not sign-extend immediates which are + already the maximum bit size. + * rx-decode.c: Regenerate. + +2012-04-27 David S. Miller + + * sparc-dis.c (v9a_asr_reg_names): Add 'cfr'. + * sparc-opc.c (sparc_opcodes): Add rd/wr cases for %cfr. + + * sparc-opc.c (sparc_opcodes): Add 'wr X, %pause' and 'pause'. + * sparc-dis.c (v9a_asr_reg_names): Add 'pause'. + + * sparc-opc.c (CBCOND): New define. + (CBCOND_XCC): Likewise. + (cbcond): New helper macro. + (sparc_opcodes): Add compare-and-branch instructions. + + * sparc-dis.c (print_insn_sparc): Handle ')'. + * sparc-opc.c (sparc_opcodes): Add crypto instructions. + + * sparc-opc.c (sparc_opcodes): Rework table to put HWCAP values + into new struct sparc_opcode 'hwcaps' field instead of 'flags'. + +2012-04-12 David S. Miller + + * sparc-dis.c (X_DISP10): Define. + (print_insn_sparc): Handle '='. + +2012-04-01 Mike Frysinger + + * bfin-dis.c (fmtconst): Replace decimal handling with a single + sprintf call and the '*' field width. + +2012-03-23 Maxim Kuvyrkov + + * mips-dis.c (mips_arch_choices): Add entry for Broadcom XLP. + +2012-03-16 Alan Modra + + * ppc-dis.c (PPC_OPC_SEGS, PPC_OP_TO_SEG): Delete. + (powerpc_opcd_indices): Bump array size. + (disassemble_init_powerpc): Set powerpc_opcd_indices entries + corresponding to unused opcodes to following entry. + (lookup_powerpc): New function, extracted and optimised from.. + (print_insn_powerpc): ..here. + +2012-03-15 Alan Modra + James Lemke + + * disassemble.c (disassemble_init_for_target): Handle ppc init. + * ppc-dis.c (private): New var. + (powerpc_init_dialect): Don't return calloc failure, instead use + private. + (PPC_OPCD_SEGS, PPC_OP_TO_SEG): Define. + (powerpc_opcd_indices): New array. + (disassemble_init_powerpc): New function. + (print_insn_big_powerpc): Don't init dialect here. + (print_insn_little_powerpc): Likewise. + (print_insn_powerpc): Start search using powerpc_opcd_indices. + +2012-03-10 Edmar Wienskoski + + * ppc-dis.c (ppc_opts): Add entries for "e5500" and "e6500". + * ppc-opc.c (insert_ls, TMR, ESYNC, XSYNCLE_MASK): New. + (PPCVEC2, PPCTMR, E6500): New short names. + (powerpc_opcodes): Add vabsdub, vabsduh, vabsduw, dni, mvidsplt, + mviwsplt, icblq., mftmr, mttmr, dcblq., miso, lvexbx, lvexhx, + lvexwx, stvexbx, stvexhx, stvexwx, lvepx, lvepxl, stvepx, stvepxl, + lvtrx, lvtrxl, lvtlx, lvtlxl, stvfrx, stvfrxl, stvflx, stvflxl, + lvswx, lvswxl, stvswx, stvswxl, lvsm mnemonics. Accept LS, ESYNC + optional operands on sync instruction for E6500 target. + +2012-03-08 Andreas Krebbel + + * s390-opc.txt: Set instruction type of pku to SS_L2RDRD. + +2012-02-27 Alan Modra + + * mt-dis.c: Regenerate. + +2012-02-27 Alan Modra + + * v850-opc.c (extract_v8): Rearrange to make it obvious this + is the inverse of corresponding insert function. + (extract_d22, extract_u9, extract_r4): Likewise. + (extract_d9): Correct sign extension. + (extract_d16_15): Don't assume "long" is 32 bits, and don't + rely on implementation defined behaviour for shift right of + signed types. + (extract_d16_16, extract_d17_16, extract_i9): Likewise. + (extract_d23): Likewise, and correct mask. + +2012-02-27 Alan Modra + + * crx-dis.c (print_arg): Mask constant to 32 bits. + * crx-opc.c (cst4_map): Use int array. + +2012-02-27 Alan Modra + + * arc-dis.c (BITS): Don't use shifts to mask off bits. + (FIELDD): Sign extend with xor,sub. + +2012-02-25 Walter Lee + + * tilegx-opc.c: Handle TILEGX_OPC_LD4S_TLS and TILEGX_OPC_LD_TLS. + * tilepro-opc.c: Handle TILEPRO_OPC_LW_TLS and + TILEPRO_OPC_LW_TLS_SN. + +2012-02-21 H.J. Lu + + * i386-opc.h (HLEPrefixNone): New. + (HLEPrefixLock): Likewise. + (HLEPrefixAny): Likewise. + (HLEPrefixRelease): Likewise. + +2012-02-08 H.J. Lu + + * i386-dis.c (HLE_Fixup1): New. + (HLE_Fixup2): Likewise. + (HLE_Fixup3): Likewise. + (Ebh1): Likewise. + (Evh1): Likewise. + (Ebh2): Likewise. + (Evh2): Likewise. + (Ebh3): Likewise. + (Evh3): Likewise. + (MOD_C6_REG_7): Likewise. + (MOD_C7_REG_7): Likewise. + (RM_C6_REG_7): Likewise. + (RM_C7_REG_7): Likewise. + (XACQUIRE_PREFIX): Likewise. + (XRELEASE_PREFIX): Likewise. + (dis386): Use Ebh1/Evh1 on add, adc, and, btc, btr, bts, + cmpxchg, dec, inc, neg, not, or, sbb, sub, xor and xadd. Use + Ebh2/Evh2 on xchg. Use Ebh3/Evh3 on mov. + (reg_table): Use Ebh1/Evh1 on add, adc, and, dec, inc, neg, + not, or, sbb, sub and xor. Use Ebh3/Evh3 on mov. Use + MOD_C6_REG_7 and MOD_C7_REG_7. + (mod_table): Add MOD_C6_REG_7 and MOD_C7_REG_7. + (rm_table): Add RM_C6_REG_7 and RM_C7_REG_7. Add xend and + xtest. + (prefix_name): Handle XACQUIRE_PREFIX and XRELEASE_PREFIX. + (CMPXCHG8B_Fixup): Handle HLE prefix on cmpxchg8b. + + * i386-gen.c (cpu_flag_init): Add CPU_HLE_FLAGS and + CPU_RTM_FLAGS. + (cpu_flags): Add CpuHLE and CpuRTM. + (opcode_modifiers): Add HLEPrefixOk. + + * i386-opc.h (CpuHLE): New. + (CpuRTM): Likewise. + (HLEPrefixOk): Likewise. + (i386_cpu_flags): Add cpuhle and cpurtm. + (i386_opcode_modifier): Add hleprefixok. + + * i386-opc.tbl: Add HLEPrefixOk=3 to mov. Add HLEPrefixOk to + add, adc, and, btc, btr, bts, cmpxchg, dec, inc, neg, not, or, + sbb, sub, xor and xadd. Add HLEPrefixOk=2 to xchg with memory + operand. Add xacquire, xrelease, xabort, xbegin, xend and + xtest. + * i386-init.h: Regenerated. + * i386-tbl.h: Likewise. + +2012-01-24 DJ Delorie + + * rl78-decode.opc (rl78_decode_opcode): Add NOT1. + * rl78-decode.c: Regenerate. + +2012-01-17 James Murray + + PR binutils/10173 + * cr16-dis.c (print_arg): Test symtab_size not num_symbols. + +2012-01-17 Andreas Schwab + + * m68k-opc.c (m68k_opcodes): Fix entries for pmove with BADx/BACx + register and move them after pmove with PSR/PCSR register. + +2012-01-13 H.J. Lu + + * i386-dis.c (mod_table): Add vmfunc. + + * i386-gen.c (cpu_flag_init): Add CPU_VMFUNC_FLAGS. + (cpu_flags): CpuVMFUNC. + + * i386-opc.h (CpuVMFUNC): New. + (i386_cpu_flags): Add cpuvmfunc. + + * i386-opc.tbl: Add vmfunc. + * i386-init.h: Regenerated. + * i386-tbl.h: Likewise. + +For older changes see ChangeLog-2011 + +Copyright (C) 2012 Free Software Foundation, Inc. + +Copying and distribution of this file, with or without modification, +are permitted in any medium without royalty provided the copyright +notice and this notice are preserved. + +Local Variables: +mode: change-log +left-margin: 8 +fill-column: 74 +version-control: never +End: diff --git a/opcodes/cr16-dis.c b/opcodes/cr16-dis.c index f299fef6c79..9fbdf00a5a9 100644 --- a/opcodes/cr16-dis.c +++ b/opcodes/cr16-dis.c @@ -1,5 +1,5 @@ /* Disassembler code for CR16. - Copyright 2007, 2008, 2009, 2012 Free Software Foundation, Inc. + Copyright 2007, 2008, 2009, 2012, 2013 Free Software Foundation, Inc. Contributed by M R Swami Reddy (MR.Swami.Reddy@nsc.com). This file is part of GAS, GDB and the GNU binutils. @@ -36,9 +36,6 @@ /* Set Bit Mask - a mask to set all bits starting from offset 'offs'. */ #define SBM(offs) ((((1 << (32 - offs)) -1) << (offs))) -typedef unsigned long dwordU; -typedef unsigned short wordU; - typedef struct { dwordU val; @@ -83,11 +80,11 @@ REG_ARG_TYPE; /* Current opcode table entry we're disassembling. */ const inst *instruction; /* Current instruction we're disassembling. */ -ins currInsn; +ins cr16_currInsn; /* The current instruction is read into 3 consecutive words. */ -wordU words[3]; +wordU cr16_words[3]; /* Contains all words in appropriate order. */ -ULONGLONG allWords; +ULONGLONG cr16_allWords; /* Holds the current processed argument number. */ int processing_argument_number; /* Nonzero means a IMM4 instruction. */ @@ -281,7 +278,7 @@ getprocpregname (int reg_index) return "ILLEGAL REGISTER"; } -/* START and END are relating 'allWords' struct, which is 48 bits size. +/* START and END are relating 'cr16_allWords' struct, which is 48 bits size. START|--------|END +---------+---------+---------+---------+ @@ -317,12 +314,13 @@ build_mask (void) /* Search for a matching opcode. Return 1 for success, 0 for failure. */ -static int +int match_opcode (void) { unsigned long mask; /* The instruction 'constant' opcode doewsn't exceed 32 bits. */ - unsigned long doubleWord = (words[1] + (words[0] << 16)) & 0xffffffff; + unsigned long doubleWord = (cr16_words[1] + + (cr16_words[0] << 16)) & 0xffffffff; /* Start searching from end of instruction table. */ instruction = &cr16_instruction[NUMOPCODES - 2]; @@ -360,38 +358,44 @@ make_argument (argument * a, int start_bits) switch (a->type) { case arg_r: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->r = p.val; break; case arg_rp: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->rp = p.val; break; case arg_pr: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->pr = p.val; break; case arg_prp: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->prp = p.val; break; case arg_ic: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->constant = p.val; break; case arg_cc: - p = makelongparameter (allWords, inst_bit_size - (start_bits + a->size), - inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->cc = p.val; break; @@ -400,28 +404,30 @@ make_argument (argument * a, int start_bits) if ((IS_INSN_MNEMONIC ("cbitb")) || (IS_INSN_MNEMONIC ("sbitb")) || (IS_INSN_MNEMONIC ("tbitb"))) - p = makelongparameter (allWords, 8, 9); + p = makelongparameter (cr16_allWords, 8, 9); else - p = makelongparameter (allWords, 9, 10); + p = makelongparameter (cr16_allWords, 9, 10); a->i_r = p.val; - p = makelongparameter (allWords, inst_bit_size - a->size, inst_bit_size); + p = makelongparameter (cr16_allWords, + inst_bit_size - a->size, inst_bit_size); a->constant = p.val; break; case arg_idxrp: - p = makelongparameter (allWords, start_bits + 12, start_bits + 13); + p = makelongparameter (cr16_allWords, start_bits + 12, start_bits + 13); a->i_r = p.val; - p = makelongparameter (allWords, start_bits + 13, start_bits + 16); + p = makelongparameter (cr16_allWords, start_bits + 13, start_bits + 16); a->rp = p.val; if (inst_bit_size > 32) { - p = makelongparameter (allWords, inst_bit_size - start_bits - 12, + p = makelongparameter (cr16_allWords, inst_bit_size - start_bits - 12, inst_bit_size); a->constant = ((p.val & 0xffff) | (p.val >> 8 & 0xf0000)); } else if (instruction->size == 2) { - p = makelongparameter (allWords, inst_bit_size - 22, inst_bit_size); + p = makelongparameter (cr16_allWords, inst_bit_size - 22, + inst_bit_size); a->constant = (p.val & 0xf) | (((p.val >>20) & 0x3) << 4) | ((p.val >>14 & 0x3) << 6) | (((p.val >>7) & 0x1f) <<7); } @@ -431,41 +437,42 @@ make_argument (argument * a, int start_bits) break; case arg_rbase: - p = makelongparameter (allWords, inst_bit_size, inst_bit_size); + p = makelongparameter (cr16_allWords, inst_bit_size, inst_bit_size); a->constant = p.val; - p = makelongparameter (allWords, inst_bit_size - (start_bits + 4), + p = makelongparameter (cr16_allWords, inst_bit_size - (start_bits + 4), inst_bit_size - start_bits); a->r = p.val; break; case arg_cr: - p = makelongparameter (allWords, start_bits + 12, start_bits + 16); + p = makelongparameter (cr16_allWords, start_bits + 12, start_bits + 16); a->r = p.val; - p = makelongparameter (allWords, inst_bit_size - 16, inst_bit_size); + p = makelongparameter (cr16_allWords, inst_bit_size - 16, inst_bit_size); a->constant = p.val; break; case arg_crp: if (instruction->size == 1) - p = makelongparameter (allWords, 12, 16); + p = makelongparameter (cr16_allWords, 12, 16); else - p = makelongparameter (allWords, start_bits + 12, start_bits + 16); + p = makelongparameter (cr16_allWords, start_bits + 12, start_bits + 16); a->rp = p.val; if (inst_bit_size > 32) { - p = makelongparameter (allWords, inst_bit_size - start_bits - 12, + p = makelongparameter (cr16_allWords, inst_bit_size - start_bits - 12, inst_bit_size); a->constant = ((p.val & 0xffff) | (p.val >> 8 & 0xf0000)); } else if (instruction->size == 2) { - p = makelongparameter (allWords, inst_bit_size - 16, inst_bit_size); + p = makelongparameter (cr16_allWords, inst_bit_size - 16, + inst_bit_size); a->constant = p.val; } else if (instruction->size == 1 && a->size != 0) { - p = makelongparameter (allWords, 4, 8); + p = makelongparameter (cr16_allWords, 4, 8); if (IS_INSN_MNEMONIC ("loadw") || IS_INSN_MNEMONIC ("loadd") || IS_INSN_MNEMONIC ("storw") @@ -489,36 +496,37 @@ make_argument (argument * a, int start_bits) switch (a->size) { case 8 : - p = makelongparameter (allWords, 0, start_bits); + p = makelongparameter (cr16_allWords, 0, start_bits); a->constant = ((((p.val&0xf00)>>4)) | (p.val&0xf)); break; case 24: if (instruction->size == 3) { - p = makelongparameter (allWords, 16, inst_bit_size); + p = makelongparameter (cr16_allWords, 16, inst_bit_size); a->constant = ((((p.val>>16)&0xf) << 20) | (((p.val>>24)&0xf) << 16) | (p.val & 0xffff)); } else if (instruction->size == 2) { - p = makelongparameter (allWords, 8, inst_bit_size); + p = makelongparameter (cr16_allWords, 8, inst_bit_size); a->constant = p.val; } break; default: - p = makelongparameter (allWords, inst_bit_size - (start_bits + - a->size), inst_bit_size - start_bits); + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), + inst_bit_size - start_bits); a->constant = p.val; break; } } else { - p = makelongparameter (allWords, inst_bit_size - - (start_bits + a->size), + p = makelongparameter (cr16_allWords, + inst_bit_size - (start_bits + a->size), inst_bit_size - start_bits); a->constant = p.val; } @@ -734,13 +742,13 @@ print_arguments (ins *currentInsn, bfd_vma memaddr, struct disassemble_info *inf /* Build the instruction's arguments. */ -static void +void make_instruction (void) { int i; unsigned int shift; - for (i = 0; i < currInsn.nargs; i++) + for (i = 0; i < cr16_currInsn.nargs; i++) { argument a; @@ -750,13 +758,13 @@ make_instruction (void) shift = instruction->operands[i].shift; make_argument (&a, shift); - currInsn.arg[i] = a; + cr16_currInsn.arg[i] = a; } /* Calculate instruction size (in bytes). */ - currInsn.size = instruction->size + (size_changed ? 1 : 0); + cr16_currInsn.size = instruction->size + (size_changed ? 1 : 0); /* Now in bits. */ - currInsn.size *= 2; + cr16_currInsn.size *= 2; } /* Retrieve a single word from a given memory address. */ @@ -785,10 +793,10 @@ get_words_at_PC (bfd_vma memaddr, struct disassemble_info *info) bfd_vma mem; for (i = 0, mem = memaddr; i < 3; i++, mem += 2) - words[i] = get_word_at_PC (mem, info); + cr16_words[i] = get_word_at_PC (mem, info); - allWords = - ((ULONGLONG) words[0] << 32) + ((unsigned long) words[1] << 16) + words[2]; + cr16_allWords = ((ULONGLONG) cr16_words[0] << 32) + + ((unsigned long) cr16_words[1] << 16) + cr16_words[2]; } /* Prints the instruction by calling print_arguments after proper matching. */ @@ -807,22 +815,22 @@ print_insn_cr16 (bfd_vma memaddr, struct disassemble_info *info) /* Find a matching opcode in table. */ is_decoded = match_opcode (); /* If found, print the instruction's mnemonic and arguments. */ - if (is_decoded > 0 && (words[0] << 16 || words[1]) != 0) + if (is_decoded > 0 && (cr16_words[0] << 16 || cr16_words[1]) != 0) { if (strneq (instruction->mnemonic, "cinv", 4)) info->fprintf_func (info->stream,"%s", getcinvstring (instruction->mnemonic)); else info->fprintf_func (info->stream, "%s", instruction->mnemonic); - if (((currInsn.nargs = get_number_of_operands ()) != 0) + if (((cr16_currInsn.nargs = get_number_of_operands ()) != 0) && ! (IS_INSN_MNEMONIC ("b"))) info->fprintf_func (info->stream, "\t"); make_instruction (); /* For push/pop/pushrtn with RA instructions. */ - if ((INST_HAS_REG_LIST) && ((words[0] >> 7) & 0x1)) - currInsn.nargs +=1; - print_arguments (&currInsn, memaddr, info); - return currInsn.size; + if ((INST_HAS_REG_LIST) && ((cr16_words[0] >> 7) & 0x1)) + cr16_currInsn.nargs +=1; + print_arguments (&cr16_currInsn, memaddr, info); + return cr16_currInsn.size; } /* No match found. */ -- 2.30.2