~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/arch/riscv/uabi.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 .. SPDX-License-Identifier: GPL-2.0
  2 
  3 RISC-V Linux User ABI
  4 =====================
  5 
  6 ISA string ordering in /proc/cpuinfo
  7 ------------------------------------
  8 
  9 The canonical order of ISA extension names in the ISA string is defined in
 10 chapter 27 of the unprivileged specification.
 11 The specification uses vague wording, such as should, when it comes to ordering,
 12 so for our purposes the following rules apply:
 13 
 14 #. Single-letter extensions come first, in canonical order.
 15    The canonical order is "IMAFDQLCBKJTPVH".
 16 
 17 #. All multi-letter extensions will be separated from other extensions by an
 18    underscore.
 19 
 20 #. Additional standard extensions (starting with 'Z') will be sorted after
 21    single-letter extensions and before any higher-privileged extensions.
 22 
 23 #. For additional standard extensions, the first letter following the 'Z'
 24    conventionally indicates the most closely related alphabetical
 25    extension category. If multiple 'Z' extensions are named, they will be
 26    ordered first by category, in canonical order, as listed above, then
 27    alphabetically within a category.
 28 
 29 #. Standard supervisor-level extensions (starting with 'S') will be listed
 30    after standard unprivileged extensions.  If multiple supervisor-level
 31    extensions are listed, they will be ordered alphabetically.
 32 
 33 #. Standard machine-level extensions (starting with 'Zxm') will be listed
 34    after any lower-privileged, standard extensions. If multiple machine-level
 35    extensions are listed, they will be ordered alphabetically.
 36 
 37 #. Non-standard extensions (starting with 'X') will be listed after all standard
 38    extensions. If multiple non-standard extensions are listed, they will be
 39    ordered alphabetically.
 40 
 41 An example string following the order is::
 42 
 43    rv64imadc_zifoo_zigoo_zafoo_sbar_scar_zxmbaz_xqux_xrux
 44 
 45 "isa" and "hart isa" lines in /proc/cpuinfo
 46 -------------------------------------------
 47 
 48 The "isa" line in /proc/cpuinfo describes the lowest common denominator of
 49 RISC-V ISA extensions recognized by the kernel and implemented on all harts. The
 50 "hart isa" line, in contrast, describes the set of extensions recognized by the
 51 kernel on the particular hart being described, even if those extensions may not
 52 be present on all harts in the system.
 53 
 54 In both lines, the presence of an extension guarantees only that the hardware
 55 has the described capability. Additional kernel support or policy changes may be
 56 required before an extension's capability is fully usable by userspace programs.
 57 Similarly, for S-mode extensions, presence in one of these lines does not
 58 guarantee that the kernel is taking advantage of the extension, or that the
 59 feature will be visible in guest VMs managed by this kernel.
 60 
 61 Inversely, the absence of an extension in these lines does not necessarily mean
 62 the hardware does not support that feature. The running kernel may not recognize
 63 the extension, or may have deliberately removed it from the listing.
 64 
 65 Misaligned accesses
 66 -------------------
 67 
 68 Misaligned scalar accesses are supported in userspace, but they may perform
 69 poorly.  Misaligned vector accesses are only supported if the Zicclsm extension
 70 is supported.

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php