Message ID | 20240202195909.3458162-8-sboyd@kernel.org |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a05:7301:9bc1:b0:106:209c:c626 with SMTP id op1csp668607dyc; Fri, 2 Feb 2024 12:01:36 -0800 (PST) X-Google-Smtp-Source: AGHT+IEF2Vo6laJvt634EXEvdyY77p4gZHb9KXdCZgPgXuqDdkPBvJaY7WJNumwf8SWcAQImb1df X-Received: by 2002:a05:622a:13d2:b0:42a:a166:16a with SMTP id p18-20020a05622a13d200b0042aa166016amr9315137qtk.52.1706904096399; Fri, 02 Feb 2024 12:01:36 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1706904096; cv=pass; d=google.com; s=arc-20160816; b=ELs2q31VQr46GyspIsNL7DBDkrgVaBYEabg+JR/hC6l0HF6tqafc15iC6rYqWBp9j/ KnCjk9YrjS9XEyVy/keOZJoAOCv1FreluHg8l6ftCp7AbrUi9MC6NztjHe9/dXkS02q8 waCd6kj/xaFXCr/GlgCok4OcuCXlXm+hbiUh4hCNFJvqElPtG1t4U/olqhSmP5Le2wNx a4AG7abjGBhC+W35d68tMQQ9QWl+FU4PlqUnlKPpPRG7XD2CAKZcr/xo/9RgN0tbrqjl TkeOALPvK4JG7NDgQs49CSzRPMGeQ8YpC1zyc8138s3UgIw2ceThFT1nEuSCSgWTy1mi fHDA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=9nr8KgIXSlmrBRc5eTEs4Ft1WJ6sE76s1g3Xw61O8GM=; fh=d8ySrDEE1vqD4SlGM/BxyavV5CxwWpd4FMSQflDXFrY=; b=oQXLwLcSnupraVDFYE90BLdm04tB5Z1eNsYwsZ85+GjlBrpE/Wx7iRlixK5cZOzjnt kuTxLN7yr6jxS6JeJAUgknyy54aWCbcKAgt402jGapTVO/eUAoHKKb/xqkxKnhVKOQg9 s46q53mO8e1s3kVxklQ6IFRVAFx2I/4rACZcoA/t4Llwt8irlqvhvsBJIwLkpim7jtzn ekBu3svH6j6ZY+2V3OMzXZc7W4CmHOEpV+8yY8Yu76bthqGiY6emERlzvJRsMG1PPMui nO7iMBzB9ncqFxzkzdzjm+fMFntfruY5UnVwez09LWRl/vPhaqS5rgh1+4GtbO7xaVN6 Yyjg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LUsABn4B; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org X-Forwarded-Encrypted: i=1; AJvYcCW9N9tdrRAAHSvTX6V8tk6FtMOYoXOVuy+vpZgKzmTjqzwux0khttnYfOVUHcdTrS/QbCtOLVqLCzNYzIxY3creZ8dPQg== Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id c22-20020ac87dd6000000b0042bf725393csi2823184qte.54.2024.02.02.12.01.36 for <ouuuleilei@gmail.com> (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 02 Feb 2024 12:01:36 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LUsABn4B; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-50516-ouuuleilei=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 346701C24B24 for <ouuuleilei@gmail.com>; Fri, 2 Feb 2024 20:01:36 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id AA24912C805; Fri, 2 Feb 2024 19:59:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="LUsABn4B" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EE9B1126F01; Fri, 2 Feb 2024 19:59:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706903957; cv=none; b=nzD4ffN0CepjBF+gTwe/lnMmHrrYGXVu7LLJ+I0KbU+5PqmCV3j7Fiwho06r7E86lzegfotTrDft72eeWoIH3AeEff5jZjx5rDt94mVcHqCu9jq2MlQPTmdURgQJRVBpHiGjRHWmmR3GVVaPoeqThK9DqPt4n9i640sg/4ZCLdM= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706903957; c=relaxed/simple; bh=PiweXFroDHF7yXaa82SMFRXH/FDbm1RzgiHTih6bLA8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=lG22swlSyaidBABSLfN58GNfQpu5CNXjMMDY7I9h+PbrxzXGV53XzEOAdMLs/KF2t3E3EuyDxA6PxquCHK2L5kqrsmo3JDHdp1TNTyYIp9HZFLeBAREGKh79lvrqDZSbD9eMfhFkPJFcx/5WCXxKjJcUfl/kDvGoLS8DjIJHrek= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=LUsABn4B; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id F0422C43390; Fri, 2 Feb 2024 19:59:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1706903956; bh=PiweXFroDHF7yXaa82SMFRXH/FDbm1RzgiHTih6bLA8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LUsABn4BtEE+3rLzRs0MQ2C02aC4eRavx+NnUEigQIDN5hEhEZNBOQJZPL8COpFiE lorefdZOxB8OV+F2B33bLbZYuCDULzTivEsiui+momrj0H+Q4M8bILqL6UXIb2VZG8 2a4s2d8yNcFame9bG1gYjm7fRnJ0b1loqO9DK41wYC40o8K8MLf+BOFe1Y+PHMhias njRXktKCexQ9Yv8x4+YTqiHhB31aR091ZwIt79dQ9s29u1QvLULGcboC0mabkoiOis bdoKOrdCx2OSnf4HWEb5yIMklX06Ug8ejLsbsHsTP/c7+WG2Qd9+ZAF9Hq4PyzUetv l0y+61kYAJv5Q== From: Stephen Boyd <sboyd@kernel.org> To: Rob Herring <robh+dt@kernel.org> Cc: linux-kernel@vger.kernel.org, patches@lists.linux.dev, linux-um@lists.infradead.org, linux-arm-kernel@lists.infradead.org, kunit-dev@googlegroups.com, linux-kselftest@vger.kernel.org, devicetree@vger.kernel.org, Frank Rowand <frowand.list@gmail.com>, David Gow <davidgow@google.com>, Brendan Higgins <brendan.higgins@linux.dev> Subject: [PATCH v3 7/7] of: Add KUnit test to confirm DTB is loaded Date: Fri, 2 Feb 2024 11:59:08 -0800 Message-ID: <20240202195909.3458162-8-sboyd@kernel.org> X-Mailer: git-send-email 2.43.0.594.gd9cf4e227d-goog In-Reply-To: <20240202195909.3458162-1-sboyd@kernel.org> References: <20240202195909.3458162-1-sboyd@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: <linux-kernel.vger.kernel.org> List-Subscribe: <mailto:linux-kernel+subscribe@vger.kernel.org> List-Unsubscribe: <mailto:linux-kernel+unsubscribe@vger.kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1789818669908903614 X-GMAIL-MSGID: 1789818669908903614 |
Series |
of: populate of_root node if bootloader doesn't
|
|
Commit Message
Stephen Boyd
Feb. 2, 2024, 7:59 p.m. UTC
Add a KUnit test that confirms a DTB has been loaded, i.e. there is a
root node, and that the of_have_populated_dt() API works properly.
Cc: Rob Herring <robh+dt@kernel.org>
Cc: Frank Rowand <frowand.list@gmail.com>
Cc: David Gow <davidgow@google.com>
Cc: Brendan Higgins <brendan.higgins@linux.dev>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
---
drivers/of/.kunitconfig | 3 +++
drivers/of/Kconfig | 9 ++++++++
drivers/of/Makefile | 2 ++
drivers/of/of_test.c | 48 +++++++++++++++++++++++++++++++++++++++++
4 files changed, 62 insertions(+)
create mode 100644 drivers/of/.kunitconfig
create mode 100644 drivers/of/of_test.c
Comments
On Sat, 3 Feb 2024 at 03:59, Stephen Boyd <sboyd@kernel.org> wrote: > > Add a KUnit test that confirms a DTB has been loaded, i.e. there is a > root node, and that the of_have_populated_dt() API works properly. > > Cc: Rob Herring <robh+dt@kernel.org> > Cc: Frank Rowand <frowand.list@gmail.com> > Cc: David Gow <davidgow@google.com> > Cc: Brendan Higgins <brendan.higgins@linux.dev> > Signed-off-by: Stephen Boyd <sboyd@kernel.org> > --- This looks pretty good to me test-wise, though it still fails on m68k. (Everything else I tried it on works, though I've definitely not tried _every_ architecture.) aarch64: PASSED i386: PASSED x86_64: PASSED x86_64 KASAN: PASSED powerpc64: PASSED UML: PASSED UML LLVM: PASSED m68k: FAILED > $ qemu-system-m68k -nodefaults -m 1024 -kernel .kunit-all-m68k/vmlinux -append 'kunit.enable=1 console=hvc0 kunit_shutdown=reboot' -no-reboot -nographic -serial stdio -machine virt > [11:55:05] ===================== dtb (2 subtests) ===================== > [11:55:05] # dtb_root_node_found_by_path: EXPECTATION FAILED at drivers/of/of_test.c:18 > [11:55:05] Expected np is not null, but is > [11:55:05] [FAILED] dtb_root_node_found_by_path > [11:55:05] # dtb_root_node_populates_of_root: EXPECTATION FAILED at drivers/of/of_test.c:28 > [11:55:05] Expected of_root is not null, but is > [11:55:05] [FAILED] dtb_root_node_populates_of_root > [11:55:05] # module: of_test > [11:55:05] # dtb: pass:0 fail:2 skip:0 total:2 > [11:55:05] # Totals: pass:0 fail:2 skip:0 total:2 > [11:55:05] ======================= [FAILED] dtb ======================= My only other question is about the test names: the mix of 'of' and 'dtb' can be a bit confusing. As is, we have: kconfig name: OF_KUNIT_TEST module name: of_test suite name: dtb test names: all start with dtb_ Given KUnit only really deals with the suite/test names directly, it's not trivial to see that 'dtb.dtb_*' is controlled by OF_KUNIT_TEST and in of_test if built as a module. (This is getting a bit easier now that we have the 'module' attribute in the output, but still.) Would 'of_dtb' work as a suite name if it's important to keep both 'of' and 'dtb'? In general, though, this test looks good to me. Particularly if m68k can be fixed. Reviewed-by: David Gow <davidgow@google.com> Cheers, -- David > drivers/of/.kunitconfig | 3 +++ > drivers/of/Kconfig | 9 ++++++++ > drivers/of/Makefile | 2 ++ > drivers/of/of_test.c | 48 +++++++++++++++++++++++++++++++++++++++++ > 4 files changed, 62 insertions(+) > create mode 100644 drivers/of/.kunitconfig > create mode 100644 drivers/of/of_test.c > > diff --git a/drivers/of/.kunitconfig b/drivers/of/.kunitconfig > new file mode 100644 > index 000000000000..5a8fee11978c > --- /dev/null > +++ b/drivers/of/.kunitconfig > @@ -0,0 +1,3 @@ > +CONFIG_KUNIT=y > +CONFIG_OF=y > +CONFIG_OF_KUNIT_TEST=y > diff --git a/drivers/of/Kconfig b/drivers/of/Kconfig > index 17733285b415..53d1b5dd89e8 100644 > --- a/drivers/of/Kconfig > +++ b/drivers/of/Kconfig > @@ -37,6 +37,15 @@ config OF_UNITTEST > > If unsure, say N here. This option is not safe to enable. > > +config OF_KUNIT_TEST > + tristate "Devicetree KUnit Test" if !KUNIT_ALL_TESTS > + depends on KUNIT > + default KUNIT_ALL_TESTS > + help > + This option builds KUnit unit tests for device tree infrastructure. > + > + If unsure, say N here, but this option is safe to enable. > + > config OF_ALL_DTBS > bool "Build all Device Tree Blobs" > depends on COMPILE_TEST > diff --git a/drivers/of/Makefile b/drivers/of/Makefile > index df305348d1cb..251d33532148 100644 > --- a/drivers/of/Makefile > +++ b/drivers/of/Makefile > @@ -19,4 +19,6 @@ obj-y += kexec.o > endif > endif > > +obj-$(CONFIG_OF_KUNIT_TEST) += of_test.o > + > obj-$(CONFIG_OF_UNITTEST) += unittest-data/ > diff --git a/drivers/of/of_test.c b/drivers/of/of_test.c > new file mode 100644 > index 000000000000..71a767b42b43 > --- /dev/null > +++ b/drivers/of/of_test.c > @@ -0,0 +1,48 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * KUnit tests for OF APIs > + */ > +#include <linux/module.h> > +#include <linux/of.h> > + > +#include <kunit/test.h> > + > +/* > + * Test that the root node "/" can be found by path. > + */ > +static void dtb_root_node_found_by_path(struct kunit *test) > +{ > + struct device_node *np; > + > + np = of_find_node_by_path("/"); > + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, np); > + of_node_put(np); > +} > + > +/* > + * Test that the 'of_root' global variable is always populated when DT code is > + * enabled. > + */ > +static void dtb_root_node_populates_of_root(struct kunit *test) > +{ > + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, of_root); > +} > + > +static struct kunit_case dtb_test_cases[] = { > + KUNIT_CASE(dtb_root_node_found_by_path), > + KUNIT_CASE(dtb_root_node_populates_of_root), > + {} > +}; > + > +/* > + * Test suite to confirm a DTB is loaded. > + */ > +static struct kunit_suite dtb_suite = { > + .name = "dtb", > + .test_cases = dtb_test_cases, > +}; > + > +kunit_test_suites( > + &dtb_suite, > +); > +MODULE_LICENSE("GPL"); > -- > https://git.kernel.org/pub/scm/linux/kernel/git/clk/linux.git/ > https://git.kernel.org/pub/scm/linux/kernel/git/sboyd/spmi.git > > -- > You received this message because you are subscribed to the Google Groups "KUnit Development" group. > To unsubscribe from this group and stop receiving emails from it, send an email to kunit-dev+unsubscribe@googlegroups.com. > To view this discussion on the web visit https://groups.google.com/d/msgid/kunit-dev/20240202195909.3458162-8-sboyd%40kernel.org.
Quoting David Gow (2024-02-02 20:10:17) > On Sat, 3 Feb 2024 at 03:59, Stephen Boyd <sboyd@kernel.org> wrote: > > > > Add a KUnit test that confirms a DTB has been loaded, i.e. there is a > > root node, and that the of_have_populated_dt() API works properly. > > > > Cc: Rob Herring <robh+dt@kernel.org> > > Cc: Frank Rowand <frowand.list@gmail.com> > > Cc: David Gow <davidgow@google.com> > > Cc: Brendan Higgins <brendan.higgins@linux.dev> > > Signed-off-by: Stephen Boyd <sboyd@kernel.org> > > --- > > This looks pretty good to me test-wise, though it still fails on m68k. > (Everything else I tried it on works, though I've definitely not tried > _every_ architecture.) > > aarch64: PASSED > i386: PASSED > x86_64: PASSED > x86_64 KASAN: PASSED > powerpc64: PASSED > UML: PASSED > UML LLVM: PASSED > m68k: FAILED > > $ qemu-system-m68k -nodefaults -m 1024 -kernel .kunit-all-m68k/vmlinux -append 'kunit.enable=1 console=hvc0 kunit_shutdown=reboot' -no-reboot -nographic -serial stdio -machine virt > > [11:55:05] ===================== dtb (2 subtests) ===================== > > [11:55:05] # dtb_root_node_found_by_path: EXPECTATION FAILED at drivers/of/of_test.c:18 > > [11:55:05] Expected np is not null, but is > > [11:55:05] [FAILED] dtb_root_node_found_by_path > > [11:55:05] # dtb_root_node_populates_of_root: EXPECTATION FAILED at drivers/of/of_test.c:28 > > [11:55:05] Expected of_root is not null, but is > > [11:55:05] [FAILED] dtb_root_node_populates_of_root > > [11:55:05] # module: of_test > > [11:55:05] # dtb: pass:0 fail:2 skip:0 total:2 > > [11:55:05] # Totals: pass:0 fail:2 skip:0 total:2 > > [11:55:05] ======================= [FAILED] dtb ======================= Ah yeah I forgot to mention that. m68k fails because it doesn't call the unflatten_(and_copy)?_device_tree() function, so we don't populate a root node on that architecture. One solution would be to make CONFIG_OF unavailable on m68k. Or we have to make sure DT works on any architecture. Rob, what do you prefer here? > > > My only other question is about the test names: the mix of 'of' and > 'dtb' can be a bit confusing. As is, we have: > kconfig name: OF_KUNIT_TEST > module name: of_test > suite name: dtb > test names: all start with dtb_ > > Given KUnit only really deals with the suite/test names directly, it's > not trivial to see that 'dtb.dtb_*' is controlled by OF_KUNIT_TEST and > in of_test if built as a module. (This is getting a bit easier now > that we have the 'module' attribute in the output, but still.) > > Would 'of_dtb' work as a suite name if it's important to keep both > 'of' and 'dtb'? Sure, I can add of_ prefix to the tests. > > In general, though, this test looks good to me. Particularly if m68k > can be fixed. > > Reviewed-by: David Gow <davidgow@google.com> > Thanks!
Hi Stephen, On Mon, Feb 5, 2024 at 8:19 PM Stephen Boyd <sboyd@kernel.org> wrote: > Quoting David Gow (2024-02-02 20:10:17) > > On Sat, 3 Feb 2024 at 03:59, Stephen Boyd <sboyd@kernel.org> wrote: > > > Add a KUnit test that confirms a DTB has been loaded, i.e. there is a > > > root node, and that the of_have_populated_dt() API works properly. > > > > > > Cc: Rob Herring <robh+dt@kernel.org> > > > Cc: Frank Rowand <frowand.list@gmail.com> > > > Cc: David Gow <davidgow@google.com> > > > Cc: Brendan Higgins <brendan.higgins@linux.dev> > > > Signed-off-by: Stephen Boyd <sboyd@kernel.org> > > > --- > > > > This looks pretty good to me test-wise, though it still fails on m68k. > > (Everything else I tried it on works, though I've definitely not tried > > _every_ architecture.) > > > > aarch64: PASSED > > i386: PASSED > > x86_64: PASSED > > x86_64 KASAN: PASSED > > powerpc64: PASSED > > UML: PASSED > > UML LLVM: PASSED > > m68k: FAILED > > > $ qemu-system-m68k -nodefaults -m 1024 -kernel .kunit-all-m68k/vmlinux -append 'kunit.enable=1 console=hvc0 kunit_shutdown=reboot' -no-reboot -nographic -serial stdio -machine virt > > > [11:55:05] ===================== dtb (2 subtests) ===================== > > > [11:55:05] # dtb_root_node_found_by_path: EXPECTATION FAILED at drivers/of/of_test.c:18 > > > [11:55:05] Expected np is not null, but is > > > [11:55:05] [FAILED] dtb_root_node_found_by_path > > > [11:55:05] # dtb_root_node_populates_of_root: EXPECTATION FAILED at drivers/of/of_test.c:28 > > > [11:55:05] Expected of_root is not null, but is > > > [11:55:05] [FAILED] dtb_root_node_populates_of_root > > > [11:55:05] # module: of_test > > > [11:55:05] # dtb: pass:0 fail:2 skip:0 total:2 > > > [11:55:05] # Totals: pass:0 fail:2 skip:0 total:2 > > > [11:55:05] ======================= [FAILED] dtb ======================= > > Ah yeah I forgot to mention that. m68k fails because it doesn't call the > unflatten_(and_copy)?_device_tree() function, so we don't populate a > root node on that architecture. One solution would be to make CONFIG_OF > unavailable on m68k. Or we have to make sure DT works on any > architecture. Rob, what do you prefer here? I guess the latter? Alpha, hexagon, parisc, s390, and sparc are also lacking calls to unflatten.*device_tree(). Gr{oetje,eeting}s, Geert
Quoting Geert Uytterhoeven (2024-02-05 11:55:29) > On Mon, Feb 5, 2024 at 8:19 PM Stephen Boyd <sboyd@kernel.org> wrote: > > Quoting David Gow (2024-02-02 20:10:17) > > > On Sat, 3 Feb 2024 at 03:59, Stephen Boyd <sboyd@kernel.org> wrote: > > > > Add a KUnit test that confirms a DTB has been loaded, i.e. there is a > > > > root node, and that the of_have_populated_dt() API works properly. > > > > > > > > Cc: Rob Herring <robh+dt@kernel.org> > > > > Cc: Frank Rowand <frowand.list@gmail.com> > > > > Cc: David Gow <davidgow@google.com> > > > > Cc: Brendan Higgins <brendan.higgins@linux.dev> > > > > Signed-off-by: Stephen Boyd <sboyd@kernel.org> > > > > --- > > > > > > This looks pretty good to me test-wise, though it still fails on m68k. > > > (Everything else I tried it on works, though I've definitely not tried > > > _every_ architecture.) > > > > > > aarch64: PASSED > > > i386: PASSED > > > x86_64: PASSED > > > x86_64 KASAN: PASSED > > > powerpc64: PASSED > > > UML: PASSED > > > UML LLVM: PASSED > > > m68k: FAILED > > > > $ qemu-system-m68k -nodefaults -m 1024 -kernel .kunit-all-m68k/vmlinux -append 'kunit.enable=1 console=hvc0 kunit_shutdown=reboot' -no-reboot -nographic -serial stdio -machine virt > > > > [11:55:05] ===================== dtb (2 subtests) ===================== > > > > [11:55:05] # dtb_root_node_found_by_path: EXPECTATION FAILED at drivers/of/of_test.c:18 > > > > [11:55:05] Expected np is not null, but is > > > > [11:55:05] [FAILED] dtb_root_node_found_by_path > > > > [11:55:05] # dtb_root_node_populates_of_root: EXPECTATION FAILED at drivers/of/of_test.c:28 > > > > [11:55:05] Expected of_root is not null, but is > > > > [11:55:05] [FAILED] dtb_root_node_populates_of_root > > > > [11:55:05] # module: of_test > > > > [11:55:05] # dtb: pass:0 fail:2 skip:0 total:2 > > > > [11:55:05] # Totals: pass:0 fail:2 skip:0 total:2 > > > > [11:55:05] ======================= [FAILED] dtb ======================= > > > > Ah yeah I forgot to mention that. m68k fails because it doesn't call the > > unflatten_(and_copy)?_device_tree() function, so we don't populate a > > root node on that architecture. One solution would be to make CONFIG_OF > > unavailable on m68k. Or we have to make sure DT works on any > > architecture. Rob, what do you prefer here? > > I guess the latter? > Alpha, hexagon, parisc, s390, and sparc are also lacking calls > to unflatten.*device_tree(). > sparc does that on purpose. Perhaps it's simplest to call unflatten_device_tree() if of_root is still NULL after setup_arch() returns. ---8<--- diff --git a/init/main.c b/init/main.c index e24b0780fdff..02f5cf8be6c1 100644 --- a/init/main.c +++ b/init/main.c @@ -97,6 +97,8 @@ #include <linux/jump_label.h> #include <linux/kcsan.h> #include <linux/init_syscalls.h> +#include <linux/of.h> +#include <linux/of_fdt.h> #include <linux/stackdepot.h> #include <linux/randomize_kstack.h> #include <net/net_namespace.h> @@ -895,6 +897,8 @@ void start_kernel(void) pr_notice("%s", linux_banner); early_security_init(); setup_arch(&command_line); + if (!of_root) + unflatten_device_tree(); setup_boot_config(); setup_command_line(command_line); setup_nr_cpu_ids();
On Fri, Feb 9, 2024 at 8:59 PM Stephen Boyd <sboyd@kernel.org> wrote: > > Quoting Geert Uytterhoeven (2024-02-05 11:55:29) > > On Mon, Feb 5, 2024 at 8:19 PM Stephen Boyd <sboyd@kernel.org> wrote: > > > Quoting David Gow (2024-02-02 20:10:17) > > > > On Sat, 3 Feb 2024 at 03:59, Stephen Boyd <sboyd@kernel.org> wrote: > > > > > Add a KUnit test that confirms a DTB has been loaded, i.e. there is a > > > > > root node, and that the of_have_populated_dt() API works properly. > > > > > > > > > > Cc: Rob Herring <robh+dt@kernel.org> > > > > > Cc: Frank Rowand <frowand.list@gmail.com> > > > > > Cc: David Gow <davidgow@google.com> > > > > > Cc: Brendan Higgins <brendan.higgins@linux.dev> > > > > > Signed-off-by: Stephen Boyd <sboyd@kernel.org> > > > > > --- > > > > > > > > This looks pretty good to me test-wise, though it still fails on m68k. > > > > (Everything else I tried it on works, though I've definitely not tried > > > > _every_ architecture.) > > > > > > > > aarch64: PASSED > > > > i386: PASSED > > > > x86_64: PASSED > > > > x86_64 KASAN: PASSED > > > > powerpc64: PASSED > > > > UML: PASSED > > > > UML LLVM: PASSED > > > > m68k: FAILED > > > > > $ qemu-system-m68k -nodefaults -m 1024 -kernel .kunit-all-m68k/vmlinux -append 'kunit.enable=1 console=hvc0 kunit_shutdown=reboot' -no-reboot -nographic -serial stdio -machine virt > > > > > [11:55:05] ===================== dtb (2 subtests) ===================== > > > > > [11:55:05] # dtb_root_node_found_by_path: EXPECTATION FAILED at drivers/of/of_test.c:18 > > > > > [11:55:05] Expected np is not null, but is > > > > > [11:55:05] [FAILED] dtb_root_node_found_by_path > > > > > [11:55:05] # dtb_root_node_populates_of_root: EXPECTATION FAILED at drivers/of/of_test.c:28 > > > > > [11:55:05] Expected of_root is not null, but is > > > > > [11:55:05] [FAILED] dtb_root_node_populates_of_root > > > > > [11:55:05] # module: of_test > > > > > [11:55:05] # dtb: pass:0 fail:2 skip:0 total:2 > > > > > [11:55:05] # Totals: pass:0 fail:2 skip:0 total:2 > > > > > [11:55:05] ======================= [FAILED] dtb ======================= > > > > > > Ah yeah I forgot to mention that. m68k fails because it doesn't call the > > > unflatten_(and_copy)?_device_tree() function, so we don't populate a > > > root node on that architecture. One solution would be to make CONFIG_OF > > > unavailable on m68k. Or we have to make sure DT works on any > > > architecture. Rob, what do you prefer here? > > > > I guess the latter? > > Alpha, hexagon, parisc, s390, and sparc are also lacking calls > > to unflatten.*device_tree(). > > > > sparc does that on purpose. Perhaps it's simplest to call > unflatten_device_tree() if of_root is still NULL after setup_arch() > returns. > > ---8<--- > diff --git a/init/main.c b/init/main.c > index e24b0780fdff..02f5cf8be6c1 100644 > --- a/init/main.c > +++ b/init/main.c > @@ -97,6 +97,8 @@ > #include <linux/jump_label.h> > #include <linux/kcsan.h> > #include <linux/init_syscalls.h> > +#include <linux/of.h> > +#include <linux/of_fdt.h> > #include <linux/stackdepot.h> > #include <linux/randomize_kstack.h> > #include <net/net_namespace.h> > @@ -895,6 +897,8 @@ void start_kernel(void) > pr_notice("%s", linux_banner); > early_security_init(); > setup_arch(&command_line); > + if (!of_root) of_root is another thing I'd like to remove direct access to. That check could be inside unflatten_device_tree(). > + unflatten_device_tree(); That's back to what Frank had essentially and I wanted to avoid. I think I'd just disable the tests on the above arches and let them opt-in. I could be convinced otherwise though. Rob
Quoting Rob Herring (2024-02-13 09:52:00) > On Fri, Feb 9, 2024 at 8:59 PM Stephen Boyd <sboyd@kernel.org> wrote: > > > > ---8<--- > > diff --git a/init/main.c b/init/main.c > > index e24b0780fdff..02f5cf8be6c1 100644 > > --- a/init/main.c > > +++ b/init/main.c > > @@ -97,6 +97,8 @@ > > #include <linux/jump_label.h> > > #include <linux/kcsan.h> > > #include <linux/init_syscalls.h> > > +#include <linux/of.h> > > +#include <linux/of_fdt.h> > > #include <linux/stackdepot.h> > > #include <linux/randomize_kstack.h> > > #include <net/net_namespace.h> > > @@ -895,6 +897,8 @@ void start_kernel(void) > > pr_notice("%s", linux_banner); > > early_security_init(); > > setup_arch(&command_line); > > + if (!of_root) > > of_root is another thing I'd like to remove direct access to. That > check could be inside unflatten_device_tree(). Ok. > > > + unflatten_device_tree(); > > That's back to what Frank had essentially and I wanted to avoid. Alright, fair enough. > > I think I'd just disable the tests on the above arches and let them > opt-in. I could be convinced otherwise though. > Kunit folks would prefer to skip tests when dependencies aren't satisfied. The OF_UNITTEST config already depends on !SPARC so perhaps it's simplest to have tests skip if OF_EARLY_FLATREE=n. Then OF_EARLY_FLATREE can be def_bool OF && !(SPARC || M68K || other arches). The OF_UNITTEST config can depend on OF_EARLY_FLATREE instead of select it then. This way new supporting architectures can remove themselves from the def_bool line when they start calling unflatten_device_tree().
diff --git a/drivers/of/.kunitconfig b/drivers/of/.kunitconfig new file mode 100644 index 000000000000..5a8fee11978c --- /dev/null +++ b/drivers/of/.kunitconfig @@ -0,0 +1,3 @@ +CONFIG_KUNIT=y +CONFIG_OF=y +CONFIG_OF_KUNIT_TEST=y diff --git a/drivers/of/Kconfig b/drivers/of/Kconfig index 17733285b415..53d1b5dd89e8 100644 --- a/drivers/of/Kconfig +++ b/drivers/of/Kconfig @@ -37,6 +37,15 @@ config OF_UNITTEST If unsure, say N here. This option is not safe to enable. +config OF_KUNIT_TEST + tristate "Devicetree KUnit Test" if !KUNIT_ALL_TESTS + depends on KUNIT + default KUNIT_ALL_TESTS + help + This option builds KUnit unit tests for device tree infrastructure. + + If unsure, say N here, but this option is safe to enable. + config OF_ALL_DTBS bool "Build all Device Tree Blobs" depends on COMPILE_TEST diff --git a/drivers/of/Makefile b/drivers/of/Makefile index df305348d1cb..251d33532148 100644 --- a/drivers/of/Makefile +++ b/drivers/of/Makefile @@ -19,4 +19,6 @@ obj-y += kexec.o endif endif +obj-$(CONFIG_OF_KUNIT_TEST) += of_test.o + obj-$(CONFIG_OF_UNITTEST) += unittest-data/ diff --git a/drivers/of/of_test.c b/drivers/of/of_test.c new file mode 100644 index 000000000000..71a767b42b43 --- /dev/null +++ b/drivers/of/of_test.c @@ -0,0 +1,48 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * KUnit tests for OF APIs + */ +#include <linux/module.h> +#include <linux/of.h> + +#include <kunit/test.h> + +/* + * Test that the root node "/" can be found by path. + */ +static void dtb_root_node_found_by_path(struct kunit *test) +{ + struct device_node *np; + + np = of_find_node_by_path("/"); + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, np); + of_node_put(np); +} + +/* + * Test that the 'of_root' global variable is always populated when DT code is + * enabled. + */ +static void dtb_root_node_populates_of_root(struct kunit *test) +{ + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, of_root); +} + +static struct kunit_case dtb_test_cases[] = { + KUNIT_CASE(dtb_root_node_found_by_path), + KUNIT_CASE(dtb_root_node_populates_of_root), + {} +}; + +/* + * Test suite to confirm a DTB is loaded. + */ +static struct kunit_suite dtb_suite = { + .name = "dtb", + .test_cases = dtb_test_cases, +}; + +kunit_test_suites( + &dtb_suite, +); +MODULE_LICENSE("GPL");