From: Stephen Boyd <sboyd@kernel.org>
To: Rob Herring <robh@kernel.org>
Cc: Michael Turquette <mturquette@baylibre.com>,
linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org,
patches@lists.linux.dev, kunit-dev@googlegroups.com,
linux-kselftest@vger.kernel.org, devicetree@vger.kernel.org,
Brendan Higgins <brendan.higgins@linux.dev>,
David Gow <davidgow@google.com>, Rae Moar <rmoar@google.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Rafael J . Wysocki <rafael@kernel.org>,
Saravana Kannan <saravanak@google.com>,
Daniel Latypov <dlatypov@google.com>,
Christian Marangi <ansuelsmth@gmail.com>,
Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>,
Conor Dooley <conor+dt@kernel.org>,
Maxime Ripard <maxime@cerno.tech>
Subject: Re: [PATCH v5 05/11] of: Add a KUnit test for overlays and test managed APIs
Date: Thu, 06 Jun 2024 08:23:30 -0700 [thread overview]
Message-ID: <025da51b45c5234dc05c4bfc6b0570e5.sboyd@kernel.org> (raw)
In-Reply-To: <20240605234720.GA3441001-robh@kernel.org>
Quoting Rob Herring (2024-06-05 16:47:20)
> On Mon, Jun 03, 2024 at 03:38:02PM -0700, Stephen Boyd wrote:
> > diff --git a/drivers/of/Makefile b/drivers/of/Makefile
> > index 2ae909adde49..abd9c578343b 100644
> > diff --git a/drivers/of/overlay_test.c b/drivers/of/overlay_test.c
> > new file mode 100644
> > index 000000000000..9a8083c3a659
> > --- /dev/null
> > +++ b/drivers/of/overlay_test.c
> > @@ -0,0 +1,116 @@
> > +// SPDX-License-Identifier: GPL-2.0
> > +/*
> > + * KUnit tests for device tree overlays
> > + */
> > +#include <linux/device/bus.h>
> > +#include <linux/kconfig.h>
> > +#include <linux/of.h>
> > +#include <linux/of_platform.h>
> > +#include <linux/platform_device.h>
> > +
> > +#include <kunit/of.h>
> > +#include <kunit/test.h>
> > +
> > +static const char * const kunit_node_name = "kunit-test";
> > +static const char * const kunit_compatible = "test,empty";
> > +
> > +/* Test that of_overlay_apply_kunit() adds a node to the live tree */
> > +static void of_overlay_apply_kunit_apply(struct kunit *test)
> > +{
> > + struct device_node *np;
> > +
> > + KUNIT_ASSERT_EQ(test, 0,
> > + of_overlay_apply_kunit(test, kunit_overlay_test));
> > +
> > + np = of_find_node_by_name(NULL, kunit_node_name);
> > + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, np);
> > + of_node_put(np);
> > +}
> > +
> > +/*
> > + * Test that of_overlay_apply_kunit() creates platform devices with the
> > + * expected device_node
> > + */
> > +static void of_overlay_apply_kunit_platform_device(struct kunit *test)
> > +{
> > + struct platform_device *pdev;
> > + struct device_node *np;
> > +
> > + KUNIT_ASSERT_EQ(test, 0,
> > + of_overlay_apply_kunit(test, kunit_overlay_test));
> > +
> > + np = of_find_node_by_name(NULL, kunit_node_name);
> > + of_node_put_kunit(test, np);
>
> Moving target, but we now have of_node_put() cleanups. Would that work
> here instead?
Do you mean cleanup.h? I don't think it will work. The assert logic is
like an exception handler. If the assertion fails we basically jump out
of the test and run any test exit code, including kunit resource exits.
I could introduce another kunit wrapper for of_find_node_by_name() and
use that here so that the reference is dropped when the test exits.
>
> > + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, np);
> > +
> > + pdev = of_find_device_by_node(np);
> > + KUNIT_EXPECT_NOT_ERR_OR_NULL(test, pdev);
> > + if (pdev)
> > + put_device(&pdev->dev);
> > +}
> > +
> > +static int of_overlay_bus_match_compatible(struct device *dev, const void *data)
> > +{
> > + return of_device_is_compatible(dev->of_node, data);
> > +}
> > +
> > +/* Test that of_overlay_apply_kunit() cleans up after the test is finished */
> > +static void of_overlay_apply_kunit_cleanup(struct kunit *test)
> > +{
> > + struct kunit fake;
> > + struct platform_device *pdev;
> > + struct device *dev;
> > + struct device_node *np;
> > +
> > + if (!IS_ENABLED(CONFIG_OF_OVERLAY))
> > + kunit_skip(test, "requires CONFIG_OF_OVERLAY");
> > + if (!IS_ENABLED(CONFIG_OF_EARLY_FLATTREE))
> > + kunit_skip(test, "requires CONFIG_OF_EARLY_FLATTREE for root node");
> > +
> > + kunit_init_test(&fake, "fake test", NULL);
> > + KUNIT_ASSERT_EQ(test, fake.status, KUNIT_SUCCESS);
> > +
> > + KUNIT_ASSERT_EQ(test, 0,
> > + of_overlay_apply_kunit(&fake, kunit_overlay_test));
> > +
> > + np = of_find_node_by_name(NULL, kunit_node_name);
> > + of_node_put(np); /* Not derefing 'np' after this */
> > + KUNIT_ASSERT_NOT_ERR_OR_NULL(test, np);
> > +
> > + pdev = of_find_device_by_node(np);
>
> Don't you need to hold a ref on np until here?
Oh, good catch. We need an of_find_node_by_name_kunit() wrapper then.
next prev parent reply other threads:[~2024-06-06 15:23 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-03 22:37 [PATCH v5 00/11] clk: Add kunit tests for fixed rate and parent data Stephen Boyd
2024-06-03 22:37 ` [PATCH v5 01/11] of/platform: Allow overlays to create platform devices from the root node Stephen Boyd
2024-06-05 23:47 ` Rob Herring (Arm)
2024-06-03 22:37 ` [PATCH v5 02/11] of: Add test managed wrappers for of_overlay_apply()/of_node_put() Stephen Boyd
2024-06-13 7:48 ` David Gow
2024-07-02 22:39 ` Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 03/11] dt-bindings: vendor-prefixes: Add "test" vendor for KUnit and friends Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 04/11] dt-bindings: test: Add KUnit empty node binding Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 05/11] of: Add a KUnit test for overlays and test managed APIs Stephen Boyd
2024-06-05 23:47 ` Rob Herring
2024-06-06 15:23 ` Stephen Boyd [this message]
2024-06-13 7:50 ` David Gow
2024-07-02 21:45 ` Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 06/11] platform: Add test managed platform_device/driver APIs Stephen Boyd
2024-06-04 13:48 ` Greg Kroah-Hartman
2024-06-13 7:50 ` David Gow
2024-06-03 22:38 ` [PATCH v5 07/11] dt-bindings: test: Add single clk consumer Stephen Boyd
2024-06-04 12:50 ` Rob Herring (Arm)
2024-06-04 13:05 ` Rob Herring
2024-06-04 18:28 ` Stephen Boyd
2024-06-04 20:19 ` Rob Herring
2024-06-04 20:52 ` Stephen Boyd
2024-06-04 20:53 ` Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 08/11] clk: Add test managed clk provider/consumer APIs Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 09/11] clk: Add KUnit tests for clk fixed rate basic type Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 10/11] dt-bindings: clk: Add clk_parent_data test Stephen Boyd
2024-06-03 22:38 ` [PATCH v5 11/11] clk: Add KUnit tests for clks registered with struct clk_parent_data Stephen Boyd
2024-06-13 7:56 ` David Gow
2024-07-02 22:25 ` Stephen Boyd
2024-07-02 22:34 ` Stephen Boyd
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=025da51b45c5234dc05c4bfc6b0570e5.sboyd@kernel.org \
--to=sboyd@kernel.org \
--cc=ansuelsmth@gmail.com \
--cc=brendan.higgins@linux.dev \
--cc=conor+dt@kernel.org \
--cc=davidgow@google.com \
--cc=devicetree@vger.kernel.org \
--cc=dlatypov@google.com \
--cc=gregkh@linuxfoundation.org \
--cc=krzysztof.kozlowski+dt@linaro.org \
--cc=kunit-dev@googlegroups.com \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=maxime@cerno.tech \
--cc=mturquette@baylibre.com \
--cc=patches@lists.linux.dev \
--cc=rafael@kernel.org \
--cc=rmoar@google.com \
--cc=robh@kernel.org \
--cc=saravanak@google.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).