Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp1478636imn; Sun, 31 Jul 2022 08:32:28 -0700 (PDT) X-Google-Smtp-Source: AA6agR4LN09OlgukyKMaePv4yrYMczOqc5GTGVdkGaF4qOc0MUrPyaCxPerW2ozGuQs2IJQAtL5W X-Received: by 2002:a17:90b:1b10:b0:1f2:bc36:f8bc with SMTP id nu16-20020a17090b1b1000b001f2bc36f8bcmr14139611pjb.214.1659281548026; Sun, 31 Jul 2022 08:32:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659281548; cv=none; d=google.com; s=arc-20160816; b=Ue2fbXX1NlVj5a6l1WE4MAKvc7wblt9WiDp6T2oJEe8yGiu1SYPMWmdEfQywzC15Lc BRKbrVWZCn60Dnu6JBDAS+PGNcb7jI0YblnwyPlTU4GEN5ghKwud3+Wm+64nr8GND/Ff nQQy8nZCldDid4b2xvz+tcX8vW8Zd440bEnqyqWH/sMSLa1El+VuPdN31p4r5gjsyVqL QK8VD3NpxIoSZ2nY0V0KvInE67PZRp4z8rLyuPMePGYLryK3LXaX1UcU/AGer19uWQt3 BV7rIyMZIB6drHDoiJ7kP+WtEgjBvMT9E3dSn2ckxzrWdX0WiXJD9tsmQOUs/NZG+wy5 5AVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:mime-version:date :message-id:dkim-signature; bh=+SopwDEr8cR4xAQdrFkgpQylaAayiDlj1FBgDdq4Rb0=; b=upE8gPAQ2xOBj+x9w8cOhRSIEeXUbbO6zMzQepNTdDe9+3SwrnRCT0wBYfSCtxnUbL ylIAcZFUEgGAbdHlVWRh0X1qXduBRkKQJ9RkiXpshk2RuBzyvLni2ix6iyzVPErdm9Ls Rs+jZv7igZ/lC/Q6A8Eif16qk/BboQ6DmqdNNwn0O7aJWX/W4dq8XM5NePNbXXts+L5z DqXXrQ2KTq+V00aLJtTfnR3UJiqyr23x5K+YBCfYKAgzG39i6CIWlsjBQ4aM04xINvH7 j7TL71hYF7F+jScPxz599V8rHcYmuMRagAr2oc6j9mMfkC+SH5+NNjWnlO2e8asgmSm/ LBVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@riseup.net header.s=squak header.b=b6p9PSd0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=riseup.net Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r201-20020a632bd2000000b0041c26d281edsi71069pgr.424.2022.07.31.08.32.11; Sun, 31 Jul 2022 08:32:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@riseup.net header.s=squak header.b=b6p9PSd0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=riseup.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236805AbiGaPXp (ORCPT + 99 others); Sun, 31 Jul 2022 11:23:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32842 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233285AbiGaPXn (ORCPT ); Sun, 31 Jul 2022 11:23:43 -0400 Received: from mx1.riseup.net (mx1.riseup.net [198.252.153.129]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9EAB7DEC6 for ; Sun, 31 Jul 2022 08:23:42 -0700 (PDT) Received: from fews2.riseup.net (fews2-pn.riseup.net [10.0.1.84]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "mail.riseup.net", Issuer "R3" (not verified)) by mx1.riseup.net (Postfix) with ESMTPS id 4LwlQP5ryBzDsRs; Sun, 31 Jul 2022 15:23:41 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=riseup.net; s=squak; t=1659281022; bh=KGSz7KHTmljNTcL0jll5cj7goyNUL4TDtN7lur63tCY=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=b6p9PSd04g39vYCAP0BxMrNd02/32kKKR0yw7n509zvwKeb349GU1tJMBP5O8jMqL unTZZwy56yb/BDJrvgV1jAdCnLwfxdFV15CP4D2YAdCfgw6QnomVTz9e7qMY2UbDvl tBFg2bw16e10t0OG7GOEmnIHlGVPVtlZ5EE5TQyw= X-Riseup-User-ID: 40A8A15C2D2551162AB75E94F831D440DCE770F961B58DBE736E48287AE1255E Received: from [127.0.0.1] (localhost [127.0.0.1]) by fews2.riseup.net (Postfix) with ESMTPSA id 4LwlQJ5KXSz1yWm; Sun, 31 Jul 2022 15:23:36 +0000 (UTC) Message-ID: Date: Sun, 31 Jul 2022 12:23:33 -0300 MIME-Version: 1.0 Subject: Re: [PATCH v5 4/5] lib/test: introduce cpumask KUnit test suite Content-Language: en-US To: Sander Vanheule , linux-kernel@vger.kernel.org, Andrew Morton Cc: Andy Shevchenko , Brendan Higgins , Dave Hansen , David Gow , Borislav Petkov , Greg Kroah-Hartman , "H . Peter Anvin" , Ingo Molnar , Marco Elver , Peter Zijlstra , Thomas Gleixner , Valentin Schneider , Yury Norov References: <85217b5de6d62257313ad7fde3e1969421acad75.1659077534.git.sander@svanheule.net> From: =?UTF-8?Q?Ma=c3=adra_Canal?= In-Reply-To: <85217b5de6d62257313ad7fde3e1969421acad75.1659077534.git.sander@svanheule.net> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_PASS,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Sander On 7/29/22 04:01, Sander Vanheule wrote: > Add a basic suite of tests for cpumask, providing some tests for empty and > completely filled cpumasks. > > Signed-off-by: Sander Vanheule > Reviewed-by: Andy Shevchenko > Suggested-by: Yury Norov > Cc: Borislav Petkov > Cc: Dave Hansen > Cc: Greg Kroah-Hartman > Cc: "H. Peter Anvin" > Cc: Ingo Molnar > Cc: Marco Elver > Cc: Peter Zijlstra > Cc: Thomas Gleixner > Cc: Valentin Schneider > Cc: Brendan Higgins > Cc: David Gow > Cc: Maíra Canal > --- > Changes since v4: > - Belated addition of Yury's Suggested-by: > - Follow KUnit style more closely > - Drop full check on cpu_possible_mask > - Update last check on cpu_possible_mask > - Log masks when starting test > - Update commit message > > Changes since v3: > - Test for_each_cpu*() over empty mask and cpu_possible_mask > - Add Andy's Reviewed-by > - Use num_{online,present,possible}_cpus() for builtin masks > - Guard against CPU hotplugging during test for dynamic builtin CPU masks > > Changes since v2: > - Rework for_each_* test macros, as suggested by Yury > > Changes since v1: > - New patch > > lib/Kconfig.debug | 12 ++++ > lib/Makefile | 1 + > lib/cpumask_test.c | 147 +++++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 160 insertions(+) > create mode 100644 lib/cpumask_test.c > > diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug > index 2e24db4bff19..e85e74646178 100644 > --- a/lib/Kconfig.debug > +++ b/lib/Kconfig.debug > @@ -2021,6 +2021,18 @@ config LKDTM > Documentation on how to use the module can be found in > Documentation/fault-injection/provoke-crashes.rst > > +config CPUMASK_KUNIT_TEST > + tristate "KUnit test for cpumask" if !KUNIT_ALL_TESTS > + depends on KUNIT > + default KUNIT_ALL_TESTS > + help > + Enable to turn on cpumask tests, running at boot or module load time. > + > + For more information on KUnit and unit tests in general, please refer > + to the KUnit documentation in Documentation/dev-tools/kunit/. > + > + If unsure, say N. > + > config TEST_LIST_SORT > tristate "Linked list sorting test" if !KUNIT_ALL_TESTS > depends on KUNIT > diff --git a/lib/Makefile b/lib/Makefile > index bcc7e8ea0cde..9f9db1376538 100644 > --- a/lib/Makefile > +++ b/lib/Makefile > @@ -59,6 +59,7 @@ obj-$(CONFIG_TEST_BPF) += test_bpf.o > obj-$(CONFIG_TEST_FIRMWARE) += test_firmware.o > obj-$(CONFIG_TEST_BITOPS) += test_bitops.o > CFLAGS_test_bitops.o += -Werror > +obj-$(CONFIG_CPUMASK_KUNIT_TEST) += cpumask_test.o > obj-$(CONFIG_TEST_SYSCTL) += test_sysctl.o > obj-$(CONFIG_TEST_SIPHASH) += test_siphash.o > obj-$(CONFIG_HASH_KUNIT_TEST) += test_hash.o > diff --git a/lib/cpumask_test.c b/lib/cpumask_test.c > new file mode 100644 > index 000000000000..0f8059a5e93b > --- /dev/null > +++ b/lib/cpumask_test.c In order to make the tests at lib/ with more compliant naming, it would make more sense to name it test_cpumask.c. Thank you for the respin to the series! All tests are passing now. Tested-by: Maíra Canal Best Regards, - Maíra Canal > @@ -0,0 +1,147 @@ > +// SPDX-License-Identifier: GPL-2.0-only > +/* > + * KUnit tests for cpumask. > + * > + * Author: Sander Vanheule > + */ > + > +#include > +#include > +#include > + > +#define EXPECT_FOR_EACH_CPU_EQ(test, mask) \ > + do { \ > + const cpumask_t *m = (mask); \ > + int mask_weight = cpumask_weight(m); \ > + int cpu, iter = 0; \ > + for_each_cpu(cpu, m) \ > + iter++; \ > + KUNIT_EXPECT_EQ((test), mask_weight, iter); \ > + } while (0) > + > +#define EXPECT_FOR_EACH_CPU_NOT_EQ(test, mask) \ > + do { \ > + const cpumask_t *m = (mask); \ > + int mask_weight = cpumask_weight(m); \ > + int cpu, iter = 0; \ > + for_each_cpu_not(cpu, m) \ > + iter++; \ > + KUNIT_EXPECT_EQ((test), nr_cpu_ids - mask_weight, iter); \ > + } while (0) > + > +#define EXPECT_FOR_EACH_CPU_WRAP_EQ(test, mask) \ > + do { \ > + const cpumask_t *m = (mask); \ > + int mask_weight = cpumask_weight(m); \ > + int cpu, iter = 0; \ > + for_each_cpu_wrap(cpu, m, nr_cpu_ids / 2) \ > + iter++; \ > + KUNIT_EXPECT_EQ((test), mask_weight, iter); \ > + } while (0) > + > +#define EXPECT_FOR_EACH_CPU_BUILTIN_EQ(test, name) \ > + do { \ > + int mask_weight = num_##name##_cpus(); \ > + int cpu, iter = 0; \ > + for_each_##name##_cpu(cpu) \ > + iter++; \ > + KUNIT_EXPECT_EQ((test), mask_weight, iter); \ > + } while (0) > + > +static cpumask_t mask_empty; > +static cpumask_t mask_all; > + > +#define STR_MASK(m) #m > +#define TEST_CPUMASK_PRINT(test, mask) \ > + kunit_info(test, "%s = '%*pbl'\n", STR_MASK(mask), nr_cpumask_bits, cpumask_bits(mask)) > + > +static void test_cpumask_weight(struct kunit *test) > +{ > + KUNIT_EXPECT_TRUE(test, cpumask_empty(&mask_empty)); > + KUNIT_EXPECT_TRUE(test, cpumask_full(&mask_all)); > + > + KUNIT_EXPECT_EQ(test, 0, cpumask_weight(&mask_empty)); > + KUNIT_EXPECT_EQ(test, nr_cpu_ids, cpumask_weight(cpu_possible_mask)); > + KUNIT_EXPECT_EQ(test, nr_cpumask_bits, cpumask_weight(&mask_all)); > +} > + > +static void test_cpumask_first(struct kunit *test) > +{ > + KUNIT_EXPECT_LE(test, nr_cpu_ids, cpumask_first(&mask_empty)); > + KUNIT_EXPECT_EQ(test, 0, cpumask_first(cpu_possible_mask)); > + > + KUNIT_EXPECT_EQ(test, 0, cpumask_first_zero(&mask_empty)); > + KUNIT_EXPECT_LE(test, nr_cpu_ids, cpumask_first_zero(cpu_possible_mask)); > +} > + > +static void test_cpumask_last(struct kunit *test) > +{ > + KUNIT_EXPECT_LE(test, nr_cpumask_bits, cpumask_last(&mask_empty)); > + KUNIT_EXPECT_EQ(test, nr_cpu_ids - 1, cpumask_last(cpu_possible_mask)); > +} > + > +static void test_cpumask_next(struct kunit *test) > +{ > + KUNIT_EXPECT_EQ(test, 0, cpumask_next_zero(-1, &mask_empty)); > + KUNIT_EXPECT_LE(test, nr_cpu_ids, cpumask_next_zero(-1, cpu_possible_mask)); > + > + KUNIT_EXPECT_LE(test, nr_cpu_ids, cpumask_next(-1, &mask_empty)); > + KUNIT_EXPECT_EQ(test, 0, cpumask_next(-1, cpu_possible_mask)); > +} > + > +static void test_cpumask_iterators(struct kunit *test) > +{ > + EXPECT_FOR_EACH_CPU_EQ(test, &mask_empty); > + EXPECT_FOR_EACH_CPU_NOT_EQ(test, &mask_empty); > + EXPECT_FOR_EACH_CPU_WRAP_EQ(test, &mask_empty); > + > + EXPECT_FOR_EACH_CPU_EQ(test, cpu_possible_mask); > + EXPECT_FOR_EACH_CPU_NOT_EQ(test, cpu_possible_mask); > + EXPECT_FOR_EACH_CPU_WRAP_EQ(test, cpu_possible_mask); > +} > + > +static void test_cpumask_iterators_builtin(struct kunit *test) > +{ > + EXPECT_FOR_EACH_CPU_BUILTIN_EQ(test, possible); > + > + /* Ensure the dynamic masks are stable while running the tests */ > + cpu_hotplug_disable(); > + > + TEST_CPUMASK_PRINT(test, cpu_online_mask); > + TEST_CPUMASK_PRINT(test, cpu_present_mask); > + > + EXPECT_FOR_EACH_CPU_BUILTIN_EQ(test, online); > + EXPECT_FOR_EACH_CPU_BUILTIN_EQ(test, present); > + > + cpu_hotplug_enable(); > +} > + > +static int test_cpumask_init(struct kunit *test) > +{ > + cpumask_clear(&mask_empty); > + cpumask_setall(&mask_all); > + > + TEST_CPUMASK_PRINT(test, &mask_all); > + TEST_CPUMASK_PRINT(test, cpu_possible_mask); > + > + return 0; > +} > + > +static struct kunit_case test_cpumask_cases[] = { > + KUNIT_CASE(test_cpumask_weight), > + KUNIT_CASE(test_cpumask_first), > + KUNIT_CASE(test_cpumask_last), > + KUNIT_CASE(test_cpumask_next), > + KUNIT_CASE(test_cpumask_iterators), > + KUNIT_CASE(test_cpumask_iterators_builtin), > + {} > +}; > + > +static struct kunit_suite test_cpumask_suite = { > + .name = "cpumask", > + .init = test_cpumask_init, > + .test_cases = test_cpumask_cases, > +}; > +kunit_test_suite(test_cpumask_suite); > + > +MODULE_LICENSE("GPL");