diff options
author | Michael Mueller <mimu@linux.vnet.ibm.com> | 2014-05-13 10:58:30 -0400 |
---|---|---|
committer | Christian Borntraeger <borntraeger@de.ibm.com> | 2014-05-16 08:57:31 -0400 |
commit | fda902cb8347da121025c4079b9e87748228a27e (patch) | |
tree | b5cbcce14afbe2da194e4b3cb8f1594cea800fb5 /arch/s390 | |
parent | 570126d370e9c018e603d63272ebcf7340efc05b (diff) |
KVM: s390: split SIE state guest prefix field
This patch splits the SIE state guest prefix at offset 4
into a prefix bit field. Additionally it provides the
access functions:
- kvm_s390_get_prefix()
- kvm_s390_set_prefix()
to access the prefix per vcpu.
Signed-off-by: Michael Mueller <mimu@linux.vnet.ibm.com>
Reviewed-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Acked-by: Christian Borntraeger <borntraeger@de.ibm.com>
Diffstat (limited to 'arch/s390')
-rw-r--r-- | arch/s390/include/asm/kvm_host.h | 4 | ||||
-rw-r--r-- | arch/s390/kvm/diag.c | 2 | ||||
-rw-r--r-- | arch/s390/kvm/gaccess.h | 8 | ||||
-rw-r--r-- | arch/s390/kvm/kvm-s390.c | 10 | ||||
-rw-r--r-- | arch/s390/kvm/kvm-s390.h | 8 | ||||
-rw-r--r-- | arch/s390/kvm/priv.c | 3 |
6 files changed, 22 insertions, 13 deletions
diff --git a/arch/s390/include/asm/kvm_host.h b/arch/s390/include/asm/kvm_host.h index dc182a5b02b7..a27f5007062a 100644 --- a/arch/s390/include/asm/kvm_host.h +++ b/arch/s390/include/asm/kvm_host.h | |||
@@ -82,7 +82,9 @@ struct sca_block { | |||
82 | 82 | ||
83 | struct kvm_s390_sie_block { | 83 | struct kvm_s390_sie_block { |
84 | atomic_t cpuflags; /* 0x0000 */ | 84 | atomic_t cpuflags; /* 0x0000 */ |
85 | __u32 prefix; /* 0x0004 */ | 85 | __u32 : 1; /* 0x0004 */ |
86 | __u32 prefix : 18; | ||
87 | __u32 : 13; | ||
86 | __u8 reserved08[4]; /* 0x0008 */ | 88 | __u8 reserved08[4]; /* 0x0008 */ |
87 | #define PROG_IN_SIE (1<<0) | 89 | #define PROG_IN_SIE (1<<0) |
88 | __u32 prog0c; /* 0x000c */ | 90 | __u32 prog0c; /* 0x000c */ |
diff --git a/arch/s390/kvm/diag.c b/arch/s390/kvm/diag.c index 004d385d9519..0161675878a2 100644 --- a/arch/s390/kvm/diag.c +++ b/arch/s390/kvm/diag.c | |||
@@ -23,7 +23,7 @@ | |||
23 | static int diag_release_pages(struct kvm_vcpu *vcpu) | 23 | static int diag_release_pages(struct kvm_vcpu *vcpu) |
24 | { | 24 | { |
25 | unsigned long start, end; | 25 | unsigned long start, end; |
26 | unsigned long prefix = vcpu->arch.sie_block->prefix; | 26 | unsigned long prefix = kvm_s390_get_prefix(vcpu); |
27 | 27 | ||
28 | start = vcpu->run->s.regs.gprs[(vcpu->arch.sie_block->ipa & 0xf0) >> 4]; | 28 | start = vcpu->run->s.regs.gprs[(vcpu->arch.sie_block->ipa & 0xf0) >> 4]; |
29 | end = vcpu->run->s.regs.gprs[vcpu->arch.sie_block->ipa & 0xf] + 4096; | 29 | end = vcpu->run->s.regs.gprs[vcpu->arch.sie_block->ipa & 0xf] + 4096; |
diff --git a/arch/s390/kvm/gaccess.h b/arch/s390/kvm/gaccess.h index 68db43e4254f..a07ee08ac478 100644 --- a/arch/s390/kvm/gaccess.h +++ b/arch/s390/kvm/gaccess.h | |||
@@ -30,7 +30,7 @@ | |||
30 | static inline unsigned long kvm_s390_real_to_abs(struct kvm_vcpu *vcpu, | 30 | static inline unsigned long kvm_s390_real_to_abs(struct kvm_vcpu *vcpu, |
31 | unsigned long gra) | 31 | unsigned long gra) |
32 | { | 32 | { |
33 | unsigned long prefix = vcpu->arch.sie_block->prefix; | 33 | unsigned long prefix = kvm_s390_get_prefix(vcpu); |
34 | 34 | ||
35 | if (gra < 2 * PAGE_SIZE) | 35 | if (gra < 2 * PAGE_SIZE) |
36 | gra += prefix; | 36 | gra += prefix; |
@@ -99,7 +99,7 @@ static inline unsigned long kvm_s390_logical_to_effective(struct kvm_vcpu *vcpu, | |||
99 | unsigned long __gpa; \ | 99 | unsigned long __gpa; \ |
100 | \ | 100 | \ |
101 | __gpa = (unsigned long)(gra); \ | 101 | __gpa = (unsigned long)(gra); \ |
102 | __gpa += __vcpu->arch.sie_block->prefix; \ | 102 | __gpa += kvm_s390_get_prefix(__vcpu); \ |
103 | kvm_write_guest(__vcpu->kvm, __gpa, &__x, sizeof(__x)); \ | 103 | kvm_write_guest(__vcpu->kvm, __gpa, &__x, sizeof(__x)); \ |
104 | }) | 104 | }) |
105 | 105 | ||
@@ -124,7 +124,7 @@ static inline __must_check | |||
124 | int write_guest_lc(struct kvm_vcpu *vcpu, unsigned long gra, void *data, | 124 | int write_guest_lc(struct kvm_vcpu *vcpu, unsigned long gra, void *data, |
125 | unsigned long len) | 125 | unsigned long len) |
126 | { | 126 | { |
127 | unsigned long gpa = gra + vcpu->arch.sie_block->prefix; | 127 | unsigned long gpa = gra + kvm_s390_get_prefix(vcpu); |
128 | 128 | ||
129 | return kvm_write_guest(vcpu->kvm, gpa, data, len); | 129 | return kvm_write_guest(vcpu->kvm, gpa, data, len); |
130 | } | 130 | } |
@@ -150,7 +150,7 @@ static inline __must_check | |||
150 | int read_guest_lc(struct kvm_vcpu *vcpu, unsigned long gra, void *data, | 150 | int read_guest_lc(struct kvm_vcpu *vcpu, unsigned long gra, void *data, |
151 | unsigned long len) | 151 | unsigned long len) |
152 | { | 152 | { |
153 | unsigned long gpa = gra + vcpu->arch.sie_block->prefix; | 153 | unsigned long gpa = gra + kvm_s390_get_prefix(vcpu); |
154 | 154 | ||
155 | return kvm_read_guest(vcpu->kvm, gpa, data, len); | 155 | return kvm_read_guest(vcpu->kvm, gpa, data, len); |
156 | } | 156 | } |
diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c index 2c243124a4e2..e519860c6031 100644 --- a/arch/s390/kvm/kvm-s390.c +++ b/arch/s390/kvm/kvm-s390.c | |||
@@ -753,7 +753,7 @@ static void kvm_gmap_notifier(struct gmap *gmap, unsigned long address) | |||
753 | 753 | ||
754 | kvm_for_each_vcpu(i, vcpu, kvm) { | 754 | kvm_for_each_vcpu(i, vcpu, kvm) { |
755 | /* match against both prefix pages */ | 755 | /* match against both prefix pages */ |
756 | if (vcpu->arch.sie_block->prefix == (address & ~0x1000UL)) { | 756 | if (kvm_s390_get_prefix(vcpu) == (address & ~0x1000UL)) { |
757 | VCPU_EVENT(vcpu, 2, "gmap notifier for %lx", address); | 757 | VCPU_EVENT(vcpu, 2, "gmap notifier for %lx", address); |
758 | kvm_make_request(KVM_REQ_MMU_RELOAD, vcpu); | 758 | kvm_make_request(KVM_REQ_MMU_RELOAD, vcpu); |
759 | exit_sie_sync(vcpu); | 759 | exit_sie_sync(vcpu); |
@@ -1017,7 +1017,7 @@ retry: | |||
1017 | if (kvm_check_request(KVM_REQ_MMU_RELOAD, vcpu)) { | 1017 | if (kvm_check_request(KVM_REQ_MMU_RELOAD, vcpu)) { |
1018 | int rc; | 1018 | int rc; |
1019 | rc = gmap_ipte_notify(vcpu->arch.gmap, | 1019 | rc = gmap_ipte_notify(vcpu->arch.gmap, |
1020 | vcpu->arch.sie_block->prefix, | 1020 | kvm_s390_get_prefix(vcpu), |
1021 | PAGE_SIZE * 2); | 1021 | PAGE_SIZE * 2); |
1022 | if (rc) | 1022 | if (rc) |
1023 | return rc; | 1023 | return rc; |
@@ -1338,7 +1338,7 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) | |||
1338 | 1338 | ||
1339 | kvm_run->psw_mask = vcpu->arch.sie_block->gpsw.mask; | 1339 | kvm_run->psw_mask = vcpu->arch.sie_block->gpsw.mask; |
1340 | kvm_run->psw_addr = vcpu->arch.sie_block->gpsw.addr; | 1340 | kvm_run->psw_addr = vcpu->arch.sie_block->gpsw.addr; |
1341 | kvm_run->s.regs.prefix = vcpu->arch.sie_block->prefix; | 1341 | kvm_run->s.regs.prefix = kvm_s390_get_prefix(vcpu); |
1342 | memcpy(&kvm_run->s.regs.crs, &vcpu->arch.sie_block->gcr, 128); | 1342 | memcpy(&kvm_run->s.regs.crs, &vcpu->arch.sie_block->gcr, 128); |
1343 | 1343 | ||
1344 | if (vcpu->sigset_active) | 1344 | if (vcpu->sigset_active) |
@@ -1357,6 +1357,7 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) | |||
1357 | int kvm_s390_store_status_unloaded(struct kvm_vcpu *vcpu, unsigned long gpa) | 1357 | int kvm_s390_store_status_unloaded(struct kvm_vcpu *vcpu, unsigned long gpa) |
1358 | { | 1358 | { |
1359 | unsigned char archmode = 1; | 1359 | unsigned char archmode = 1; |
1360 | unsigned int px; | ||
1360 | u64 clkcomp; | 1361 | u64 clkcomp; |
1361 | int rc; | 1362 | int rc; |
1362 | 1363 | ||
@@ -1375,8 +1376,9 @@ int kvm_s390_store_status_unloaded(struct kvm_vcpu *vcpu, unsigned long gpa) | |||
1375 | vcpu->run->s.regs.gprs, 128); | 1376 | vcpu->run->s.regs.gprs, 128); |
1376 | rc |= write_guest_abs(vcpu, gpa + offsetof(struct save_area, psw), | 1377 | rc |= write_guest_abs(vcpu, gpa + offsetof(struct save_area, psw), |
1377 | &vcpu->arch.sie_block->gpsw, 16); | 1378 | &vcpu->arch.sie_block->gpsw, 16); |
1379 | px = kvm_s390_get_prefix(vcpu); | ||
1378 | rc |= write_guest_abs(vcpu, gpa + offsetof(struct save_area, pref_reg), | 1380 | rc |= write_guest_abs(vcpu, gpa + offsetof(struct save_area, pref_reg), |
1379 | &vcpu->arch.sie_block->prefix, 4); | 1381 | &px, 4); |
1380 | rc |= write_guest_abs(vcpu, | 1382 | rc |= write_guest_abs(vcpu, |
1381 | gpa + offsetof(struct save_area, fp_ctrl_reg), | 1383 | gpa + offsetof(struct save_area, fp_ctrl_reg), |
1382 | &vcpu->arch.guest_fpregs.fpc, 4); | 1384 | &vcpu->arch.guest_fpregs.fpc, 4); |
diff --git a/arch/s390/kvm/kvm-s390.h b/arch/s390/kvm/kvm-s390.h index 87edfc919db9..a8655ed31616 100644 --- a/arch/s390/kvm/kvm-s390.h +++ b/arch/s390/kvm/kvm-s390.h | |||
@@ -61,9 +61,15 @@ static inline int kvm_is_ucontrol(struct kvm *kvm) | |||
61 | #endif | 61 | #endif |
62 | } | 62 | } |
63 | 63 | ||
64 | #define GUEST_PREFIX_SHIFT 13 | ||
65 | static inline u32 kvm_s390_get_prefix(struct kvm_vcpu *vcpu) | ||
66 | { | ||
67 | return vcpu->arch.sie_block->prefix << GUEST_PREFIX_SHIFT; | ||
68 | } | ||
69 | |||
64 | static inline void kvm_s390_set_prefix(struct kvm_vcpu *vcpu, u32 prefix) | 70 | static inline void kvm_s390_set_prefix(struct kvm_vcpu *vcpu, u32 prefix) |
65 | { | 71 | { |
66 | vcpu->arch.sie_block->prefix = prefix & 0x7fffe000u; | 72 | vcpu->arch.sie_block->prefix = prefix >> GUEST_PREFIX_SHIFT; |
67 | vcpu->arch.sie_block->ihcpu = 0xffff; | 73 | vcpu->arch.sie_block->ihcpu = 0xffff; |
68 | kvm_make_request(KVM_REQ_MMU_RELOAD, vcpu); | 74 | kvm_make_request(KVM_REQ_MMU_RELOAD, vcpu); |
69 | } | 75 | } |
diff --git a/arch/s390/kvm/priv.c b/arch/s390/kvm/priv.c index d99f5f0305a0..6296159ac883 100644 --- a/arch/s390/kvm/priv.c +++ b/arch/s390/kvm/priv.c | |||
@@ -119,8 +119,7 @@ static int handle_store_prefix(struct kvm_vcpu *vcpu) | |||
119 | if (operand2 & 3) | 119 | if (operand2 & 3) |
120 | return kvm_s390_inject_program_int(vcpu, PGM_SPECIFICATION); | 120 | return kvm_s390_inject_program_int(vcpu, PGM_SPECIFICATION); |
121 | 121 | ||
122 | address = vcpu->arch.sie_block->prefix; | 122 | address = kvm_s390_get_prefix(vcpu); |
123 | address = address & 0x7fffe000u; | ||
124 | 123 | ||
125 | /* get the value */ | 124 | /* get the value */ |
126 | rc = write_guest(vcpu, operand2, &address, sizeof(address)); | 125 | rc = write_guest(vcpu, operand2, &address, sizeof(address)); |