aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
diff options
context:
space:
mode:
authorMing Wang <[email protected]>2025-04-24 12:15:47 +0000
committerHuacai Chen <[email protected]>2025-04-26 01:58:12 +0000
commitbd51834d1cf65a2c801295d230c220aeebf87a73 (patch)
tree2e29953b31ac94381968adc1f1c7e4e479bf5f93 /drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
parentLoongArch: Remove a bogus reference to ZONE_DMA (diff)
downloadkernel-bd51834d1cf65a2c801295d230c220aeebf87a73.tar.gz
kernel-bd51834d1cf65a2c801295d230c220aeebf87a73.zip
LoongArch: Return NULL from huge_pte_offset() for invalid PMD
LoongArch's huge_pte_offset() currently returns a pointer to a PMD slot even if the underlying entry points to invalid_pte_table (indicating no mapping). Callers like smaps_hugetlb_range() fetch this invalid entry value (the address of invalid_pte_table) via this pointer. The generic is_swap_pte() check then incorrectly identifies this address as a swap entry on LoongArch, because it satisfies the "!pte_present() && !pte_none()" conditions. This misinterpretation, combined with a coincidental match by is_migration_entry() on the address bits, leads to kernel crashes in pfn_swap_entry_to_page(). Fix this at the architecture level by modifying huge_pte_offset() to check the PMD entry's content using pmd_none() before returning. If the entry is invalid (i.e., it points to invalid_pte_table), return NULL instead of the pointer to the slot. Cc: [email protected] Acked-by: Peter Xu <[email protected]> Co-developed-by: Hongchen Zhang <[email protected]> Signed-off-by: Hongchen Zhang <[email protected]> Signed-off-by: Ming Wang <[email protected]> Signed-off-by: Huacai Chen <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_object.c')
0 files changed, 0 insertions, 0 deletions