8f595e9b4f
1. Remove the -mriscv-isa-version and --with-riscv-isa-version options. We can still use -march to choose the version for each extensions, so there is no need to add these. 2. Change the arguments of options from [1p9|1p9p1|...] to [1.9|1.9.1|...]. Unlike the architecture string has specified by spec, ther is no need to do the same thing for options. 3. Spilt the patches to reduce the burdens of review. [PATCH 3/7] RISC-V: Support new GAS options and configure options to set ISA versions to [PATCH v2 3/9] RISC-V: Support GAS option -misa-spec to set ISA versions [PATCH v2 4/9] RISC-V: Support configure options to set ISA versions by default. [PATCH 4/7] RISC-V: Support version checking for CSR according to privilege version. to [PATCH v2 5/9] RISC-V: Support version checking for CSR according to privilege spec version. [PATCH v2 6/9] RISC-V: Support configure option to choose the privilege spec version. 4. Use enum class rather than string to compare the choosen ISA spec in opcodes/riscv-opc.c. The behavior is same as comparing the choosen privilege spec. include * opcode/riscv.h: Include "bfd.h" to support bfd_boolean. (enum riscv_isa_spec_class): New enum class. All supported ISA spec belong to one of the class (struct riscv_ext_version): New structure holds version information for the specific ISA. * opcode/riscv-opc.h (DECLARE_CSR): There are two version information, define_version and abort_version. The define_version means which privilege spec is started to define the CSR, and the abort_version means which privilege spec is started to abort the CSR. If the CSR is valid for the newest spec, then the abort_version should be PRIV_SPEC_CLASS_DRAFT. (DECLARE_CSR_ALIAS): Same as DECLARE_CSR, but only for the obselete CSR. * opcode/riscv.h (enum riscv_priv_spec_class): New enum class. Define the current supported privilege spec versions. (struct riscv_csr_extra): Add new fields to store more information about the CSR. We use these information to find the suitable CSR address when user choosing a specific privilege spec. binutils * dwarf.c: Updated since DECLARE_CSR is changed. opcodes * riscv-opc.c (riscv_ext_version_table): The table used to store all information about the supported spec and the corresponding ISA versions. Currently, only Zicsr is supported to verify the correctness of Z sub extension settings. Others will be supported in the future patches. (struct isa_spec_t, isa_specs): List for all supported ISA spec classes and the corresponding strings. (riscv_get_isa_spec_class): New function. Get the corresponding ISA spec class by giving a ISA spec string. * riscv-opc.c (struct priv_spec_t): New structure. (struct priv_spec_t priv_specs): List for all supported privilege spec classes and the corresponding strings. (riscv_get_priv_spec_class): New function. Get the corresponding privilege spec class by giving a spec string. (riscv_get_priv_spec_name): New function. Get the corresponding privilege spec string by giving a CSR version class. * riscv-dis.c: Updated since DECLARE_CSR is changed. * riscv-dis.c: Add new disassembler option -Mpriv-spec to dump the CSR according to the chosen version. Build a hash table riscv_csr_hash to store the valid CSR for the chosen pirv verison. Dump the direct CSR address rather than it's name if it is invalid. (parse_riscv_dis_option_without_args): New function. Parse the options without arguments. (parse_riscv_dis_option): Call parse_riscv_dis_option_without_args to parse the options without arguments first, and then handle the options with arguments. Add the new option -Mpriv-spec, which has argument. * riscv-dis.c (print_riscv_disassembler_options): Add description about the new OBJDUMP option. ld * testsuite/ld-riscv-elf/attr-merge-arch-01.d: Updated priv attributes according to the -mpriv-spec option. * testsuite/ld-riscv-elf/attr-merge-arch-02.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-arch-03.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-priv-spec-a.s: Likewise. * testsuite/ld-riscv-elf/attr-merge-priv-spec-b.s: Likewise. * testsuite/ld-riscv-elf/attr-merge-priv-spec.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-stack-align.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-strict-align-01.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-strict-align-02.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-strict-align-03.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-strict-align-04.d: Likewise. * testsuite/ld-riscv-elf/attr-merge-strict-align-05.d: Likewise. bfd * elfxx-riscv.h (riscv_parse_subset_t): Add new callback function get_default_version. It is used to find the default version for the specific extension. * elfxx-riscv.c (riscv_parsing_subset_version): Remove the parameters default_major_version and default_minor_version. Add new bfd_boolean parameter *use_default_version. Set it to TRUE if we need to call the callback rps->get_default_version to find the default version. (riscv_parse_std_ext): Call rps->get_default_version if we fail to find the default version in riscv_parsing_subset_version, and then call riscv_add_subset to add the subset into subset list. (riscv_parse_prefixed_ext): Likewise. (riscv_std_z_ext_strtab): Support Zicsr extensions. * elfnn-riscv.c (riscv_merge_std_ext): Use strcasecmp to compare the strings rather than characters. riscv_merge_arch_attr_info): The callback function get_default_version is only needed for assembler, so set it to NULL int the linker. * elfxx-riscv.c (riscv_estimate_digit): Remove the static. * elfxx-riscv.h: Updated. gas * testsuite/gas/riscv/priv-reg-fail-read-only-01.s: Updated. * config/tc-riscv.c (default_arch_with_ext, default_isa_spec): Static variables which are used to set the ISA extensions. You can use -march (or ELF build attributes) and -misa-spec to set them, respectively. (ext_version_hash): The hash table used to handle the extensions with versions. (init_ext_version_hash): Initialize the ext_version_hash according to riscv_ext_version_table. (riscv_get_default_ext_version): The callback function of riscv_parse_subset_t. According to the choosed ISA spec, get the default version for the specific extension. (riscv_set_arch): Set the callback function. (enum options, struct option md_longopts): Add new option -misa-spec. (md_parse_option): Do not call riscv_set_arch for -march. We will call it later in riscv_after_parse_args. Call riscv_get_isa_spec_class to set default_isa_spec class. (riscv_after_parse_args): Call init_ext_version_hash to initialize the ext_version_hash, and then call riscv_set_arch to set the architecture with versions according to default_arch_with_ext. * testsuite/gas/riscv/attribute-02.d: Set 0p0 as default version for x extensions. * testsuite/gas/riscv/attribute-03.d: Likewise. * testsuite/gas/riscv/attribute-09.d: New testcase. For i-ext, we already set it's version to 2p1 by march, so no need to use the default 2p2 version. For m-ext, we do not set the version by -march and ELF arch attribute, so set the default 2p0 to it. For zicsr, it is not defined in ISA spec 2p2, so set 0p0 to it. * testsuite/gas/riscv/attribute-10.d: New testcase. The version of zicsr is 2p0 according to ISA spec 20191213. * config/tc-riscv.c (DEFAULT_RISCV_ARCH_WITH_EXT) (DEFAULT_RISCV_ISA_SPEC): Default configure option settings. You can set them by configure options --with-arch and --with-isa-spec, respectively. (riscv_set_default_isa_spec): New function used to set the default ISA spec. (md_parse_option): Call riscv_set_default_isa_spec rather than call riscv_get_isa_spec_class directly. (riscv_after_parse_args): If the -isa-spec is not set, then we set the default ISA spec according to DEFAULT_RISCV_ISA_SPEC by calling riscv_set_default_isa_spec. * testsuite/gas/riscv/attribute-01.d: Add -misa-spec=2.2, since the --with-isa-spec may be set to different ISA spec. * testsuite/gas/riscv/attribute-02.d: Likewise. * testsuite/gas/riscv/attribute-03.d: Likewise. * testsuite/gas/riscv/attribute-04.d: Likewise. * testsuite/gas/riscv/attribute-05.d: Likewise. * testsuite/gas/riscv/attribute-06.d: Likewise. * testsuite/gas/riscv/attribute-07.d: Likewise. * configure.ac: Add configure options, --with-arch and --with-isa-spec. * configure: Regenerated. * config.in: Regenerated. * config/tc-riscv.c (default_priv_spec): Static variable which is used to check if the CSR is valid for the chosen privilege spec. You can use -mpriv-spec to set it. (enum reg_class): We now get the CSR address from csr_extra_hash rather than reg_names_hash. Therefore, move RCLASS_CSR behind RCLASS_MAX. (riscv_init_csr_hashes): Only need to initialize one hash table csr_extra_hash. (riscv_csr_class_check): Change the return type to void. Don't check the ISA dependency if -mcsr-check isn't set. (riscv_csr_version_check): New function. Check and find the CSR address from csr_extra_hash, according to default_priv_spec. Report warning for the invalid CSR if -mcsr-check is set. (reg_csr_lookup_internal): Updated. (reg_lookup_internal): Likewise. (md_begin): Updated since DECLARE_CSR and DECLARE_CSR_ALIAS are changed. (enum options, struct option md_longopts): Add new GAS option -mpriv-spec. (md_parse_option): Call riscv_set_default_priv_version to set default_priv_spec. (riscv_after_parse_args): If -mpriv-spec isn't set, then set the default privilege spec to the newest one. (enum riscv_csr_class, struct riscv_csr_extra): Move them to include/opcode/riscv.h. * testsuite/gas/riscv/priv-reg-fail-fext.d: This test case just want to check the ISA dependency for CSR, so fix the spec version by adding -mpriv-spec=1.11. * testsuite/gas/riscv/priv-reg-fail-fext.l: Likewise. There are some version warnings for the test case. * gas/testsuite/gas/riscv/priv-reg-fail-read-only-01.d: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-read-only-01.l: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-read-only-02.d: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-rv32-only.d: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-rv32-only.l: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p9.d: New test case. Check whether the CSR is valid when privilege version 1.9 is choosed. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p9.l: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p9p1.d: New test case. Check whether the CSR is valid when privilege version 1.9.1 is choosed. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p9p1.l: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p10.d: New test case. Check whether the CSR is valid when privilege version 1.10 is choosed. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p10.l: Likewise. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p11.d: New test case. Check whether the CSR is valid when privilege version 1.11 is choosed. * gas/testsuite/gas/riscv/priv-reg-fail-version-1p11.l: Likewise. * config/tc-riscv.c (DEFAULT_RISCV_ISA_SPEC): Default configure option setting. You can set it by configure option --with-priv-spec. (riscv_set_default_priv_spec): New function used to set the default privilege spec. (md_parse_option): Call riscv_set_default_priv_spec rather than call riscv_get_priv_spec_class directly. (riscv_after_parse_args): If -mpriv-spec isn't set, then we set the default privilege spec according to DEFAULT_RISCV_PRIV_SPEC by calling riscv_set_default_priv_spec. * testsuite/gas/riscv/csr-dw-regnums.d: Add -mpriv-spec=1.11, since the --with-priv-spec may be set to different privilege spec. * testsuite/gas/riscv/priv-reg.d: Likewise. * configure.ac: Add configure option --with-priv-spec. * configure: Regenerated. * config.in: Regenerated. * config/tc-riscv.c (explicit_attr): Rename explicit_arch_attr to explicit_attr. Set it to TRUE if any ELF attribute is found. (riscv_set_default_priv_spec): Try to set the default_priv_spec if the priv attributes are set. (md_assemble): Set the default_priv_spec according to the priv attributes when we start to assemble instruction. (riscv_write_out_attrs): Rename riscv_write_out_arch_attr to riscv_write_out_attrs. Update the arch and priv attributes. If we don't set the corresponding ELF attributes, then try to output the default ones. (riscv_set_public_attributes): If any ELF attribute or -march-attr options is set (explicit_attr is TRUE), then call riscv_write_out_attrs to update the arch and priv attributes. (s_riscv_attribute): Make sure all arch and priv attributes are set before any instruction. * testsuite/gas/riscv/attribute-01.d: Update the priv attributes if any ELF attribute or -march-attr is set. If the priv attributes are not set, then try to update them by the default setting (-mpriv-spec or --with-priv-spec). * testsuite/gas/riscv/attribute-02.d: Likewise. * testsuite/gas/riscv/attribute-03.d: Likewise. * testsuite/gas/riscv/attribute-04.d: Likewise. * testsuite/gas/riscv/attribute-06.d: Likewise. * testsuite/gas/riscv/attribute-07.d: Likewise. * testsuite/gas/riscv/attribute-08.d: Likewise. * testsuite/gas/riscv/attribute-09.d: Likewise. * testsuite/gas/riscv/attribute-10.d: Likewise. * testsuite/gas/riscv/attribute-unknown.d: Likewise. * testsuite/gas/riscv/attribute-05.d: Likewise. Also, the priv spec set by priv attributes must be supported. * testsuite/gas/riscv/attribute-05.s: Likewise. * testsuite/gas/riscv/priv-reg-fail-version-1p9.d: Likewise. Updated priv attributes according to the -mpriv-spec option. * testsuite/gas/riscv/priv-reg-fail-version-1p9p1.d: Likewise. * testsuite/gas/riscv/priv-reg-fail-version-1p10.d: Likewise. * testsuite/gas/riscv/priv-reg-fail-version-1p11.d: Likewise. * testsuite/gas/riscv/priv-reg.d: Removed. * testsuite/gas/riscv/priv-reg-version-1p9.d: New test case. Dump the CSR according to the priv spec 1.9. * testsuite/gas/riscv/priv-reg-version-1p9p1.d: New test case. Dump the CSR according to the priv spec 1.9.1. * testsuite/gas/riscv/priv-reg-version-1p10.d: New test case. Dump the CSR according to the priv spec 1.10. * testsuite/gas/riscv/priv-reg-version-1p11.d: New test case. Dump the CSR according to the priv spec 1.11. * config/tc-riscv.c (md_show_usage): Add descriptions about the new GAS options. * doc/c-riscv.texi: Likewise. |
||
---|---|---|
.. | ||
doc | ||
hosts | ||
po | ||
.gitignore | ||
acinclude.m4 | ||
aclocal.m4 | ||
aix5ppc-core.c | ||
aix386-core.c | ||
aout32.c | ||
aout64.c | ||
aout-cris.c | ||
aout-ns32k.c | ||
aout-target.h | ||
aout-tic30.c | ||
aoutx.h | ||
arc-got.h | ||
arc-plt.def | ||
arc-plt.h | ||
archive64.c | ||
archive.c | ||
archures.c | ||
bfd-in2.h | ||
bfd-in.h | ||
bfd.c | ||
bfd.m4 | ||
bfdio.c | ||
bfdwin.c | ||
binary.c | ||
cache.c | ||
cf-i386lynx.c | ||
ChangeLog | ||
ChangeLog-0001 | ||
ChangeLog-0203 | ||
ChangeLog-2004 | ||
ChangeLog-2005 | ||
ChangeLog-2006 | ||
ChangeLog-2007 | ||
ChangeLog-2008 | ||
ChangeLog-2009 | ||
ChangeLog-2010 | ||
ChangeLog-2011 | ||
ChangeLog-2012 | ||
ChangeLog-2013 | ||
ChangeLog-2014 | ||
ChangeLog-2015 | ||
ChangeLog-2016 | ||
ChangeLog-2017 | ||
ChangeLog-2018 | ||
ChangeLog-2019 | ||
ChangeLog-9193 | ||
ChangeLog-9495 | ||
ChangeLog-9697 | ||
ChangeLog-9899 | ||
cisco-core.c | ||
coff64-rs6000.c | ||
coff-alpha.c | ||
coff-arm.c | ||
coff-arm.h | ||
coff-bfd.c | ||
coff-bfd.h | ||
coff-go32.c | ||
coff-i386.c | ||
coff-ia64.c | ||
coff-mcore.c | ||
coff-mips.c | ||
coff-ppc.c | ||
coff-rs6000.c | ||
coff-sh.c | ||
coff-stgo32.c | ||
coff-tic4x.c | ||
coff-tic30.c | ||
coff-tic54x.c | ||
coff-x86_64.c | ||
coff-z8k.c | ||
coff-z80.c | ||
coffcode.h | ||
coffgen.c | ||
cofflink.c | ||
coffswap.h | ||
compress.c | ||
config.bfd | ||
config.in | ||
configure | ||
configure.ac | ||
configure.com | ||
configure.host | ||
COPYING | ||
corefile.c | ||
cpu-aarch64.c | ||
cpu-aarch64.h | ||
cpu-alpha.c | ||
cpu-arc.c | ||
cpu-arm.c | ||
cpu-arm.h | ||
cpu-avr.c | ||
cpu-bfin.c | ||
cpu-bpf.c | ||
cpu-cr16.c | ||
cpu-cris.c | ||
cpu-crx.c | ||
cpu-csky.c | ||
cpu-d10v.c | ||
cpu-d30v.c | ||
cpu-dlx.c | ||
cpu-epiphany.c | ||
cpu-fr30.c | ||
cpu-frv.c | ||
cpu-ft32.c | ||
cpu-h8300.c | ||
cpu-h8300.h | ||
cpu-hppa.c | ||
cpu-i386.c | ||
cpu-ia64-opc.c | ||
cpu-ia64.c | ||
cpu-iamcu.c | ||
cpu-ip2k.c | ||
cpu-iq2000.c | ||
cpu-k1om.c | ||
cpu-l1om.c | ||
cpu-lm32.c | ||
cpu-m9s12x.c | ||
cpu-m9s12xg.c | ||
cpu-m32c.c | ||
cpu-m32r.c | ||
cpu-m68hc11.c | ||
cpu-m68hc12.c | ||
cpu-m68k.c | ||
cpu-m68k.h | ||
cpu-m10200.c | ||
cpu-m10300.c | ||
cpu-mcore.c | ||
cpu-mep.c | ||
cpu-metag.c | ||
cpu-microblaze.c | ||
cpu-mips.c | ||
cpu-mmix.c | ||
cpu-moxie.c | ||
cpu-msp430.c | ||
cpu-mt.c | ||
cpu-nds32.c | ||
cpu-nfp.c | ||
cpu-nios2.c | ||
cpu-ns32k.c | ||
cpu-or1k.c | ||
cpu-pdp11.c | ||
cpu-pj.c | ||
cpu-powerpc.c | ||
cpu-pru.c | ||
cpu-riscv.c | ||
cpu-rl78.c | ||
cpu-rs6000.c | ||
cpu-rx.c | ||
cpu-s12z.c | ||
cpu-s390.c | ||
cpu-score.c | ||
cpu-sh.c | ||
cpu-sparc.c | ||
cpu-spu.c | ||
cpu-tic4x.c | ||
cpu-tic6x.c | ||
cpu-tic30.c | ||
cpu-tic54x.c | ||
cpu-tilegx.c | ||
cpu-tilepro.c | ||
cpu-v850_rh850.c | ||
cpu-v850.c | ||
cpu-vax.c | ||
cpu-visium.c | ||
cpu-wasm32.c | ||
cpu-xc16x.c | ||
cpu-xgate.c | ||
cpu-xstormy16.c | ||
cpu-xtensa.c | ||
cpu-z8k.c | ||
cpu-z80.c | ||
dep-in.sed | ||
development.sh | ||
dwarf1.c | ||
dwarf2.c | ||
ecoff-bfd.h | ||
ecoff.c | ||
ecofflink.c | ||
ecoffswap.h | ||
elf32-am33lin.c | ||
elf32-arc.c | ||
elf32-arm.c | ||
elf32-arm.h | ||
elf32-avr.c | ||
elf32-avr.h | ||
elf32-bfin.c | ||
elf32-bfin.h | ||
elf32-cr16.c | ||
elf32-cr16.h | ||
elf32-cris.c | ||
elf32-crx.c | ||
elf32-csky.c | ||
elf32-csky.h | ||
elf32-d10v.c | ||
elf32-d30v.c | ||
elf32-dlx.c | ||
elf32-dlx.h | ||
elf32-epiphany.c | ||
elf32-fr30.c | ||
elf32-frv.c | ||
elf32-ft32.c | ||
elf32-gen.c | ||
elf32-h8300.c | ||
elf32-hppa.c | ||
elf32-hppa.h | ||
elf32-i386.c | ||
elf32-ip2k.c | ||
elf32-iq2000.c | ||
elf32-lm32.c | ||
elf32-m32c.c | ||
elf32-m32r.c | ||
elf32-m68hc1x.c | ||
elf32-m68hc1x.h | ||
elf32-m68hc11.c | ||
elf32-m68hc12.c | ||
elf32-m68k.c | ||
elf32-m68k.h | ||
elf32-mcore.c | ||
elf32-mep.c | ||
elf32-metag.c | ||
elf32-metag.h | ||
elf32-microblaze.c | ||
elf32-mips.c | ||
elf32-moxie.c | ||
elf32-msp430.c | ||
elf32-mt.c | ||
elf32-nds32.c | ||
elf32-nds32.h | ||
elf32-nios2.c | ||
elf32-nios2.h | ||
elf32-or1k.c | ||
elf32-pj.c | ||
elf32-ppc.c | ||
elf32-ppc.h | ||
elf32-pru.c | ||
elf32-rl78.c | ||
elf32-rx.c | ||
elf32-rx.h | ||
elf32-s12z.c | ||
elf32-s390.c | ||
elf32-score7.c | ||
elf32-score.c | ||
elf32-score.h | ||
elf32-sh-relocs.h | ||
elf32-sh.c | ||
elf32-sparc.c | ||
elf32-spu.c | ||
elf32-spu.h | ||
elf32-tic6x.c | ||
elf32-tic6x.h | ||
elf32-tilegx.c | ||
elf32-tilegx.h | ||
elf32-tilepro.c | ||
elf32-tilepro.h | ||
elf32-v850.c | ||
elf32-v850.h | ||
elf32-vax.c | ||
elf32-visium.c | ||
elf32-wasm32.c | ||
elf32-xc16x.c | ||
elf32-xgate.c | ||
elf32-xstormy16.c | ||
elf32-xtensa.c | ||
elf32-z80.c | ||
elf32.c | ||
elf64-alpha.c | ||
elf64-bpf.c | ||
elf64-gen.c | ||
elf64-hppa.c | ||
elf64-hppa.h | ||
elf64-ia64-vms.c | ||
elf64-mips.c | ||
elf64-mmix.c | ||
elf64-nfp.c | ||
elf64-ppc.c | ||
elf64-ppc.h | ||
elf64-s390.c | ||
elf64-sparc.c | ||
elf64-tilegx.c | ||
elf64-tilegx.h | ||
elf64-x86-64.c | ||
elf64.c | ||
elf-attrs.c | ||
elf-bfd.h | ||
elf-eh-frame.c | ||
elf-hppa.h | ||
elf-ifunc.c | ||
elf-linker-x86.h | ||
elf-linux-core.h | ||
elf-m10200.c | ||
elf-m10300.c | ||
elf-nacl.c | ||
elf-nacl.h | ||
elf-properties.c | ||
elf-s390-common.c | ||
elf-s390.h | ||
elf-strtab.c | ||
elf-vxworks.c | ||
elf-vxworks.h | ||
elf.c | ||
elfcode.h | ||
elfcore.h | ||
elflink.c | ||
elfn32-mips.c | ||
elfnn-aarch64.c | ||
elfnn-ia64.c | ||
elfnn-riscv.c | ||
elfxx-aarch64.c | ||
elfxx-aarch64.h | ||
elfxx-ia64.c | ||
elfxx-ia64.h | ||
elfxx-mips.c | ||
elfxx-mips.h | ||
elfxx-riscv.c | ||
elfxx-riscv.h | ||
elfxx-sparc.c | ||
elfxx-sparc.h | ||
elfxx-target.h | ||
elfxx-tilegx.c | ||
elfxx-tilegx.h | ||
elfxx-x86.c | ||
elfxx-x86.h | ||
format.c | ||
gen-aout.c | ||
genlink.h | ||
go32stub.h | ||
hash.c | ||
host-aout.c | ||
hppabsd-core.c | ||
hpux-core.c | ||
i386aout.c | ||
i386bsd.c | ||
i386lynx.c | ||
i386msdos.c | ||
ihex.c | ||
init.c | ||
irix-core.c | ||
libaout.h | ||
libbfd-in.h | ||
libbfd.c | ||
libbfd.h | ||
libcoff-in.h | ||
libcoff.h | ||
libecoff.h | ||
libhppa.h | ||
libpei.h | ||
libxcoff.h | ||
linker.c | ||
lynx-core.c | ||
mach-o-aarch64.c | ||
mach-o-arm.c | ||
mach-o-i386.c | ||
mach-o-target.c | ||
mach-o-x86-64.c | ||
mach-o.c | ||
mach-o.h | ||
MAINTAINERS | ||
Makefile.am | ||
Makefile.in | ||
makefile.vms | ||
mep-relocs.pl | ||
merge.c | ||
mmo.c | ||
netbsd-core.c | ||
netbsd.h | ||
ns32k.h | ||
ns32knetbsd.c | ||
opncls.c | ||
osf-core.c | ||
pc532-mach.c | ||
pdp11.c | ||
pe-arm-wince.c | ||
pe-arm.c | ||
pe-i386.c | ||
pe-mcore.c | ||
pe-ppc.c | ||
pe-sh.c | ||
pe-x86_64.c | ||
pef-traceback.h | ||
pef.c | ||
pef.h | ||
pei-arm-wince.c | ||
pei-arm.c | ||
pei-i386.c | ||
pei-ia64.c | ||
pei-mcore.c | ||
pei-ppc.c | ||
pei-sh.c | ||
pei-x86_64.c | ||
peicode.h | ||
peXXigen.c | ||
plugin.c | ||
plugin.h | ||
PORTING | ||
ppcboot.c | ||
ptrace-core.c | ||
README | ||
reloc16.c | ||
reloc.c | ||
rs6000-core.c | ||
sco5-core.c | ||
section.c | ||
simple.c | ||
som.c | ||
som.h | ||
srec.c | ||
stab-syms.c | ||
stabs.c | ||
stamp-h.in | ||
syms.c | ||
sysdep.h | ||
targets.c | ||
targmatch.sed | ||
tekhex.c | ||
TODO | ||
trad-core.c | ||
vax1knetbsd.c | ||
vaxnetbsd.c | ||
verilog.c | ||
version.h | ||
version.m4 | ||
vms-alpha.c | ||
vms-lib.c | ||
vms-misc.c | ||
vms.h | ||
warning.m4 | ||
wasm-module.c | ||
wasm-module.h | ||
xcofflink.c | ||
xcofflink.h | ||
xsym.c | ||
xsym.h | ||
xtensa-isa.c | ||
xtensa-modules.c |
BFD is an object file library. It permits applications to use the
same routines to process object files regardless of their format.
BFD is used by the GNU debugger, assembler, linker, and the binary
utilities.
The documentation on using BFD is scanty and may be occasionally
incorrect. Pointers to documentation problems, or an entirely
rewritten manual, would be appreciated.
There is some BFD internals documentation in doc/bfdint.texi which may
help programmers who want to modify BFD.
BFD is normally built as part of another package. See the build
instructions for that package, probably in a README file in the
appropriate directory.
BFD supports the following configure options:
--target=TARGET
The default target for which to build the library. TARGET is
a configuration target triplet, such as sparc-sun-solaris.
--enable-targets=TARGET,TARGET,TARGET...
Additional targets the library should support. To include
support for all known targets, use --enable-targets=all.
--enable-64-bit-bfd
Include support for 64 bit targets. This is automatically
turned on if you explicitly request a 64 bit target, but not
for --enable-targets=all. This requires a compiler with a 64
bit integer type, such as gcc.
--enable-shared
Build BFD as a shared library.
--with-mmap
Use mmap when accessing files. This is faster on some hosts,
but slower on others. It may not work on all hosts.
Report bugs with BFD to bug-binutils@gnu.org.
Patches are encouraged. When sending patches, always send the output
of diff -u or diff -c from the original file to the new file. Do not
send default diff output. Do not make the diff from the new file to
the original file. Remember that any patch must not break other
systems. Remember that BFD must support cross compilation from any
host to any target, so patches which use ``#ifdef HOST'' are not
acceptable. Please also read the ``Reporting Bugs'' section of the
gcc manual.
Bug reports without patches will be remembered, but they may never get
fixed until somebody volunteers to fix them.
Copyright (C) 2012-2020 Free Software Foundation, Inc.
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
notice and this notice are preserved.