linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
From: Kalesh Singh <kaleshsingh@google.com>
To: "Aneesh Kumar K.V" <aneesh.kumar@linux.ibm.com>
Cc: npiggin@gmail.com,
	"open list:MEMORY MANAGEMENT" <linux-mm@kvack.org>,
	joel@joelfernandes.org, Andrew Morton <akpm@linux-foundation.org>,
	linuxppc-dev@lists.ozlabs.org
Subject: Re: [PATCH v3 1/9] selftest/mremap_test: Update the test to handle pagesize other than 4K
Date: Mon, 12 Apr 2021 11:37:24 -0700	[thread overview]
Message-ID: <CAC_TJvckza8EDro7orzWbtT3dbs=MG+zcASvvpFzj+eedVMXKA@mail.gmail.com> (raw)
In-Reply-To: <20210330060752.592769-2-aneesh.kumar@linux.ibm.com>

On Mon, Mar 29, 2021 at 11:08 PM Aneesh Kumar K.V
<aneesh.kumar@linux.ibm.com> wrote:
>
> Instead of hardcoding 4K page size fetch it using sysconf(). For the performance
> measurements test still assume 2M and 1G are hugepage sizes.
>
> Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.ibm.com>

Reviewed-by: Kalesh Singh <kaleshsingh@google.com>

> ---
>  tools/testing/selftests/vm/mremap_test.c | 113 ++++++++++++-----------
>  1 file changed, 61 insertions(+), 52 deletions(-)
>
> diff --git a/tools/testing/selftests/vm/mremap_test.c b/tools/testing/selftests/vm/mremap_test.c
> index 9c391d016922..c9a5461eb786 100644
> --- a/tools/testing/selftests/vm/mremap_test.c
> +++ b/tools/testing/selftests/vm/mremap_test.c
> @@ -45,14 +45,15 @@ enum {
>         _4MB = 4ULL << 20,
>         _1GB = 1ULL << 30,
>         _2GB = 2ULL << 30,
> -       PTE = _4KB,
>         PMD = _2MB,
>         PUD = _1GB,
>  };
>
> +#define PTE page_size
> +
>  #define MAKE_TEST(source_align, destination_align, size,       \
>                   overlaps, should_fail, test_name)             \
> -{                                                              \
> +(struct test){                                                 \
>         .name = test_name,                                      \
>         .config = {                                             \
>                 .src_alignment = source_align,                  \
> @@ -252,12 +253,17 @@ static int parse_args(int argc, char **argv, unsigned int *threshold_mb,
>         return 0;
>  }
>
> +#define MAX_TEST 13
> +#define MAX_PERF_TEST 3
>  int main(int argc, char **argv)
>  {
>         int failures = 0;
>         int i, run_perf_tests;
>         unsigned int threshold_mb = VALIDATION_DEFAULT_THRESHOLD;
>         unsigned int pattern_seed;
> +       struct test test_cases[MAX_TEST];
> +       struct test perf_test_cases[MAX_PERF_TEST];
> +       int page_size;
>         time_t t;
>
>         pattern_seed = (unsigned int) time(&t);
> @@ -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",
>                        threshold_mb, pattern_seed);
>
> -       struct test test_cases[] = {
> -               /* Expected mremap failures */
> -               MAKE_TEST(_4KB, _4KB, _4KB, OVERLAPPING, EXPECT_FAILURE,
> -                 "mremap - Source and Destination Regions Overlapping"),
> -               MAKE_TEST(_4KB, _1KB, _4KB, NON_OVERLAPPING, EXPECT_FAILURE,
> -                 "mremap - Destination Address Misaligned (1KB-aligned)"),
> -               MAKE_TEST(_1KB, _4KB, _4KB, NON_OVERLAPPING, EXPECT_FAILURE,
> -                 "mremap - Source Address Misaligned (1KB-aligned)"),
> -
> -               /* Src addr PTE aligned */
> -               MAKE_TEST(PTE, PTE, _8KB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "8KB mremap - Source PTE-aligned, Destination PTE-aligned"),
> -
> -               /* Src addr 1MB aligned */
> -               MAKE_TEST(_1MB, PTE, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2MB mremap - Source 1MB-aligned, Destination PTE-aligned"),
> -               MAKE_TEST(_1MB, _1MB, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2MB mremap - Source 1MB-aligned, Destination 1MB-aligned"),
> -
> -               /* Src addr PMD aligned */
> -               MAKE_TEST(PMD, PTE, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "4MB mremap - Source PMD-aligned, Destination PTE-aligned"),
> -               MAKE_TEST(PMD, _1MB, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "4MB mremap - Source PMD-aligned, Destination 1MB-aligned"),
> -               MAKE_TEST(PMD, PMD, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "4MB mremap - Source PMD-aligned, Destination PMD-aligned"),
> -
> -               /* Src addr PUD aligned */
> -               MAKE_TEST(PUD, PTE, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2GB mremap - Source PUD-aligned, Destination PTE-aligned"),
> -               MAKE_TEST(PUD, _1MB, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2GB mremap - Source PUD-aligned, Destination 1MB-aligned"),
> -               MAKE_TEST(PUD, PMD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2GB mremap - Source PUD-aligned, Destination PMD-aligned"),
> -               MAKE_TEST(PUD, PUD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "2GB mremap - Source PUD-aligned, Destination PUD-aligned"),
> -       };
> -
> -       struct test perf_test_cases[] = {
> -               /*
> -                * mremap 1GB region - Page table level aligned time
> -                * comparison.
> -                */
> -               MAKE_TEST(PTE, PTE, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "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"),
> -               MAKE_TEST(PUD, PUD, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> -                 "1GB mremap - Source PUD-aligned, Destination PUD-aligned"),
> -       };
> +       page_size = sysconf(_SC_PAGESIZE);
> +
> +       /* Expected mremap failures */
> +       test_cases[0] = MAKE_TEST(page_size, page_size, page_size,
> +                                 OVERLAPPING, EXPECT_FAILURE,
> +                                 "mremap - Source and Destination Regions Overlapping");
> +
> +       test_cases[1] = MAKE_TEST(page_size, page_size/4, page_size,
> +                                 NON_OVERLAPPING, EXPECT_FAILURE,
> +                                 "mremap - Destination Address Misaligned (1KB-aligned)");
> +       test_cases[2] = MAKE_TEST(page_size/4, page_size, page_size,
> +                                 NON_OVERLAPPING, EXPECT_FAILURE,
> +                                 "mremap - Source Address Misaligned (1KB-aligned)");
> +
> +       /* Src addr PTE aligned */
> +       test_cases[3] = MAKE_TEST(PTE, PTE, PTE * 2,
> +                                 NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "8KB mremap - Source PTE-aligned, Destination PTE-aligned");
> +
> +       /* Src addr 1MB aligned */
> +       test_cases[4] = MAKE_TEST(_1MB, PTE, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "2MB mremap - Source 1MB-aligned, Destination PTE-aligned");
> +       test_cases[5] = MAKE_TEST(_1MB, _1MB, _2MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "2MB mremap - Source 1MB-aligned, Destination 1MB-aligned");
> +
> +       /* Src addr PMD aligned */
> +       test_cases[6] = MAKE_TEST(PMD, PTE, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "4MB mremap - Source PMD-aligned, Destination PTE-aligned");
> +       test_cases[7] = MAKE_TEST(PMD, _1MB, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "4MB mremap - Source PMD-aligned, Destination 1MB-aligned");
> +       test_cases[8] = MAKE_TEST(PMD, PMD, _4MB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "4MB mremap - Source PMD-aligned, Destination PMD-aligned");
> +
> +       /* Src addr PUD aligned */
> +       test_cases[9] = MAKE_TEST(PUD, PTE, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                 "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");
> +       test_cases[11] = MAKE_TEST(PUD, PMD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                  "2GB mremap - Source PUD-aligned, Destination PMD-aligned");
> +       test_cases[12] = MAKE_TEST(PUD, PUD, _2GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                  "2GB mremap - Source PUD-aligned, Destination PUD-aligned");
> +
> +       perf_test_cases[0] =  MAKE_TEST(page_size, page_size, _1GB, NON_OVERLAPPING, EXPECT_SUCCESS,
> +                                       "1GB mremap - Source PTE-aligned, Destination PTE-aligned");
> +       /*
> +        * mremap 1GB region - Page table level aligned time
> +        * comparison.
> +        */
> +       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) ||
>                                 (threshold_mb * _1MB >= _1GB);
> --
> 2.30.2
>

  reply	other threads:[~2021-04-12 22:03 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-03-30  6:07 [PATCH v3 0/9] Speedup mremap on ppc64 Aneesh Kumar K.V
2021-03-30  6:07 ` [PATCH v3 1/9] selftest/mremap_test: Update the test to handle pagesize other than 4K Aneesh Kumar K.V
2021-04-12 18:37   ` Kalesh Singh [this message]
2021-03-30  6:07 ` [PATCH v3 2/9] selftest/mremap_test: Avoid crash with static build Aneesh Kumar K.V
2021-04-12 18:38   ` Kalesh Singh
2021-03-30  6:07 ` [PATCH v3 3/9] mm/mremap: Use pmd/pud_poplulate to update page table entries Aneesh Kumar K.V
2021-03-30  6:07 ` [PATCH v3 4/9] powerpc/mm/book3s64: Fix possible build error Aneesh Kumar K.V
2021-04-09  9:15   ` Christophe Leroy
2021-03-30  6:07 ` [PATCH v3 5/9] powerpc/mm/book3s64: Update tlb flush routines to take a page walk cache flush argument Aneesh Kumar K.V
2021-03-30 13:28   ` kernel test robot
2021-04-09  9:18   ` Christophe Leroy
2021-03-30  6:07 ` [PATCH v3 6/9] mm/mremap: Use range flush that does TLB and page walk cache flush Aneesh Kumar K.V
2021-03-30  6:07 ` [PATCH v3 7/9] mm/mremap: Move TLB flush outside page table lock Aneesh Kumar K.V
2021-03-30  6:07 ` [PATCH v3 8/9] mm/mremap: Allow arch runtime override Aneesh Kumar K.V
2021-04-09  9:35   ` Christophe Leroy
2021-04-09 11:59     ` Aneesh Kumar K.V
2021-03-30  6:07 ` [PATCH v3 9/9] powerpc/mm: Enable move pmd/pud Aneesh Kumar K.V
2021-04-09  5:48 ` [PATCH v3 0/9] Speedup mremap on ppc64 Aneesh Kumar K.V

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='CAC_TJvckza8EDro7orzWbtT3dbs=MG+zcASvvpFzj+eedVMXKA@mail.gmail.com' \
    --to=kaleshsingh@google.com \
    --cc=akpm@linux-foundation.org \
    --cc=aneesh.kumar@linux.ibm.com \
    --cc=joel@joelfernandes.org \
    --cc=linux-mm@kvack.org \
    --cc=linuxppc-dev@lists.ozlabs.org \
    --cc=npiggin@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).