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

TOMOYO Linux Cross Reference
Linux/Documentation/virt/kvm/arm/vcpu-features.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 ] ~

Diff markup

Differences between /Documentation/virt/kvm/arm/vcpu-features.rst (Architecture mips) and /Documentation/virt/kvm/arm/vcpu-features.rst (Architecture sparc)


  1 .. SPDX-License-Identifier: GPL-2.0                 1 .. SPDX-License-Identifier: GPL-2.0
  2                                                     2 
  3 ===============================                     3 ===============================
  4 vCPU feature selection on arm64                     4 vCPU feature selection on arm64
  5 ===============================                     5 ===============================
  6                                                     6 
  7 KVM/arm64 provides two mechanisms that allow u      7 KVM/arm64 provides two mechanisms that allow userspace to configure
  8 the CPU features presented to the guest.            8 the CPU features presented to the guest.
  9                                                     9 
 10 KVM_ARM_VCPU_INIT                                  10 KVM_ARM_VCPU_INIT
 11 =================                                  11 =================
 12                                                    12 
 13 The ``KVM_ARM_VCPU_INIT`` ioctl accepts a bitm     13 The ``KVM_ARM_VCPU_INIT`` ioctl accepts a bitmap of feature flags
 14 (``struct kvm_vcpu_init::features``). Features     14 (``struct kvm_vcpu_init::features``). Features enabled by this interface are
 15 *opt-in* and may change/extend UAPI. See :ref:     15 *opt-in* and may change/extend UAPI. See :ref:`KVM_ARM_VCPU_INIT` for complete
 16 documentation of the features controlled by th     16 documentation of the features controlled by the ioctl.
 17                                                    17 
 18 Otherwise, all CPU features supported by KVM a     18 Otherwise, all CPU features supported by KVM are described by the architected
 19 ID registers.                                      19 ID registers.
 20                                                    20 
 21 The ID Registers                                   21 The ID Registers
 22 ================                                   22 ================
 23                                                    23 
 24 The Arm architecture specifies a range of *ID      24 The Arm architecture specifies a range of *ID Registers* that describe the set
 25 of architectural features supported by the CPU     25 of architectural features supported by the CPU implementation. KVM initializes
 26 the guest's ID registers to the maximum set of     26 the guest's ID registers to the maximum set of CPU features supported by the
 27 system. The ID register values may be VM-scope     27 system. The ID register values may be VM-scoped in KVM, meaning that the
 28 values could be shared for all vCPUs in a VM.      28 values could be shared for all vCPUs in a VM.
 29                                                    29 
 30 KVM allows userspace to *opt-out* of certain C     30 KVM allows userspace to *opt-out* of certain CPU features described by the ID
 31 registers by writing values to them via the ``     31 registers by writing values to them via the ``KVM_SET_ONE_REG`` ioctl. The ID
 32 registers are mutable until the VM has started     32 registers are mutable until the VM has started, i.e. userspace has called
 33 ``KVM_RUN`` on at least one vCPU in the VM. Us     33 ``KVM_RUN`` on at least one vCPU in the VM. Userspace can discover what fields
 34 are mutable in the ID registers using the ``KV     34 are mutable in the ID registers using the ``KVM_ARM_GET_REG_WRITABLE_MASKS``.
 35 See the :ref:`ioctl documentation <KVM_ARM_GET     35 See the :ref:`ioctl documentation <KVM_ARM_GET_REG_WRITABLE_MASKS>` for more
 36 details.                                           36 details.
 37                                                    37 
 38 Userspace is allowed to *limit* or *mask* CPU      38 Userspace is allowed to *limit* or *mask* CPU features according to the rules
 39 outlined by the architecture in DDI0487J.a D19     39 outlined by the architecture in DDI0487J.a D19.1.3 'Principles of the ID
 40 scheme for fields in ID register'. KVM does no     40 scheme for fields in ID register'. KVM does not allow ID register values that
 41 exceed the capabilities of the system.             41 exceed the capabilities of the system.
 42                                                    42 
 43 .. warning::                                       43 .. warning::
 44    It is **strongly recommended** that userspa     44    It is **strongly recommended** that userspace modify the ID register values
 45    before accessing the rest of the vCPU's CPU     45    before accessing the rest of the vCPU's CPU register state. KVM may use the
 46    ID register values to control feature emula     46    ID register values to control feature emulation. Interleaving ID register
 47    modification with other system register acc     47    modification with other system register accesses may lead to unpredictable
 48    behavior.                                       48    behavior.
                                                      

~ [ 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