binutils-gdb/ld/testsuite/ld-mips-elf/elf-rel-got-n64-embed.d

328 lines
12 KiB
D
Raw Normal View History

gas/testsuite/ * gas/mips/mips.exp: Set has_newabi for mips*-sde-elf* too. * gas/mips/elf-rel-got-n32.s: Adjust padding. * gas/mips/elf-rel-got-n64.s: Likewise. * gas/mips/elf-rel23.s: Likewise. * gas/mips/elf-rel28.s: Likewise. * gas/mips/n32-consec.s: Likewise. * gas/mips/elf-rel-xgot-n32.d: Adjust output expected. * gas/mips/elf-rel-xgot-n64.d: Likewise. * gas/mips/elf-rel23.d: Likewise. * gas/mips/elf-rel23a.d: Likewise. * gas/mips/elf-rel23b.d: Likewise. * gas/mips/elf-rel28-n32.d: Likewise. ld/testsuite/ * lib/ld-lib.exp (run_dump_test): Implement the EXTRA_OPTIONS argument and the "dump" keyword. * ld-mips-elf/emit-relocs-1a.s: Make section alignment uniform across targets. * ld-mips-elf/emit-relocs-1b.s: Likewise. * ld-mips-elf/jalbal.s: Adjust padding. * ld-mips-elf/elf-rel-got-n32-embed.d: New test. * ld-mips-elf/elf-rel-got-n64-embed.d: New test. * ld-mips-elf/elf-rel-xgot-n32-embed.d: New test. * ld-mips-elf/elf-rel-xgot-n64-embed.d: New test. * ld-mips-elf/elf-rel-got-n32.d: Remove -melf32btsmipn32. * ld-mips-elf/elf-rel-got-n64.d: Remove -melf64btsmip. Adjust output. * ld-mips-elf/elf-rel-got-n64-linux.d: Remove -melf64btsmip. * ld-mips-elf/elf-rel-xgot-n32.d: Remove -melf32btsmipn32. Adjust output. * ld-mips-elf/elf-rel-xgot-n64.d: Remove -melf64btsmip. Adjust output. * ld-mips-elf/elf-rel-xgot-n64-linux.d: Likewise. * ld-mips-elf/reloc-1-n64.d: Remove -melf64btsmip. * ld-mips-elf/mips-elf.exp: Set has_newabi for mips*-sde-elf* too. Move tool flags from o32_as_flags and o32_ld_flags variables into abi_asflags and abi_ldflags arrays. Adjust test cases run to use them. Run the new tests.
2012-08-07 05:05:54 +08:00
#name: MIPS ELF got reloc n64
gas/testsuite/ * gas/mips/mips.exp: Set has_newabi for all Linux targets. * gas/mips/cfi-n64-1.d: Adjust for targets that do not infer the ISA from the ABI. * gas/mips/elf-rel-got-n32.d: Likewise. * gas/mips/elf-rel-got-n64.d: Likewise. * gas/mips/elf-rel-xgot-n32.d: Likewise. * gas/mips/elf-rel-xgot-n64.d: Likewise. * gas/mips/elf-rel18.d: Likewise. * gas/mips/elf-rel28-n32.d: Likewise. * gas/mips/elf-rel28-n64.d: Likewise. * gas/mips/jal-newabi.d: Likewise. * gas/mips/ldstla-n64-shared.d: Likewise. * gas/mips/ldstla-n64-sym32.d: Likewise. * gas/mips/ldstla-n64.d: Likewise. * gas/mips/macro-warn-1-n32.d: Likewise. * gas/mips/macro-warn-2-n32.d: Likewise. * gas/mips/n32-consec.d: Likewise. ld/testsuite/ * ld-mips-elf/mips-elf.exp: Set has_newabi for all Linux targets. Adjust abi_asflags for targets that do not infer the ISA from the ABI. * ld-mips-elf/eh-frame1-n32.d: Adjust for targets that do not infer the ISA from the ABI. * ld-mips-elf/eh-frame1-n64.d: Likewise. * ld-mips-elf/eh-frame2-n32.d: Likewise. * ld-mips-elf/eh-frame2-n64.d: Likewise. * ld-mips-elf/elf-rel-got-n32-embed.d: Likewise. * ld-mips-elf/elf-rel-got-n32.d: Likewise. * ld-mips-elf/elf-rel-got-n64-embed.d: Likewise. * ld-mips-elf/elf-rel-got-n64-linux.d: Likewise. * ld-mips-elf/elf-rel-got-n64.d: Likewise. * ld-mips-elf/elf-rel-xgot-n32-embed.d: Likewise. * ld-mips-elf/elf-rel-xgot-n32.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64-embed.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64-linux.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64.d: Likewise. * ld-mips-elf/emit-relocs-1.d: Likewise. * ld-mips-elf/got-page-2.d: Likewise. * ld-mips-elf/no-shared-1-n32.d: Likewise. * ld-mips-elf/no-shared-1-n64.d: Likewise. * ld-mips-elf/rel32-n32.d: Likewise. * ld-mips-elf/rel64.d: Likewise. * ld-mips-elf/relax-jalr-n32-shared.d: Likewise. * ld-mips-elf/relax-jalr-n32.d: Likewise. * ld-mips-elf/relax-jalr-n64-shared.d: Likewise. * ld-mips-elf/relax-jalr-n64.d: Likewise. * ld-mips-elf/reloc-1-n32.d: Likewise. * ld-mips-elf/reloc-1-n64.d: Likewise. * ld-mips-elf/textrel-1.d: Likewise.
2012-08-07 05:28:45 +08:00
#as: -march=from-abi -EB -64 -KPIC
[MIPS] Implement O32 FPXX, FP64 and FP64A ABI extensions Specification: https://dmz-portal.mips.com/wiki/MIPS_O32_ABI_-_FR0_and_FR1_Interlinking include/ * elf/mips.h (PT_MIPS_ABIFLAGS, SHT_MIPS_ABIFLAGS): Define. (Val_GNU_MIPS_ABI_FP_OLD_64): Rename from Val_GNU_MIPS_ABI_FP_64. (Val_GNU_MIPS_ABI_FP_64): Redefine. (Val_GNU_MIPS_ABI_FP_XX): Define. (Elf_External_ABIFlags_v0, Elf_Internal_ABIFlags_v0): New structures. (AFL_REG_NONE, AFL_REG_32, AFL_REG_64, AFL_REG_128): Define. (AFL_ASE_DSP, AFL_ASE_DSPR2, AFL_ASE_EVA, AFL_ASE_MCU): Likewise. (AFL_ASE_MDMX, AFL_ASE_MIPS3D, AFL_ASE_MT, AFL_ASE_SMARTMIPS): Likewise. (AFL_ASE_VIRT, AFL_ASE_MSA, AFL_ASE_MIPS16): Likewise. (AFL_ASE_MICROMIPS, AFL_ASE_XPA): Likewise. (AFL_EXT_XLR, AFL_EXT_OCTEON2, AFL_EXT_OCTEONP): Likewise. (AFL_EXT_LOONGSON_3A, AFL_EXT_OCTEON, AFL_EXT_5900): Likewise. (AFL_EXT_4650, AFL_EXT_4010, AFL_EXT_4100, AFL_EXT_3900): Likewise. (AFL_EXT_10000, AFL_EXT_SB1, AFL_EXT_4111, AFL_EXT_4120): Likewise. (AFL_EXT_5400, AFL_EXT_5500, AFL_EXT_LOONGSON_2E): Likewise. (AFL_EXT_LOONGSON_2F): Likewise. (bfd_mips_elf_swap_abiflags_v0_in): Prototype. (bfd_mips_elf_swap_abiflags_v0_out): Likewise. (bfd_mips_isa_ext): Likewise. bfd/ * elfxx-mips.c (ABI_O32_P, MIPS_ELF_ABIFLAGS_SECTION_NAME_P): New macro. (mips_elf_obj_tdata): Add abiflags and abiflags_valid fields. (bfd_mips_elf_swap_abiflags_v0_in): New function. (bfd_mips_elf_swap_abiflags_v0_out): Likewise. (_bfd_mips_elf_section_from_shdr): Handle SHT_MIPS_ABIFLAGS. (_bfd_mips_elf_fake_sections): Likewise. (_bfd_mips_elf_always_size_sections): Handle .MIPS.abiflags. (_bfd_mips_elf_additional_program_headers): Account for new PT_MIPS_ABIFLAGS program header. (_bfd_mips_elf_modify_segment_map): Create PT_MIPS_ABIFLAGS segment and associate with .MIPS.abiflags. (_bfd_mips_elf_gc_mark_extra_sections): New function. (bfd_mips_isa_ext, update_mips_abiflags_isa): New static function. (infer_mips_abiflags): Likewise. (_bfd_mips_elf_final_link): Handle .MIPS.abiflags. (mips_32bit_flags_p): Moved higher. (mips_elf_merge_obj_attributes, _bfd_mips_fp_abi_string): Error checking for FP ABIs. (_bfd_mips_elf_merge_private_bfd_data): Restructure and add abiflags checks. Check EF_MIPS_FP64 flag consistency. (print_mips_ases, print_mips_isa_ext): New static function. (print_mips_fp_abi_value, get_mips_reg_size): Likewise. (_bfd_mips_elf_print_private_bfd_data): Display abiflags data. (_bfd_mips_post_process_headers): Set EI_ABIVERSION = 3 for Val_GNU_MIPS_ABI_FP_64 or Val_GNU_MIPS_ABI_FP_64A. * elfxx-mips.h (_bfd_mips_elf_gc_mark_extra_sections): New prototype. * elf32-mips.c (elf_backend_gc_mark_extra_sections): Implement. * elfn32-mips.c (elf_backend_gc_mark_extra_sections): Implement. * elf64-mips.c (elf_backend_gc_mark_extra_sections): Implement. binutils/ * readelf.c (get_mips_segment_type): Display name for PT_MIPS_ABIFLAGS. (get_mips_section_type_name): Display name for SHT_MIPS_ABIFLAGS. (display_mips_gnu_attribute): Abstracted fp abi printing to... (print_mips_fp_abi_value): New static function. Handle new FP ABIs. (print_mips_ases, print_mips_isa_ext): New static functions. (get_mips_reg_size): Likewise. (process_mips_specific): Display abiflags data. elfcpp/ * elfcpp.h (PT_MIPS_ABIFLAGS): New program header type. gas/ * config/tc-mips.c (mips_flags_frag): New static global. (struct mips_set_options): Add oddspreg field. (file_mips_opts, mips_opts): Initialize oddspreg. (ISA_HAS_ODD_SINGLE_FPR): Add CPU argument and update for R5900 and Loongson-3a. (enum options, md_longopts, md_parse_option): Add -mfpxx, -modd-spreg and -mno-odd-spreg options. (md_begin): Create .MIPS.abiflags section. (fpabi_incompatible_with, fpabi_requires): New static function. (check_fpabi): Likewise. (mips_check_options): Handle fp=xx and oddspreg restrictions. (file_mips_check_options): Set oddspreg by default for fp=xx. (mips_oddfpreg_ok): Re-write function. (check_regno): Check odd numbered registers regardless of FPR size. For fp != 32 use as_bad instead of as_warn. (match_float_constant): Rewrite check regarding FP register width. Add support for generating constants when MXHC1 is present. Handle fp=xx to comply with the ABI. (macro): Update M_LI_DD similarly to match_float_constant. Generate MTHC1 when available. Check that correct code can be generated for fp=xx and fp=64 ABIs. (parse_code_option, s_mipsset): Add fp=xx, oddspreg and nooddspreg options. (mips_convert_ase_flags): New static function. (mips_elf_final_processing): Use fpabi == Val_GNU_MIPS_ABI_FP_OLD_64 to determine when to add the EF_MIPS_FP64 flag. Populate the .MIPS.abiflags section. (md_mips_end): Update .gnu_attribute based on command line and .module as applicable. Use check_fpabi to ensure .gnu.attribute and command line/.module options are consistent. * doc/as.texinfo: Add missing -mgp64/-mfp64 options and document new -mfpxx, -modd-spreg and -mno-odd-spreg options. * doc/c-mips.texi: Document -mfpxx, -modd-spreg, -mno-odd-spreg, gnu_attribute values and FP ABIs. ld/ * emulparams/elf32bmip.sh: Add .MIPS.abiflags. * emulparams/elf32bmipn32-defs.sh: Likewise. * emulparams/elf64bmip-defs.sh: Likewise. opcodes/ * micromips-opc.c (COD, LCD) New macros. (cfc1, ctc1): Remove FP_S attribute. (dmfc1, mfc1, mfhc1): Add LCD attribute. (dmtc1, mtc1, mthc1): Add COD attribute. * mips-opc.c (cfc1, cftc1, ctc, cttc1): Remove FP_S attribute. binutils/testsuite/ * binutils-all/readelf.s: Account for .MIPS.abiflags and .gnu.attributes. * binutils-all/readelf.ss-tmips: Likewise. * binutils-all/strip-3.d: Likewise. gas/testsuite/ * gas/mips/attr-gnu-4-0.d: New. * gas/mips/attr-gnu-4-0.s: Likewise. * gas/mips/attr-gnu-4-1-mfp32.l: Likewise. * gas/mips/attr-gnu-4-1-mfp32.s: Likewise. * gas/mips/attr-gnu-4-1-mfp64.l: Likewise. * gas/mips/attr-gnu-4-1-mfp64.s: Likewise. * gas/mips/attr-gnu-4-1-mfpxx.s: Likewise. * gas/mips/attr-gnu-4-1-msingle-float.l: Likewise. * gas/mips/attr-gnu-4-1-msingle-float.s: Likewise. * gas/mips/attr-gnu-4-1-msoft-float.l: Likewise. * gas/mips/attr-gnu-4-1-msoft-float.s: Likewise. * gas/mips/attr-gnu-4-1.d: Likewise. * gas/mips/attr-gnu-4-1.s: Likewise. * gas/mips/attr-gnu-4-2-mdouble-float.l: Likewise. * gas/mips/attr-gnu-4-2-mdouble-float.s: Likewise. * gas/mips/attr-gnu-4-2-msoft-float.l: Likewise. * gas/mips/attr-gnu-4-2-msoft-float.s: Likewise. * gas/mips/attr-gnu-4-2.d: Likewise. * gas/mips/attr-gnu-4-2.s: Likewise. * gas/mips/attr-gnu-4-3-mhard-float.l: Likewise. * gas/mips/attr-gnu-4-3-mhard-float.s: Likewise. * gas/mips/attr-gnu-4-3.d: Likewise. * gas/mips/attr-gnu-4-3.s: Likewise. * gas/mips/attr-gnu-4-4.l: Likewise. * gas/mips/attr-gnu-4-4.s: Likewise. * gas/mips/attr-gnu-4-5-64.l: Likewise. * gas/mips/attr-gnu-4-5-64.s: Likewise. * gas/mips/attr-gnu-4-5.d: Likewise. * gas/mips/attr-gnu-4-5.l: Likewise. * gas/mips/attr-gnu-4-5.s: Likewise. * gas/mips/attr-gnu-4-6-64.l: Likewise. * gas/mips/attr-gnu-4-6-64.s: Likewise. * gas/mips/attr-gnu-4-6.d: Likewise. * gas/mips/attr-gnu-4-6.l: Likewise. * gas/mips/attr-gnu-4-6.s: Likewise. * gas/mips/attr-gnu-4-6-msingle-float.l: Likewise. * gas/mips/attr-gnu-4-6-msingle-float.s: Likewise. * gas/mips/attr-gnu-4-6-msoft-float.l: Likewise. * gas/mips/attr-gnu-4-6-msoft-float.s: Likewise. * gas/mips/attr-gnu-4-6-noodd.l: Likewise. * gas/mips/attr-gnu-4-6-noodd.s: Likewise. * gas/mips/attr-gnu-4-7-64.l: Likewise. * gas/mips/attr-gnu-4-7-64.s: Likewise. * gas/mips/attr-gnu-4-7-msingle-float.l: Likewise. * gas/mips/attr-gnu-4-7-msingle-float.s: Likewise. * gas/mips/attr-gnu-4-7-msoft-float.l: Likewise. * gas/mips/attr-gnu-4-7-msoft-float.s: Likewise. * gas/mips/attr-gnu-4-7-odd.l: Likewise. * gas/mips/attr-gnu-4-7-odd.s: Likewise. * gas/mips/attr-gnu-4-7.d: Likewise. * gas/mips/attr-gnu-4-7.l: Likewise. * gas/mips/attr-gnu-4-7.s: Likewise. * gas/mips/attr-none-double.d: Likewise. * gas/mips/attr-none-o32-fp64.d: Likewise. * gas/mips/attr-none-o32-fp64-nooddspreg.d * gas/mips/attr-none-o32-fpxx.d: Likewise. * gas/mips/attr-none-single-float.d: Likewise. * gas/mips/attr-none-soft-float.d: Likewise. * gas/mips/elf_arch_mips32r3.d: Likewise. * gas/mips/elf_arch_mips32r5.d: Likewise. * gas/mips/elf_arch_mips64r3.d: Likewise. * gas/mips/elf_arch_mips64r5.d: Likewise. * gas/mips/li-d.d: Likewise. * gas/mips/li-d.s: Likewise. * gas/mips/module-check-warn.l: Likewise. * gas/mips/module-check-warn.s: Likewise. * gas/mips/module-check.d: Likewise. * gas/mips/module-check.s: Likewise. * gas/mips/module-mfp32.d: Likewise. * gas/mips/module-mfp32.s: Likewise. * gas/mips/module-mfp64.d: Likewise. * gas/mips/module-mfp64.s: Likewise. * gas/mips/module-mfp64-noodd.d: Likewise. * gas/mips/module-mfp64-noodd.s: Likewise. * gas/mips/module-mfpxx.d: Likewise. * gas/mips/module-mfpxx.s: Likewise. * gas/mips/module-msingle-float.d: Likewise. * gas/mips/module-msingle-float.s: Likewise. * gas/mips/module-msoft-float.d: Likewise. * gas/mips/module-msoft-float.s: Likewise. * gas/mips/module-set-mfpxx.d: Likewise. * gas/mips/module-set-mfpxx.s: Likewise. * gas/mips/fpxx-oddfpreg.d: Likewise. * gas/mips/fpxx-oddfpreg.l: Likewise. * gas/mips/fpxx-oddfpreg.s: Likewise. * gas/mips/no-odd-spreg.d: Likewise. * gas/mips/odd-spreg.d: Likewise. * gas/elf/section2.e-mips: Adjust expected output. * gas/mips/attr-gnu-abi-fp-1.d: Likewise. * gas/mips/attr-gnu-abi-msa-1.d: Likewise. * gas/mips/call-nonpic-1.d: Likewise. * gas/mips/elf_arch_mips1.d: Likewise. * gas/mips/elf_arch_mips2.d: Likewise. * gas/mips/elf_arch_mips3.d: Likewise. * gas/mips/elf_arch_mips32.d: Likewise. * gas/mips/elf_arch_mips32r2.d: Likewise. * gas/mips/elf_arch_mips4.d: Likewise. * gas/mips/elf_arch_mips5.d: Likewise. * gas/mips/elf_arch_mips64.d: Likewise. * gas/mips/elf_arch_mips64r2.d: Likewise. * gas/mips/elf_ase_micromips-2.d: Likewise. * gas/mips/elf_ase_micromips.d: Likewise. * gas/mips/elf_ase_mips16-2.d: Likewise. * gas/mips/elf_ase_mips16.d: Likewise. * gas/mips/module-defer-warn1.d: Likewise. * gas/mips/module-override.d: Likewise. * gas/mips/n32-consec.d: Likewise. * gas/mips/nan-2008-1.d: Likewise. * gas/mips/nan-2008-2.d: Likewise. * gas/mips/nan-2008-3.d: Likewise. * gas/mips/nan-2008-4.d: Likewise. * gas/mips/nan-legacy-1.d: Likewise. * gas/mips/nan-legacy-2.d: Likewise. * gas/mips/nan-legacy-3.d: Likewise. * gas/mips/nan-legacy-4.d: Likewise. * gas/mips/nan-legacy-5.d: Likewise. * gas/mips/tmips16-e.d: Likewise. * gas/mips/tmips16-f.d: Likewise. * gas/mips/tmipsel16-e.d: Likewise. * gas/mips/tmipsel16-f.d: Likewise. * gas/testsuite/gas/mips/mips.exp: Add new tests. ld/testsuite/ * ld-mips-elf/abiflags-strip1-ph.d: New. * ld-mips-elf/abiflags-strip2-ph.d: Likewise. * ld-mips-elf/abiflags-strip3-ph.d: Likewise. * ld-mips-elf/abiflags-strip4-ph.d: Likewise. * ld-mips-elf/abiflags-strip5-ph.d: Likewise. * ld-mips-elf/abiflags-strip6-ph.d: Likewise. * ld-mips-elf/abiflags-strip7-ph.d: Likewise. * ld-mips-elf/abiflags-strip8-ph.d: Likewise. * ld-mips-elf/abiflags-strip9-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-0-n32-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-0-n64-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-0-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-06.d: Likewise. * ld-mips-elf/attr-gnu-4-07.d: Likewise. * ld-mips-elf/attr-gnu-4-08.d: Likewise. * ld-mips-elf/attr-gnu-4-1-n32-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-1-n64-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-1-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-16.d: Likewise. * ld-mips-elf/attr-gnu-4-17.d: Likewise. * ld-mips-elf/attr-gnu-4-18.d: Likewise. * ld-mips-elf/attr-gnu-4-2-n32-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-2-n64-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-2-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-26.d: Likewise. * ld-mips-elf/attr-gnu-4-27.d: Likewise. * ld-mips-elf/attr-gnu-4-28.d: Likewise. * ld-mips-elf/attr-gnu-4-3-n32-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-3-n64-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-3-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-36.d: Likewise. * ld-mips-elf/attr-gnu-4-37.d: Likewise. * ld-mips-elf/attr-gnu-4-38.d: Likewise. * ld-mips-elf/attr-gnu-4-4-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-46.d: Likewise. * ld-mips-elf/attr-gnu-4-47.d: Likewise. * ld-mips-elf/attr-gnu-4-48.d: Likewise. * ld-mips-elf/attr-gnu-4-5-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-50.d: Likewise. * ld-mips-elf/attr-gnu-4-52.d: Likewise. * ld-mips-elf/attr-gnu-4-53.d: Likewise. * ld-mips-elf/attr-gnu-4-54.d: Likewise. * ld-mips-elf/attr-gnu-4-55.d: Likewise. * ld-mips-elf/attr-gnu-4-56.d: Likewise. * ld-mips-elf/attr-gnu-4-57.d: Likewise. * ld-mips-elf/attr-gnu-4-58.d: Likewise. * ld-mips-elf/attr-gnu-4-6-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-6.s: Likewise. * ld-mips-elf/attr-gnu-4-60.d: Likewise. * ld-mips-elf/attr-gnu-4-61.d: Likewise. * ld-mips-elf/attr-gnu-4-62.d: Likewise. * ld-mips-elf/attr-gnu-4-63.d: Likewise. * ld-mips-elf/attr-gnu-4-64.d: Likewise. * ld-mips-elf/attr-gnu-4-65.d: Likewise. * ld-mips-elf/attr-gnu-4-66.d: Likewise. * ld-mips-elf/attr-gnu-4-67.d: Likewise. * ld-mips-elf/attr-gnu-4-68.d: Likewise. * ld-mips-elf/attr-gnu-4-7-ph.d: Likewise. * ld-mips-elf/attr-gnu-4-7.s: Likewise. * ld-mips-elf/attr-gnu-4-70.d: Likewise. * ld-mips-elf/attr-gnu-4-71.d: Likewise. * ld-mips-elf/attr-gnu-4-72.d: Likewise. * ld-mips-elf/attr-gnu-4-73.d: Likewise. * ld-mips-elf/attr-gnu-4-74.d: Likewise. * ld-mips-elf/attr-gnu-4-75.d: Likewise. * ld-mips-elf/attr-gnu-4-76.d: Likewise. * ld-mips-elf/attr-gnu-4-77.d: Likewise. * ld-mips-elf/attr-gnu-4-78.d: Likewise. * ld-mips-elf/attr-gnu-4-8.s: Likewise. * ld-mips-elf/attr-gnu-4-81.d: Likewise. * ld-mips-elf/empty.s: Likewise. * ld-mips-elf/attr-gnu-4-00.d: Adjust expected output. * ld-mips-elf/attr-gnu-4-01.d: Likewise. * ld-mips-elf/attr-gnu-4-02.d: Likewise. * ld-mips-elf/attr-gnu-4-03.d: Likewise. * ld-mips-elf/attr-gnu-4-04.d: Likewise. * ld-mips-elf/attr-gnu-4-05.d: Likewise. * ld-mips-elf/attr-gnu-4-10.d: Likewise. * ld-mips-elf/attr-gnu-4-11.d: Likewise. * ld-mips-elf/attr-gnu-4-14.d: Likewise. * ld-mips-elf/attr-gnu-4-15.d: Likewise. * ld-mips-elf/attr-gnu-4-2.s: Likewise. * ld-mips-elf/attr-gnu-4-20.d: Likewise. * ld-mips-elf/attr-gnu-4-22.d: Likewise. * ld-mips-elf/attr-gnu-4-24.d: Likewise. * ld-mips-elf/attr-gnu-4-25.d: Likewise. * ld-mips-elf/attr-gnu-4-3.s: Likewise. * ld-mips-elf/attr-gnu-4-30.d: Likewise. * ld-mips-elf/attr-gnu-4-33.d: Likewise. * ld-mips-elf/attr-gnu-4-34.d: Likewise. * ld-mips-elf/attr-gnu-4-35.d: Likewise. * ld-mips-elf/attr-gnu-4-40.d: Likewise. * ld-mips-elf/attr-gnu-4-41.d: Likewise. * ld-mips-elf/attr-gnu-4-42.d: Likewise. * ld-mips-elf/attr-gnu-4-43.d: Likewise. * ld-mips-elf/attr-gnu-4-44.d: Likewise. * ld-mips-elf/attr-gnu-4-45.d: Likewise. * ld-mips-elf/attr-gnu-4-5.s: Likewise. * ld-mips-elf/attr-gnu-4-51.d: Likewise. * ld-mips-elf/attr-gnu-8-00.d: Likewise. * ld-mips-elf/attr-gnu-8-01.d: Likewise. * ld-mips-elf/attr-gnu-8-02.d: Likewise. * ld-mips-elf/attr-gnu-8-10.d: Likewise. * ld-mips-elf/attr-gnu-8-11.d: Likewise. * ld-mips-elf/attr-gnu-8-20.d: Likewise. * ld-mips-elf/attr-gnu-8-22.d: Likewise. * ld-mips-elf/jalx-2.dd: Likewise. * ld-mips-elf/mips16-pic-1.gd: Likewise. * ld-mips-elf/mips16-pic-2.gd: Likewise. * ld-mips-elf/mips16-pic-3.gd: Likewise. * ld-mips-elf/mips16-pic-4a.gd: Likewise. * ld-mips-elf/multi-got-no-shared.d: Likewise. * ld-mips-elf/nan-2008.d: Likewise. * ld-mips-elf/nan-legacy.d: Rework test. * ld-mips-elf/pic-and-nonpic-3a.gd: Likewise. * ld-mips-elf/pic-and-nonpic-3b.gd: Likewise. * ld-mips-elf/pic-and-nonpic-5b.gd: Likewise. * ld-mips-elf/pic-and-nonpic-6.ld: Likewise. * ld-mips-elf/rel32-n32.d: Likewise. * ld-mips-elf/rel32-o32.d: Likewise. * ld-mips-elf/rel64.d: Likewise. * ld-mips-elf/tls-multi-got-1.r: Likewise. * ld-elf/group.ld: Discard .MIPS.abiflags and .gnu.attributes. * ld-elf/orphan-region.ld: Likewise. * ld-elf/orphan.ld: Likewise. * ld-mips-elf/compressed-plt-1.ld: Likewise. * ld-mips-elf/dyn-sec64.ld: Likewise. * ld-mips-elf/got-dump-1.ld: Likewise. * ld-mips-elf/got-dump-2.ld: Likewise. * ld-mips-elf/got-page-1.ld: Likewise. * ld-mips-elf/mips-dyn.ld: Likewise. * ld-mips-elf/mips-lib.ld: Likewise. * ld-mips-elf/pic-and-nonpic-3a.ld: Likewise. * ld-mips-elf/pic-and-nonpic-3b.ld: Likewise. * ld-mips-elf/pic-and-nonpic-4b.ld: Likewise. * ld-mips-elf/pic-and-nonpic-5b.ld: Likewise. * ld-mips-elf/region1.t: Likewise. * ld-mips-elf/stub-dynsym-1.ld: Likewise. * ld-mips-elf/tls-hidden3.ld: Likewise. * ld-mips-elf/vxworks1.ld: Likewise. * ld-scripts/overlay-size.t: Likewise. * ld-mips-elf/elf-rel-got-n32-embed.d: Remove .MIPS.abiflags from objects. * ld-mips-elf/elf-rel-got-n32.d: Likewise. * ld-mips-elf/elf-rel-got-n64-embed.d: Likewise. * ld-mips-elf/elf-rel-got-n64-linux.d: Likewise. * ld-mips-elf/elf-rel-got-n64.d: Likewise. * ld-mips-elf/elf-rel-xgot-n32.d: Likewise. * ld-mips-elf/elf-rel-xgot-n32-embed.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64-linux.d: Likewise. * ld-mips-elf/elf-rel-xgot-n64-embed.d: Likewise. * ld-mips-elf/mips-elf.exp: Add new tests.
2014-07-29 18:27:59 +08:00
#objcopy_objects: -R .MIPS.abiflags
#source: ../../../gas/testsuite/gas/mips/elf-rel-got-n64.s RUN_OBJCOPY
gas/testsuite/ * gas/mips/mips.exp: Set has_newabi for mips*-sde-elf* too. * gas/mips/elf-rel-got-n32.s: Adjust padding. * gas/mips/elf-rel-got-n64.s: Likewise. * gas/mips/elf-rel23.s: Likewise. * gas/mips/elf-rel28.s: Likewise. * gas/mips/n32-consec.s: Likewise. * gas/mips/elf-rel-xgot-n32.d: Adjust output expected. * gas/mips/elf-rel-xgot-n64.d: Likewise. * gas/mips/elf-rel23.d: Likewise. * gas/mips/elf-rel23a.d: Likewise. * gas/mips/elf-rel23b.d: Likewise. * gas/mips/elf-rel28-n32.d: Likewise. ld/testsuite/ * lib/ld-lib.exp (run_dump_test): Implement the EXTRA_OPTIONS argument and the "dump" keyword. * ld-mips-elf/emit-relocs-1a.s: Make section alignment uniform across targets. * ld-mips-elf/emit-relocs-1b.s: Likewise. * ld-mips-elf/jalbal.s: Adjust padding. * ld-mips-elf/elf-rel-got-n32-embed.d: New test. * ld-mips-elf/elf-rel-got-n64-embed.d: New test. * ld-mips-elf/elf-rel-xgot-n32-embed.d: New test. * ld-mips-elf/elf-rel-xgot-n64-embed.d: New test. * ld-mips-elf/elf-rel-got-n32.d: Remove -melf32btsmipn32. * ld-mips-elf/elf-rel-got-n64.d: Remove -melf64btsmip. Adjust output. * ld-mips-elf/elf-rel-got-n64-linux.d: Remove -melf64btsmip. * ld-mips-elf/elf-rel-xgot-n32.d: Remove -melf32btsmipn32. Adjust output. * ld-mips-elf/elf-rel-xgot-n64.d: Remove -melf64btsmip. Adjust output. * ld-mips-elf/elf-rel-xgot-n64-linux.d: Likewise. * ld-mips-elf/reloc-1-n64.d: Remove -melf64btsmip. * ld-mips-elf/mips-elf.exp: Set has_newabi for mips*-sde-elf* too. Move tool flags from o32_as_flags and o32_ld_flags variables into abi_asflags and abi_ldflags arrays. Adjust test cases run to use them. Run the new tests.
2012-08-07 05:05:54 +08:00
#ld:
#objdump: -D --show-raw-insn
.*: +file format elf64-.*mips.*
Disassembly of section \.MIPS\.options:
00000001200000b0 <\.MIPS\.options>:
1200000b0: 01280000 .*
1200000b4: 00000000 .*
1200000b8: 92020022 .*
\.\.\.
1200000d0: 00000001 .*
1200000d4: 200185a0 .*
Disassembly of section \.text:
00000001200000b0 <fn>:
1200000b0: df858020 ld a1,-32736\(gp\)
1200000b4: df858020 ld a1,-32736\(gp\)
1200000b8: 64a5000c daddiu a1,a1,12
1200000bc: df858020 ld a1,-32736\(gp\)
1200000c0: 3c010001 lui at,0x1
1200000c4: 3421e240 ori at,at,0xe240
1200000c8: 00a1282d daddu a1,a1,at
1200000cc: df858020 ld a1,-32736\(gp\)
1200000d0: 00b1282d daddu a1,a1,s1
1200000d4: df858020 ld a1,-32736\(gp\)
1200000d8: 64a5000c daddiu a1,a1,12
1200000dc: 00b1282d daddu a1,a1,s1
1200000e0: df858020 ld a1,-32736\(gp\)
1200000e4: 3c010001 lui at,0x1
1200000e8: 3421e240 ori at,at,0xe240
1200000ec: 00a1282d daddu a1,a1,at
1200000f0: 00b1282d daddu a1,a1,s1
1200000f4: df858028 ld a1,-32728\(gp\)
1200000f8: dca504fc ld a1,1276\(a1\)
1200000fc: df858028 ld a1,-32728\(gp\)
120000100: dca50508 ld a1,1288\(a1\)
120000104: df858028 ld a1,-32728\(gp\)
120000108: 00b1282d daddu a1,a1,s1
12000010c: dca504fc ld a1,1276\(a1\)
120000110: df858028 ld a1,-32728\(gp\)
120000114: 00b1282d daddu a1,a1,s1
120000118: dca50508 ld a1,1288\(a1\)
12000011c: df818028 ld at,-32728\(gp\)
120000120: 0025082d daddu at,at,a1
120000124: dc25051e ld a1,1310\(at\)
120000128: df818028 ld at,-32728\(gp\)
12000012c: 0025082d daddu at,at,a1
120000130: fc250534 sd a1,1332\(at\)
120000134: df818020 ld at,-32736\(gp\)
120000138: 88250000 lwl a1,0\(at\)
12000013c: 98250003 lwr a1,3\(at\)
120000140: df818020 ld at,-32736\(gp\)
120000144: 6421000c daddiu at,at,12
120000148: 88250000 lwl a1,0\(at\)
12000014c: 98250003 lwr a1,3\(at\)
120000150: df818020 ld at,-32736\(gp\)
120000154: 0031082d daddu at,at,s1
120000158: 88250000 lwl a1,0\(at\)
12000015c: 98250003 lwr a1,3\(at\)
120000160: df818020 ld at,-32736\(gp\)
120000164: 6421000c daddiu at,at,12
120000168: 0031082d daddu at,at,s1
12000016c: 88250000 lwl a1,0\(at\)
120000170: 98250003 lwr a1,3\(at\)
120000174: df818020 ld at,-32736\(gp\)
120000178: 64210022 daddiu at,at,34
12000017c: 0025082d daddu at,at,a1
120000180: 88250000 lwl a1,0\(at\)
120000184: 98250003 lwr a1,3\(at\)
120000188: df818020 ld at,-32736\(gp\)
12000018c: 64210038 daddiu at,at,56
120000190: 0025082d daddu at,at,a1
120000194: a8250000 swl a1,0\(at\)
120000198: b8250003 swr a1,3\(at\)
12000019c: df858020 ld a1,-32736\(gp\)
1200001a0: df858030 ld a1,-32720\(gp\)
1200001a4: df858038 ld a1,-32712\(gp\)
1200001a8: df858020 ld a1,-32736\(gp\)
1200001ac: 00b1282d daddu a1,a1,s1
1200001b0: df858030 ld a1,-32720\(gp\)
1200001b4: 00b1282d daddu a1,a1,s1
1200001b8: df858038 ld a1,-32712\(gp\)
1200001bc: 00b1282d daddu a1,a1,s1
1200001c0: df858028 ld a1,-32728\(gp\)
1200001c4: dca504fc ld a1,1276\(a1\)
1200001c8: df858028 ld a1,-32728\(gp\)
1200001cc: dca50508 ld a1,1288\(a1\)
1200001d0: df858028 ld a1,-32728\(gp\)
1200001d4: 00b1282d daddu a1,a1,s1
1200001d8: dca504fc ld a1,1276\(a1\)
1200001dc: df858028 ld a1,-32728\(gp\)
1200001e0: 00b1282d daddu a1,a1,s1
1200001e4: dca50508 ld a1,1288\(a1\)
1200001e8: df818028 ld at,-32728\(gp\)
1200001ec: 0025082d daddu at,at,a1
1200001f0: dc25051e ld a1,1310\(at\)
1200001f4: df818028 ld at,-32728\(gp\)
1200001f8: 0025082d daddu at,at,a1
1200001fc: fc250534 sd a1,1332\(at\)
120000200: df818020 ld at,-32736\(gp\)
120000204: 88250000 lwl a1,0\(at\)
120000208: 98250003 lwr a1,3\(at\)
12000020c: df818030 ld at,-32720\(gp\)
120000210: 88250000 lwl a1,0\(at\)
120000214: 98250003 lwr a1,3\(at\)
120000218: df818020 ld at,-32736\(gp\)
12000021c: 0031082d daddu at,at,s1
120000220: 88250000 lwl a1,0\(at\)
120000224: 98250003 lwr a1,3\(at\)
120000228: df818030 ld at,-32720\(gp\)
12000022c: 0031082d daddu at,at,s1
120000230: 88250000 lwl a1,0\(at\)
120000234: 98250003 lwr a1,3\(at\)
120000238: df818040 ld at,-32704\(gp\)
12000023c: 0025082d daddu at,at,a1
120000240: 88250000 lwl a1,0\(at\)
120000244: 98250003 lwr a1,3\(at\)
120000248: df818048 ld at,-32696\(gp\)
12000024c: 0025082d daddu at,at,a1
120000250: a8250000 swl a1,0\(at\)
120000254: b8250003 swr a1,3\(at\)
120000258: df858050 ld a1,-32688\(gp\)
12000025c: df858050 ld a1,-32688\(gp\)
120000260: df998050 ld t9,-32688\(gp\)
120000264: df998050 ld t9,-32688\(gp\)
120000268: df998050 ld t9,-32688\(gp\)
12000026c: 0411ff90 bal 1200000b0 <fn>
120000270: 00000000 nop
120000274: df998050 ld t9,-32688\(gp\)
120000278: 0411ff8d bal 1200000b0 <fn>
12000027c: 00000000 nop
120000280: df858058 ld a1,-32680\(gp\)
120000284: df858058 ld a1,-32680\(gp\)
120000288: 64a5000c daddiu a1,a1,12
12000028c: df858058 ld a1,-32680\(gp\)
120000290: 3c010001 lui at,0x1
120000294: 3421e240 ori at,at,0xe240
120000298: 00a1282d daddu a1,a1,at
12000029c: df858058 ld a1,-32680\(gp\)
1200002a0: 00b1282d daddu a1,a1,s1
1200002a4: df858058 ld a1,-32680\(gp\)
1200002a8: 64a5000c daddiu a1,a1,12
1200002ac: 00b1282d daddu a1,a1,s1
1200002b0: df858058 ld a1,-32680\(gp\)
1200002b4: 3c010001 lui at,0x1
1200002b8: 3421e240 ori at,at,0xe240
1200002bc: 00a1282d daddu a1,a1,at
1200002c0: 00b1282d daddu a1,a1,s1
1200002c4: df858028 ld a1,-32728\(gp\)
1200002c8: dca50574 ld a1,1396\(a1\)
1200002cc: df858028 ld a1,-32728\(gp\)
1200002d0: dca50580 ld a1,1408\(a1\)
1200002d4: df858028 ld a1,-32728\(gp\)
1200002d8: 00b1282d daddu a1,a1,s1
1200002dc: dca50574 ld a1,1396\(a1\)
1200002e0: df858028 ld a1,-32728\(gp\)
1200002e4: 00b1282d daddu a1,a1,s1
1200002e8: dca50580 ld a1,1408\(a1\)
1200002ec: df818028 ld at,-32728\(gp\)
1200002f0: 0025082d daddu at,at,a1
1200002f4: dc250596 ld a1,1430\(at\)
1200002f8: df818028 ld at,-32728\(gp\)
1200002fc: 0025082d daddu at,at,a1
120000300: fc2505ac sd a1,1452\(at\)
120000304: df818058 ld at,-32680\(gp\)
120000308: 88250000 lwl a1,0\(at\)
12000030c: 98250003 lwr a1,3\(at\)
120000310: df818058 ld at,-32680\(gp\)
120000314: 6421000c daddiu at,at,12
120000318: 88250000 lwl a1,0\(at\)
12000031c: 98250003 lwr a1,3\(at\)
120000320: df818058 ld at,-32680\(gp\)
120000324: 0031082d daddu at,at,s1
120000328: 88250000 lwl a1,0\(at\)
12000032c: 98250003 lwr a1,3\(at\)
120000330: df818058 ld at,-32680\(gp\)
120000334: 6421000c daddiu at,at,12
120000338: 0031082d daddu at,at,s1
12000033c: 88250000 lwl a1,0\(at\)
120000340: 98250003 lwr a1,3\(at\)
120000344: df818058 ld at,-32680\(gp\)
120000348: 64210022 daddiu at,at,34
12000034c: 0025082d daddu at,at,a1
120000350: 88250000 lwl a1,0\(at\)
120000354: 98250003 lwr a1,3\(at\)
120000358: df818058 ld at,-32680\(gp\)
12000035c: 64210038 daddiu at,at,56
120000360: 0025082d daddu at,at,a1
120000364: a8250000 swl a1,0\(at\)
120000368: b8250003 swr a1,3\(at\)
12000036c: df858058 ld a1,-32680\(gp\)
120000370: df858060 ld a1,-32672\(gp\)
120000374: df858068 ld a1,-32664\(gp\)
120000378: df858058 ld a1,-32680\(gp\)
12000037c: 00b1282d daddu a1,a1,s1
120000380: df858060 ld a1,-32672\(gp\)
120000384: 00b1282d daddu a1,a1,s1
120000388: df858068 ld a1,-32664\(gp\)
12000038c: 00b1282d daddu a1,a1,s1
120000390: df858028 ld a1,-32728\(gp\)
120000394: dca50574 ld a1,1396\(a1\)
120000398: df858028 ld a1,-32728\(gp\)
12000039c: dca50580 ld a1,1408\(a1\)
1200003a0: df858028 ld a1,-32728\(gp\)
1200003a4: 00b1282d daddu a1,a1,s1
1200003a8: dca50574 ld a1,1396\(a1\)
1200003ac: df858028 ld a1,-32728\(gp\)
1200003b0: 00b1282d daddu a1,a1,s1
1200003b4: dca50580 ld a1,1408\(a1\)
1200003b8: df818028 ld at,-32728\(gp\)
1200003bc: 0025082d daddu at,at,a1
1200003c0: dc250596 ld a1,1430\(at\)
1200003c4: df818028 ld at,-32728\(gp\)
1200003c8: 0025082d daddu at,at,a1
1200003cc: fc2505ac sd a1,1452\(at\)
1200003d0: df818058 ld at,-32680\(gp\)
1200003d4: 88250000 lwl a1,0\(at\)
1200003d8: 98250003 lwr a1,3\(at\)
1200003dc: df818060 ld at,-32672\(gp\)
1200003e0: 88250000 lwl a1,0\(at\)
1200003e4: 98250003 lwr a1,3\(at\)
1200003e8: df818058 ld at,-32680\(gp\)
1200003ec: 0031082d daddu at,at,s1
1200003f0: 88250000 lwl a1,0\(at\)
1200003f4: 98250003 lwr a1,3\(at\)
1200003f8: df818060 ld at,-32672\(gp\)
1200003fc: 0031082d daddu at,at,s1
120000400: 88250000 lwl a1,0\(at\)
120000404: 98250003 lwr a1,3\(at\)
120000408: df818070 ld at,-32656\(gp\)
12000040c: 0025082d daddu at,at,a1
120000410: 88250000 lwl a1,0\(at\)
120000414: 98250003 lwr a1,3\(at\)
120000418: df818078 ld at,-32648\(gp\)
12000041c: 0025082d daddu at,at,a1
120000420: a8250000 swl a1,0\(at\)
120000424: b8250003 swr a1,3\(at\)
120000428: df858080 ld a1,-32640\(gp\)
12000042c: df858080 ld a1,-32640\(gp\)
120000430: df998080 ld t9,-32640\(gp\)
120000434: df998080 ld t9,-32640\(gp\)
120000438: df998080 ld t9,-32640\(gp\)
12000043c: 0411001d bal 1200004b4 <fn2>
120000440: 00000000 nop
120000444: df998080 ld t9,-32640\(gp\)
120000448: 0411001a bal 1200004b4 <fn2>
12000044c: 00000000 nop
120000450: 1000ff17 b 1200000b0 <fn>
120000454: df858020 ld a1,-32736\(gp\)
120000458: df858028 ld a1,-32728\(gp\)
12000045c: 10000015 b 1200004b4 <fn2>
120000460: dca50574 ld a1,1396\(a1\)
120000464: 1000ff12 b 1200000b0 <fn>
120000468: df858020 ld a1,-32736\(gp\)
12000046c: df858060 ld a1,-32672\(gp\)
120000470: 10000010 b 1200004b4 <fn2>
120000474: 00000000 nop
120000478: df858038 ld a1,-32712\(gp\)
12000047c: 1000ff0c b 1200000b0 <fn>
120000480: 00000000 nop
120000484: df858028 ld a1,-32728\(gp\)
120000488: 1000000a b 1200004b4 <fn2>
12000048c: dca50574 ld a1,1396\(a1\)
120000490: df858028 ld a1,-32728\(gp\)
120000494: 1000ff06 b 1200000b0 <fn>
120000498: dca50508 ld a1,1288\(a1\)
12000049c: df818028 ld at,-32728\(gp\)
1200004a0: 0025082d daddu at,at,a1
1200004a4: 10000003 b 1200004b4 <fn2>
1200004a8: dc250596 ld a1,1430\(at\)
\.\.\.
00000001200004b4 <fn2>:
\.\.\.
Disassembly of section \.data:
00000001200104c0 <_fdata>:
\.\.\.
00000001200104fc <dg1>:
\.\.\.
0000000120010538 <sp2>:
\.\.\.
0000000120010574 <dg2>:
\.\.\.
Disassembly of section \.got:
00000001200105b0 <_GLOBAL_OFFSET_TABLE_>:
\.\.\.
1200105b8: 80000000 .*
1200105bc: 00000000 .*
1200105c0: 00000001 .*
1200105c4: 200104fc .*
1200105c8: 00000001 .*
1200105cc: 20010000 .*
1200105d0: 00000001 .*
1200105d4: 20010508 .*
1200105d8: 00000001 .*
1200105dc: 2002e73c .*
1200105e0: 00000001 .*
1200105e4: 2001051e .*
1200105e8: 00000001 .*
1200105ec: 20010534 .*
1200105f0: 00000001 .*
1200105f4: 200000b0 .*
1200105f8: 00000001 .*
1200105fc: 20010574 .*
120010600: 00000001 .*
120010604: 20010580 .*
120010608: 00000001 .*
12001060c: 2002e7b4 .*
120010610: 00000001 .*
120010614: 20010596 .*
120010618: 00000001 .*
12001061c: 200105ac .*
120010620: 00000001 .*
120010624: 200004b4 .*
\.\.\.
#pass