| # SPDX-License-Identifier: (GPL-2.0 OR MIT) |
| %YAML 1.2 |
| --- |
| $id: http://devicetree.org/schemas/riscv/extensions.yaml# |
| $schema: http://devicetree.org/meta-schemas/core.yaml# |
| |
| title: RISC-V ISA extensions |
| |
| maintainers: |
| - Paul Walmsley <paul.walmsley@sifive.com> |
| - Palmer Dabbelt <palmer@sifive.com> |
| - Conor Dooley <conor@kernel.org> |
| |
| description: | |
| RISC-V has a large number of extensions, some of which are "standard" |
| extensions, meaning they are ratified by RISC-V International, and others |
| are "vendor" extensions. |
| This document defines properties that indicate whether a hart supports a |
| given extension. |
| |
| Once a standard extension has been ratified, no changes in behaviour can be |
| made without the creation of a new extension. |
| The properties for standard extensions therefore map to their originally |
| ratified states, with the exception of the I, Zicntr & Zihpm extensions. |
| See the "i" property for more information. |
| |
| select: |
| properties: |
| compatible: |
| contains: |
| const: riscv |
| |
| properties: |
| riscv,isa: |
| description: |
| Identifies the specific RISC-V instruction set architecture |
| supported by the hart. These are documented in the RISC-V |
| User-Level ISA document, available from |
| https://riscv.org/specifications/ |
| |
| Due to revisions of the ISA specification, some deviations |
| have arisen over time. |
| Notably, riscv,isa was defined prior to the creation of the |
| Zicntr, Zicsr, Zifencei and Zihpm extensions and thus "i" |
| implies "zicntr_zicsr_zifencei_zihpm". |
| |
| While the isa strings in ISA specification are case |
| insensitive, letters in the riscv,isa string must be all |
| lowercase. |
| $ref: /schemas/types.yaml#/definitions/string |
| pattern: ^rv(?:64|32)imaf?d?q?c?b?k?j?p?v?h?(?:[hsxz](?:[a-z])+)?(?:_[hsxz](?:[a-z])+)*$ |
| deprecated: true |
| |
| riscv,isa-base: |
| description: |
| The base ISA implemented by this hart, as described by the 20191213 |
| version of the unprivileged ISA specification. |
| enum: |
| - rv32i |
| - rv64i |
| |
| riscv,isa-extensions: |
| $ref: /schemas/types.yaml#/definitions/string-array |
| minItems: 1 |
| description: Extensions supported by the hart. |
| items: |
| anyOf: |
| # single letter extensions, in canonical order |
| - const: i |
| description: | |
| The base integer instruction set, as ratified in the 20191213 |
| version of the unprivileged ISA specification. |
| |
| This does not include Chapter 10, "Counters", which was moved into |
| the Zicntr and Zihpm extensions after the ratification of the |
| 20191213 version of the unprivileged specification. |
| |
| - const: m |
| description: |
| The standard M extension for integer multiplication and division, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: a |
| description: |
| The standard A extension for atomic instructions, as ratified in the |
| 20191213 version of the unprivileged ISA specification. |
| |
| - const: f |
| description: |
| The standard F extension for single-precision floating point, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: d |
| description: |
| The standard D extension for double-precision floating-point, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: q |
| description: |
| The standard Q extension for quad-precision floating-point, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: c |
| description: |
| The standard C extension for compressed instructions, as ratified in |
| the 20191213 version of the unprivileged ISA specification. |
| |
| - const: v |
| description: |
| The standard V extension for vector operations, as ratified |
| in-and-around commit 7a6c8ae ("Fix text that describes vfmv.v.f |
| encoding") of the riscv-v-spec. |
| |
| - const: h |
| description: |
| The standard H extension for hypervisors as ratified in the 20191213 |
| version of the privileged ISA specification. |
| |
| # multi-letter extensions, sorted alphanumerically |
| - const: smaia |
| description: | |
| The standard Smaia supervisor-level extension for the advanced |
| interrupt architecture for machine-mode-visible csr and behavioural |
| changes to interrupts as frozen at commit ccbddab ("Merge pull |
| request #42 from riscv/jhauser-2023-RC4") of riscv-aia. |
| |
| - const: ssaia |
| description: | |
| The standard Ssaia supervisor-level extension for the advanced |
| interrupt architecture for supervisor-mode-visible csr and |
| behavioural changes to interrupts as frozen at commit ccbddab |
| ("Merge pull request #42 from riscv/jhauser-2023-RC4") of riscv-aia. |
| |
| - const: sscofpmf |
| description: | |
| The standard Sscofpmf supervisor-level extension for count overflow |
| and mode-based filtering as ratified at commit 01d1df0 ("Add ability |
| to manually trigger workflow. (#2)") of riscv-count-overflow. |
| |
| - const: sstc |
| description: | |
| The standard Sstc supervisor-level extension for time compare as |
| ratified at commit 3f9ed34 ("Add ability to manually trigger |
| workflow. (#2)") of riscv-time-compare. |
| |
| - const: svinval |
| description: |
| The standard Svinval supervisor-level extension for fine-grained |
| address-translation cache invalidation as ratified in the 20191213 |
| version of the privileged ISA specification. |
| |
| - const: svnapot |
| description: |
| The standard Svnapot supervisor-level extensions for napot |
| translation contiguity as ratified in the 20191213 version of the |
| privileged ISA specification. |
| |
| - const: svpbmt |
| description: |
| The standard Svpbmt supervisor-level extensions for page-based |
| memory types as ratified in the 20191213 version of the privileged |
| ISA specification. |
| |
| - const: zba |
| description: | |
| The standard Zba bit-manipulation extension for address generation |
| acceleration instructions as ratified at commit 6d33919 ("Merge pull |
| request #158 from hirooih/clmul-fix-loop-end-condition") of |
| riscv-bitmanip. |
| |
| - const: zbb |
| description: | |
| The standard Zbb bit-manipulation extension for basic bit-manipulation |
| as ratified at commit 6d33919 ("Merge pull request #158 from |
| hirooih/clmul-fix-loop-end-condition") of riscv-bitmanip. |
| |
| - const: zbc |
| description: | |
| The standard Zbc bit-manipulation extension for carry-less |
| multiplication as ratified at commit 6d33919 ("Merge pull request |
| #158 from hirooih/clmul-fix-loop-end-condition") of riscv-bitmanip. |
| |
| - const: zbs |
| description: | |
| The standard Zbs bit-manipulation extension for single-bit |
| instructions as ratified at commit 6d33919 ("Merge pull request #158 |
| from hirooih/clmul-fix-loop-end-condition") of riscv-bitmanip. |
| |
| - const: zicbom |
| description: |
| The standard Zicbom extension for base cache management operations as |
| ratified in commit 3dd606f ("Create cmobase-v1.0.pdf") of riscv-CMOs. |
| |
| - const: zicbop |
| description: |
| The standard Zicbop extension for cache-block prefetch instructions |
| as ratified in commit 3dd606f ("Create cmobase-v1.0.pdf") of |
| riscv-CMOs. |
| |
| - const: zicboz |
| description: |
| The standard Zicboz extension for cache-block zeroing as ratified |
| in commit 3dd606f ("Create cmobase-v1.0.pdf") of riscv-CMOs. |
| |
| - const: zicntr |
| description: |
| The standard Zicntr extension for base counters and timers, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: zicsr |
| description: | |
| The standard Zicsr extension for control and status register |
| instructions, as ratified in the 20191213 version of the |
| unprivileged ISA specification. |
| |
| This does not include Chapter 10, "Counters", which documents |
| special case read-only CSRs, that were moved into the Zicntr and |
| Zihpm extensions after the ratification of the 20191213 version of |
| the unprivileged specification. |
| |
| - const: zifencei |
| description: |
| The standard Zifencei extension for instruction-fetch fence, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: zihintpause |
| description: |
| The standard Zihintpause extension for pause hints, as ratified in |
| commit d8ab5c7 ("Zihintpause is ratified") of the riscv-isa-manual. |
| |
| - const: zihpm |
| description: |
| The standard Zihpm extension for hardware performance counters, as |
| ratified in the 20191213 version of the unprivileged ISA |
| specification. |
| |
| - const: ztso |
| description: |
| The standard Ztso extension for total store ordering, as ratified |
| in commit 2e5236 ("Ztso is now ratified.") of the |
| riscv-isa-manual. |
| |
| additionalProperties: true |
| ... |