10061efdc4
This patch is doing several things: - Core ISA and extension Kconfig symbols have now a formalized name (CONFIG_RISCV_ISA_* and CONFIG_RISCV_ISA_EXT_*) - a new Kconfig.isa file was introduced with the full set of extensions currently supported by the v2.2 spec - a new Kconfig.core file was introduced to host all the RISCV cores (currently only E31) - ISA and extensions settings are moved to SoC configuration files Signed-off-by: Carlo Caione <ccaione@baylibre.com>
94 lines
2.5 KiB
Plaintext
94 lines
2.5 KiB
Plaintext
# Copyright (c) 2022 Carlo Caione <ccaione@baylibre.com>
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
config RISCV_ISA_RV32I
|
|
bool
|
|
help
|
|
RV32I Base Integer Instruction Set - 32bit
|
|
|
|
config RISCV_ISA_RV32E
|
|
bool
|
|
help
|
|
RV32E Base Integer Instruction Set (Embedded) - 32bit
|
|
|
|
config RISCV_ISA_RV64I
|
|
bool
|
|
default y if 64BIT
|
|
help
|
|
RV64I Base Integer Instruction Set - 64bit
|
|
|
|
config RISCV_ISA_RV128I
|
|
bool
|
|
help
|
|
RV128I Base Integer Instruction Set - 128bit
|
|
|
|
config RISCV_ISA_EXT_M
|
|
bool
|
|
help
|
|
(M) - Standard Extension for Integer Multiplication and Division
|
|
|
|
Standard integer multiplication and division instruction extension,
|
|
which is named "M" and contains instructions that multiply or divide
|
|
values held in two integer registers.
|
|
|
|
config RISCV_ISA_EXT_A
|
|
bool
|
|
help
|
|
(A) - Standard Extension for Atomic Instructions
|
|
|
|
The standard atomic instruction extension is denoted by instruction
|
|
subset name "A", and contains instructions that atomically
|
|
read-modify-write memory to support synchronization between multiple
|
|
RISC-V threads running in the same memory space.
|
|
|
|
config RISCV_ISA_EXT_F
|
|
bool
|
|
help
|
|
(F) - Standard Extension for Single-Precision Floating-Point
|
|
|
|
Standard instruction-set extension for single-precision
|
|
floating-point, which is named "F" and adds single-precision
|
|
floating-point computational instructions compliant with the IEEE
|
|
754-2008 arithmetic standard.
|
|
|
|
config RISCV_ISA_EXT_D
|
|
bool
|
|
depends on RISCV_ISA_EXT_F
|
|
help
|
|
(D) - Standard Extension for Double-Precision Floating-Point
|
|
|
|
Standard double-precision floating-point instruction-set extension,
|
|
which is named "D" and adds double-precision floating-point
|
|
computational instructions compliant with the IEEE 754-2008
|
|
arithmetic standard.
|
|
|
|
config RISCV_ISA_EXT_G
|
|
bool
|
|
select RISCV_ISA_EXT_M
|
|
select RISCV_ISA_EXT_A
|
|
select RISCV_ISA_EXT_F
|
|
select RISCV_ISA_EXT_D
|
|
help
|
|
(MAFD) MAFD extensions
|
|
|
|
config RISCV_ISA_EXT_Q
|
|
bool
|
|
depends on RISCV_ISA_RV64I
|
|
depends on RISCV_ISA_EXT_F
|
|
depends on RISCV_ISA_EXT_D
|
|
help
|
|
(Q) - Standard Extension for Quad-Precision Floating-Point
|
|
|
|
Standard extension for 128-bit binary floating-point instructions
|
|
compliant with the IEEE 754-2008 arithmetic standard. The 128-bit or
|
|
quad-precision binary floatingpoint instruction subset is named "Q".
|
|
|
|
config RISCV_ISA_EXT_C
|
|
bool
|
|
help
|
|
(C) - Standard Extension for Compressed Instructions
|
|
|
|
RISC-V standard compressed instruction set extension, named "C",
|
|
which reduces static and dynamic code size by adding short 16-bit
|
|
instruction encodings for common operations.
|