420370f3ae
Otherwise we fall through to vmalloc_to_page() which panics since the
address does not lie in the vmalloc region.
Fixes: 043cb41a85
("riscv: introduce interfaces to patch kernel code")
Signed-off-by: Alexandre Ghiti <alexghiti@rivosinc.com>
Reviewed-by: Charlie Jenkins <charlie@rivosinc.com>
Link: https://lore.kernel.org/r/20231214091926.203439-1-alexghiti@rivosinc.com
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
35 lines
883 B
C
35 lines
883 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (C) 2020 Western Digital Corporation or its affiliates.
|
|
*/
|
|
#ifndef __ASM_SECTIONS_H
|
|
#define __ASM_SECTIONS_H
|
|
|
|
#include <asm-generic/sections.h>
|
|
#include <linux/mm.h>
|
|
|
|
extern char _start[];
|
|
extern char _start_kernel[];
|
|
extern char __init_data_begin[], __init_data_end[];
|
|
extern char __init_text_begin[], __init_text_end[];
|
|
extern char __alt_start[], __alt_end[];
|
|
extern char __exittext_begin[], __exittext_end[];
|
|
|
|
static inline bool is_va_kernel_text(uintptr_t va)
|
|
{
|
|
uintptr_t start = (uintptr_t)_start;
|
|
uintptr_t end = (uintptr_t)__init_data_begin;
|
|
|
|
return va >= start && va < end;
|
|
}
|
|
|
|
static inline bool is_va_kernel_lm_alias_text(uintptr_t va)
|
|
{
|
|
uintptr_t start = (uintptr_t)lm_alias(_start);
|
|
uintptr_t end = (uintptr_t)lm_alias(__init_data_begin);
|
|
|
|
return va >= start && va < end;
|
|
}
|
|
|
|
#endif /* __ASM_SECTIONS_H */
|