macro_rules! is_riscv_feature_detected {
    ("rv32i") => { ... };
    ("rv32e") => { ... };
    ("rv64i") => { ... };
    ("rv128i") => { ... };
    ("unaligned-scalar-mem") => { ... };
    ("unaligned-vector-mem") => { ... };
    ("zicsr") => { ... };
    ("zicntr") => { ... };
    ("zihpm") => { ... };
    ("zifencei") => { ... };
    ("zihintntl") => { ... };
    ("zihintpause") => { ... };
    ("zimop") => { ... };
    ("zicboz") => { ... };
    ("zicond") => { ... };
    ("m") => { ... };
    ("a") => { ... };
    ("zalrsc") => { ... };
    ("zaamo") => { ... };
    ("zawrs") => { ... };
    ("zacas") => { ... };
    ("zam") => { ... };
    ("ztso") => { ... };
    ("f") => { ... };
    ("d") => { ... };
    ("q") => { ... };
    ("zfh") => { ... };
    ("zfhmin") => { ... };
    ("zfa") => { ... };
    ("zfinx") => { ... };
    ("zdinx") => { ... };
    ("zhinx") => { ... };
    ("zhinxmin") => { ... };
    ("c") => { ... };
    ("zca") => { ... };
    ("zcf") => { ... };
    ("zcd") => { ... };
    ("zcb") => { ... };
    ("zcmop") => { ... };
    ("b") => { ... };
    ("zba") => { ... };
    ("zbb") => { ... };
    ("zbc") => { ... };
    ("zbs") => { ... };
    ("zbkb") => { ... };
    ("zbkc") => { ... };
    ("zbkx") => { ... };
    ("zknd") => { ... };
    ("zkne") => { ... };
    ("zknh") => { ... };
    ("zksed") => { ... };
    ("zksh") => { ... };
    ("zkr") => { ... };
    ("zkn") => { ... };
    ("zks") => { ... };
    ("zk") => { ... };
    ("zkt") => { ... };
    ("v") => { ... };
    ("zve32x") => { ... };
    ("zve32f") => { ... };
    ("zve64x") => { ... };
    ("zve64f") => { ... };
    ("zve64d") => { ... };
    ("zvfh") => { ... };
    ("zvfhmin") => { ... };
    ("zvbb") => { ... };
    ("zvbc") => { ... };
    ("zvkb") => { ... };
    ("zvkg") => { ... };
    ("zvkned") => { ... };
    ("zvknha") => { ... };
    ("zvknhb") => { ... };
    ("zvksed") => { ... };
    ("zvksh") => { ... };
    ("zvkn") => { ... };
    ("zvknc") => { ... };
    ("zvkng") => { ... };
    ("zvks") => { ... };
    ("zvksc") => { ... };
    ("zvksg") => { ... };
    ("zvkt") => { ... };
    ("j") => { ... };
    ("p") => { ... };
    ($t:tt,) => { ... };
    ($t:tt) => { ... };
}Expand description
A macro to test at runtime whether instruction sets are available on RISC-V platforms.
RISC-V standard defined the base sets and the extension sets. The base sets are RV32I, RV64I, RV32E or RV128I. Any RISC-V platform must support one base set and/or multiple extension sets.
Any RISC-V standard instruction sets can be in state of either ratified, frozen or draft. The version and status of current standard instruction sets can be checked out from preface section of the ISA manual.
Platform may define and support their own custom instruction sets with ISA prefix X. These sets are highly platform specific and should be detected with their own platform support crates.
§Unprivileged Specification
The supported ratified RISC-V instruction sets are as follows:
- RV32E: "rv32e"
- RV32I: "rv32i"
- RV64I: "rv64i"
- A: "a"- Zaamo: "zaamo"
- Zalrsc: "zalrsc"
 
- Zaamo: 
- B: "b"- Zba: "zba"
- Zbb: "zbb"
- Zbs: "zbs"
 
- Zba: 
- C: "c"- Zca: "zca"
- Zcd: "zcd"(if D is enabled)
- Zcf: "zcf"(if F is enabled on RV32)
 
- Zca: 
- D: "d"
- F: "f"
- M: "m"
- Q: "q"
- V: "v"- Zve32x: "zve32x"
- Zve32f: "zve32f"
- Zve64x: "zve64x"
- Zve64f: "zve64f"
- Zve64d: "zve64d"
 
- Zve32x: 
- Zicboz: "zicboz"
- Zicntr: "zicntr"
- Zicond: "zicond"
- Zicsr: "zicsr"
- Zifencei: "zifencei"
- Zihintntl: "zihintntl"
- Zihintpause: "zihintpause"
- Zihpm: "zihpm"
- Zimop: "zimop"
- Zacas: "zacas"
- Zawrs: "zawrs"
- Zfa: "zfa"
- Zfh: "zfh"- Zfhmin: "zfhmin"
 
- Zfhmin: 
- Zfinx: "zfinx"
- Zdinx: "zdinx"
- Zhinx: "zhinx"- Zhinxmin: "zhinxmin"
 
- Zhinxmin: 
- Zcb: "zcb"
- Zcmop: "zcmop"
- Zbc: "zbc"
- Zbkb: "zbkb"
- Zbkc: "zbkc"
- Zbkx: "zbkx"
- Zk: "zk"
- Zkn: "zkn"- Zknd: "zknd"
- Zkne: "zkne"
- Zknh: "zknh"
 
- Zknd: 
- Zkr: "zkr"
- Zks: "zks"- Zksed: "zksed"
- Zksh: "zksh"
 
- Zksed: 
- Zkt: "zkt"
- Zvbb: "zvbb"
- Zvbc: "zvbc"
- Zvfh: "zvfh"- Zvfhmin: "zvfhmin"
 
- Zvfhmin: 
- Zvkb: "zvkb"
- Zvkg: "zvkg"
- Zvkn: "zvkn"- Zvkned: "zvkned"
- Zvknha: "zvknha"
- Zvknhb: "zvknhb"
 
- Zvkned: 
- Zvknc: "zvknc"
- Zvkng: "zvkng"
- Zvks: "zvks"- Zvksed: "zvksed"
- Zvksh: "zvksh"
 
- Zvksed: 
- Zvksc: "zvksc"
- Zvksg: "zvksg"
- Zvkt: "zvkt"
- Ztso: "ztso"
There’s also bases and extensions marked as standard instruction set, but they are in frozen or draft state. These instruction sets are also reserved by this macro and can be detected in the future platforms.
Draft RISC-V instruction sets:
- RV128I: "rv128i"
- J: "j"
- P: "p"
- Zam: "zam"
§Performance Hints
The two features below define performance hints for unaligned scalar/vector memory accesses, respectively. If enabled, it denotes that corresponding unaligned memory access is reasonably fast.
- "unaligned-scalar-mem"
- "unaligned-vector-mem"