Commit f27a5c93 authored by Aneesh Kumar K.V's avatar Aneesh Kumar K.V Committed by Linus Torvalds

selftest/mremap_test: update the test to handle pagesize other than 4K

Patch series "mrermap fixes", v2.

This patch (of 6):

Instead of hardcoding 4K page size fetch it using sysconf().  For the
performance measurements test still assume 2M and 1G are hugepage sizes.

Link: https://lkml.kernel.org/r/20210616045239.370802-1-aneesh.kumar@linux.ibm.com
Link: https://lkml.kernel.org/r/20210616045239.370802-2-aneesh.kumar@linux.ibm.comSigned-off-by: default avatarAneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
Reviewed-by: default avatarKalesh Singh <kaleshsingh@google.com>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Nicholas Piggin <npiggin@gmail.com>
Cc: Joel Fernandes <joel@joelfernandes.org>
Cc: Christophe Leroy <christophe.leroy@csgroup.eu>
Cc: Kirill A. Shutemov <kirill@shutemov.name>
Cc: Hugh Dickins <hughd@google.com>
Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Stephen Rothwell <sfr@canb.auug.org.au>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent dc4875f0
...@@ -45,14 +45,15 @@ enum { ...@@ -45,14 +45,15 @@ enum {
_4MB = 4ULL << 20, _4MB = 4ULL << 20,
_1GB = 1ULL << 30, _1GB = 1ULL << 30,
_2GB = 2ULL << 30, _2GB = 2ULL << 30,
PTE = _4KB,
PMD = _2MB, PMD = _2MB,
PUD = _1GB, PUD = _1GB,
}; };
#define PTE page_size
#define MAKE_TEST(source_align, destination_align, size, \ #define MAKE_TEST(source_align, destination_align, size, \
overlaps, should_fail, test_name) \ overlaps, should_fail, test_name) \
{ \ (struct test){ \
.name = test_name, \ .name = test_name, \
.config = { \ .config = { \
.src_alignment = source_align, \ .src_alignment = source_align, \
...@@ -252,12 +253,17 @@ static int parse_args(int argc, char **argv, unsigned int *threshold_mb, ...@@ -252,12 +253,17 @@ static int parse_args(int argc, char **argv, unsigned int *threshold_mb,
return 0; return 0;
} }
#define MAX_TEST 13
#define MAX_PERF_TEST 3
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
int failures = 0; int failures = 0;
int i, run_perf_tests; int i, run_perf_tests;
unsigned int threshold_mb = VALIDATION_DEFAULT_THRESHOLD; unsigned int threshold_mb = VALIDATION_DEFAULT_THRESHOLD;
unsigned int pattern_seed; unsigned int pattern_seed;
struct test test_cases[MAX_TEST];
struct test perf_test_cases[MAX_PERF_TEST];
int page_size;
time_t t; time_t t;
pattern_seed = (unsigned int) time(&t); pattern_seed = (unsigned int) time(&t);
...@@ -268,56 +274,59 @@ int main(int argc, char **argv) ...@@ -268,56 +274,59 @@ int main(int argc, char **argv)
ksft_print_msg("Test configs:\n\tthreshold_mb=%u\n\tpattern_seed=%u\n\n", ksft_print_msg("Test configs:\n\tthreshold_mb=%u\n\tpattern_seed=%u\n\n",
threshold_mb, pattern_seed); threshold_mb, pattern_seed);
struct test test_cases[] = { page_size = sysconf(_SC_PAGESIZE);
/* Expected mremap failures */
MAKE_TEST(_4KB, _4KB, _4KB, OVERLAPPING, EXPECT_FAILURE, /* Expected mremap failures */
"mremap - Source and Destination Regions Overlapping"), test_cases[0] = MAKE_TEST(page_size, page_size, page_size,
MAKE_TEST(_4KB, _1KB, _4KB, NON_OVERLAPPING, EXPECT_FAILURE, OVERLAPPING, EXPECT_FAILURE,
"mremap - Destination Address Misaligned (1KB-aligned)"), "mremap - Source and Destination Regions Overlapping");
MAKE_TEST(_1KB, _4KB, _4KB, NON_OVERLAPPING, EXPECT_FAILURE,
"mremap - Source Address Misaligned (1KB-aligned)"), test_cases[1] = MAKE_TEST(page_size, page_size/4, page_size,
NON_OVERLAPPING, EXPECT_FAILURE,
/* Src addr PTE aligned */ "mremap - Destination Address Misaligned (1KB-aligned)");
MAKE_TEST(PTE, PTE, _8KB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[2] = MAKE_TEST(page_size/4, page_size, page_size,
"8KB mremap - Source PTE-aligned, Destination PTE-aligned"), NON_OVERLAPPING, EXPECT_FAILURE,
"mremap - Source Address Misaligned (1KB-aligned)");
/* Src addr 1MB aligned */
MAKE_TEST(_1MB, PTE, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS, /* Src addr PTE aligned */
"2MB mremap - Source 1MB-aligned, Destination PTE-aligned"), test_cases[3] = MAKE_TEST(PTE, PTE, PTE * 2,
MAKE_TEST(_1MB, _1MB, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS, NON_OVERLAPPING, EXPECT_SUCCESS,
"2MB mremap - Source 1MB-aligned, Destination 1MB-aligned"), "8KB mremap - Source PTE-aligned, Destination PTE-aligned");
/* Src addr PMD aligned */ /* Src addr 1MB aligned */
MAKE_TEST(PMD, PTE, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[4] = MAKE_TEST(_1MB, PTE, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
"4MB mremap - Source PMD-aligned, Destination PTE-aligned"), "2MB mremap - Source 1MB-aligned, Destination PTE-aligned");
MAKE_TEST(PMD, _1MB, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[5] = MAKE_TEST(_1MB, _1MB, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
"4MB mremap - Source PMD-aligned, Destination 1MB-aligned"), "2MB mremap - Source 1MB-aligned, Destination 1MB-aligned");
MAKE_TEST(PMD, PMD, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
"4MB mremap - Source PMD-aligned, Destination PMD-aligned"), /* Src addr PMD aligned */
test_cases[6] = MAKE_TEST(PMD, PTE, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
/* Src addr PUD aligned */ "4MB mremap - Source PMD-aligned, Destination PTE-aligned");
MAKE_TEST(PUD, PTE, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[7] = MAKE_TEST(PMD, _1MB, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
"2GB mremap - Source PUD-aligned, Destination PTE-aligned"), "4MB mremap - Source PMD-aligned, Destination 1MB-aligned");
MAKE_TEST(PUD, _1MB, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[8] = MAKE_TEST(PMD, PMD, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
"2GB mremap - Source PUD-aligned, Destination 1MB-aligned"), "4MB mremap - Source PMD-aligned, Destination PMD-aligned");
MAKE_TEST(PUD, PMD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"2GB mremap - Source PUD-aligned, Destination PMD-aligned"), /* Src addr PUD aligned */
MAKE_TEST(PUD, PUD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS, test_cases[9] = MAKE_TEST(PUD, PTE, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"2GB mremap - Source PUD-aligned, Destination PUD-aligned"), "2GB mremap - Source PUD-aligned, Destination PTE-aligned");
}; test_cases[10] = MAKE_TEST(PUD, _1MB, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"2GB mremap - Source PUD-aligned, Destination 1MB-aligned");
struct test perf_test_cases[] = { test_cases[11] = MAKE_TEST(PUD, PMD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
/* "2GB mremap - Source PUD-aligned, Destination PMD-aligned");
* mremap 1GB region - Page table level aligned time test_cases[12] = MAKE_TEST(PUD, PUD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
* comparison. "2GB mremap - Source PUD-aligned, Destination PUD-aligned");
*/
MAKE_TEST(PTE, PTE, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS, perf_test_cases[0] = MAKE_TEST(page_size, page_size, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"1GB mremap - Source PTE-aligned, Destination PTE-aligned"), "1GB mremap - Source PTE-aligned, Destination PTE-aligned");
MAKE_TEST(PMD, PMD, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS, /*
"1GB mremap - Source PMD-aligned, Destination PMD-aligned"), * mremap 1GB region - Page table level aligned time
MAKE_TEST(PUD, PUD, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS, * comparison.
"1GB mremap - Source PUD-aligned, Destination PUD-aligned"), */
}; perf_test_cases[1] = MAKE_TEST(PMD, PMD, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"1GB mremap - Source PMD-aligned, Destination PMD-aligned");
perf_test_cases[2] = MAKE_TEST(PUD, PUD, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
"1GB mremap - Source PUD-aligned, Destination PUD-aligned");
run_perf_tests = (threshold_mb == VALIDATION_NO_THRESHOLD) || run_perf_tests = (threshold_mb == VALIDATION_NO_THRESHOLD) ||
(threshold_mb * _1MB >= _1GB); (threshold_mb * _1MB >= _1GB);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment