[PATCH][makedumpfile] 2/2 riscv64: Fix huge page translation in vtop_riscv64()
Rui Qi
qirui.001 at bytedance.com
Thu May 14 23:48:51 PDT 2026
On 5/14/26 10:26 AM, HAGIO KAZUHITO(萩尾 一仁) wrote:
> 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:
> ^~~
Good catch. The out: label is now unused since we replaced all goto out
with goto invalid. We will remove it in v2.
>
>> + 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.
>
Agreed, using goto invalid for a valid huge page translation path is
indeed misleading. We will replace it with a direct return paddr in v2.
Will send v2 shortly with both issues addressed.
Thanks,
Rui Qi
> 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