diff options
author | Helge Deller <deller@gmx.de> | 2021-10-31 21:58:12 +0100 |
---|---|---|
committer | Helge Deller <deller@gmx.de> | 2021-11-01 12:00:22 +0100 |
commit | 6e866a462867b60841202e900f10936a0478608c (patch) | |
tree | 66c92ef6e80332c11b902e5001065a38047c0fe5 /arch/parisc | |
parent | parisc: Use swap() to swap values in setup_bootmem() (diff) | |
download | linux-6e866a462867b60841202e900f10936a0478608c.tar.xz linux-6e866a462867b60841202e900f10936a0478608c.zip |
parisc: Fix set_fixmap() on PA1.x CPUs
Fix a kernel crash which happens on PA1.x CPUs while initializing the
FTRACE/KPROBE breakpoints. The PTE table entries for the fixmap area
were not created correctly.
Signed-off-by: Helge Deller <deller@gmx.de>
Fixes: ccfbc68d41c2 ("parisc: add set_fixmap()/clear_fixmap()")
Cc: stable@vger.kernel.org # v5.2+
Diffstat (limited to 'arch/parisc')
-rw-r--r-- | arch/parisc/mm/fixmap.c | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/arch/parisc/mm/fixmap.c b/arch/parisc/mm/fixmap.c index 24426a7e1a5e..cc15d737fda6 100644 --- a/arch/parisc/mm/fixmap.c +++ b/arch/parisc/mm/fixmap.c @@ -20,12 +20,9 @@ void notrace set_fixmap(enum fixed_addresses idx, phys_addr_t phys) pte_t *pte; if (pmd_none(*pmd)) - pmd = pmd_alloc(NULL, pud, vaddr); - - pte = pte_offset_kernel(pmd, vaddr); - if (pte_none(*pte)) pte = pte_alloc_kernel(pmd, vaddr); + pte = pte_offset_kernel(pmd, vaddr); set_pte_at(&init_mm, vaddr, pte, __mk_pte(phys, PAGE_KERNEL_RWX)); flush_tlb_kernel_range(vaddr, vaddr + PAGE_SIZE); } |