2021-01-01 06:58:58 +08:00
|
|
|
@c Copyright (C) 2016-2021 Free Software Foundation, Inc.
|
2016-11-02 00:45:57 +08:00
|
|
|
@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
|
2017-12-02 07:34:42 +08:00
|
|
|
* RISC-V-Options:: RISC-V Options
|
|
|
|
* RISC-V-Directives:: RISC-V Directives
|
2020-03-04 13:08:04 +08:00
|
|
|
* RISC-V-Modifiers:: RISC-V Assembler Modifiers
|
2018-03-15 07:04:03 +08:00
|
|
|
* RISC-V-Formats:: RISC-V Instruction Formats
|
2019-01-17 05:14:59 +08:00
|
|
|
* RISC-V-ATTRIBUTE:: RISC-V Object Attribute
|
2016-11-02 00:45:57 +08:00
|
|
|
@end menu
|
|
|
|
|
2017-12-02 07:34:42 +08:00
|
|
|
@node RISC-V-Options
|
|
|
|
@section RISC-V Options
|
2016-11-02 00:45:57 +08:00
|
|
|
|
2017-12-02 07:34:42 +08:00
|
|
|
The following table lists all available RISC-V specific options.
|
2016-11-02 00:45:57 +08:00
|
|
|
|
|
|
|
@c man begin OPTIONS
|
|
|
|
@table @gcctabopt
|
|
|
|
|
2017-03-21 23:36:44 +08:00
|
|
|
@cindex @samp{-fpic} option, RISC-V
|
|
|
|
@item -fpic
|
2017-12-02 07:34:42 +08:00
|
|
|
@itemx -fPIC
|
2017-03-21 23:36:44 +08:00
|
|
|
Generate position-independent code
|
|
|
|
|
|
|
|
@cindex @samp{-fno-pic} option, RISC-V
|
|
|
|
@item -fno-pic
|
|
|
|
Don't generate position-independent code (default)
|
|
|
|
|
2016-11-04 22:18:06 +08:00
|
|
|
@cindex @samp{-march=ISA} option, RISC-V
|
|
|
|
@item -march=ISA
|
Re-work RISC-V gas flags: now we just support -mabi and -march
We've decided to standardize on two flags for RISC-V: "-march" sets the
target architecture (which determines which instructions can be
generated), and "-mabi" sets the target ABI. We needed to rework this
because the old flag set didn't support soft-float or single-float ABIs,
and didn't support an x32-style ABI on RISC-V.
Additionally, we've changed the behavior of the -march flag: it's now a
lot stricter and only parses things we can actually understand.
Additionally, it's now lowercase-only: the rationale is that while the
RISC-V ISA manual specifies that ISA strings are case-insensitive, in
Linux-land things are usually case-sensitive. Since this flag can be
used to determine library paths, we didn't want to bake some
case-insensitivity in there that would case trouble later.
This patch implements these two new flags and removes the old flags that
could conflict with these. There wasn't a RISC-V release before, so we
want to just support a clean flag set.
include/
* elf/riscv.h (EF_RISCV_SOFT_FLOAT): Don't define.
(EF_RISCV_FLOAT_ABI, EF_RISCV_FLOAT_ABI_SOFT): Define.
(EF_RISCV_FLOAT_ABI_SINGLE, EF_RISCV_FLOAT_ABI_DOUBLE): Define.
(EF_RISCV_FLOAT_ABI_QUAD): Define.
bfd/
* elfnn-riscv.c (_bfd_riscv_elf_merge_private_bfd_data): Use
EF_RISCV_FLOAT_ABI_SOFT instead of EF_RISCV_SOFT_FLOAT.
binutils/
* readelf.c (get_machine_flags): Use
EF_RISCV_FLOAT_ABI_{SOFT,SINGLE,DOBULE,QUAD) instead of
EF_RISCV_{SOFT,HARD}_FLOAT.
gas/
* config/tc-riscv.h (xlen): Delete.
* config/tc-riscv.c (xlen): Make static.
(abi_xlen): New variable.
(options): Replace OPTION_{M32,M64,MSOFT_FLOAT,MHARD_FLOAT,MRVC}
with OPTION_MABI.
(md_longopts): Likewise.
(md_parse_option): Likewise.
(riscv_elf_final_processing): Likewise.
* doc/as.texinfo (Target RISC-V options): Likewise.
* doc/c-riscv.texi (OPTIONS): Likewise.
* config/tc-riscv.c (float_mode): Removed.
(float_abi): New type, specifies the floating-point ABI.
(riscv_set_abi): New function.
(riscv_add_subset): Only allow lower-case ISA names and require
them to start with "rv".
(riscv_after_parse_args): Likewise.
opcodes/
* riscv-dis.c (riscv_disassemble_insn): Default to the ELF's
XLEN when none is provided.
2016-12-19 14:53:50 +08:00
|
|
|
Select the base isa, as specified by ISA. For example -march=rv32ima.
|
2020-06-04 04:42:54 +08:00
|
|
|
If this option and the architecture attributes aren't set, then assembler
|
[PATCH v2 0/9] RISC-V: Support version controling for ISA standard extensions and CSR
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.
2020-05-21 00:22:48 +08:00
|
|
|
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.
|
Re-work RISC-V gas flags: now we just support -mabi and -march
We've decided to standardize on two flags for RISC-V: "-march" sets the
target architecture (which determines which instructions can be
generated), and "-mabi" sets the target ABI. We needed to rework this
because the old flag set didn't support soft-float or single-float ABIs,
and didn't support an x32-style ABI on RISC-V.
Additionally, we've changed the behavior of the -march flag: it's now a
lot stricter and only parses things we can actually understand.
Additionally, it's now lowercase-only: the rationale is that while the
RISC-V ISA manual specifies that ISA strings are case-insensitive, in
Linux-land things are usually case-sensitive. Since this flag can be
used to determine library paths, we didn't want to bake some
case-insensitivity in there that would case trouble later.
This patch implements these two new flags and removes the old flags that
could conflict with these. There wasn't a RISC-V release before, so we
want to just support a clean flag set.
include/
* elf/riscv.h (EF_RISCV_SOFT_FLOAT): Don't define.
(EF_RISCV_FLOAT_ABI, EF_RISCV_FLOAT_ABI_SOFT): Define.
(EF_RISCV_FLOAT_ABI_SINGLE, EF_RISCV_FLOAT_ABI_DOUBLE): Define.
(EF_RISCV_FLOAT_ABI_QUAD): Define.
bfd/
* elfnn-riscv.c (_bfd_riscv_elf_merge_private_bfd_data): Use
EF_RISCV_FLOAT_ABI_SOFT instead of EF_RISCV_SOFT_FLOAT.
binutils/
* readelf.c (get_machine_flags): Use
EF_RISCV_FLOAT_ABI_{SOFT,SINGLE,DOBULE,QUAD) instead of
EF_RISCV_{SOFT,HARD}_FLOAT.
gas/
* config/tc-riscv.h (xlen): Delete.
* config/tc-riscv.c (xlen): Make static.
(abi_xlen): New variable.
(options): Replace OPTION_{M32,M64,MSOFT_FLOAT,MHARD_FLOAT,MRVC}
with OPTION_MABI.
(md_longopts): Likewise.
(md_parse_option): Likewise.
(riscv_elf_final_processing): Likewise.
* doc/as.texinfo (Target RISC-V options): Likewise.
* doc/c-riscv.texi (OPTIONS): Likewise.
* config/tc-riscv.c (float_mode): Removed.
(float_abi): New type, specifies the floating-point ABI.
(riscv_set_abi): New function.
(riscv_add_subset): Only allow lower-case ISA names and require
them to start with "rv".
(riscv_after_parse_args): Likewise.
opcodes/
* riscv-dis.c (riscv_disassemble_insn): Default to the ELF's
XLEN when none is provided.
2016-12-19 14:53:50 +08:00
|
|
|
|
|
|
|
@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
|
2018-05-19 05:03:18 +08:00
|
|
|
the soft-float calling convention. Also, "ilp32" can optionally be followed
|
|
|
|
by "e" to indicate the RVE ABI, which is always soft-float.
|
2016-11-02 00:45:57 +08:00
|
|
|
|
2018-04-21 06:30:18 +08:00
|
|
|
@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.
|
|
|
|
|
2020-02-06 11:14:21 +08:00
|
|
|
@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.
|
|
|
|
|
2020-02-12 18:18:50 +08:00
|
|
|
@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
|
2020-08-12 20:47:04 +08:00
|
|
|
Don't do CSR checking.
|
2021-01-06 05:50:37 +08:00
|
|
|
|
|
|
|
@cindex @samp{-mlittle-endian} option, RISC-V
|
|
|
|
@item -mlittle-endian
|
|
|
|
Generate code for a little endian machine.
|
|
|
|
|
|
|
|
@cindex @samp{-mbig-endian} option, RISC-V
|
|
|
|
@item -mbig-endian
|
|
|
|
Generate code for a big endian machine.
|
2016-11-02 00:45:57 +08:00
|
|
|
@end table
|
|
|
|
@c man end
|
2017-12-02 07:34:42 +08:00
|
|
|
|
|
|
|
@node RISC-V-Directives
|
2017-12-04 07:11:07 +08:00
|
|
|
@section RISC-V Directives
|
2017-12-02 07:34:42 +08:00
|
|
|
@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
|
|
|
|
|
2020-02-12 18:18:50 +08:00
|
|
|
@item csr-check
|
|
|
|
@itemx no-csr-check
|
|
|
|
Enables or disables the CSR checking.
|
|
|
|
|
2018-03-15 07:04:03 +08:00
|
|
|
@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}.
|
|
|
|
|
2019-01-17 05:14:59 +08:00
|
|
|
@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}.
|
|
|
|
|
2017-12-02 07:34:42 +08:00
|
|
|
@end table
|
2018-03-15 07:04:03 +08:00
|
|
|
|
2020-03-04 13:08:04 +08:00
|
|
|
@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
|
|
|
|
|
2020-03-04 13:08:05 +08:00
|
|
|
@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.
|
|
|
|
|
2020-03-04 13:08:04 +08:00
|
|
|
@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
|
|
|
|
|
2018-03-15 07:04:03 +08:00
|
|
|
@node RISC-V-Formats
|
2020-03-04 13:08:04 +08:00
|
|
|
@section RISC-V Instruction Formats
|
2018-03-15 07:04:03 +08:00
|
|
|
@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.
|
2018-11-28 03:29:23 +08:00
|
|
|
@item func6 @tab Unsigned immediate for 6-bits function code.
|
2018-03-15 07:04:03 +08:00
|
|
|
@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.
|
|
|
|
|
2019-07-05 15:19:11 +08:00
|
|
|
@item MISC_MEM
|
2018-03-15 07:04:03 +08:00
|
|
|
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
|
2019-07-05 15:19:11 +08:00
|
|
|
@itemx R4 type: .insn r4 opcode, func3, func2, rd, rs1, rs2, rs3
|
2018-03-15 07:04:03 +08:00
|
|
|
@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
|
2020-06-03 09:36:14 +08:00
|
|
|
@itemx I type: .insn i opcode, func3, rd, simm12(rs1)
|
2018-03-15 07:04:03 +08:00
|
|
|
@verbatim
|
|
|
|
+-------------+-----+-------+----+-------------+
|
|
|
|
| simm12 | rs1 | func3 | rd | opcode |
|
|
|
|
+-------------+-----+-------+----+-------------+
|
|
|
|
31 20 15 12 7 0
|
|
|
|
@end verbatim
|
|
|
|
|
2020-06-03 09:36:14 +08:00
|
|
|
@item S type: .insn s opcode, func3, rs2, simm12(rs1)
|
2018-03-15 07:04:03 +08:00
|
|
|
@verbatim
|
|
|
|
+--------------+-----+-----+-------+-------------+-------------+
|
|
|
|
| simm12[11:5] | rs2 | rs1 | func3 | simm12[4:0] | opcode |
|
|
|
|
+--------------+-----+-----+-------+-------------+-------------+
|
|
|
|
31 25 20 15 12 7 0
|
|
|
|
@end verbatim
|
|
|
|
|
2020-06-03 09:36:14 +08:00
|
|
|
@item B type: .insn s opcode, func3, rs1, rs2, symbol
|
|
|
|
@itemx SB type: .insn sb opcode, func3, rs1, rs2, symbol
|
2018-03-15 07:04:03 +08:00
|
|
|
@verbatim
|
2019-07-05 15:19:11 +08:00
|
|
|
+------------+--------------+-----+-----+-------+-------------+-------------+--------+
|
|
|
|
| simm12[12] | simm12[10:5] | rs2 | rs1 | func3 | simm12[4:1] | simm12[11]] | opcode |
|
|
|
|
+------------+--------------+-----+-----+-------+-------------+-------------+--------+
|
|
|
|
31 30 25 20 15 12 7 0
|
2018-03-15 07:04:03 +08:00
|
|
|
@end verbatim
|
|
|
|
|
|
|
|
@item U type: .insn u opcode, rd, simm20
|
|
|
|
@verbatim
|
|
|
|
+---------------------------+----+-------------+
|
|
|
|
| simm20 | rd | opcode |
|
|
|
|
+---------------------------+----+-------------+
|
|
|
|
31 12 7 0
|
|
|
|
@end verbatim
|
|
|
|
|
2020-06-03 09:36:14 +08:00
|
|
|
@item J type: .insn j opcode, rd, symbol
|
|
|
|
@itemx UJ type: .insn uj opcode, rd, symbol
|
2018-03-15 07:04:03 +08:00
|
|
|
@verbatim
|
|
|
|
+------------+--------------+------------+---------------+----+-------------+
|
|
|
|
| simm20[20] | simm20[10:1] | simm20[11] | simm20[19:12] | rd | opcode |
|
|
|
|
+------------+--------------+------------+---------------+----+-------------+
|
|
|
|
31 30 21 20 12 7 0
|
|
|
|
@end verbatim
|
|
|
|
|
2018-11-28 03:29:23 +08:00
|
|
|
@item CR type: .insn cr opcode2, func4, rd, rs2
|
2018-03-15 07:04:03 +08:00
|
|
|
@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
|
|
|
|
|
2018-11-28 03:29:23 +08:00
|
|
|
@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
|
|
|
|
|
2018-03-15 07:04:03 +08:00
|
|
|
@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.
|
2019-01-17 05:14:59 +08:00
|
|
|
|
|
|
|
@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
|