diff options
author | Alexander Graf <agraf@suse.de> | 2011-09-14 04:02:41 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2012-03-05 07:52:40 -0500 |
commit | e24ed81fedd551e80378be62fa0b0532480ea7d4 (patch) | |
tree | 254bcf7fbe858bc75087432667c7409e58b35575 /Documentation/virtual/kvm/api.txt | |
parent | 6b75e6bfef7ba108ac3df0d430d80dea68fde4bf (diff) |
KVM: PPC: Add generic single register ioctls
Right now we transfer a static struct every time we want to get or set
registers. Unfortunately, over time we realize that there are more of
these than we thought of before and the extensibility and flexibility of
transferring a full struct every time is limited.
So this is a new approach to the problem. With these new ioctls, we can
get and set a single register that is identified by an ID. This allows for
very precise and limited transmittal of data. When we later realize that
it's a better idea to shove over multiple registers at once, we can reuse
most of the infrastructure and simply implement a GET_MANY_REGS / SET_MANY_REGS
interface.
Signed-off-by: Alexander Graf <agraf@suse.de>
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'Documentation/virtual/kvm/api.txt')
-rw-r--r-- | Documentation/virtual/kvm/api.txt | 46 |
1 files changed, 43 insertions, 3 deletions
diff --git a/Documentation/virtual/kvm/api.txt b/Documentation/virtual/kvm/api.txt index bcd45d5afcab..e0c75dcb2ca3 100644 --- a/Documentation/virtual/kvm/api.txt +++ b/Documentation/virtual/kvm/api.txt | |||
@@ -1533,7 +1533,7 @@ following algorithm: | |||
1533 | Some guests configure the LINT1 NMI input to cause a panic, aiding in | 1533 | Some guests configure the LINT1 NMI input to cause a panic, aiding in |
1534 | debugging. | 1534 | debugging. |
1535 | 1535 | ||
1536 | 4.64 KVM_S390_UCAS_MAP | 1536 | 4.65 KVM_S390_UCAS_MAP |
1537 | 1537 | ||
1538 | Capability: KVM_CAP_S390_UCONTROL | 1538 | Capability: KVM_CAP_S390_UCONTROL |
1539 | Architectures: s390 | 1539 | Architectures: s390 |
@@ -1552,7 +1552,7 @@ This ioctl maps the memory at "user_addr" with the length "length" to | |||
1552 | the vcpu's address space starting at "vcpu_addr". All parameters need to | 1552 | the vcpu's address space starting at "vcpu_addr". All parameters need to |
1553 | be alligned by 1 megabyte. | 1553 | be alligned by 1 megabyte. |
1554 | 1554 | ||
1555 | 4.65 KVM_S390_UCAS_UNMAP | 1555 | 4.66 KVM_S390_UCAS_UNMAP |
1556 | 1556 | ||
1557 | Capability: KVM_CAP_S390_UCONTROL | 1557 | Capability: KVM_CAP_S390_UCONTROL |
1558 | Architectures: s390 | 1558 | Architectures: s390 |
@@ -1571,7 +1571,7 @@ This ioctl unmaps the memory in the vcpu's address space starting at | |||
1571 | "vcpu_addr" with the length "length". The field "user_addr" is ignored. | 1571 | "vcpu_addr" with the length "length". The field "user_addr" is ignored. |
1572 | All parameters need to be alligned by 1 megabyte. | 1572 | All parameters need to be alligned by 1 megabyte. |
1573 | 1573 | ||
1574 | 4.66 KVM_S390_VCPU_FAULT | 1574 | 4.67 KVM_S390_VCPU_FAULT |
1575 | 1575 | ||
1576 | Capability: KVM_CAP_S390_UCONTROL | 1576 | Capability: KVM_CAP_S390_UCONTROL |
1577 | Architectures: s390 | 1577 | Architectures: s390 |
@@ -1587,6 +1587,46 @@ table upfront. This is useful to handle validity intercepts for user | |||
1587 | controlled virtual machines to fault in the virtual cpu's lowcore pages | 1587 | controlled virtual machines to fault in the virtual cpu's lowcore pages |
1588 | prior to calling the KVM_RUN ioctl. | 1588 | prior to calling the KVM_RUN ioctl. |
1589 | 1589 | ||
1590 | 4.68 KVM_SET_ONE_REG | ||
1591 | |||
1592 | Capability: KVM_CAP_ONE_REG | ||
1593 | Architectures: all | ||
1594 | Type: vcpu ioctl | ||
1595 | Parameters: struct kvm_one_reg (in) | ||
1596 | Returns: 0 on success, negative value on failure | ||
1597 | |||
1598 | struct kvm_one_reg { | ||
1599 | __u64 id; | ||
1600 | __u64 addr; | ||
1601 | }; | ||
1602 | |||
1603 | Using this ioctl, a single vcpu register can be set to a specific value | ||
1604 | defined by user space with the passed in struct kvm_one_reg, where id | ||
1605 | refers to the register identifier as described below and addr is a pointer | ||
1606 | to a variable with the respective size. There can be architecture agnostic | ||
1607 | and architecture specific registers. Each have their own range of operation | ||
1608 | and their own constants and width. To keep track of the implemented | ||
1609 | registers, find a list below: | ||
1610 | |||
1611 | Arch | Register | Width (bits) | ||
1612 | | | | ||
1613 | |||
1614 | 4.69 KVM_GET_ONE_REG | ||
1615 | |||
1616 | Capability: KVM_CAP_ONE_REG | ||
1617 | Architectures: all | ||
1618 | Type: vcpu ioctl | ||
1619 | Parameters: struct kvm_one_reg (in and out) | ||
1620 | Returns: 0 on success, negative value on failure | ||
1621 | |||
1622 | This ioctl allows to receive the value of a single register implemented | ||
1623 | in a vcpu. The register to read is indicated by the "id" field of the | ||
1624 | kvm_one_reg struct passed in. On success, the register value can be found | ||
1625 | at the memory location pointed to by "addr". | ||
1626 | |||
1627 | The list of registers accessible using this interface is identical to the | ||
1628 | list in 4.64. | ||
1629 | |||
1590 | 5. The kvm_run structure | 1630 | 5. The kvm_run structure |
1591 | 1631 | ||
1592 | Application code obtains a pointer to the kvm_run structure by | 1632 | Application code obtains a pointer to the kvm_run structure by |