Skip to content

Commit 6b79de4

Browse files
Pierre Morelborntraeger
authored andcommitted
KVM: s390: vsie: allow guest FORMAT-1 CRYCB on host FORMAT-2
When the guest schedules a SIE with a CRYCB FORMAT-1 CRYCB, we are able to schedule it in the host with a FORMAT-2 CRYCB if the host uses FORMAT-2. Signed-off-by: Pierre Morel <pmorel@linux.ibm.com> Signed-off-by: Tony Krowiak <akrowiak@linux.ibm.com> Message-Id: <20180925231641.4954-23-akrowiak@linux.vnet.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
1 parent c9ba8c2 commit 6b79de4

File tree

1 file changed

+28
-5
lines changed

1 file changed

+28
-5
lines changed

arch/s390/kvm/vsie.c

Lines changed: 28 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -135,6 +135,22 @@ static int prepare_cpuflags(struct kvm_vcpu *vcpu, struct vsie_page *vsie_page)
135135
atomic_set(&scb_s->cpuflags, newflags);
136136
return 0;
137137
}
138+
/* Copy to APCB FORMAT1 from APCB FORMAT0 */
139+
static int setup_apcb10(struct kvm_vcpu *vcpu, struct kvm_s390_apcb1 *apcb_s,
140+
unsigned long apcb_o, struct kvm_s390_apcb1 *apcb_h)
141+
{
142+
struct kvm_s390_apcb0 tmp;
143+
144+
if (read_guest_real(vcpu, apcb_o, &tmp, sizeof(struct kvm_s390_apcb0)))
145+
return -EFAULT;
146+
147+
apcb_s->apm[0] = apcb_h->apm[0] & tmp.apm[0];
148+
apcb_s->aqm[0] = apcb_h->aqm[0] & tmp.aqm[0] & 0xffff000000000000UL;
149+
apcb_s->adm[0] = apcb_h->adm[0] & tmp.adm[0] & 0xffff000000000000UL;
150+
151+
return 0;
152+
153+
}
138154

139155
/**
140156
* setup_apcb00 - Copy to APCB FORMAT0 from APCB FORMAT0
@@ -212,11 +228,18 @@ static int setup_apcb(struct kvm_vcpu *vcpu, struct kvm_s390_crypto_cb *crycb_s,
212228
(unsigned long) &crycb->apcb1,
213229
(unsigned long *)&crycb_h->apcb1);
214230
case CRYCB_FORMAT1:
215-
if (fmt_h != CRYCB_FORMAT1)
216-
return -EINVAL;
217-
return setup_apcb00(vcpu, (unsigned long *) &crycb_s->apcb0,
218-
(unsigned long) &crycb->apcb0,
219-
(unsigned long *) &crycb_h->apcb0);
231+
switch (fmt_h) {
232+
case CRYCB_FORMAT2:
233+
return setup_apcb10(vcpu, &crycb_s->apcb1,
234+
(unsigned long) &crycb->apcb0,
235+
&crycb_h->apcb1);
236+
case CRYCB_FORMAT1:
237+
return setup_apcb00(vcpu,
238+
(unsigned long *) &crycb_s->apcb0,
239+
(unsigned long) &crycb->apcb0,
240+
(unsigned long *) &crycb_h->apcb0);
241+
}
242+
break;
220243
case CRYCB_FORMAT0:
221244
if ((crycb_o & PAGE_MASK) != ((crycb_o + 32) & PAGE_MASK))
222245
return -EACCES;

0 commit comments

Comments
 (0)