[PATCH 2/5] sandbox: scmi: test against a single scmi agent

Etienne Carriere etienne.carriere at linaro.org
Mon Feb 21 08:36:53 CET 2022


Hello Patrick,

On Fri, 11 Feb 2022 at 14:46, Patrick DELAUNAY
<patrick.delaunay at foss.st.com> wrote:
>
> Hi Etienne,
>
> On 2/11/22 13:07, Etienne Carriere wrote:
> > As per DT bindings since Linux kernel v5.14, the device tree can define
> > only 1 SCMI agent node that is named scmi [1]. As a consequence, change
> > implementation of the SCMI driver test through sandbox architecture to
> > reflect that.
> >
> > This change updates sandbox test DT and sandbox SCMI driver accordingly
> > since all these are impacted.
> >
> > Cc: Simon Glass <sjg at chromium.org>
> > Signed-off-by: Etienne Carriere <etienne.carriere at linaro.org>
> > ---
> >   arch/sandbox/dts/test.dts                    |  37 ++--
> >   arch/sandbox/include/asm/scmi_test.h         |  12 +-
> >   drivers/firmware/scmi/sandbox-scmi_agent.c   | 167 ++++++-------------
> >   drivers/firmware/scmi/sandbox-scmi_devices.c |   4 +-
> >   test/dm/scmi.c                               | 117 +++++++------
> >   5 files changed, 129 insertions(+), 208 deletions(-)
> > (snip)
> >
> >   static int sandbox_scmi_test_probe(struct udevice *dev)
> >   {
> > -     static const char basename[] = "sandbox-scmi-agent@";
> > +     static const char basename[] = "scmi";
> >       struct sandbox_scmi_agent *agent = dev_get_priv(dev);
> > -     const size_t basename_size = sizeof(basename) - 1;
> >
> > -     if (strncmp(basename, dev->name, basename_size))
> > +     if (strcmp(basename, dev->name))
> >               return -ENOENT;
>
> This check is still needed ?
>
> you test in drivier if device is correct
>
> - static const char basename[] = "scmi";
> ....
>
> - if (strcmp(basename, dev->name))
> -               return -ENOENT;
>


Indeed I missed that update. Thanks, i'll fix.

> >
> > (snip)
> >
> > diff --git a/test/dm/scmi.c b/test/dm/scmi.c
> > index c938e6d4fc..2f19b99d7c 100644
> > --- a/test/dm/scmi.c
> > +++ b/test/dm/scmi.c
> > @@ -5,7 +5,7 @@
> >    * Tests scmi_agent uclass and the SCMI drivers implemented in other
> >    * uclass devices probe when a SCMI server exposes resources.
> >    *
> > - * Note in test.dts the protocol at 10 node in agent 1. Protocol 0x10 is not
> > + * Note in test.dts the protocol at 10 node in scmi node. Protocol 0x10 is not
> >    * implemented in U-Boot SCMI components but the implementation is exepected
> >    * to not complain on unknown protocol IDs, as long as it is not used. Note
> >    * in test.dts tests that SCMI drivers probing does not fail for such an
> > @@ -28,8 +28,7 @@ static int ut_assert_scmi_state_preprobe(struct unit_test_state *uts)
> >       struct sandbox_scmi_service *scmi_ctx = sandbox_scmi_service_ctx();
> >
> >       ut_assertnonnull(scmi_ctx);
> > -     if (scmi_ctx->agent_count)
> > -             ut_asserteq(2, scmi_ctx->agent_count);
> > +     ut_assertnull(scmi_ctx->agent);
> >
> >       return 0;
> >   }
> > @@ -39,35 +38,28 @@ static int ut_assert_scmi_state_postprobe(struct unit_test_state *uts,
> >   {
> >       struct sandbox_scmi_devices *scmi_devices;
> >       struct sandbox_scmi_service *scmi_ctx;
> > -     struct sandbox_scmi_agent *agent0;
> > -     struct sandbox_scmi_agent *agent1;
> > +     struct sandbox_scmi_agent *agent;
> >
> >       /* Device references to check context against test sequence */
> >       scmi_devices = sandbox_scmi_devices_ctx(dev);
> > -
> >       ut_assertnonnull(scmi_devices);
> > -     ut_asserteq(3, scmi_devices->clk_count);
> > +
> added line ?

will remove

> > +     ut_asserteq(2, scmi_devices->clk_count);
> >       ut_asserteq(1, scmi_devices->reset_count);
> >       ut_asserteq(2, scmi_devices->regul_count);
> >
> >       /* State of the simulated SCMI server exposed */
> >       scmi_ctx = sandbox_scmi_service_ctx();
> > -     agent0 = scmi_ctx->agent[0];
> > -     agent1 = scmi_ctx->agent[1];
> > -
> > -     ut_asserteq(2, scmi_ctx->agent_count);
> > -
> > -     ut_assertnonnull(agent0);
> > -     ut_asserteq(2, agent0->clk_count);
> > -     ut_assertnonnull(agent0->clk);
> > -     ut_asserteq(1, agent0->reset_count);
> > -     ut_assertnonnull(agent0->reset);
> > -     ut_asserteq(2, agent0->voltd_count);
> > -     ut_assertnonnull(agent0->voltd);
> > +     ut_assertnonnull(scmi_ctx);
> > +     agent = scmi_ctx->agent;
> > +     ut_assertnonnull(agent);
> >
> line to remove

ok

> > -     ut_assertnonnull(agent1);
> > -     ut_assertnonnull(agent1->clk);
> > -     ut_asserteq(1, agent1->clk_count);
> > +     ut_asserteq(2, agent->clk_count);
> > +     ut_assertnonnull(agent->clk);
> > +     ut_asserteq(1, agent->reset_count);
> > +     ut_assertnonnull(agent->reset);
> > +     ut_asserteq(2, agent->voltd_count);
> > +     ut_assertnonnull(agent->voltd);
> >
> >       return 0;
> >   }
> >  (snip)
>
>
> with few minor remarks
>
> Reviewed-by: Patrick Delaunay <patrick.delaunay at foss.st.com>

I'll send the fixes. Many thanks.

Best regards,
Etienne

>
> Thanks
> Patrick
>
>


More information about the U-Boot mailing list