* [PATCH v1 1/1] KVM: s390: Fix a deadlock
@ 2026-03-03 17:52 Claudio Imbrenda
2026-03-04 8:07 ` Christoph Schlameuss
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Claudio Imbrenda @ 2026-03-03 17:52 UTC (permalink / raw)
To: kvm
Cc: linux-kernel, linux-s390, borntraeger, frankja, nsg, nrb, seiden,
gra, schlameuss, hca, david
In some scenarios, a deadlock can happen, involving _do_shadow_pte().
Convert all usages of pgste_get_lock() to pgste_get_trylock() in
_do_shadow_pte() and return -EAGAIN. All callers can already deal with
-EAGAIN being returned.
Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
Fixes: e38c884df921 ("KVM: s390: Switch to new gmap")
---
arch/s390/kvm/gaccess.c | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/arch/s390/kvm/gaccess.c b/arch/s390/kvm/gaccess.c
index 4630b2a067ea..a9da9390867d 100644
--- a/arch/s390/kvm/gaccess.c
+++ b/arch/s390/kvm/gaccess.c
@@ -1434,7 +1434,8 @@ static int _do_shadow_pte(struct gmap *sg, gpa_t raddr, union pte *ptep_h, union
if (rc)
return rc;
- pgste = pgste_get_lock(ptep_h);
+ if (!pgste_get_trylock(ptep_h, &pgste))
+ return -EAGAIN;
newpte = _pte(f->pfn, f->writable, !p, 0);
newpte.s.d |= ptep->s.d;
newpte.s.sd |= ptep->s.sd;
@@ -1444,7 +1445,8 @@ static int _do_shadow_pte(struct gmap *sg, gpa_t raddr, union pte *ptep_h, union
pgste_set_unlock(ptep_h, pgste);
newpte = _pte(f->pfn, 0, !p, 0);
- pgste = pgste_get_lock(ptep);
+ if (!pgste_get_trylock(ptep, &pgste))
+ return -EAGAIN;
pgste = __dat_ptep_xchg(ptep, pgste, newpte, gpa_to_gfn(raddr), sg->asce, uses_skeys(sg));
pgste_set_unlock(ptep, pgste);
--
2.53.0
^ permalink raw reply related [flat|nested] 4+ messages in thread* Re: [PATCH v1 1/1] KVM: s390: Fix a deadlock
2026-03-03 17:52 [PATCH v1 1/1] KVM: s390: Fix a deadlock Claudio Imbrenda
@ 2026-03-04 8:07 ` Christoph Schlameuss
2026-03-04 12:36 ` Janosch Frank
2026-03-05 15:44 ` Christian Borntraeger
2 siblings, 0 replies; 4+ messages in thread
From: Christoph Schlameuss @ 2026-03-04 8:07 UTC (permalink / raw)
To: Claudio Imbrenda, kvm
Cc: linux-kernel, linux-s390, borntraeger, frankja, nsg, nrb, seiden,
gra, schlameuss, hca, david
On Tue Mar 3, 2026 at 6:52 PM CET, Claudio Imbrenda wrote:
> In some scenarios, a deadlock can happen, involving _do_shadow_pte().
>
> Convert all usages of pgste_get_lock() to pgste_get_trylock() in
> _do_shadow_pte() and return -EAGAIN. All callers can already deal with
> -EAGAIN being returned.
>
> Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
> Fixes: e38c884df921 ("KVM: s390: Switch to new gmap")
Reviewed-by: Christoph Schlameuss <schlameuss@linux.ibm.com>
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [PATCH v1 1/1] KVM: s390: Fix a deadlock
2026-03-03 17:52 [PATCH v1 1/1] KVM: s390: Fix a deadlock Claudio Imbrenda
2026-03-04 8:07 ` Christoph Schlameuss
@ 2026-03-04 12:36 ` Janosch Frank
2026-03-05 15:44 ` Christian Borntraeger
2 siblings, 0 replies; 4+ messages in thread
From: Janosch Frank @ 2026-03-04 12:36 UTC (permalink / raw)
To: Claudio Imbrenda, kvm
Cc: linux-kernel, linux-s390, borntraeger, nsg, nrb, seiden, gra,
schlameuss, hca, david
On 3/3/26 18:52, Claudio Imbrenda wrote:
> In some scenarios, a deadlock can happen, involving _do_shadow_pte().
>
> Convert all usages of pgste_get_lock() to pgste_get_trylock() in
> _do_shadow_pte() and return -EAGAIN. All callers can already deal with
> -EAGAIN being returned.
>
> Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
> Fixes: e38c884df921 ("KVM: s390: Switch to new gmap")
Reviewed-by: Janosch Frank <frankja@linux.ibm.com>
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [PATCH v1 1/1] KVM: s390: Fix a deadlock
2026-03-03 17:52 [PATCH v1 1/1] KVM: s390: Fix a deadlock Claudio Imbrenda
2026-03-04 8:07 ` Christoph Schlameuss
2026-03-04 12:36 ` Janosch Frank
@ 2026-03-05 15:44 ` Christian Borntraeger
2 siblings, 0 replies; 4+ messages in thread
From: Christian Borntraeger @ 2026-03-05 15:44 UTC (permalink / raw)
To: Claudio Imbrenda, kvm
Cc: linux-kernel, linux-s390, frankja, nsg, nrb, seiden, gra,
schlameuss, hca, david
Am 03.03.26 um 18:52 schrieb Claudio Imbrenda:
> In some scenarios, a deadlock can happen, involving _do_shadow_pte().
>
> Convert all usages of pgste_get_lock() to pgste_get_trylock() in
> _do_shadow_pte() and return -EAGAIN. All callers can already deal with
> -EAGAIN being returned.
>
> Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
> Fixes: e38c884df921 ("KVM: s390: Switch to new gmap")
Tested-by: Christian Borntraeger <borntraeger@linux.ibm.com>
I no longer see the rcu stalls.
> ---
> arch/s390/kvm/gaccess.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/arch/s390/kvm/gaccess.c b/arch/s390/kvm/gaccess.c
> index 4630b2a067ea..a9da9390867d 100644
> --- a/arch/s390/kvm/gaccess.c
> +++ b/arch/s390/kvm/gaccess.c
> @@ -1434,7 +1434,8 @@ static int _do_shadow_pte(struct gmap *sg, gpa_t raddr, union pte *ptep_h, union
> if (rc)
> return rc;
>
> - pgste = pgste_get_lock(ptep_h);
> + if (!pgste_get_trylock(ptep_h, &pgste))
> + return -EAGAIN;
> newpte = _pte(f->pfn, f->writable, !p, 0);
> newpte.s.d |= ptep->s.d;
> newpte.s.sd |= ptep->s.sd;
> @@ -1444,7 +1445,8 @@ static int _do_shadow_pte(struct gmap *sg, gpa_t raddr, union pte *ptep_h, union
> pgste_set_unlock(ptep_h, pgste);
>
> newpte = _pte(f->pfn, 0, !p, 0);
> - pgste = pgste_get_lock(ptep);
> + if (!pgste_get_trylock(ptep, &pgste))
> + return -EAGAIN;
> pgste = __dat_ptep_xchg(ptep, pgste, newpte, gpa_to_gfn(raddr), sg->asce, uses_skeys(sg));
> pgste_set_unlock(ptep, pgste);
>
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2026-03-05 15:44 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-03-03 17:52 [PATCH v1 1/1] KVM: s390: Fix a deadlock Claudio Imbrenda
2026-03-04 8:07 ` Christoph Schlameuss
2026-03-04 12:36 ` Janosch Frank
2026-03-05 15:44 ` Christian Borntraeger
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox