mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-24 19:12:14 +00:00
Add PPC64 Radix MMU support to the va_high_addr_switch.sh by introducing check_supported_ppc64(). The function verifies: - 5-level paging (PGTABLE_LEVELS >= 5) enable in kernel config - Radix MMU (required for PPC64 5-level translation) - HugePages availability (needed for some tests) If any check fails, the test is skipped (ksft_skip). This ensures compatibility with Power9/Power10 systems running in Radix MMU mode. Avoid failures on 4-level paging system: # mmap(NULL, MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(LOW_ADDR, MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(HIGH_ADDR, MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(HIGH_ADDR, MAP_HUGETLB) again: 0xffffffffffffffff - FAILED # mmap(HIGH_ADDR, MAP_FIXED | MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(-1, MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(-1, MAP_HUGETLB) again: 0xffffffffffffffff - FAILED # mmap(ADDR_SWITCH_HINT - PAGE_SIZE, 2*HUGETLB_SIZE, MAP_HUGETLB): 0xffffffffffffffff - FAILED # mmap(ADDR_SWITCH_HINT , 2*HUGETLB_SIZE, MAP_FIXED | MAP_HUGETLB): 0xffffffffffffffff - FAILED Link: https://lkml.kernel.org/r/20250327114813.25980-1-liwang@redhat.com Signed-off-by: Li Wang <liwang@redhat.com> Cc: Anshuman Khandual <anshuman.khandual@arm.com> Cc: Dev Jain <dev.jain@arm.com> Cc: Kirill A. Shuemov <kirill.shutemov@linux.intel.com> Cc: Shuah Khan <shuah@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
89 lines
2.4 KiB
Bash
Executable File
89 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
#
|
|
# Copyright (C) 2022 Adam Sindelar (Meta) <adam@wowsignal.io>
|
|
#
|
|
# This is a test for mmap behavior with 5-level paging. This script wraps the
|
|
# real test to check that the kernel is configured to support at least 5
|
|
# pagetable levels.
|
|
|
|
# 1 means the test failed
|
|
exitcode=1
|
|
|
|
# Kselftest framework requirement - SKIP code is 4.
|
|
ksft_skip=4
|
|
|
|
fail()
|
|
{
|
|
echo "$1"
|
|
exit $exitcode
|
|
}
|
|
|
|
check_supported_x86_64()
|
|
{
|
|
local config="/proc/config.gz"
|
|
[[ -f "${config}" ]] || config="/boot/config-$(uname -r)"
|
|
[[ -f "${config}" ]] || fail "Cannot find kernel config in /proc or /boot"
|
|
|
|
# gzip -dcfq automatically handles both compressed and plaintext input.
|
|
# See man 1 gzip under '-f'.
|
|
local pg_table_levels=$(gzip -dcfq "${config}" | grep PGTABLE_LEVELS | cut -d'=' -f 2)
|
|
|
|
local cpu_supports_pl5=$(awk '/^flags/ {if (/la57/) {print 0;}
|
|
else {print 1}; exit}' /proc/cpuinfo 2>/dev/null)
|
|
|
|
if [[ "${pg_table_levels}" -lt 5 ]]; then
|
|
echo "$0: PGTABLE_LEVELS=${pg_table_levels}, must be >= 5 to run this test"
|
|
exit $ksft_skip
|
|
elif [[ "${cpu_supports_pl5}" -ne 0 ]]; then
|
|
echo "$0: CPU does not have the necessary la57 flag to support page table level 5"
|
|
exit $ksft_skip
|
|
fi
|
|
}
|
|
|
|
check_supported_ppc64()
|
|
{
|
|
local config="/proc/config.gz"
|
|
[[ -f "${config}" ]] || config="/boot/config-$(uname -r)"
|
|
[[ -f "${config}" ]] || fail "Cannot find kernel config in /proc or /boot"
|
|
|
|
local pg_table_levels=$(gzip -dcfq "${config}" | grep PGTABLE_LEVELS | cut -d'=' -f 2)
|
|
if [[ "${pg_table_levels}" -lt 5 ]]; then
|
|
echo "$0: PGTABLE_LEVELS=${pg_table_levels}, must be >= 5 to run this test"
|
|
exit $ksft_skip
|
|
fi
|
|
|
|
local mmu_support=$(grep -m1 "mmu" /proc/cpuinfo | awk '{print $3}')
|
|
if [[ "$mmu_support" != "radix" ]]; then
|
|
echo "$0: System does not use Radix MMU, required for 5-level paging"
|
|
exit $ksft_skip
|
|
fi
|
|
|
|
local hugepages_total=$(awk '/HugePages_Total/ {print $2}' /proc/meminfo)
|
|
if [[ "${hugepages_total}" -eq 0 ]]; then
|
|
echo "$0: HugePages are not enabled, required for some tests"
|
|
exit $ksft_skip
|
|
fi
|
|
}
|
|
|
|
check_test_requirements()
|
|
{
|
|
# The test supports x86_64 and powerpc64. We currently have no useful
|
|
# eligibility check for powerpc64, and the test itself will reject other
|
|
# architectures.
|
|
case `uname -m` in
|
|
"x86_64")
|
|
check_supported_x86_64
|
|
;;
|
|
"ppc64le"|"ppc64")
|
|
check_supported_ppc64
|
|
;;
|
|
*)
|
|
return 0
|
|
;;
|
|
esac
|
|
}
|
|
|
|
check_test_requirements
|
|
./va_high_addr_switch --run-hugetlb
|