Skip to content

Commit cb9083e

Browse files
committed
Merge tag 'kvm-s390-master-4.13-1' of git://git.kernel.org/pub/scm/linux/kernel/git/kvms390/linux into HEAD
KVM: s390: fixup missing srcu lock We need to hold the srcu lock when accessing memory slots during migration Signed-off-by: Paolo Bonzini <[email protected]>
2 parents 2d6144e + 4f89914 commit cb9083e

File tree

1 file changed

+6
-2
lines changed

1 file changed

+6
-2
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);

0 commit comments

Comments
 (0)