diff options
| -rw-r--r-- | arch/s390/include/asm/kvm.h | 3 | ||||
| -rw-r--r-- | arch/s390/kvm/kvm-s390.c | 16 |
2 files changed, 19 insertions, 0 deletions
diff --git a/arch/s390/include/asm/kvm.h b/arch/s390/include/asm/kvm.h index 96076676e224..53a53720830a 100644 --- a/arch/s390/include/asm/kvm.h +++ b/arch/s390/include/asm/kvm.h | |||
| @@ -52,4 +52,7 @@ struct kvm_sync_regs { | |||
| 52 | __u32 acrs[16]; /* access registers */ | 52 | __u32 acrs[16]; /* access registers */ |
| 53 | __u64 crs[16]; /* control registers */ | 53 | __u64 crs[16]; /* control registers */ |
| 54 | }; | 54 | }; |
| 55 | |||
| 56 | #define KVM_REG_S390_TODPR (KVM_REG_S390 | KVM_REG_SIZE_U32 | 0x1) | ||
| 57 | #define KVM_REG_S390_EPOCHDIFF (KVM_REG_S390 | KVM_REG_SIZE_U64 | 0x2) | ||
| 55 | #endif | 58 | #endif |
diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c index 894b3e47b8c1..cc4c01322ce4 100644 --- a/arch/s390/kvm/kvm-s390.c +++ b/arch/s390/kvm/kvm-s390.c | |||
| @@ -446,6 +446,14 @@ static int kvm_arch_vcpu_ioctl_get_one_reg(struct kvm_vcpu *vcpu, | |||
| 446 | int r = -EINVAL; | 446 | int r = -EINVAL; |
| 447 | 447 | ||
| 448 | switch (reg->id) { | 448 | switch (reg->id) { |
| 449 | case KVM_REG_S390_TODPR: | ||
| 450 | r = put_user(vcpu->arch.sie_block->todpr, | ||
| 451 | (u32 __user *)reg->addr); | ||
| 452 | break; | ||
| 453 | case KVM_REG_S390_EPOCHDIFF: | ||
| 454 | r = put_user(vcpu->arch.sie_block->epoch, | ||
| 455 | (u64 __user *)reg->addr); | ||
| 456 | break; | ||
| 449 | default: | 457 | default: |
| 450 | break; | 458 | break; |
| 451 | } | 459 | } |
| @@ -459,6 +467,14 @@ static int kvm_arch_vcpu_ioctl_set_one_reg(struct kvm_vcpu *vcpu, | |||
| 459 | int r = -EINVAL; | 467 | int r = -EINVAL; |
| 460 | 468 | ||
| 461 | switch (reg->id) { | 469 | switch (reg->id) { |
| 470 | case KVM_REG_S390_TODPR: | ||
| 471 | r = get_user(vcpu->arch.sie_block->todpr, | ||
| 472 | (u32 __user *)reg->addr); | ||
| 473 | break; | ||
| 474 | case KVM_REG_S390_EPOCHDIFF: | ||
| 475 | r = get_user(vcpu->arch.sie_block->epoch, | ||
| 476 | (u64 __user *)reg->addr); | ||
| 477 | break; | ||
| 462 | default: | 478 | default: |
| 463 | break; | 479 | break; |
| 464 | } | 480 | } |
