]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
x86/xen: Fix Xen PV guest boot
authorJuergen Gross <jgross@suse.com>
Sat, 14 Feb 2026 13:50:35 +0000 (14:50 +0100)
committerJuergen Gross <jgross@suse.com>
Wed, 18 Feb 2026 09:47:58 +0000 (10:47 +0100)
A recent patch moving the call of sparse_init() to common mm code
broke booting as a Xen PV guest.

Reason is that the Xen PV specific boot code relied on struct page area
being accessible rather early, but this changed by the move of the call
of sparse_init().

Fortunately the fix is rather easy: there is a static branch available
indicating whether struct page contents are usable by Xen. This static
branch just needs to be tested in some places for avoiding the access
of struct page.

Fixes: 4267739cabb8 ("arch, mm: consolidate initialization of SPARSE memory model")
Signed-off-by: Juergen Gross <jgross@suse.com>
Message-ID: <20260214135035.119357-1-jgross@suse.com>

arch/x86/xen/mmu_pv.c

index 2a4a8deaf612f5211defacc22dfed850a8e4889c..aa6755385887ea9c47ac59906c6d0e2c3f637c09 100644 (file)
@@ -509,6 +509,9 @@ static pgd_t *xen_get_user_pgd(pgd_t *pgd)
        unsigned offset = pgd - pgd_page;
        pgd_t *user_ptr = NULL;
 
+       if (!static_branch_likely(&xen_struct_pages_ready))
+               return NULL;
+
        if (offset < pgd_index(USER_LIMIT)) {
                struct page *page = virt_to_page(pgd_page);
                user_ptr = (pgd_t *)page->private;
@@ -1098,7 +1101,8 @@ static void __init xen_cleanmfnmap_free_pgtbl(void *pgtbl, bool unpin)
 
        if (unpin)
                pin_pagetable_pfn(MMUEXT_UNPIN_TABLE, PFN_DOWN(pa));
-       ClearPagePinned(virt_to_page(__va(pa)));
+       if (static_branch_likely(&xen_struct_pages_ready))
+               ClearPagePinned(virt_to_page(__va(pa)));
        xen_free_ro_pages(pa, PAGE_SIZE);
 }