Skip to content

Commit ccc59f4

Browse files
committed
Merge tag 'kvm-s390-master-4.13-2' into kvms390/next
Additional fixes on top of these two - missing inline assembly constraint - wrong exception handling are necessary
2 parents 962734f + 857b8de commit ccc59f4

File tree

2 files changed

+11
-4
lines changed

2 files changed

+11
-4
lines changed

arch/s390/kvm/kvm-s390.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1324,7 +1324,7 @@ static long kvm_s390_get_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
13241324
{
13251325
uint8_t *keys;
13261326
uint64_t hva;
1327-
int i, r = 0;
1327+
int srcu_idx, i, r = 0;
13281328

13291329
if (args->flags != 0)
13301330
return -EINVAL;
@@ -1342,6 +1342,7 @@ static long kvm_s390_get_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
13421342
return -ENOMEM;
13431343

13441344
down_read(&current->mm->mmap_sem);
1345+
srcu_idx = srcu_read_lock(&kvm->srcu);
13451346
for (i = 0; i < args->count; i++) {
13461347
hva = gfn_to_hva(kvm, args->start_gfn + i);
13471348
if (kvm_is_error_hva(hva)) {
@@ -1353,6 +1354,7 @@ static long kvm_s390_get_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
13531354
if (r)
13541355
break;
13551356
}
1357+
srcu_read_unlock(&kvm->srcu, srcu_idx);
13561358
up_read(&current->mm->mmap_sem);
13571359

13581360
if (!r) {
@@ -1370,7 +1372,7 @@ static long kvm_s390_set_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
13701372
{
13711373
uint8_t *keys;
13721374
uint64_t hva;
1373-
int i, r = 0;
1375+
int srcu_idx, i, r = 0;
13741376

13751377
if (args->flags != 0)
13761378
return -EINVAL;
@@ -1396,6 +1398,7 @@ static long kvm_s390_set_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
13961398
goto out;
13971399

13981400
down_read(&current->mm->mmap_sem);
1401+
srcu_idx = srcu_read_lock(&kvm->srcu);
13991402
for (i = 0; i < args->count; i++) {
14001403
hva = gfn_to_hva(kvm, args->start_gfn + i);
14011404
if (kvm_is_error_hva(hva)) {
@@ -1413,6 +1416,7 @@ static long kvm_s390_set_skeys(struct kvm *kvm, struct kvm_s390_skeys *args)
14131416
if (r)
14141417
break;
14151418
}
1419+
srcu_read_unlock(&kvm->srcu, srcu_idx);
14161420
up_read(&current->mm->mmap_sem);
14171421
out:
14181422
kvfree(keys);

arch/s390/kvm/sthyi.c

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -394,7 +394,7 @@ static int sthyi(u64 vaddr)
394394
"srl %[cc],28\n"
395395
: [cc] "=d" (cc)
396396
: [code] "d" (code), [addr] "a" (addr)
397-
: "memory", "cc");
397+
: "3", "memory", "cc");
398398
return cc;
399399
}
400400

@@ -425,14 +425,17 @@ int handle_sthyi(struct kvm_vcpu *vcpu)
425425
VCPU_EVENT(vcpu, 3, "STHYI: fc: %llu addr: 0x%016llx", code, addr);
426426
trace_kvm_s390_handle_sthyi(vcpu, code, addr);
427427

428-
if (reg1 == reg2 || reg1 & 1 || reg2 & 1 || addr & ~PAGE_MASK)
428+
if (reg1 == reg2 || reg1 & 1 || reg2 & 1)
429429
return kvm_s390_inject_program_int(vcpu, PGM_SPECIFICATION);
430430

431431
if (code & 0xffff) {
432432
cc = 3;
433433
goto out;
434434
}
435435

436+
if (addr & ~PAGE_MASK)
437+
return kvm_s390_inject_program_int(vcpu, PGM_SPECIFICATION);
438+
436439
/*
437440
* If the page has not yet been faulted in, we want to do that
438441
* now and not after all the expensive calculations.

0 commit comments

Comments
 (0)