mirror of https://gitee.com/openkylin/linux.git
93 lines
3.2 KiB
ReStructuredText
93 lines
3.2 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
|
|
|
=========================
|
|
XICS interrupt controller
|
|
=========================
|
|
|
|
Device type supported: KVM_DEV_TYPE_XICS
|
|
|
|
Groups:
|
|
1. KVM_DEV_XICS_GRP_SOURCES
|
|
Attributes:
|
|
|
|
One per interrupt source, indexed by the source number.
|
|
2. KVM_DEV_XICS_GRP_CTRL
|
|
Attributes:
|
|
|
|
2.1 KVM_DEV_XICS_NR_SERVERS (write only)
|
|
|
|
The kvm_device_attr.addr points to a __u32 value which is the number of
|
|
interrupt server numbers (ie, highest possible vcpu id plus one).
|
|
|
|
Errors:
|
|
|
|
======= ==========================================
|
|
-EINVAL Value greater than KVM_MAX_VCPU_ID.
|
|
-EFAULT Invalid user pointer for attr->addr.
|
|
-EBUSY A vcpu is already connected to the device.
|
|
======= ==========================================
|
|
|
|
This device emulates the XICS (eXternal Interrupt Controller
|
|
Specification) defined in PAPR. The XICS has a set of interrupt
|
|
sources, each identified by a 20-bit source number, and a set of
|
|
Interrupt Control Presentation (ICP) entities, also called "servers",
|
|
each associated with a virtual CPU.
|
|
|
|
The ICP entities are created by enabling the KVM_CAP_IRQ_ARCH
|
|
capability for each vcpu, specifying KVM_CAP_IRQ_XICS in args[0] and
|
|
the interrupt server number (i.e. the vcpu number from the XICS's
|
|
point of view) in args[1] of the kvm_enable_cap struct. Each ICP has
|
|
64 bits of state which can be read and written using the
|
|
KVM_GET_ONE_REG and KVM_SET_ONE_REG ioctls on the vcpu. The 64 bit
|
|
state word has the following bitfields, starting at the
|
|
least-significant end of the word:
|
|
|
|
* Unused, 16 bits
|
|
|
|
* Pending interrupt priority, 8 bits
|
|
Zero is the highest priority, 255 means no interrupt is pending.
|
|
|
|
* Pending IPI (inter-processor interrupt) priority, 8 bits
|
|
Zero is the highest priority, 255 means no IPI is pending.
|
|
|
|
* Pending interrupt source number, 24 bits
|
|
Zero means no interrupt pending, 2 means an IPI is pending
|
|
|
|
* Current processor priority, 8 bits
|
|
Zero is the highest priority, meaning no interrupts can be
|
|
delivered, and 255 is the lowest priority.
|
|
|
|
Each source has 64 bits of state that can be read and written using
|
|
the KVM_GET_DEVICE_ATTR and KVM_SET_DEVICE_ATTR ioctls, specifying the
|
|
KVM_DEV_XICS_GRP_SOURCES attribute group, with the attribute number being
|
|
the interrupt source number. The 64 bit state word has the following
|
|
bitfields, starting from the least-significant end of the word:
|
|
|
|
* Destination (server number), 32 bits
|
|
|
|
This specifies where the interrupt should be sent, and is the
|
|
interrupt server number specified for the destination vcpu.
|
|
|
|
* Priority, 8 bits
|
|
|
|
This is the priority specified for this interrupt source, where 0 is
|
|
the highest priority and 255 is the lowest. An interrupt with a
|
|
priority of 255 will never be delivered.
|
|
|
|
* Level sensitive flag, 1 bit
|
|
|
|
This bit is 1 for a level-sensitive interrupt source, or 0 for
|
|
edge-sensitive (or MSI).
|
|
|
|
* Masked flag, 1 bit
|
|
|
|
This bit is set to 1 if the interrupt is masked (cannot be delivered
|
|
regardless of its priority), for example by the ibm,int-off RTAS
|
|
call, or 0 if it is not masked.
|
|
|
|
* Pending flag, 1 bit
|
|
|
|
This bit is 1 if the source has a pending interrupt, otherwise 0.
|
|
|
|
Only one XICS instance may be created per VM.
|