RISC-V Support

Intrinsic Detection Macros

Clang provides macros to detect which RISC-V intrinsics are supported by the toolchain. This is only available if intrinsics are ratified, in other word, experimental intrinsics do not have macro defined. Note: This is independent from assembler support.

Intrinsic Detection

Macros of the form __riscv_intrinsic_<extension> indicate that the toolchain supports intrinsics for a given extension:

#if defined(__riscv_intrinsic_zbb)
  // Toolchain supports Zbb scalar intrinsics like __riscv_orc_b_*
  // These can be used with target attributes even if -march doesn't include Zbb
  __attribute__((target("arch=+zbb")))
  unsigned long process_with_zbb(unsigned long x) {
    return __riscv_orc_b_64(x);
  }
#endif
Composite extensions are also defined when all their sub-extensions are available, e.g.

__riscv_intrinsic_zkn - zbkb + zbkc + zbkx + zkne + zknd + zknh