2012-08-06 17:05:54 -04:00
|
|
|
#name: MIPS ELF got reloc n32
|
MIPS/LD/testsuite: Correct mips-elf.exp test ABI/emul/endian arrangement
Similarly to commit 86b24e15c45b ("MIPS/LD/testsuite: Correct
comm-data.exp test ABI/emul/endian arrangement") update the mips-elf.exp
test script to:
- correctly select emulations for targets using non-traditional MIPS
emulations,
- correctly select ABIs for targets that do not support all of them,
- use the default endianness selection where possible to benefit targets
that support only one,
- simplify test invocation by providing ABI-specific `run_dump_test'
wrappers, specifically `run_dump_test_o32', `run_dump_test_n32',
`run_dump_test_n64' and `run_dump_test_eabi', which remove the need to
use conditionals across the Expect script or to repeat ABI-specific
GAS and LD flags with each invocation,
removing numerous test failures for `mips-sgi-irix6', `mips64-openbsd',
`mips64el-openbsd' and `mips64el-ps2-elf' targets and broadening
coverage for several MIPS targets.
There are some new failures for the `mips64el-ps2-elf' target with tests
that were not previously run for that target:
FAIL: MIPS16 link branch to absolute expression (n32)
FAIL: MIPS16 link branch to absolute expression 1 (n32)
FAIL: MIPS16 link branch to absolute expression 2 (n32)
FAIL: microMIPS link branch to absolute expression (n32)
FAIL: MIPS ELF got reloc n32
FAIL: MIPS ELF xgot reloc n32
FAIL: undefined weak symbol overflow (n32)
FAIL: R_MIPS16_HI16 and R_MIPS16_LO16 relocs n32
FAIL: ld-mips-elf/attr-gnu-4-0-n32-ph
FAIL: ld-mips-elf/attr-gnu-4-1-n32-ph
FAIL: ld-mips-elf/attr-gnu-4-2-n32-ph
FAIL: ld-mips-elf/attr-gnu-4-3-n32-ph
FAIL: MIPSr6 JALR reloc unaligned/cross-mode link test (n32)
which are mostly due to dump discrepancies caused by mapping differences
coming from the default linker scripts used by these test cases, or
sometimes because of the specific MIPS processor architecture recorded
in the ELF file taking precedence over the general MIPS ISA level also
recorded. Finally, the R_MIPS16_HI16/R_MIPS16_LO16 relocation test
failure is a preexisting issue with the IRIX style emulation.
These failures will have to be addressed separately.
ld/
* testsuite/ld-mips-elf/mips-elf.exp (run_dump_test_abi)
(run_dump_test_o32, run_dump_test_n32, run_dump_test_n64)
(run_dump_test_eabi): New procedures.
(has_newabi, has_elf32): Remove variables.
(has_abi): New associative array variable.
(abi_asflags, abi_ldflags): Update settings across targets.
(irixemul): New variable.
Replace `run_dump_test' calls where applicable throughout with
`run_dump_test_o32', `run_dump_test_n32', `run_dump_test_n64'
and `run_dump_test_eabi' as appropriate. Remove explicit
passing of `abi_asflags' and `abi_ldflags'. Use `noarch' for
tests that require their own architecture setting. Force the
big endianness for tests that require it. Select the endianness
required for `objdump invocation with the `reloc-2' test.
Conditionalize tests run via `run_ld_link_tests' on the ABI
required and use the ABI list from the `has_abi' array where
appropriate.
* testsuite/ld-mips-elf/attr-gnu-4-0-n32-ph.d: Remove ABI and
endianness selection options from `ld' and `source' tags. Relax
output format matching.
* testsuite/ld-mips-elf/attr-gnu-4-0-n64-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-1-n32-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-1-n64-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-2-n32-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-2-n64-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-3-n32-ph.d: Likewise.
* testsuite/ld-mips-elf/attr-gnu-4-3-n64-ph.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-addend-micromips-n32.d: Remove
ABI and endianness selection options from `as', `ld', `source'
tags, and also the `-march=from-abi' option. Remove the `as'
tag where it would become empty.
* testsuite/ld-mips-elf/bal-jalx-addend-micromips-n64.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-addend-micromips.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-addend-n32.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-addend-n64.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-addend.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-local-micromips-n32.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-local-micromips-n64.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-local-micromips.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-local-n32.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-local-n64.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-local.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore-micromips-n32.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore-micromips-n64.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore-micromips.d:
Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore-n32.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore-n64.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-ignore.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-micromips-n32.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-micromips-n64.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-micromips.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-n32.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic-n64.d: Likewise.
* testsuite/ld-mips-elf/bal-jalx-pic.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute-addend-n32.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute-addend-n64.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute-addend.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute-n32.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute-n64.d: Likewise.
* testsuite/ld-mips-elf/branch-absolute.d: Likewise.
* testsuite/ld-mips-elf/dyn-sec64.d: Likewise.
* testsuite/ld-mips-elf/eh-frame1-n32.d: Likewise.
* testsuite/ld-mips-elf/eh-frame1-n64.d: Likewise.
* testsuite/ld-mips-elf/eh-frame2-n32.d: Likewise.
* testsuite/ld-mips-elf/eh-frame2-n64.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-got-n32-embed.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-got-n32.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-got-n64-embed.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-got-n64-irix.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-got-n64.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-xgot-n32-embed.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-xgot-n32.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-xgot-n64-embed.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-xgot-n64-irix.d: Likewise.
* testsuite/ld-mips-elf/elf-rel-xgot-n64.d: Likewise.
* testsuite/ld-mips-elf/emit-relocs-1.d: Likewise.
* testsuite/ld-mips-elf/got-dump-2.d: Likewise.
* testsuite/ld-mips-elf/got-page-2.d: Likewise.
* testsuite/ld-mips-elf/jal-global-overflow-0.d: Likewise.
* testsuite/ld-mips-elf/jal-global-overflow-1.d: Likewise.
* testsuite/ld-mips-elf/jal-local-overflow-0.d: Likewise.
* testsuite/ld-mips-elf/jal-local-overflow-1.d: Likewise.
* testsuite/ld-mips-elf/jalbal.d: Likewise.
* testsuite/ld-mips-elf/jalx-addend-n32.d: Likewise.
* testsuite/ld-mips-elf/jalx-addend-n64.d: Likewise.
* testsuite/ld-mips-elf/jalx-addend.d: Likewise.
* testsuite/ld-mips-elf/jalx-local-n32.d: Likewise.
* testsuite/ld-mips-elf/jalx-local-n64.d: Likewise.
* testsuite/ld-mips-elf/jalx-local.d: Likewise.
* testsuite/ld-mips-elf/jr-to-b-1.d: Likewise.
* testsuite/ld-mips-elf/jr-to-b-2.d: Likewise.
* testsuite/ld-mips-elf/lsi-4010-isa.d: Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend-n32.d:
Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend-n64.d:
Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend.d:
Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute-n32.d:
Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute-n64.d:
Likewise.
* testsuite/ld-mips-elf/micromips-branch-absolute.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-2.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-3.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-1.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-2.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend-1.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend-n32-1.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend-n32.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend-n64-1.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend-n64.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-addend.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n32-1.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n32-2.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n32.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n64-1.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n64-2.d:
Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute-n64.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-absolute.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-addend-2.d: Likewise.
* testsuite/ld-mips-elf/mips16-branch-addend-3.d: Likewise.
* testsuite/ld-mips-elf/mips16-hilo-n32.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-0.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-1.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-addend-2.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-addend-6.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-n32-0.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-n32-1.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-n64-sym32-0.d: Likewise.
* testsuite/ld-mips-elf/mips16-pcrel-n64-sym32-1.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-0.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-1.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-addend-2.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-addend-6.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-n32-0.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-n32-1.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-n64-sym32-0.d: Likewise.
* testsuite/ld-mips-elf/mips16e2-pcrel-n64-sym32-1.d: Likewise.
* testsuite/ld-mips-elf/multi-got-1.d: Likewise.
* testsuite/ld-mips-elf/multi-got-hidden-1.d: Likewise.
* testsuite/ld-mips-elf/multi-got-hidden-2.d: Likewise.
* testsuite/ld-mips-elf/multi-got-no-shared.d: Likewise.
* testsuite/ld-mips-elf/no-shared-1-n32.d: Likewise.
* testsuite/ld-mips-elf/no-shared-1-n64.d: Likewise.
* testsuite/ld-mips-elf/no-shared-1-o32.d: Likewise.
* testsuite/ld-mips-elf/pic-and-nonpic-2.d: Likewise.
* testsuite/ld-mips-elf/pic-and-nonpic-3-error.d: Likewise.
* testsuite/ld-mips-elf/pic-and-nonpic-4-error.d: Likewise.
* testsuite/ld-mips-elf/pie-n32.d: Likewise.
* testsuite/ld-mips-elf/pie-n64.d: Likewise.
* testsuite/ld-mips-elf/pie-o32.d: Likewise.
* testsuite/ld-mips-elf/rel32-n32.d: Likewise.
* testsuite/ld-mips-elf/rel32-o32.d: Likewise.
* testsuite/ld-mips-elf/rel64.d: Likewise.
* testsuite/ld-mips-elf/relax-jalr-n32.d: Likewise.
* testsuite/ld-mips-elf/reloc-1-n32.d: Likewise.
* testsuite/ld-mips-elf/reloc-1-n64.d: Likewise.
* testsuite/ld-mips-elf/reloc-2.d: Likewise.
* testsuite/ld-mips-elf/reloc-3-n32.d: Likewise.
* testsuite/ld-mips-elf/reloc-local-overflow.d: Likewise.
* testsuite/ld-mips-elf/textrel-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-2.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-ignore-2.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-ignore-micromips.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-branch-ignore-mips16.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-branch-ignore-r6-1.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-branch-micromips.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-mips16.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-r6-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch-r6-2.d: Likewise.
* testsuite/ld-mips-elf/unaligned-branch.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-0.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-2.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-3.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-0.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-1.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-0.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-1.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jump-micromips.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jump-mips16.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jump.d: Likewise.
* testsuite/ld-mips-elf/unaligned-ldpc-0.d: Likewise.
* testsuite/ld-mips-elf/unaligned-ldpc-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-lwpc-0.d: Likewise.
* testsuite/ld-mips-elf/unaligned-lwpc-1.d: Likewise.
2018-07-12 15:01:44 -04:00
|
|
|
#as: -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 06:27:59 -04:00
|
|
|
#objcopy_objects: -R .MIPS.abiflags
|
|
|
|
#source: ../../../gas/testsuite/gas/mips/elf-rel-got-n32.s RUN_OBJCOPY
|
2012-08-06 17:05:54 -04:00
|
|
|
#ld:
|
|
|
|
#objdump: -D --show-raw-insn
|
|
|
|
|
|
|
|
.*: +file format elf32-n.*mips.*
|
|
|
|
|
|
|
|
Disassembly of section \.reginfo:
|
|
|
|
|
|
|
|
10000078 <\.reginfo>:
|
|
|
|
10000078: 92020022 .*
|
|
|
|
\.\.\.
|
|
|
|
1000008c: 10018560 .*
|
|
|
|
|
|
|
|
Disassembly of section \.text:
|
|
|
|
|
|
|
|
10000074 <fn>:
|
|
|
|
10000074: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000078: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
1000007c: 24a5000c addiu a1,a1,12
|
|
|
|
10000080: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000084: 3c010001 lui at,0x1
|
|
|
|
10000088: 3421e240 ori at,at,0xe240
|
|
|
|
1000008c: 00a12821 addu a1,a1,at
|
|
|
|
10000090: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000094: 00b12821 addu a1,a1,s1
|
|
|
|
10000098: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
1000009c: 24a5000c addiu a1,a1,12
|
|
|
|
100000a0: 00b12821 addu a1,a1,s1
|
|
|
|
100000a4: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
100000a8: 3c010001 lui at,0x1
|
|
|
|
100000ac: 3421e240 ori at,at,0xe240
|
|
|
|
100000b0: 00a12821 addu a1,a1,at
|
|
|
|
100000b4: 00b12821 addu a1,a1,s1
|
|
|
|
100000b8: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100000bc: 8ca504bc lw a1,1212\(a1\)
|
|
|
|
100000c0: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100000c4: 8ca504c8 lw a1,1224\(a1\)
|
|
|
|
100000c8: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100000cc: 00b12821 addu a1,a1,s1
|
|
|
|
100000d0: 8ca504bc lw a1,1212\(a1\)
|
|
|
|
100000d4: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100000d8: 00b12821 addu a1,a1,s1
|
|
|
|
100000dc: 8ca504c8 lw a1,1224\(a1\)
|
|
|
|
100000e0: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100000e4: 00250821 addu at,at,a1
|
|
|
|
100000e8: 8c2504de lw a1,1246\(at\)
|
|
|
|
100000ec: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100000f0: 00250821 addu at,at,a1
|
|
|
|
100000f4: ac2504f4 sw a1,1268\(at\)
|
|
|
|
100000f8: 8f818018 lw at,-32744\(gp\)
|
|
|
|
100000fc: 88250000 lwl a1,0\(at\)
|
|
|
|
10000100: 98250003 lwr a1,3\(at\)
|
|
|
|
10000104: 8f818018 lw at,-32744\(gp\)
|
|
|
|
10000108: 2421000c addiu at,at,12
|
|
|
|
1000010c: 88250000 lwl a1,0\(at\)
|
|
|
|
10000110: 98250003 lwr a1,3\(at\)
|
|
|
|
10000114: 8f818018 lw at,-32744\(gp\)
|
|
|
|
10000118: 00310821 addu at,at,s1
|
|
|
|
1000011c: 88250000 lwl a1,0\(at\)
|
|
|
|
10000120: 98250003 lwr a1,3\(at\)
|
|
|
|
10000124: 8f818018 lw at,-32744\(gp\)
|
|
|
|
10000128: 2421000c addiu at,at,12
|
|
|
|
1000012c: 00310821 addu at,at,s1
|
|
|
|
10000130: 88250000 lwl a1,0\(at\)
|
|
|
|
10000134: 98250003 lwr a1,3\(at\)
|
|
|
|
10000138: 8f818018 lw at,-32744\(gp\)
|
|
|
|
1000013c: 24210022 addiu at,at,34
|
|
|
|
10000140: 00250821 addu at,at,a1
|
|
|
|
10000144: 88250000 lwl a1,0\(at\)
|
|
|
|
10000148: 98250003 lwr a1,3\(at\)
|
|
|
|
1000014c: 8f818018 lw at,-32744\(gp\)
|
|
|
|
10000150: 24210038 addiu at,at,56
|
|
|
|
10000154: 00250821 addu at,at,a1
|
|
|
|
10000158: a8250000 swl a1,0\(at\)
|
|
|
|
1000015c: b8250003 swr a1,3\(at\)
|
|
|
|
10000160: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000164: 8f858020 lw a1,-32736\(gp\)
|
|
|
|
10000168: 8f858024 lw a1,-32732\(gp\)
|
|
|
|
1000016c: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000170: 00b12821 addu a1,a1,s1
|
|
|
|
10000174: 8f858020 lw a1,-32736\(gp\)
|
|
|
|
10000178: 00b12821 addu a1,a1,s1
|
|
|
|
1000017c: 8f858024 lw a1,-32732\(gp\)
|
|
|
|
10000180: 00b12821 addu a1,a1,s1
|
|
|
|
10000184: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000188: 8ca504bc lw a1,1212\(a1\)
|
|
|
|
1000018c: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000190: 8ca504c8 lw a1,1224\(a1\)
|
|
|
|
10000194: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000198: 00b12821 addu a1,a1,s1
|
|
|
|
1000019c: 8ca504bc lw a1,1212\(a1\)
|
|
|
|
100001a0: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100001a4: 00b12821 addu a1,a1,s1
|
|
|
|
100001a8: 8ca504c8 lw a1,1224\(a1\)
|
|
|
|
100001ac: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100001b0: 00250821 addu at,at,a1
|
|
|
|
100001b4: 8c2504de lw a1,1246\(at\)
|
|
|
|
100001b8: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100001bc: 00250821 addu at,at,a1
|
|
|
|
100001c0: ac2504f4 sw a1,1268\(at\)
|
|
|
|
100001c4: 8f818018 lw at,-32744\(gp\)
|
|
|
|
100001c8: 88250000 lwl a1,0\(at\)
|
|
|
|
100001cc: 98250003 lwr a1,3\(at\)
|
|
|
|
100001d0: 8f818020 lw at,-32736\(gp\)
|
|
|
|
100001d4: 88250000 lwl a1,0\(at\)
|
|
|
|
100001d8: 98250003 lwr a1,3\(at\)
|
|
|
|
100001dc: 8f818018 lw at,-32744\(gp\)
|
|
|
|
100001e0: 00310821 addu at,at,s1
|
|
|
|
100001e4: 88250000 lwl a1,0\(at\)
|
|
|
|
100001e8: 98250003 lwr a1,3\(at\)
|
|
|
|
100001ec: 8f818020 lw at,-32736\(gp\)
|
|
|
|
100001f0: 00310821 addu at,at,s1
|
|
|
|
100001f4: 88250000 lwl a1,0\(at\)
|
|
|
|
100001f8: 98250003 lwr a1,3\(at\)
|
|
|
|
100001fc: 8f818028 lw at,-32728\(gp\)
|
|
|
|
10000200: 00250821 addu at,at,a1
|
|
|
|
10000204: 88250000 lwl a1,0\(at\)
|
|
|
|
10000208: 98250003 lwr a1,3\(at\)
|
|
|
|
1000020c: 8f81802c lw at,-32724\(gp\)
|
|
|
|
10000210: 00250821 addu at,at,a1
|
|
|
|
10000214: a8250000 swl a1,0\(at\)
|
|
|
|
10000218: b8250003 swr a1,3\(at\)
|
|
|
|
1000021c: 8f858030 lw a1,-32720\(gp\)
|
|
|
|
10000220: 8f858030 lw a1,-32720\(gp\)
|
|
|
|
10000224: 8f998030 lw t9,-32720\(gp\)
|
|
|
|
10000228: 8f998030 lw t9,-32720\(gp\)
|
|
|
|
1000022c: 8f998030 lw t9,-32720\(gp\)
|
|
|
|
10000230: 0411ff90 bal 10000074 <fn>
|
|
|
|
10000234: 00000000 nop
|
|
|
|
10000238: 8f998030 lw t9,-32720\(gp\)
|
|
|
|
1000023c: 0411ff8d bal 10000074 <fn>
|
|
|
|
10000240: 00000000 nop
|
|
|
|
10000244: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000248: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
1000024c: 24a5000c addiu a1,a1,12
|
|
|
|
10000250: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000254: 3c010001 lui at,0x1
|
|
|
|
10000258: 3421e240 ori at,at,0xe240
|
|
|
|
1000025c: 00a12821 addu a1,a1,at
|
|
|
|
10000260: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000264: 00b12821 addu a1,a1,s1
|
|
|
|
10000268: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
1000026c: 24a5000c addiu a1,a1,12
|
|
|
|
10000270: 00b12821 addu a1,a1,s1
|
|
|
|
10000274: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000278: 3c010001 lui at,0x1
|
|
|
|
1000027c: 3421e240 ori at,at,0xe240
|
|
|
|
10000280: 00a12821 addu a1,a1,at
|
|
|
|
10000284: 00b12821 addu a1,a1,s1
|
|
|
|
10000288: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
1000028c: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
10000290: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000294: 8ca50540 lw a1,1344\(a1\)
|
|
|
|
10000298: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
1000029c: 00b12821 addu a1,a1,s1
|
|
|
|
100002a0: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
100002a4: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
100002a8: 00b12821 addu a1,a1,s1
|
|
|
|
100002ac: 8ca50540 lw a1,1344\(a1\)
|
|
|
|
100002b0: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100002b4: 00250821 addu at,at,a1
|
|
|
|
100002b8: 8c250556 lw a1,1366\(at\)
|
|
|
|
100002bc: 8f81801c lw at,-32740\(gp\)
|
|
|
|
100002c0: 00250821 addu at,at,a1
|
|
|
|
100002c4: ac25056c sw a1,1388\(at\)
|
|
|
|
100002c8: 8f818034 lw at,-32716\(gp\)
|
|
|
|
100002cc: 88250000 lwl a1,0\(at\)
|
|
|
|
100002d0: 98250003 lwr a1,3\(at\)
|
|
|
|
100002d4: 8f818034 lw at,-32716\(gp\)
|
|
|
|
100002d8: 2421000c addiu at,at,12
|
|
|
|
100002dc: 88250000 lwl a1,0\(at\)
|
|
|
|
100002e0: 98250003 lwr a1,3\(at\)
|
|
|
|
100002e4: 8f818034 lw at,-32716\(gp\)
|
|
|
|
100002e8: 00310821 addu at,at,s1
|
|
|
|
100002ec: 88250000 lwl a1,0\(at\)
|
|
|
|
100002f0: 98250003 lwr a1,3\(at\)
|
|
|
|
100002f4: 8f818034 lw at,-32716\(gp\)
|
|
|
|
100002f8: 2421000c addiu at,at,12
|
|
|
|
100002fc: 00310821 addu at,at,s1
|
|
|
|
10000300: 88250000 lwl a1,0\(at\)
|
|
|
|
10000304: 98250003 lwr a1,3\(at\)
|
|
|
|
10000308: 8f818034 lw at,-32716\(gp\)
|
|
|
|
1000030c: 24210022 addiu at,at,34
|
|
|
|
10000310: 00250821 addu at,at,a1
|
|
|
|
10000314: 88250000 lwl a1,0\(at\)
|
|
|
|
10000318: 98250003 lwr a1,3\(at\)
|
|
|
|
1000031c: 8f818034 lw at,-32716\(gp\)
|
|
|
|
10000320: 24210038 addiu at,at,56
|
|
|
|
10000324: 00250821 addu at,at,a1
|
|
|
|
10000328: a8250000 swl a1,0\(at\)
|
|
|
|
1000032c: b8250003 swr a1,3\(at\)
|
|
|
|
10000330: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000334: 8f858038 lw a1,-32712\(gp\)
|
|
|
|
10000338: 8f85803c lw a1,-32708\(gp\)
|
|
|
|
1000033c: 8f858034 lw a1,-32716\(gp\)
|
|
|
|
10000340: 00b12821 addu a1,a1,s1
|
|
|
|
10000344: 8f858038 lw a1,-32712\(gp\)
|
|
|
|
10000348: 00b12821 addu a1,a1,s1
|
|
|
|
1000034c: 8f85803c lw a1,-32708\(gp\)
|
|
|
|
10000350: 00b12821 addu a1,a1,s1
|
|
|
|
10000354: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000358: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
1000035c: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000360: 8ca50540 lw a1,1344\(a1\)
|
|
|
|
10000364: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000368: 00b12821 addu a1,a1,s1
|
|
|
|
1000036c: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
10000370: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000374: 00b12821 addu a1,a1,s1
|
|
|
|
10000378: 8ca50540 lw a1,1344\(a1\)
|
|
|
|
1000037c: 8f81801c lw at,-32740\(gp\)
|
|
|
|
10000380: 00250821 addu at,at,a1
|
|
|
|
10000384: 8c250556 lw a1,1366\(at\)
|
|
|
|
10000388: 8f81801c lw at,-32740\(gp\)
|
|
|
|
1000038c: 00250821 addu at,at,a1
|
|
|
|
10000390: ac25056c sw a1,1388\(at\)
|
|
|
|
10000394: 8f818034 lw at,-32716\(gp\)
|
|
|
|
10000398: 88250000 lwl a1,0\(at\)
|
|
|
|
1000039c: 98250003 lwr a1,3\(at\)
|
|
|
|
100003a0: 8f818038 lw at,-32712\(gp\)
|
|
|
|
100003a4: 88250000 lwl a1,0\(at\)
|
|
|
|
100003a8: 98250003 lwr a1,3\(at\)
|
|
|
|
100003ac: 8f818034 lw at,-32716\(gp\)
|
|
|
|
100003b0: 00310821 addu at,at,s1
|
|
|
|
100003b4: 88250000 lwl a1,0\(at\)
|
|
|
|
100003b8: 98250003 lwr a1,3\(at\)
|
|
|
|
100003bc: 8f818038 lw at,-32712\(gp\)
|
|
|
|
100003c0: 00310821 addu at,at,s1
|
|
|
|
100003c4: 88250000 lwl a1,0\(at\)
|
|
|
|
100003c8: 98250003 lwr a1,3\(at\)
|
|
|
|
100003cc: 8f818040 lw at,-32704\(gp\)
|
|
|
|
100003d0: 00250821 addu at,at,a1
|
|
|
|
100003d4: 88250000 lwl a1,0\(at\)
|
|
|
|
100003d8: 98250003 lwr a1,3\(at\)
|
|
|
|
100003dc: 8f818044 lw at,-32700\(gp\)
|
|
|
|
100003e0: 00250821 addu at,at,a1
|
|
|
|
100003e4: a8250000 swl a1,0\(at\)
|
|
|
|
100003e8: b8250003 swr a1,3\(at\)
|
|
|
|
100003ec: 8f858048 lw a1,-32696\(gp\)
|
|
|
|
100003f0: 8f858048 lw a1,-32696\(gp\)
|
|
|
|
100003f4: 8f998048 lw t9,-32696\(gp\)
|
|
|
|
100003f8: 8f998048 lw t9,-32696\(gp\)
|
|
|
|
100003fc: 8f998048 lw t9,-32696\(gp\)
|
|
|
|
10000400: 0411001d bal 10000478 <fn2>
|
|
|
|
10000404: 00000000 nop
|
|
|
|
10000408: 8f998048 lw t9,-32696\(gp\)
|
|
|
|
1000040c: 0411001a bal 10000478 <fn2>
|
|
|
|
10000410: 00000000 nop
|
|
|
|
10000414: 1000ff17 b 10000074 <fn>
|
|
|
|
10000418: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
1000041c: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000420: 10000015 b 10000478 <fn2>
|
|
|
|
10000424: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
10000428: 1000ff12 b 10000074 <fn>
|
|
|
|
1000042c: 8f858018 lw a1,-32744\(gp\)
|
|
|
|
10000430: 8f858038 lw a1,-32712\(gp\)
|
|
|
|
10000434: 10000010 b 10000478 <fn2>
|
|
|
|
10000438: 00000000 nop
|
|
|
|
1000043c: 8f858024 lw a1,-32732\(gp\)
|
|
|
|
10000440: 1000ff0c b 10000074 <fn>
|
|
|
|
10000444: 00000000 nop
|
|
|
|
10000448: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
1000044c: 1000000a b 10000478 <fn2>
|
|
|
|
10000450: 8ca50534 lw a1,1332\(a1\)
|
|
|
|
10000454: 8f85801c lw a1,-32740\(gp\)
|
|
|
|
10000458: 1000ff06 b 10000074 <fn>
|
|
|
|
1000045c: 8ca504c8 lw a1,1224\(a1\)
|
|
|
|
10000460: 8f81801c lw at,-32740\(gp\)
|
|
|
|
10000464: 00250821 addu at,at,a1
|
|
|
|
10000468: 10000003 b 10000478 <fn2>
|
|
|
|
1000046c: 8c250556 lw a1,1366\(at\)
|
|
|
|
\.\.\.
|
|
|
|
|
|
|
|
10000478 <fn2>:
|
|
|
|
\.\.\.
|
|
|
|
Disassembly of section \.data:
|
|
|
|
|
|
|
|
10010480 <_fdata>:
|
|
|
|
\.\.\.
|
|
|
|
|
|
|
|
100104bc <dg1>:
|
|
|
|
\.\.\.
|
|
|
|
|
|
|
|
100104f8 <sp2>:
|
|
|
|
\.\.\.
|
|
|
|
|
|
|
|
10010534 <dg2>:
|
|
|
|
\.\.\.
|
|
|
|
Disassembly of section \.got:
|
|
|
|
|
|
|
|
10010570 <_GLOBAL_OFFSET_TABLE_>:
|
|
|
|
10010570: 00000000 .*
|
|
|
|
10010574: 80000000 .*
|
|
|
|
10010578: 100104bc .*
|
|
|
|
1001057c: 10010000 .*
|
|
|
|
10010580: 100104c8 .*
|
|
|
|
10010584: 1002e6fc .*
|
|
|
|
10010588: 100104de .*
|
|
|
|
1001058c: 100104f4 .*
|
|
|
|
10010590: 10000074 .*
|
|
|
|
10010594: 10010534 .*
|
|
|
|
10010598: 10010540 .*
|
|
|
|
1001059c: 1002e774 .*
|
|
|
|
100105a0: 10010556 .*
|
|
|
|
100105a4: 1001056c .*
|
|
|
|
100105a8: 10000478 .*
|
|
|
|
100105ac: 00000000 .*
|
|
|
|
\.\.\.
|
|
|
|
#pass
|