Re: [PATCH] s390/mm: Fix in_atomic() handling in do_secure_storage_access()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 4 Jun 2025 18:27:49 +0200
Alexander Gordeev <agordeev@xxxxxxxxxxxxx> wrote:

> On Tue, Jun 03, 2025 at 03:49:36PM +0200, Heiko Carstens wrote:
> > diff --git a/arch/s390/mm/fault.c b/arch/s390/mm/fault.c
> > index 3829521450dd..e1ad05bfd28a 100644
> > --- a/arch/s390/mm/fault.c
> > +++ b/arch/s390/mm/fault.c
> > @@ -441,6 +441,8 @@ void do_secure_storage_access(struct pt_regs *regs)
> >  		if (rc)
> >  			BUG();
> >  	} else {
> > +		if (faulthandler_disabled())
> > +			return handle_fault_error_nolock(regs, 0);
> >  
> 
> This could trigger WARN_ON_ONCE() in handle_fault_error_nolock():
> 
> 		if (WARN_ON_ONCE(!si_code))
> 			si_code = SEGV_MAPERR;
> 
> Would this warning be justified in this case (aka user_mode(regs) ==
> true)?

I think so, because if we are in usermode, we should never trigger
faulthandler_disabled()

> 
> >  		mm = current->mm;
> >  		mmap_read_lock(mm);
> >  		vma = find_vma(mm, addr);  





[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux