--- x/mm/hugetlb.c +++ y/mm/hugetlb.c @@ -6251,6 +6251,12 @@ static vm_fault_t hugetlb_no_page(struct VM_UFFD_MISSING); } + if (!(vma->vm_flags & VM_MAYSHARE)) { + ret = vmf_anon_prepare(vmf); + if (unlikely(ret)) + goto out; + } + folio = alloc_hugetlb_folio(vma, vmf->address, 0); if (IS_ERR(folio)) { /* @@ -6290,15 +6296,12 @@ static vm_fault_t hugetlb_no_page(struct restore_reserve_on_error(h, vma, vmf->address, folio); folio_put(folio); + ret = VM_FAULT_SIGBUS; goto out; } new_pagecache_folio = true; } else { folio_lock(folio); - - ret = vmf_anon_prepare(vmf); - if (unlikely(ret)) - goto backout_unlocked; anon_rmap = 1; } } else { --- x/kernel/softirq.c +++ y/kernel/softirq.c @@ -564,7 +564,7 @@ restart: } if (!IS_ENABLED(CONFIG_PREEMPT_RT) && - __this_cpu_read(ksoftirqd) == current) + __this_cpu_read(ksoftirqd) == current && in_task()) rcu_softirq_qs(); local_irq_disable();