old-cross-binutils/gold/testsuite
H.J. Lu 4fc1b9d43c Handle stack split for x32
X32 uses cmp %fs:NN,%esp, lea NN(%rsp),%r10d, lea NN(%rsp),%r11d,
instead of cmp %fs:NN,%rsp, lea NN(%rsp),%r10, lea NN(%rsp),%r11.
This patch handles it.

	PR gold/17729
	* configure.ac (DEFAULT_TARGET_X86_64): Don't set for x32.
	(DEFAULT_TARGET_X32): Set for x32.
	* x86_64.cc (cmp_insn_32): New.
	(lea_r10_insn_32): Likewise.
	(lea_r11_insn_32): Likewise.
	(cmp_insn_64): Likewise.
	(lea_r10_insn_64): Likewise.
	(lea_r11_insn_64): Likewise.
	(Target_x86_64<size>::do_calls_non_split): Handle x32.
	* testsuite/Makefile.am (check_SCRIPTS): Add split_x32.sh.
	(check_DATA): Add split_x32 files.
	(split_x32_[1234n].o): New targets.
	(split_x32_[124]): New targets.
	(split_x32_[1234r].stdout): New targets.
	* testsuite/split_x32.sh: New file.
	* testsuite/split_x32_1.s: Likewise.
	* testsuite/split_x32_2.s: Likewise.
	* testsuite/split_x32_3.s: Likewise.
	* testsuite/split_x32_4.s: Likewise.
	* testsuite/split_x32_n.s: Likewise.
	* configure: Regenerated.
	* testsuite/Makefile.in: Likewise.
2015-01-06 15:38:25 -08:00
..
arm_abs_global.s
arm_abs_global.sh
arm_abs_lib.s
arm_attr_merge.sh
arm_attr_merge_6a.s
arm_attr_merge_6b.s
arm_attr_merge_7a.s
arm_attr_merge_7b.s
arm_bl_in_range.s
arm_bl_out_of_range.s
arm_branch_in_range.sh
arm_branch_out_of_range.sh
arm_branch_range.t
arm_cortex_a8.sh
arm_cortex_a8_b.s
arm_cortex_a8_b_cond.s
arm_cortex_a8_b_local.s
arm_cortex_a8_bl.s
arm_cortex_a8_blx.s
arm_cortex_a8_local.s
arm_cortex_a8_local_reloc.s
arm_exidx_test.s
arm_exidx_test.sh
arm_farcall_arm_arm.s
arm_farcall_arm_arm.sh
arm_farcall_arm_thumb.s
arm_farcall_arm_thumb.sh
arm_farcall_thumb_arm.s
arm_farcall_thumb_arm.sh
arm_farcall_thumb_thumb.s
arm_farcall_thumb_thumb.sh
arm_fix_1176.s
arm_fix_1176.sh
arm_fix_v4bx.s
arm_fix_v4bx.sh
arm_thm_jump8.s
arm_thm_jump8.t
arm_thm_jump11.s
arm_thm_jump11.t
arm_unaligned_reloc.s
arm_unaligned_reloc.sh
basic_test.cc
binary.in
binary_test.cc
binary_unittest.cc
common_test_1.c
common_test_1_v1.c
common_test_1_v2.c
common_test_2.c
common_test_3.c
constructor_test.cc
copy_test.cc
copy_test_1.cc
copy_test_2.cc
copy_test_v1.cc
debug_msg.cc
debug_msg.sh
defsym_test.c
defsym_test.sh
discard_locals_relocatable_test.c
discard_locals_test.c
discard_locals_test.sh
dwp_test.h
dwp_test_1.cc
dwp_test_1.s
dwp_test_1.sh
dwp_test_1b.cc
dwp_test_1b.s
dwp_test_2.cc
dwp_test_2.s
dwp_test_2.sh
dwp_test_main.cc
dwp_test_main.s
dyn_weak_ref.sh
dyn_weak_ref_1.c
dyn_weak_ref_2.c
dynamic_list.sh
dynamic_list.t
dynamic_list_2.cc
dynamic_list_2.t
dynamic_list_lib1.cc
dynamic_list_lib2.cc
ehdr_start_def.cc
ehdr_start_test.cc
ehdr_start_test.t
ehdr_start_test_4.sh
exception_test.h
exception_test_1.cc
exception_test_2.cc
exception_test_main.cc
exclude_libs_test.c
exclude_libs_test.sh
exclude_libs_test_1.c
exclude_libs_test_2.c
exclude_libs_test_3.c
final_layout.cc
final_layout.sh
gc_comdat_test.sh
gc_comdat_test_1.cc
gc_comdat_test_2.cc
gc_dynamic_list_test.c
gc_dynamic_list_test.sh
gc_dynamic_list_test.t
gc_orphan_section_test.cc
gc_orphan_section_test.sh
gc_tls_test.cc
gc_tls_test.sh
gdb_index_test.cc
gdb_index_test_1.sh
gdb_index_test_2.sh
gdb_index_test_3.c
gdb_index_test_3.sh
gdb_index_test_4.sh
gdb_index_test_comm.sh
hidden_test.sh
hidden_test_1.c
hidden_test_main.c
icf_keep_unique_test.cc
icf_keep_unique_test.sh
icf_preemptible_functions_test.cc
icf_preemptible_functions_test.sh
icf_safe_so_test.cc
icf_safe_so_test.sh
icf_safe_test.cc
icf_safe_test.sh
icf_sht_rel_addend_test.sh
icf_sht_rel_addend_test_1.cc
icf_sht_rel_addend_test_2.cc
icf_string_merge_test.cc
icf_string_merge_test.sh
icf_test.cc
icf_test.sh
icf_virtual_function_folding_test.cc
ifunc-sel.h
ifuncdep2.c
ifuncmain1.c
ifuncmain1vis.c
ifuncmain2.c
ifuncmain3.c
ifuncmain4.c
ifuncmain5.c
ifuncmain6pie.c
ifuncmain7.c
ifuncmod1.c
ifuncmod3.c
ifuncmod5.c
ifuncmod6.c
ifuncvar1.c
ifuncvar2.c
ifuncvar3.c
incr_comdat_test_1.cc
incr_comdat_test_2_v1.cc
incr_comdat_test_2_v2.cc
incr_comdat_test_2_v3.cc
incremental_test.sh
incremental_test_1.c
incremental_test_2.c
initpri1.c
initpri2.c
initpri3.c
justsyms.t
justsyms_1.cc
justsyms_2.cc
justsyms_exec.c
justsyms_lib.c
large.c
large_symbol_alignment.cc
leb128_unittest.cc
Makefile.am Handle stack split for x32 2015-01-06 15:38:25 -08:00
Makefile.in Handle stack split for x32 2015-01-06 15:38:25 -08:00
many_sections_test.cc
memory_test.s
memory_test.sh
memory_test.t
merge_string_literals.sh
merge_string_literals_1.cc
merge_string_literals_2.cc
missing_key_func.cc
missing_key_func.sh
no_version_test.c
no_version_test.sh
object_unittest.cc
odr_header1.h
odr_header2.h
odr_violation1.cc
odr_violation2.cc
pie_copyrelocs_shared_test.cc
pie_copyrelocs_test.cc
plugin_common_test_1.c
plugin_common_test_2.c
plugin_final_layout.cc
plugin_final_layout.sh
plugin_section_order.c
plugin_test.c
plugin_test_1.sh
plugin_test_2.sh
plugin_test_3.sh
plugin_test_4.sh
plugin_test_6.sh
plugin_test_7.sh
plugin_test_7_1.c
plugin_test_7_2.c
plugin_test_10.sh
plugin_test_tls.sh
pr12826.sh
pr12826_1.s
pr12826_2.s
pr14265.c
pr14265.sh
pr14265.t
protected_1.cc
protected_2.cc
protected_3.cc
protected_4.cc
protected_main_1.cc
protected_main_2.cc
protected_main_3.cc
relro_script_test.t
relro_test.cc
relro_test.sh
relro_test_main.cc
retain_symbols_file_test.sh
script_test_1.cc
script_test_1.t
script_test_2.cc
script_test_2.t
script_test_2a.cc
script_test_2b.cc
script_test_3.sh
script_test_3.t
script_test_4.sh
script_test_4.t
script_test_5.cc
script_test_5.sh
script_test_5.t
script_test_6.sh
script_test_6.t
script_test_7.sh
script_test_7.t
script_test_8.sh
script_test_9.cc
script_test_9.sh
script_test_9.t
script_test_10.s
script_test_10.sh
script_test_10.t
script_test_11.c
script_test_11.t
searched_file_test.cc
searched_file_test_lib.cc
section_sorting_name.cc
section_sorting_name.sh
split_i386.sh
split_i386_1.s
split_i386_2.s
split_i386_3.s
split_i386_4.s
split_i386_n.s
split_x32.sh Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x32_1.s Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x32_2.s Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x32_3.s Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x32_4.s Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x32_n.s Handle stack split for x32 2015-01-06 15:38:25 -08:00
split_x86_64.sh
split_x86_64_1.s
split_x86_64_2.s
split_x86_64_3.s
split_x86_64_4.s
split_x86_64_n.s
start_lib_test_1.c
start_lib_test_2.c
start_lib_test_3.c
start_lib_test_main.c
strong_ref_weak_def.sh
strong_ref_weak_def_1.c
strong_ref_weak_def_2.c
test.cc
test.h
testfile.cc
testfile.h
testmain.cc
text_section_grouping.cc
text_section_grouping.sh
thin_archive_main.cc
thin_archive_test_1.cc
thin_archive_test_2.cc
thin_archive_test_3.cc
thin_archive_test_4.cc
thumb2_branch_range.t
thumb_bl_in_range.s
thumb_bl_out_of_range.s
thumb_bl_out_of_range_local.s
thumb_blx_in_range.s
thumb_blx_out_of_range.s
thumb_branch_range.t
tls_test.cc
tls_test.h
tls_test_c.c
tls_test_file2.cc
tls_test_main.cc
two_file_shared.sh
two_file_test.h
two_file_test_1.cc
two_file_test_1_v1.cc
two_file_test_1b.cc
two_file_test_1b_v1.cc
two_file_test_2.cc
two_file_test_2_tls.cc
two_file_test_2_v1.cc
two_file_test_main.cc
two_file_test_tls.cc
undef_symbol.cc
undef_symbol.sh
undef_symbol_main.cc
ver_matching_def.cc
ver_matching_test.sh
ver_test.h
ver_test_1.cc
ver_test_1.sh
ver_test_2.cc
ver_test_2.script
ver_test_2.sh
ver_test_3.cc
ver_test_4.cc
ver_test_4.script
ver_test_4.sh
ver_test_5.cc
ver_test_5.script
ver_test_5.sh
ver_test_6.c
ver_test_7.cc
ver_test_7.sh
ver_test_8.script
ver_test_9.cc
ver_test_10.script
ver_test_10.sh
ver_test_main.cc
ver_test_main_2.cc
version_script.map
weak_alias_test.script
weak_alias_test_1.cc
weak_alias_test_2.cc
weak_alias_test_3.cc
weak_alias_test_4.cc
weak_alias_test_5.cc
weak_alias_test_main.cc
weak_plt.sh
weak_plt_main.cc
weak_plt_shared.cc
weak_test.cc
weak_undef.h
weak_undef_file1.cc
weak_undef_file2.cc
weak_undef_file3.cc
weak_undef_file4.cc
weak_undef_test.cc
weak_undef_test_2.cc