aboutsummaryrefslogtreecommitdiff
path: root/ld/emultempl
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2018-09-20 13:27:31 +0100
committerNick Clifton <nickc@redhat.com>2018-09-20 13:32:58 +0100
commitfbaf61ad525eb2818598b699d44df32e46583925 (patch)
tree72886133a128d6bbd4be1af0804b10119598af3d /ld/emultempl
parentcf93e9c2cf8f8b2566f8fc86e961592b51b5980d (diff)
downloadbinutils-fbaf61ad525eb2818598b699d44df32e46583925.zip
binutils-fbaf61ad525eb2818598b699d44df32e46583925.tar.gz
binutils-fbaf61ad525eb2818598b699d44df32e46583925.tar.bz2
Andes Technology has good news for you, we plan to update the nds32 port of binutils on upstream!
We have not only removed all unsupported and obsolete code, but also supported lost of new features, including better link-time relaxations and TLS implementations. Besides, the files generated by the newly assembler and linker usually get higher performance and more optimized code size. ld * emultempl/nds32elf.em (hyper_relax): New variable. (nds32_elf_create_output_section_statements): the parameters of bfd_elf32_nds32_set_target_option (PARSE_AND_LIST_PROLOGUE, PARSE_AND_LIST_OPTIONS, PARSE_AND_LIST_ARGS_CASES): Add new option --mhyper-relax. * emultempl/nds32elf.em (nds32_elf_after_open): Updated. * emultempl/nds32elf.em (tls_desc_trampoline): New variable. * (nds32_elf_create_output_section_statements): Updated. * (nds32_elf_after_parse): Disable relaxations when PIC is enable. * (PARSE_AND_LIST_PROLOGUE, PARSE_AND_LIST_OPTIONS, PARSE_AND_LIST_ARGS_CASES): Add new option --m[no-]tlsdesc-trampoline. include * elf/nds32.h: Remove the unused target features. * dis-asm.h (disassemble_init_nds32): Declared. * elf/nds32.h (E_NDS32_NULL): Removed. (E_NDS32_HAS_DSP_INST, E_NDS32_HAS_ZOL): New. * opcode/nds32.h: Ident. (N32_SUB6, INSN_LW): New macros. (enum n32_opcodes): Updated. * elf/nds32.h: Doc fixes. * elf/nds32.h: Add R_NDS32_LSI. * elf/nds32.h: Add new relocations for TLS. gas * config/tc-nds32.c: Remove the unused target features. (nds32_relax_relocs, md_pseudo_table, nds32_elf_record_fixup_exp, nds32_set_elf_flags_by_insn, nds32_insert_relax_entry, nds32_apply_fix): Likewise. (nds32_no_ex9_begin): Removed. * config/tc-nds32.c (add_mapping_symbol_for_align, make_mapping_symbol, add_mapping_symbol): New functions. * config/tc-nds32.h (enum mstate): New. (nds32_segment_info_type): Likewise. * configure.ac (--enable-dsp-ext, --enable-zol-ext): New options. * config.in: Regenerated. * configure: Regenerated. * config/tc-nds32.c (nds32_dx_regs): Set the value according to the configuration. (nds32_perf_ext, nds32_perf_ext2, nds32_string_ext, nds32_audio_ext): Likewise. (nds32_dsp_ext): New variable. Set the value according to the configuration. (nds32_zol_ext): Likewise. (asm_desc, nds32_pseudo_opcode_table): Make them static. (nds32_set_elf_flags_by_insn): Updated. (nds32_check_insn_available): Updated. (nds32_str_tolower): New function. * config/tc-nds32.c (relax_table): Updated. (md_begin): Updated. (md_assemble): Use XNEW macro to allocate space for `insn.info', and then remember to free it. (md_section_align): Cast (-1) to ValueT. (nds32_get_align): Cast (~0U) to addressT. (nds32_relax_branch_instructions): Updated. (md_convert_frag): Add new local variable `final_r_type'. (invalid_prev_frag): Add new bfd_boolean parameter `relax'. All callers changed. * config/tc-nds32.c (struct nds32_relocs_pattern): Add `insn' field. (struct nds32_hint_map): Add `option_list' field. (struct suffix_name, suffix_table): Remove the unused `pic' field. (do_pseudo_b, do_pseudo_bal): Remove the suffix checking. (do_pseudo_la_internal, do_pseudo_pushpopm): Indent. (relax_hint_bias, relax_hint_id_current): New static variables. (reset_bias, relax_hint_begin): New variables. (nds_itoa): New function. (CLEAN_REG, GET_OPCODE): New macros. (struct relax_hint_id): New. (nds32_relax_hint): For .relax_hint directive, we can use `begin' and `end' to mark the relax pattern without giving exactly id number. (nds32_elf_append_relax_relocs): Handle the case that the .relax_hint directives are attached to pseudo instruction. (nds32_elf_save_pseudo_pattern): Change the second parameter from instruction's opcode to byte code. (nds32_elf_build_relax_relation): Add new bfd_boolean parameter `pseudo_hint'. (nds32_lookup_pseudo_opcode): Fix the overflow issue. (enum nds32_insn_type): Add N32_RELAX_ALU1 and N32_RELAX_16BIT. (nds32_elf_record_fixup_exp, relax_ls_table, hint_map, nds32_find_reloc_table, nds32_match_hint_insn, nds32_parse_name): Updated. * config/tc-nds32.h (MAX_RELAX_NUM): Extend it to 6. (enum nds32_relax_hint_type): Merge NDS32_RELAX_HINT_LA and NDS32_RELAX_HINT_LS into NDS32_RELAX_HINT_LALS. Add NDS32_RELAX_HINT_LA_PLT, NDS32_RELAX_HINT_LA_GOT and NDS32_RELAX_HINT_LA_GOTOFF. * config/tc-nds32.h (relax_ls_table): Add floating load/store to gp relax pattern. (hint_map, nds32_find_reloc_table): Likewise. * configure.ac: Define NDS32_LINUX_TOOLCHAIN. * configure: Regenerated. * config.in: Regenerated. * config/tc-nds32.h (enum nds32_ramp): Updated. (enum nds32_relax_hint_type): Likewise. * config/tc-nds32.c: Include "errno.h" and "limits.h". (relax_ls_table): Add TLS relax patterns. (nds32_elf_append_relax_relocs): Attach BFD_RELOC_NDS32_GROUP on each instructions of TLS patterns. (nds32_elf_record_fixup_exp): Updated. (nds32_apply_fix): Likewise. (suffix_table): Add TLSDESC suffix. binutils* testsuite/binutils-all/objcopy.exp: Set the unsupported reloc number from 215 to 255 for NDS32. bfd * elf32-nds32.c (nds32_elf_relax_loadstore): Remove the unused target features. (bfd_elf32_nds32_set_target_option): Remove the unused parameters. (nds32_elf_relax_piclo12, nds32_elf_relax_letlslo12, nds32_elf_relax_letlsadd, nds32_elf_relax_letlsls, nds32_elf_relax_pltgot_suff, nds32_elf_relax_got_suff nds32_elf_relax_gotoff_suff, calculate_plt_memory_address, calculate_plt_offset, calculate_got_memory_address, nds32_elf_check_dup_relocs): Removed. All callers changed. * elf32-nds32.h: Remove the unused macros and defines. (elf_nds32_link_hash_table): Remove the unused variable. (bfd_elf32_nds32_set_target_option): Update prototype. (nds32_elf_ex9_init): Removed. * elf32-nds32.c (nds32_convert_32_to_16): Updated. * elf32-nds32.c (HOWTO2, HOWTO3): Define new HOWTO macros to initialize array nds32_elf_howto_table in any order without lots of EMPTY_HOWTO. (nds32_reloc_map): Updated. * reloc.c: Add BFD_RELOC_NDS32_LSI. * bfd-in2.h: Regenerated. * bfd/libbfd.h: Regenerated. * elf32-nds32.c (nds32_elf_relax_howto_table): Add R_NDS32_LSI. (nds32_reloc_map): Likewise. (nds32_elf_relax_flsi): New function. (nds32_elf_relax_section): Support floating load/store relaxation. * elf32-nds32.c (NDS32_GUARD_SEC_P, elf32_nds32_local_gp_offset): New macro. (struct elf_nds32_link_hash_entry): New `offset_to_gp' field. (struct elf_nds32_obj_tdata): New `offset_to_gp' and `hdr_size' fields. (elf32_nds32_allocate_local_sym_info, nds32_elf_relax_guard, nds32_elf_is_target_special_symbol, nds32_elf_maybe_function_sym): New functions. (nds32_info_to_howto_rel): Add BFD_ASSERT. (bfd_elf32_bfd_reloc_type_table_lookup, nds32_elf_link_hash_newfunc, nds32_elf_link_hash_table_create, nds32_elf_relocate_section, nds32_elf_relax_loadstore, nds32_elf_relax_lo12, nds32_relax_adjust_label, bfd_elf32_nds32_set_target_option, nds32_fag_mark_relax): Updated. (nds32_elf_final_sda_base): Improve it to find the better gp value. (insert_nds32_elf_blank): Must consider `len' when inserting blanks. * elf32-nds32.h (bfd_elf32_nds32_set_target_option): Update prototype. (struct elf_nds32_link_hash_table): Add new variable `hyper_relax'. * elf32-nds32.c (elf32_nds32_allocate_dynrelocs): New function. (create_got_section): Likewise. (allocate_dynrelocs, nds32_elf_size_dynamic_sections, nds32_elf_relocate_section, nds32_elf_finish_dynamic_symbol): Updated. (nds32_elf_check_relocs): Fix the issue that the shared library may has TEXTREL entry in the dynamic section. (nds32_elf_create_dynamic_sections): Enable to call readonly_dynrelocs since the TEXTREL issue is fixed in the nds32_elf_check_relocs. (nds32_elf_finish_dynamic_sections): Update and add DT_RELASZ dynamic entry. (calculate_offset): Remove the unused parameter `pic_ext_target' and related codes. All callers changed. (elf_backend_dtrel_excludes_plt): Disable it temporarily since it will cause some errors for our test cases. * elf32-nds32.c (nds32_elf_merge_private_bfd_data): Allow to link the generic object. * reloc.c: Add TLS relocations. * libbfd.h: Regenerated. * bfd-in2.h: Regenerated. * elf32-nds32.h (struct section_id_list_t): New. (elf32_nds32_lookup_section_id, elf32_nds32_check_relax_group, elf32_nds32_unify_relax_group, nds32_elf_unify_tls_model): New prototypes. (elf32_nds32_compute_jump_table_size, elf32_nds32_local_tlsdesc_gotent): New macro. (nds32_insertion_sort, bfd_elf32_nds32_set_target_option, elf_nds32_link_hash_table): Updated. * elf32-nds32.c (enum elf_nds32_tls_type): New. (struct elf32_nds32_relax_group_t, struct relax_group_list_t): New. (elf32_nds32_add_dynreloc, patch_tls_desc_to_ie, get_tls_type, fls, ones32, list_insert, list_insert_sibling, dump_chain, elf32_nds32_check_relax_group, elf32_nds32_lookup_section_id, elf32_nds32_unify_relax_group, nds32_elf_unify_tls_model): New functions. (elf_nds32_obj_tdata): Add new fields. (elf32_nds32_relax_group_ptr, nds32_elf_local_tlsdesc_gotent): New macros. (nds32_elf_howto_table): Add TLS relocations. (nds32_reloc_map): Likewise. (nds32_elf_copy_indirect_symbol, nds32_elf_size_dynamic_sections, nds32_elf_finish_dynamic_symbol, elf32_nds32_allocate_local_sym_info, nds32_elf_relocate_section, bfd_elf32_nds32_set_target_option, nds32_elf_check_relocs, allocate_dynrelocs): Updated. (nds32_elf_relax_section): Call nds32_elf_unify_tls_model. (dtpoff_base): Rename it to `gottpof' and then update it. opcodes * nds32-asm.c (operand_fields): Remove the unused fields. (nds32_opcodes): Remove the unused instructions. * nds32-dis.c (nds32_ex9_info): Removed. (nds32_parse_opcode): Updated. (print_insn_nds32): Likewise. * nds32-asm.c (config.h, stdlib.h, string.h): New includes. (LEX_SET_FIELD, LEX_GET_FIELD): Update defines. (nds32_asm_init, build_operand_hash_table, build_keyword_hash_table, build_opcode_hash_table): New functions. (nds32_keyword_table, nds32_keyword_count_table, nds32_field_table, nds32_opcode_table): New. (hw_ktabs): Declare it to a pointer rather than an array. (build_hash_table): Removed. * nds32-asm.h (enum): Add SYN_INPUT, SYN_OUTPUT, SYN_LOPT, SYN_ROPT and upadte HW_GPR and HW_INT. * nds32-dis.c (keywords): Remove const. (match_field): New function. (nds32_parse_opcode): Updated. * disassemble.c (disassemble_init_for_target): Add disassemble_init_nds32. * nds32-dis.c (eum map_type): New. (nds32_private_data): Likewise. (get_mapping_symbol_type, is_mapping_symbol, nds32_symbol_is_valid, nds32_add_opcode_hash_table, disassemble_init_nds32): New functions. (print_insn_nds32): Updated. * nds32-asm.c (parse_aext_reg): Add new parameter. (parse_re, parse_re2, parse_aext_reg): Only reduced registers are allowed to use. All callers changed. * nds32-asm.c (keyword_usr, keyword_sr): Updated. (operand_fields): Add new fields. (nds32_opcodes): Add new instructions. (keyword_aridxi_mx): New keyword. * nds32-asm.h (enum): Add NASM_ATTR_DSP_ISAEXT, HW_AEXT_ARIDXI_MX and NASM_ATTR_ZOL. (ALU2_1, ALU2_2, ALU2_3): New macros. * nds32-dis.c (nds32_filter_unknown_insn): Updated.
Diffstat (limited to 'ld/emultempl')
-rw-r--r--ld/emultempl/nds32elf.em234
1 files changed, 40 insertions, 194 deletions
diff --git a/ld/emultempl/nds32elf.em b/ld/emultempl/nds32elf.em
index eb29d04..6fb5a48 100644
--- a/ld/emultempl/nds32elf.em
+++ b/ld/emultempl/nds32elf.em
@@ -30,17 +30,10 @@ fragment <<EOF
static int relax_fp_as_gp = 1; /* --mrelax-omit-fp */
static int eliminate_gc_relocs = 0; /* --meliminate-gc-relocs */
static FILE *sym_ld_script = NULL; /* --mgen-symbol-ld-script=<file> */
+static int hyper_relax = 1; /* --mhyper-relax */
+static int tls_desc_trampoline = 0; /* --m[no]tlsdesc-trampoline. */
/* Disable if linking a dynamically linked executable. */
static int load_store_relax = 1;
-static int target_optimize = 0; /* Switch optimization. */
-static int relax_status = 0; /* Finished optimization. */
-static int relax_round = 0; /* Going optimization. */
-static FILE *ex9_export_file = NULL; /* --mexport-ex9=<file> */
-static FILE *ex9_import_file = NULL; /* --mimport-ex9=<file> */
-static int update_ex9_table = 0; /* --mupdate-ex9. */
-static int ex9_limit = 511;
-static bfd_boolean ex9_loop_aware = FALSE; /* Ignore ex9 if inside a loop. */
-static bfd_boolean ifc_loop_aware = FALSE; /* Ignore ifc if inside a loop. */
/* Save the target options into output bfd to avoid using to many global
variables. Do this after the output has been created, but before
@@ -56,42 +49,24 @@ nds32_elf_create_output_section_statements (void)
return;
}
- bfd_elf32_nds32_set_target_option (&link_info, relax_fp_as_gp,
+ bfd_elf32_nds32_set_target_option (&link_info,
+ relax_fp_as_gp,
eliminate_gc_relocs,
sym_ld_script,
- load_store_relax,
- target_optimize, relax_status, relax_round,
- ex9_export_file, ex9_import_file,
- update_ex9_table, ex9_limit,
- ex9_loop_aware, ifc_loop_aware);
+ hyper_relax,
+ tls_desc_trampoline,
+ load_store_relax);
}
static void
nds32_elf_after_parse (void)
{
- if (bfd_link_relocatable (&link_info))
+ if (bfd_link_relocatable (&link_info)
+ || bfd_link_pic (&link_info))
DISABLE_RELAXATION;
if (!RELAXATION_ENABLED)
- {
- target_optimize = target_optimize & (!NDS32_RELAX_JUMP_IFC_ON);
- target_optimize = target_optimize & (!NDS32_RELAX_EX9_ON);
- relax_fp_as_gp = 0;
- }
-
- if (ex9_import_file != NULL)
- {
- ex9_export_file = NULL;
- target_optimize = target_optimize & (!NDS32_RELAX_EX9_ON);
- }
- else
- update_ex9_table = 0;
-
- if (bfd_link_pic (&link_info))
- {
- target_optimize = target_optimize & (!NDS32_RELAX_JUMP_IFC_ON);
- target_optimize = target_optimize & (!NDS32_RELAX_EX9_ON);
- }
+ relax_fp_as_gp = 0;
gld${EMULATION_NAME}_after_parse ();
}
@@ -124,64 +99,19 @@ nds32_elf_after_open (void)
einfo (_("%F%P: %pB: ABI version of object files mismatched\n"),
abfd);
}
-
-#if defined NDS32_EX9_EXT
- /* Append .ex9.itable section in the last input object file. */
- if (abfd->link_next == NULL && (target_optimize & NDS32_RELAX_EX9_ON))
- {
- asection *itable;
- struct bfd_link_hash_entry *h;
- itable = bfd_make_section_with_flags (abfd, ".ex9.itable",
- SEC_CODE | SEC_ALLOC | SEC_LOAD
- | SEC_HAS_CONTENTS | SEC_READONLY
- | SEC_IN_MEMORY | SEC_KEEP);
- if (itable)
- {
- itable->gc_mark = 1;
- itable->alignment_power = 2;
- itable->size = 0x1000;
- itable->contents = bfd_zalloc (abfd, itable->size);
-
- /* Add a symbol in the head of ex9.itable to objdump clearly. */
- h = bfd_link_hash_lookup (link_info.hash, "_EX9_BASE_",
- FALSE, FALSE, FALSE);
- _bfd_generic_link_add_one_symbol
- (&link_info, link_info.output_bfd, "_EX9_BASE_",
- BSF_GLOBAL | BSF_WEAK, itable, 0, (const char *) NULL, FALSE,
- get_elf_backend_data (link_info.output_bfd)->collect, &h);
- }
- }
-#endif
}
/* Check object files if the target is dynamic linked executable
or shared object. */
if (elf_hash_table (&link_info)->dynamic_sections_created
- || bfd_link_pic (&link_info))
+ || bfd_link_pic (&link_info)
+ || bfd_link_pie (&link_info))
{
- for (abfd = link_info.input_bfds; abfd != NULL; abfd = abfd->link.next)
- {
- if (!(elf_elfheader (abfd)->e_flags & E_NDS32_HAS_PIC))
- {
- /* Non-PIC object file is used. */
- if (bfd_link_pic (&link_info))
- {
- /* For PIE or shared object, all input must be PIC. */
- einfo (_("%P: %pB: must use -fpic to compile this file "
- "for shared object or PIE\n"), abfd);
- }
- else
- {
- /* Dynamic linked executable with SDA and non-PIC.
- Turn off load/store relaxtion. */
- /* TODO: This may support in the future. */
- load_store_relax = 0 ;
- relax_fp_as_gp = 0;
- }
- }
- }
- /* Turn off relax when building shared object or PIE
- until we can support their relaxation. */
+ /* Dynamic linked executable with SDA and non-PIC.
+ Turn off load/store relaxtion. */
+ /* This may support in the future. */
+ load_store_relax = 0 ;
+ relax_fp_as_gp = 0;
}
/* Call the standard elf routine. */
@@ -210,31 +140,17 @@ PARSE_AND_LIST_PROLOGUE='
#define OPTION_REDUCE_FP_UPDATE (OPTION_BASELINE + 4)
#define OPTION_NO_REDUCE_FP_UPDATE (OPTION_BASELINE + 5)
#define OPTION_EXPORT_SYMBOLS (OPTION_BASELINE + 6)
-
-/* These are only available to ex9. */
-#if defined NDS32_EX9_EXT
-#define OPTION_EX9_BASELINE 320
-#define OPTION_EX9_TABLE (OPTION_EX9_BASELINE + 1)
-#define OPTION_NO_EX9_TABLE (OPTION_EX9_BASELINE + 2)
-#define OPTION_EXPORT_EX9 (OPTION_EX9_BASELINE + 3)
-#define OPTION_IMPORT_EX9 (OPTION_EX9_BASELINE + 4)
-#define OPTION_UPDATE_EX9 (OPTION_EX9_BASELINE + 5)
-#define OPTION_EX9_LIMIT (OPTION_EX9_BASELINE + 6)
-#define OPTION_EX9_LOOP (OPTION_EX9_BASELINE + 7)
-#endif
-
-/* These are only available to link-time ifc. */
-#if defined NDS32_IFC_EXT
-#define OPTION_IFC_BASELINE 340
-#define OPTION_JUMP_IFC (OPTION_IFC_BASELINE + 1)
-#define OPTION_NO_JUMP_IFC (OPTION_IFC_BASELINE + 2)
-#define OPTION_IFC_LOOP (OPTION_IFC_BASELINE + 3)
-#endif
+#define OPTION_HYPER_RELAX (OPTION_BASELINE + 7)
+#define OPTION_TLSDESC_TRAMPOLINE (OPTION_BASELINE + 8)
+#define OPTION_NO_TLSDESC_TRAMPOLINE (OPTION_BASELINE + 9)
'
PARSE_AND_LIST_LONGOPTS='
{ "mfp-as-gp", no_argument, NULL, OPTION_FP_AS_GP},
{ "mno-fp-as-gp", no_argument, NULL, OPTION_NO_FP_AS_GP},
{ "mexport-symbols", required_argument, NULL, OPTION_EXPORT_SYMBOLS},
+ { "mhyper-relax", required_argument, NULL, OPTION_HYPER_RELAX},
+ { "mtlsdesc-trampoline", no_argument, NULL, OPTION_TLSDESC_TRAMPOLINE},
+ { "mno-tlsdesc-trampoline", no_argument, NULL, OPTION_NO_TLSDESC_TRAMPOLINE},
/* These are deprecated options. Remove them in the future. */
{ "mrelax-reduce-fp-update", no_argument, NULL, OPTION_REDUCE_FP_UPDATE},
{ "mrelax-no-reduce-fp-update", no_argument, NULL, OPTION_NO_REDUCE_FP_UPDATE},
@@ -243,50 +159,16 @@ PARSE_AND_LIST_LONGOPTS='
{ "mrelax-omit-fp", no_argument, NULL, OPTION_FP_AS_GP},
{ "mrelax-no-omit-fp", no_argument, NULL, OPTION_NO_FP_AS_GP},
{ "mgen-symbol-ld-script", required_argument, NULL, OPTION_EXPORT_SYMBOLS},
- /* These are specific optioins for ex9-ext support. */
-#if defined NDS32_EX9_EXT
- { "mex9", no_argument, NULL, OPTION_EX9_TABLE},
- { "mno-ex9", no_argument, NULL, OPTION_NO_EX9_TABLE},
- { "mexport-ex9", required_argument, NULL, OPTION_EXPORT_EX9},
- { "mimport-ex9", required_argument, NULL, OPTION_IMPORT_EX9},
- { "mupdate-ex9", no_argument, NULL, OPTION_UPDATE_EX9},
- { "mex9-limit", required_argument, NULL, OPTION_EX9_LIMIT},
- { "mex9-loop-aware", no_argument, NULL, OPTION_EX9_LOOP},
-#endif
- /* These are specific optioins for ifc-ext support. */
-#if defined NDS32_IFC_EXT
- { "mifc", no_argument, NULL, OPTION_JUMP_IFC},
- { "mno-ifc", no_argument, NULL, OPTION_NO_JUMP_IFC},
- { "mifc-loop-aware", no_argument, NULL, OPTION_IFC_LOOP},
-#endif
'
PARSE_AND_LIST_OPTIONS='
fprintf (file, _("\
--m[no-]fp-as-gp Disable/enable fp-as-gp relaxation\n"));
fprintf (file, _("\
--mexport-symbols=FILE Exporting symbols in linker script\n"));
-
-#if defined NDS32_EX9_EXT
- fprintf (file, _("\
- --m[no-]ex9 Disable/enable link-time EX9 relaxation\n"));
fprintf (file, _("\
- --mexport-ex9=FILE Export EX9 table after linking\n"));
+ --mhyper-relax=level Adjust relax level (low|medium|high). default: medium\n"));
fprintf (file, _("\
- --mimport-ex9=FILE Import Ex9 table for EX9 relaxation\n"));
- fprintf (file, _("\
- --mupdate-ex9 Update existing EX9 table\n"));
- fprintf (file, _("\
- --mex9-limit=NUM Maximum number of entries in ex9 table\n"));
- fprintf (file, _("\
- --mex9-loop-aware Avoid generate EX9 instruction inside loop\n"));
-#endif
-
-#if defined NDS32_IFC_EXT
- fprintf (file, _("\
- --m[no-]ifc Disable/enable link-time IFC optimization\n"));
- fprintf (file, _("\
- --mifc-loop-aware Avoid generate IFC instruction inside loop\n"));
-#endif
+ --m[no-]tlsdesc-trampoline Disable/enable TLS DESC trampoline\n"));
'
PARSE_AND_LIST_ARGS_CASES='
case OPTION_BASELINE:
@@ -316,62 +198,26 @@ PARSE_AND_LIST_ARGS_CASES='
einfo (_("%F%P: cannot open map file %s: %E\n"), optarg);
}
break;
-#if defined NDS32_EX9_EXT
- case OPTION_EX9_TABLE:
- target_optimize = target_optimize | NDS32_RELAX_EX9_ON;
- break;
- case OPTION_NO_EX9_TABLE:
- target_optimize = target_optimize & (!NDS32_RELAX_EX9_ON);
- break;
- case OPTION_EXPORT_EX9:
+ case OPTION_HYPER_RELAX:
if (!optarg)
- einfo (_("%P: missing file for --mexport-ex9=<file>\n"));
-
- if(strcmp (optarg, "-") == 0)
- ex9_export_file = stdout;
+ einfo (_("%P: valid arguments to --mhyper-relax=(low|medium|high)\n"));
+
+ if (strcmp (optarg, "low") == 0)
+ hyper_relax = 0;
+ else if (strcmp (optarg, "medium") == 0)
+ hyper_relax = 1;
+ else if (strcmp (optarg, "high") == 0)
+ hyper_relax = 2;
else
- {
- ex9_export_file = fopen (optarg, "wb");
- if(ex9_export_file == NULL)
- einfo (_("%F%P: cannot open ex9 export file %s\n"), optarg);
- }
- break;
- case OPTION_IMPORT_EX9:
- if (!optarg)
- einfo (_("%P: missing file for --mimport-ex9=<file>\n"));
+ einfo (_("%P: valid arguments to --mhyper-relax=(low|medium|high)\n"));
- ex9_import_file = fopen (optarg, "rb+");
- if(ex9_import_file == NULL)
- einfo (_("%F%P: cannot open ex9 import file %s\n"), optarg);
- break;
- case OPTION_UPDATE_EX9:
- update_ex9_table = 1;
- break;
- case OPTION_EX9_LIMIT:
- if (optarg)
- {
- ex9_limit = atoi (optarg);
- if (ex9_limit > 511 || ex9_limit < 1)
- einfo (_("%F%P: the range of ex9_limit must between 1 and 511\n"));
- }
- break;
- case OPTION_EX9_LOOP:
- target_optimize = target_optimize | NDS32_RELAX_EX9_ON;
- ex9_loop_aware = 1;
- break;
-#endif
-#if defined NDS32_IFC_EXT
- case OPTION_JUMP_IFC:
- target_optimize = target_optimize | NDS32_RELAX_JUMP_IFC_ON;
- break;
- case OPTION_NO_JUMP_IFC:
- target_optimize = target_optimize & (!NDS32_RELAX_JUMP_IFC_ON);
break;
- case OPTION_IFC_LOOP:
- target_optimize = target_optimize | NDS32_RELAX_JUMP_IFC_ON;
- ifc_loop_aware = 1;
+ case OPTION_TLSDESC_TRAMPOLINE:
+ tls_desc_trampoline = 1;
break;
-#endif
+ case OPTION_NO_TLSDESC_TRAMPOLINE:
+ tls_desc_trampoline = 0;
+ break;
'
LDEMUL_AFTER_OPEN=nds32_elf_after_open
LDEMUL_AFTER_PARSE=nds32_elf_after_parse