mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-03-01 13:26:47 +08:00
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.
639 lines
21 KiB
Plaintext
639 lines
21 KiB
Plaintext
@c Copyright (C) 2016-2020 Free Software Foundation, Inc.
|
||
@c This is part of the GAS anual.
|
||
@c For copying conditions, see the file as.texinfo
|
||
@c man end
|
||
|
||
@ifset GENERIC
|
||
@page
|
||
@node RISC-V-Dependent
|
||
@chapter RISC-V Dependent Features
|
||
@end ifset
|
||
@ifclear GENERIC
|
||
@node Machine Dependencies
|
||
@chapter RISC-V Dependent Features
|
||
@end ifclear
|
||
|
||
@cindex RISC-V support
|
||
@menu
|
||
* RISC-V-Options:: RISC-V Options
|
||
* RISC-V-Directives:: RISC-V Directives
|
||
* RISC-V-Modifiers:: RISC-V Assembler Modifiers
|
||
* RISC-V-Formats:: RISC-V Instruction Formats
|
||
* RISC-V-ATTRIBUTE:: RISC-V Object Attribute
|
||
@end menu
|
||
|
||
@node RISC-V-Options
|
||
@section RISC-V Options
|
||
|
||
The following table lists all available RISC-V specific options.
|
||
|
||
@c man begin OPTIONS
|
||
@table @gcctabopt
|
||
|
||
@cindex @samp{-fpic} option, RISC-V
|
||
@item -fpic
|
||
@itemx -fPIC
|
||
Generate position-independent code
|
||
|
||
@cindex @samp{-fno-pic} option, RISC-V
|
||
@item -fno-pic
|
||
Don't generate position-independent code (default)
|
||
|
||
@cindex @samp{-march=ISA} option, RISC-V
|
||
@item -march=ISA
|
||
Select the base isa, as specified by ISA. For example -march=rv32ima.
|
||
If this option and the architecture attributes aren’t set, then assembler
|
||
will check the default configure setting --with-arch=ISA.
|
||
|
||
@cindex @samp{-misa-spec=ISAspec} option, RISC-V
|
||
@item -misa-spec=ISAspec
|
||
Select the default isa spec version. If the version of ISA isn't set
|
||
by -march, then assembler helps to set the version according to
|
||
the default chosen spec. If this option isn't set, then assembler will
|
||
check the default configure setting --with-isa-spec=ISAspec.
|
||
|
||
@cindex @samp{-mpriv-spec=PRIVspec} option, RISC-V
|
||
@item -mpriv-spec=PRIVspec
|
||
Select the privileged spec version. We can decide whether the CSR is valid or
|
||
not according to the chosen spec. If this option and the privilege attributes
|
||
aren't set, then assembler will check the default configure setting
|
||
--with-priv-spec=PRIVspec.
|
||
|
||
@cindex @samp{-mabi=ABI} option, RISC-V
|
||
@item -mabi=ABI
|
||
Selects the ABI, which is either "ilp32" or "lp64", optionally followed
|
||
by "f", "d", or "q" to indicate single-precision, double-precision, or
|
||
quad-precision floating-point calling convention, or none to indicate
|
||
the soft-float calling convention. Also, "ilp32" can optionally be followed
|
||
by "e" to indicate the RVE ABI, which is always soft-float.
|
||
|
||
@cindex @samp{-mrelax} option, RISC-V
|
||
@item -mrelax
|
||
Take advantage of linker relaxations to reduce the number of instructions
|
||
required to materialize symbol addresses. (default)
|
||
|
||
@cindex @samp{-mno-relax} option, RISC-V
|
||
@item -mno-relax
|
||
Don't do linker relaxations.
|
||
|
||
@cindex @samp{-march-attr} option, RISC-V
|
||
@item -march-attr
|
||
Generate the default contents for the riscv elf attribute section if the
|
||
.attribute directives are not set. This section is used to record the
|
||
information that a linker or runtime loader needs to check compatibility.
|
||
This information includes ISA string, stack alignment requirement, unaligned
|
||
memory accesses, and the major, minor and revision version of privileged
|
||
specification.
|
||
|
||
@cindex @samp{-mno-arch-attr} option, RISC-V
|
||
@item -mno-arch-attr
|
||
Don't generate the default riscv elf attribute section if the .attribute
|
||
directives are not set.
|
||
|
||
@cindex @samp{-mcsr-check} option, RISC-V
|
||
@item -mcsr-check
|
||
Enable the CSR checking for the ISA-dependent CRS and the read-only CSR.
|
||
The ISA-dependent CSR are only valid when the specific ISA is set. The
|
||
read-only CSR can not be written by the CSR instructions.
|
||
|
||
@cindex @samp{-mno-csr-check} option, RISC-V
|
||
@item -mno-csr-check
|
||
Don't do CSR cheching.
|
||
@end table
|
||
@c man end
|
||
|
||
@node RISC-V-Directives
|
||
@section RISC-V Directives
|
||
@cindex machine directives, RISC-V
|
||
@cindex RISC-V machine directives
|
||
|
||
The following table lists all available RISC-V specific directives.
|
||
|
||
@table @code
|
||
|
||
@cindex @code{align} directive
|
||
@item .align @var{size-log-2}
|
||
Align to the given boundary, with the size given as log2 the number of bytes to
|
||
align to.
|
||
|
||
@cindex Data directives
|
||
@item .half @var{value}
|
||
@itemx .word @var{value}
|
||
@itemx .dword @var{value}
|
||
Emits a half-word, word, or double-word value at the current position.
|
||
|
||
@cindex DTP-relative data directives
|
||
@item .dtprelword @var{value}
|
||
@itemx .dtpreldword @var{value}
|
||
Emits a DTP-relative word (or double-word) at the current position. This is
|
||
meant to be used by the compiler in shared libraries for DWARF debug info for
|
||
thread local variables.
|
||
|
||
@cindex BSS directive
|
||
@item .bss
|
||
Sets the current section to the BSS section.
|
||
|
||
@cindex LEB128 directives
|
||
@item .uleb128 @var{value}
|
||
@itemx .sleb128 @var{value}
|
||
Emits a signed or unsigned LEB128 value at the current position. This only
|
||
accepts constant expressions, because symbol addresses can change with
|
||
relaxation, and we don't support relocations to modify LEB128 values at link
|
||
time.
|
||
|
||
@cindex Option directive
|
||
@cindex @code{option} directive
|
||
@item .option @var{argument}
|
||
Modifies RISC-V specific assembler options inline with the assembly code.
|
||
This is used when particular instruction sequences must be assembled with a
|
||
specific set of options. For example, since we relax addressing sequences to
|
||
shorter GP-relative sequences when possible the initial load of GP must not be
|
||
relaxed and should be emitted as something like
|
||
|
||
@smallexample
|
||
.option push
|
||
.option norelax
|
||
la gp, __global_pointer$
|
||
.option pop
|
||
@end smallexample
|
||
|
||
in order to produce after linker relaxation the expected
|
||
|
||
@smallexample
|
||
auipc gp, %pcrel_hi(__global_pointer$)
|
||
addi gp, gp, %pcrel_lo(__global_pointer$)
|
||
@end smallexample
|
||
|
||
instead of just
|
||
|
||
@smallexample
|
||
addi gp, gp, 0
|
||
@end smallexample
|
||
|
||
It's not expected that options are changed in this manner during regular use,
|
||
but there are a handful of esoteric cases like the one above where users need
|
||
to disable particular features of the assembler for particular code sequences.
|
||
The complete list of option arguments is shown below:
|
||
|
||
@table @code
|
||
@item push
|
||
@itemx pop
|
||
Pushes or pops the current option stack. These should be used whenever
|
||
changing an option in line with assembly code in order to ensure the user's
|
||
command-line options are respected for the bulk of the file being assembled.
|
||
|
||
@item rvc
|
||
@itemx norvc
|
||
Enables or disables the generation of compressed instructions. Instructions
|
||
are opportunistically compressed by the RISC-V assembler when possible, but
|
||
sometimes this behavior is not desirable.
|
||
|
||
@item pic
|
||
@itemx nopic
|
||
Enables or disables position-independent code generation. Unless you really
|
||
know what you're doing, this should only be at the top of a file.
|
||
|
||
@item relax
|
||
@itemx norelax
|
||
Enables or disables relaxation. The RISC-V assembler and linker
|
||
opportunistically relax some code sequences, but sometimes this behavior is not
|
||
desirable.
|
||
@end table
|
||
|
||
@item csr-check
|
||
@itemx no-csr-check
|
||
Enables or disables the CSR checking.
|
||
|
||
@cindex INSN directives
|
||
@item .insn @var{value}
|
||
@itemx .insn @var{value}
|
||
This directive permits the numeric representation of an instructions
|
||
and makes the assembler insert the operands according to one of the
|
||
instruction formats for @samp{.insn} (@ref{RISC-V-Formats}).
|
||
For example, the instruction @samp{add a0, a1, a2} could be written as
|
||
@samp{.insn r 0x33, 0, 0, a0, a1, a2}.
|
||
|
||
@cindex @code{.attribute} directive, RISC-V
|
||
@item .attribute @var{tag}, @var{value}
|
||
Set the object attribute @var{tag} to @var{value}.
|
||
|
||
The @var{tag} is either an attribute number, or one of the following:
|
||
@code{Tag_RISCV_arch}, @code{Tag_RISCV_stack_align},
|
||
@code{Tag_RISCV_unaligned_access}, @code{Tag_RISCV_priv_spec},
|
||
@code{Tag_RISCV_priv_spec_minor}, @code{Tag_RISCV_priv_spec_revision}.
|
||
|
||
@end table
|
||
|
||
@node RISC-V-Modifiers
|
||
@section RISC-V Assembler Modifiers
|
||
|
||
The RISC-V assembler supports following modifiers for relocatable addresses
|
||
used in RISC-V instruction operands. However, we also support some pseudo
|
||
instructions that are easier to use than these modifiers.
|
||
|
||
@table @code
|
||
@item %lo(@var{symbol})
|
||
The low 12 bits of absolute address for @var{symbol}.
|
||
|
||
@item %hi(@var{symbol})
|
||
The high 20 bits of absolute address for @var{symbol}. This is usually
|
||
used with the %lo modifier to represent a 32-bit absolute address.
|
||
|
||
@smallexample
|
||
lui a0, %hi(@var{symbol}) // R_RISCV_HI20
|
||
addi a0, a0, %lo(@var{symbol}) // R_RISCV_LO12_I
|
||
|
||
lui a0, %hi(@var{symbol}) // R_RISCV_HI20
|
||
load/store a0, %lo(@var{symbol})(a0) // R_RISCV_LO12_I/S
|
||
@end smallexample
|
||
|
||
@item %pcrel_lo(@var{label})
|
||
The low 12 bits of relative address between pc and @var{symbol}.
|
||
The @var{symbol} is related to the high part instruction which is marked
|
||
by @var{label}.
|
||
|
||
@item %pcrel_hi(@var{symbol})
|
||
The high 20 bits of relative address between pc and @var{symbol}.
|
||
This is usually used with the %pcrel_lo modifier to represent a +/-2GB
|
||
pc-relative range.
|
||
|
||
@smallexample
|
||
@var{label}:
|
||
auipc a0, %pcrel_hi(@var{symbol}) // R_RISCV_PCREL_HI20
|
||
addi a0, a0, %pcrel_lo(@var{label}) // R_RISCV_PCREL_LO12_I
|
||
|
||
@var{label}:
|
||
auipc a0, %pcrel_hi(@var{symbol}) // R_RISCV_PCREL_HI20
|
||
load/store a0, %pcrel_lo(@var{label})(a0) // R_RISCV_PCREL_LO12_I/S
|
||
@end smallexample
|
||
|
||
Or you can use the pseudo lla/lw/sw/... instruction to do this.
|
||
|
||
@smallexample
|
||
lla a0, @var{symbol}
|
||
@end smallexample
|
||
|
||
@item %got_pcrel_hi(@var{symbol})
|
||
The high 20 bits of relative address between pc and the GOT entry of
|
||
@var{symbol}. This is usually used with the %pcrel_lo modifier to access
|
||
the GOT entry.
|
||
|
||
@smallexample
|
||
@var{label}:
|
||
auipc a0, %got_pcrel_hi(@var{symbol}) // R_RISCV_GOT_HI20
|
||
addi a0, a0, %pcrel_lo(@var{label}) // R_RISCV_PCREL_LO12_I
|
||
|
||
@var{label}:
|
||
auipc a0, %got_pcrel_hi(@var{symbol}) // R_RISCV_GOT_HI20
|
||
load/store a0, %pcrel_lo(@var{label})(a0) // R_RISCV_PCREL_LO12_I/S
|
||
@end smallexample
|
||
|
||
Also, the pseudo la instruction with PIC has similar behavior.
|
||
|
||
@item %tprel_add(@var{symbol})
|
||
This is used purely to associate the R_RISCV_TPREL_ADD relocation for
|
||
TLS relaxation. This one is only valid as the fourth operand to the normally
|
||
3 operand add instruction.
|
||
|
||
@item %tprel_lo(@var{symbol})
|
||
The low 12 bits of relative address between tp and @var{symbol}.
|
||
|
||
@item %tprel_hi(@var{symbol})
|
||
The high 20 bits of relative address between tp and @var{symbol}. This is
|
||
usually used with the %tprel_lo and %tprel_add modifiers to access the thread
|
||
local variable @var{symbol} in TLS Local Exec.
|
||
|
||
@smallexample
|
||
lui a5, %tprel_hi(@var{symbol}) // R_RISCV_TPREL_HI20
|
||
add a5, a5, tp, %tprel_add(@var{symbol}) // R_RISCV_TPREL_ADD
|
||
load/store t0, %tprel_lo(@var{symbol})(a5) // R_RISCV_TPREL_LO12_I/S
|
||
@end smallexample
|
||
|
||
@item %tls_ie_pcrel_hi(@var{symbol})
|
||
The high 20 bits of relative address between pc and GOT entry. It is
|
||
usually used with the %pcrel_lo modifier to access the thread local
|
||
variable @var{symbol} in TLS Initial Exec.
|
||
|
||
@smallexample
|
||
la.tls.ie a5, @var{symbol}
|
||
add a5, a5, tp
|
||
load/store t0, 0(a5)
|
||
@end smallexample
|
||
|
||
The pseudo la.tls.ie instruction can be expended to
|
||
|
||
@smallexample
|
||
@var{label}:
|
||
auipc a5, %tls_ie_pcrel_hi(@var{symbol}) // R_RISCV_TLS_GOT_HI20
|
||
load a5, %pcrel_lo(@var{label})(a5) // R_RISCV_PCREL_LO12_I
|
||
@end smallexample
|
||
|
||
@item %tls_gd_pcrel_hi(@var{symbol})
|
||
The high 20 bits of relative address between pc and GOT entry. It is
|
||
usually used with the %pcrel_lo modifier to access the thread local variable
|
||
@var{symbol} in TLS Global Dynamic.
|
||
|
||
@smallexample
|
||
la.tls.gd a0, @var{symbol}
|
||
call __tls_get_addr@@plt
|
||
mv a5, a0
|
||
load/store t0, 0(a5)
|
||
@end smallexample
|
||
|
||
The pseudo la.tls.gd instruction can be expended to
|
||
|
||
@smallexample
|
||
@var{label}:
|
||
auipc a0, %tls_gd_pcrel_hi(@var{symbol}) // R_RISCV_TLS_GD_HI20
|
||
addi a0, a0, %pcrel_lo(@var{label}) // R_RISCV_PCREL_LO12_I
|
||
@end smallexample
|
||
|
||
@end table
|
||
|
||
@node RISC-V-Formats
|
||
@section RISC-V Instruction Formats
|
||
@cindex instruction formats, risc-v
|
||
@cindex RISC-V instruction formats
|
||
|
||
The RISC-V Instruction Set Manual Volume I: User-Level ISA lists 12
|
||
instruction formats where some of the formats have multiple variants.
|
||
For the @samp{.insn} pseudo directive the assembler recognizes some
|
||
of the formats.
|
||
Typically, the most general variant of the instruction format is used
|
||
by the @samp{.insn} directive.
|
||
|
||
The following table lists the abbreviations used in the table of
|
||
instruction formats:
|
||
|
||
@display
|
||
@multitable @columnfractions .15 .40
|
||
@item opcode @tab Unsigned immediate or opcode name for 7-bits opcode.
|
||
@item opcode2 @tab Unsigned immediate or opcode name for 2-bits opcode.
|
||
@item func7 @tab Unsigned immediate for 7-bits function code.
|
||
@item func6 @tab Unsigned immediate for 6-bits function code.
|
||
@item func4 @tab Unsigned immediate for 4-bits function code.
|
||
@item func3 @tab Unsigned immediate for 3-bits function code.
|
||
@item func2 @tab Unsigned immediate for 2-bits function code.
|
||
@item rd @tab Destination register number for operand x, can be GPR or FPR.
|
||
@item rd' @tab Destination register number for operand x,
|
||
only accept s0-s1, a0-a5, fs0-fs1 and fa0-fa5.
|
||
@item rs1 @tab First source register number for operand x, can be GPR or FPR.
|
||
@item rs1' @tab First source register number for operand x,
|
||
only accept s0-s1, a0-a5, fs0-fs1 and fa0-fa5.
|
||
@item rs2 @tab Second source register number for operand x, can be GPR or FPR.
|
||
@item rs2' @tab Second source register number for operand x,
|
||
only accept s0-s1, a0-a5, fs0-fs1 and fa0-fa5.
|
||
@item simm12 @tab Sign-extended 12-bit immediate for operand x.
|
||
@item simm20 @tab Sign-extended 20-bit immediate for operand x.
|
||
@item simm6 @tab Sign-extended 6-bit immediate for operand x.
|
||
@item uimm8 @tab Unsigned 8-bit immediate for operand x.
|
||
@item symbol @tab Symbol or lable reference for operand x.
|
||
@end multitable
|
||
@end display
|
||
|
||
The following table lists all available opcode name:
|
||
|
||
@table @code
|
||
@item C0
|
||
@item C1
|
||
@item C2
|
||
Opcode space for compressed instructions.
|
||
|
||
@item LOAD
|
||
Opcode space for load instructions.
|
||
|
||
@item LOAD_FP
|
||
Opcode space for floating-point load instructions.
|
||
|
||
@item STORE
|
||
Opcode space for store instructions.
|
||
|
||
@item STORE_FP
|
||
Opcode space for floating-point store instructions.
|
||
|
||
@item AUIPC
|
||
Opcode space for auipc instruction.
|
||
|
||
@item LUI
|
||
Opcode space for lui instruction.
|
||
|
||
@item BRANCH
|
||
Opcode space for branch instructions.
|
||
|
||
@item JAL
|
||
Opcode space for jal instruction.
|
||
|
||
@item JALR
|
||
Opcode space for jalr instruction.
|
||
|
||
@item OP
|
||
Opcode space for ALU instructions.
|
||
|
||
@item OP_32
|
||
Opcode space for 32-bits ALU instructions.
|
||
|
||
@item OP_IMM
|
||
Opcode space for ALU with immediate instructions.
|
||
|
||
@item OP_IMM_32
|
||
Opcode space for 32-bits ALU with immediate instructions.
|
||
|
||
@item OP_FP
|
||
Opcode space for floating-point operation instructions.
|
||
|
||
@item MADD
|
||
Opcode space for madd instruction.
|
||
|
||
@item MSUB
|
||
Opcode space for msub instruction.
|
||
|
||
@item NMADD
|
||
Opcode space for nmadd instruction.
|
||
|
||
@item NMSUB
|
||
Opcode space for msub instruction.
|
||
|
||
@item AMO
|
||
Opcode space for atomic memory operation instructions.
|
||
|
||
@item MISC_MEM
|
||
Opcode space for misc instructions.
|
||
|
||
@item SYSTEM
|
||
Opcode space for system instructions.
|
||
|
||
@item CUSTOM_0
|
||
@item CUSTOM_1
|
||
@item CUSTOM_2
|
||
@item CUSTOM_3
|
||
Opcode space for customize instructions.
|
||
|
||
@end table
|
||
|
||
An instruction is two or four bytes in length and must be aligned
|
||
on a 2 byte boundary. The first two bits of the instruction specify the
|
||
length of the instruction, 00, 01 and 10 indicates a two byte instruction,
|
||
11 indicates a four byte instruction.
|
||
|
||
The following table lists the RISC-V instruction formats that are available
|
||
with the @samp{.insn} pseudo directive:
|
||
|
||
@table @code
|
||
@item R type: .insn r opcode, func3, func7, rd, rs1, rs2
|
||
@verbatim
|
||
+-------+-----+-----+-------+----+-------------+
|
||
| func7 | rs2 | rs1 | func3 | rd | opcode |
|
||
+-------+-----+-----+-------+----+-------------+
|
||
31 25 20 15 12 7 0
|
||
@end verbatim
|
||
|
||
@item R type with 4 register operands: .insn r opcode, func3, func2, rd, rs1, rs2, rs3
|
||
@itemx R4 type: .insn r4 opcode, func3, func2, rd, rs1, rs2, rs3
|
||
@verbatim
|
||
+-----+-------+-----+-----+-------+----+-------------+
|
||
| rs3 | func2 | rs2 | rs1 | func3 | rd | opcode |
|
||
+-----+-------+-----+-----+-------+----+-------------+
|
||
31 27 25 20 15 12 7 0
|
||
@end verbatim
|
||
|
||
@item I type: .insn i opcode, func3, rd, rs1, simm12
|
||
@verbatim
|
||
+-------------+-----+-------+----+-------------+
|
||
| simm12 | rs1 | func3 | rd | opcode |
|
||
+-------------+-----+-------+----+-------------+
|
||
31 20 15 12 7 0
|
||
@end verbatim
|
||
|
||
@item S type: .insn s opcode, func3, rd, rs1, simm12
|
||
@verbatim
|
||
+--------------+-----+-----+-------+-------------+-------------+
|
||
| simm12[11:5] | rs2 | rs1 | func3 | simm12[4:0] | opcode |
|
||
+--------------+-----+-----+-------+-------------+-------------+
|
||
31 25 20 15 12 7 0
|
||
@end verbatim
|
||
|
||
@item SB type: .insn sb opcode, func3, rd, rs1, symbol
|
||
@itemx SB type: .insn sb opcode, func3, rd, simm12(rs1)
|
||
@itemx B type: .insn s opcode, func3, rd, rs1, symbol
|
||
@itemx B type: .insn s opcode, func3, rd, simm12(rs1)
|
||
@verbatim
|
||
+------------+--------------+-----+-----+-------+-------------+-------------+--------+
|
||
| simm12[12] | simm12[10:5] | rs2 | rs1 | func3 | simm12[4:1] | simm12[11]] | opcode |
|
||
+------------+--------------+-----+-----+-------+-------------+-------------+--------+
|
||
31 30 25 20 15 12 7 0
|
||
@end verbatim
|
||
|
||
@item U type: .insn u opcode, rd, simm20
|
||
@verbatim
|
||
+---------------------------+----+-------------+
|
||
| simm20 | rd | opcode |
|
||
+---------------------------+----+-------------+
|
||
31 12 7 0
|
||
@end verbatim
|
||
|
||
@item UJ type: .insn uj opcode, rd, symbol
|
||
@itemx J type: .insn j opcode, rd, symbol
|
||
@verbatim
|
||
+------------+--------------+------------+---------------+----+-------------+
|
||
| simm20[20] | simm20[10:1] | simm20[11] | simm20[19:12] | rd | opcode |
|
||
+------------+--------------+------------+---------------+----+-------------+
|
||
31 30 21 20 12 7 0
|
||
@end verbatim
|
||
|
||
@item CR type: .insn cr opcode2, func4, rd, rs2
|
||
@verbatim
|
||
+---------+--------+-----+---------+
|
||
| func4 | rd/rs1 | rs2 | opcode2 |
|
||
+---------+--------+-----+---------+
|
||
15 12 7 2 0
|
||
@end verbatim
|
||
|
||
@item CI type: .insn ci opcode2, func3, rd, simm6
|
||
@verbatim
|
||
+---------+-----+--------+-----+---------+
|
||
| func3 | imm | rd/rs1 | imm | opcode2 |
|
||
+---------+-----+--------+-----+---------+
|
||
15 13 12 7 2 0
|
||
@end verbatim
|
||
|
||
@item CIW type: .insn ciw opcode2, func3, rd, uimm8
|
||
@verbatim
|
||
+---------+--------------+-----+---------+
|
||
| func3 | imm | rd' | opcode2 |
|
||
+---------+--------------+-----+---------+
|
||
15 13 7 2 0
|
||
@end verbatim
|
||
|
||
@item CA type: .insn ca opcode2, func6, func2, rd, rs2
|
||
@verbatim
|
||
+---------+----------+-------+------+--------+
|
||
| func6 | rd'/rs1' | func2 | rs2' | opcode |
|
||
+---------+----------+-------+------+--------+
|
||
15 10 7 5 2 0
|
||
@end verbatim
|
||
|
||
@item CB type: .insn cb opcode2, func3, rs1, symbol
|
||
@verbatim
|
||
+---------+--------+------+--------+---------+
|
||
| func3 | offset | rs1' | offset | opcode2 |
|
||
+---------+--------+------+--------+---------+
|
||
15 13 10 7 2 0
|
||
@end verbatim
|
||
|
||
@item CJ type: .insn cj opcode2, symbol
|
||
@verbatim
|
||
+---------+--------------------+---------+
|
||
| func3 | jump target | opcode2 |
|
||
+---------+--------------------+---------+
|
||
15 13 7 2 0
|
||
@end verbatim
|
||
|
||
|
||
@end table
|
||
|
||
For the complete list of all instruction format variants see
|
||
The RISC-V Instruction Set Manual Volume I: User-Level ISA.
|
||
|
||
@node RISC-V-ATTRIBUTE
|
||
@section RISC-V Object Attribute
|
||
@cindex Object Attribute, RISC-V
|
||
|
||
RISC-V attributes have a string value if the tag number is odd and an integer
|
||
value if the tag number is even.
|
||
|
||
@table @r
|
||
@item Tag_RISCV_stack_align (4)
|
||
Tag_RISCV_strict_align records the N-byte stack alignment for this object. The
|
||
default value is 16 for RV32I or RV64I, and 4 for RV32E.
|
||
|
||
The smallest value will be used if object files with different
|
||
Tag_RISCV_stack_align values are merged.
|
||
|
||
@item Tag_RISCV_arch (5)
|
||
Tag_RISCV_arch contains a string for the target architecture taken from the
|
||
option @option{-march}. Different architectures will be integrated into a
|
||
superset when object files are merged.
|
||
|
||
Note that the version information of the target architecture must be presented
|
||
explicitly in the attribute and abbreviations must be expanded. The version
|
||
information, if not given by @option{-march}, must be in accordance with the
|
||
default specified by the tool. For example, the architecture @code{RV32I} has
|
||
to be recorded in the attribute as @code{RV32I2P0} in which @code{2P0} stands
|
||
for the default version of its base ISA. On the other hand, the architecture
|
||
@code{RV32G} has to be presented as @code{RV32I2P0_M2P0_A2P0_F2P0_D2P0} in
|
||
which the abbreviation @code{G} is expanded to the @code{IMAFD} combination
|
||
with default versions of the standard extensions.
|
||
|
||
@item Tag_RISCV_unaligned_access (6)
|
||
Tag_RISCV_unaligned_access is 0 for files that do not allow any unaligned
|
||
memory accesses, and 1 for files that do allow unaligned memory accesses.
|
||
|
||
@item Tag_RISCV_priv_spec (8)
|
||
@item Tag_RISCV_priv_spec_minor (10)
|
||
@item Tag_RISCV_priv_spec_revision (12)
|
||
Tag_RISCV_priv_spec contains the major/minor/revision version information of
|
||
the privileged specification. It will report errors if object files of
|
||
different privileged specification versions are merged.
|
||
|
||
@end table
|