[PATCH][makedumpfile] 2/2 riscv64: Fix huge page translation in vtop_riscv64()
HAGIO KAZUHITO(萩尾 一仁)
k-hagio-ab at nec.com
Wed May 13 19:26:43 PDT 2026
On 2026/05/06 20:57, Rui Qi wrote:
> When a page table entry has _PAGE_LEAF set at PGD/P4D/PUD/PMD level,
> the current code incorrectly falls through to the next level instead
> of computing the correct physical address. Fix this by calculating
> the paddr with the proper level shift and returning directly.
>
> Co-developed-by: Rui Qi <qirui.001 at bytedance.com>
> Signed-off-by: Shuan He <heshuan at bytedance.com>
> ---
> arch/riscv64.c | 26 ++++++++++++++++++--------
> 1 file changed, 18 insertions(+), 8 deletions(-)
>
> diff --git a/arch/riscv64.c b/arch/riscv64.c
> index 28365fa0cc5b..67755331de24 100644
> --- a/arch/riscv64.c
> +++ b/arch/riscv64.c
> @@ -107,8 +107,12 @@ vtop_riscv64(pgd_t * pgd, unsigned long vaddr, long va_bits)
>
> pt_phys = (pt_val >> _PAGE_PFN_SHIFT) << PAGESHIFT();
>
> - if (pt_val & _PAGE_LEAF)
> - goto out;
the following warning is observed:
cc -g -O2 -Wall -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D__riscv64__ -U__x86_64__ -c -o ./arch/riscv64.o arch/riscv64.c
arch/riscv64.c: In function 'vtop_riscv64':
arch/riscv64.c:203:1: warning: label 'out' defined but not used [-Wunused-label]
out:
^~~
> + if (pt_val & _PAGE_LEAF) {
> + unsigned long shift = (va_bits == VA_BITS_SV57) ? PGD_SHIFT_L5 :
> + (va_bits == VA_BITS_SV48) ? PGD_SHIFT_L4 : PGD_SHIFT_L3;
> + paddr = (pt_phys & ~((1ULL << shift) - 1)) + (vaddr & ((1ULL << shift) - 1));
> + goto invalid;
just a style point, if this path is not invalid, please do no use the 'invalid'
label and better to return here instead.
Thanks,
Kazu
> + }
>
> if (va_bits == VA_BITS_SV57)
> goto p4d;
> @@ -133,8 +137,10 @@ p4d:
>
> pt_phys = (pt_val >> _PAGE_PFN_SHIFT) << PAGESHIFT();
>
> - if (pt_val & _PAGE_LEAF)
> - goto out;
> + if (pt_val & _PAGE_LEAF) {
> + paddr = (pt_phys & ~((1ULL << P4D_SHIFT) - 1)) + (vaddr & ((1ULL << P4D_SHIFT) - 1));
> + goto invalid;
> + }
> pud:
> /* PUD */
> puda = (pud_t *)(pt_phys) + pud_index(vaddr);
> @@ -152,8 +158,10 @@ pud:
>
> pt_phys = (pt_val >> _PAGE_PFN_SHIFT) << PAGESHIFT();
>
> - if(pt_val & _PAGE_LEAF)
> - goto out;
> + if (pt_val & _PAGE_LEAF) {
> + paddr = (pt_phys & ~((1ULL << PUD_SHIFT) - 1)) + (vaddr & ((1ULL << PUD_SHIFT) - 1));
> + goto invalid;
> + }
> pmd:
> /* PMD */
> pmda = (pmd_t *)(pt_phys) + pmd_index(vaddr);
> @@ -171,8 +179,10 @@ pmd:
>
> pt_phys = (pt_val >> _PAGE_PFN_SHIFT) << PAGESHIFT();
>
> - if (pt_val & _PAGE_LEAF)
> - goto out;
> + if (pt_val & _PAGE_LEAF) {
> + paddr = (pt_phys & ~((1ULL << PMD_SHIFT) - 1)) + (vaddr & ((1ULL << PMD_SHIFT) - 1));
> + goto invalid;
> + }
>
> /* PTE */
> ptea = (pte_t *)(pt_phys) + pte_index(vaddr);
More information about the kexec
mailing list