From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: Sakari Ailus <sakari.ailus@linux.intel.com>
Cc: Jacopo Mondi <jacopo.mondi@ideasonboard.com>,
Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>,
Mauro Carvalho Chehab <mchehab@kernel.org>,
Raspberry Pi Kernel Maintenance <kernel-list@raspberrypi.com>,
Rob Herring <robh+dt@kernel.org>,
Krzysztof Kozlowski <krzk@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
Florian Fainelli <florian.fainelli@broadcom.com>,
Broadcom internal kernel review list
<bcm-kernel-feedback-list@broadcom.com>,
oe-kbuild-all@lists.linux.dev, linux-media@vger.kernel.org,
linux-kernel@vger.kernel.org, devicetree@vger.kernel.org,
linux-rpi-kernel@lists.infradead.org,
linux-arm-kernel@lists.infradead.org,
Naushir Patuck <naush@raspberrypi.com>,
Kieran Bingham <kieran.bingham@ideasonboard.com>,
kernel test robot <lkp@intel.com>
Subject: Re: [PATCH v4 3/4] media: raspberrypi: Add support for RP1-CFE
Date: Tue, 10 Sep 2024 13:06:08 +0300 [thread overview]
Message-ID: <20240910100608.GC6996@pendragon.ideasonboard.com> (raw)
In-Reply-To: <ZuAXiKjdgMUY1jcV@kekkonen.localdomain>
On Tue, Sep 10, 2024 at 09:55:20AM +0000, Sakari Ailus wrote:
> On Tue, Sep 10, 2024 at 11:42:06AM +0200, Jacopo Mondi wrote:
> > > > > > > > Ah, I missed that one.
> > > > > > > >
> > > > > > > > I don't think it fixes the issue I mentioned. If we have PM enabled, and the
> > > > > > > > parent device requires powering up for the child device (BE) to be
> > > > > > > > accessible, the driver will crash when calling pispbe_hw_init(). I think you
> > > > > > > > should call pm_runtime_set_active() before calling pispbe_runtime_resume().
> > > > > > >
> > > > > > > As discussed, this is not a problem currently for BE, but indeed you
> > > > > > > have a point.
> > > >
> > > > I admit the runtime_pm intrinsics are obscure to me, but Laurent just
> > > > made me notice something.
> > > >
> > > > Consider the following scenario
> > > >
> > > > *) Kernel compiled with CONFIG_PM
> > > > *) i2c sensor driver that supports both CONFIG_PM and !CONFIG_PM by:
> > > > *) Manually power up the sensor during probe
> > > > *) Call pm_runtime_enable() and pm_runtime_set_active() at the end
> > > > of the probe routine after having accessed the chip over i2c
> > > > (like most, if not all the i2c drivers in mainline do including
> > > > ccs)
> > > >
> > > > All these drivers work, and during the probe routine before accessing
> > > > the HW, they don't need to power up the parent i2c controller.
> > >
> > > This isn't done explicitly by the I²C drivers, indeed but...
> > >
> > > >
> > > > Might it be that during probe() the parent is guaranteed to be enabled ?
> > >
> > > ...yes.
> > >
> >
> > Unrelated, but I am wrong the driver core calls pm_request_idle() on
> > the just probed device ? Does this mean drivers doesn't have to do
> > that by themseleves ? (it's not a big deal, as request_idle() doesn't
> > change the usage counter)
>
> Seems like that. This could be omitted from drivers then.
Is that guaranteed, or is it an implementation detail that could change
at any time ?
> > > > I add a look in the driver-core and pm Documentation/ but found
> > > > nothing.
> > > >
> > > > A quick stroll in driver/base/ got me to __device_attach() and it
> > > > seems parents are powered up before attaching a driver to a device
> > > > (which in my understanding should be what ends up calling probe()).
> > > > Clearly I've no real understanding of what I'm talking about when it
> > > > comes to driver-core, so take this with a grain of salt.
> > >
> > > This only works with runtime PM enabled.
> >
> > It's the CONFIG_PM case that was worrying for Tomi
> >
> > > > > > > Sad note: most of all the occurrences of "grep set_active" in
> > > > > > > drivers/media/platform/ show that set_active() is used as I've done in
> > > > > > > my patch
> > > > > > >
> > > > > > > > However, you said above that "supporting !CONFIG_PM is not that much work".
> > > > > > > > Maybe not. But how much work is it to get it right (for both PM and !PM),
> > > > > > > > and make sure it stays right? =).
> > > > > > > >
> > > > > > > > Just my opinion, but if there are zero use cases for the !PM, I would just
> > > > > > > > go with "depends on PM" to keep the driver simpler, less bug-prone, and
> > > > > > > > easier to maintain.
> > > > > >
> > > > > > I'm fine with that, and for platform drivers, that's my preferred
> > > > > > option. Sakari ?
> > > > >
> > > > > I'm concerned with your (?) recent finding that many architectures don't
> > > > > have support for CONFIG_PM. In this case the device is very unlikely to be
> > > > > used outside ARM(64) so I guess it's fine.
> > > > >
> > > >
> > > > Also, this IP is RPi specific, and the !CONFIG_PM case is not used or
> > > > tested on Pi.
> > > >
> > > > However, I think this current patch is correct (assuming the above
> > > > reasoning on i2c sensor drivers is correct) and doesn't require
> > > > CONFIG_PM, so I would be tempted to keep this version.
> > >
> > > I understand the current patch does depend on CONFIG_PM: it requires
> > > runtime PM to be operational to start the clock, for instance.
> >
> > Where do you see that ?
> >
> > This version still calls pispbe_runtime_resume() to power up the IP,
> > it doesn't go through runtime_pm:
> > https://patchwork.linuxtv.org/project/linux-media/patch/20240904095836.344833-5-jacopo.mondi@ideasonboard.com/
>
> cfe_runtime_resume() is only called via runtime PM.
>
> > Thanks!
> >
> > > > > > > I don't see a use case for !PM and we confirmed with RPi they don't
> > > > > > > need to support it. During the review of a previous version of the BE
> > > > > > > driver iirc I've been asked to support !PM but I'm not sure I recall
> > > > > > > the reasons.
> > > > > >
> > > > > > I hope it wasn't me :-)
> > > > >
> > > > > Me neither. Although it'd be nice: CONFIG_PM isn't a hardware specific
> > > > > option as such. As one part of the kernel requires !CONFIG_PM and another
> > > > > CONFIG_PM, we can expect problems, at least in principle.
> > > > >
> > > > > Ideally all architectures would support it so CONFIG_PM could be removed
> > > > > and we could say the problem has been solved. :-)
--
Regards,
Laurent Pinchart
next prev parent reply other threads:[~2024-09-10 10:06 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-04 11:19 [PATCH v4 0/4] media: raspberrypi: Support RPi5's CFE Tomi Valkeinen
2024-09-04 11:19 ` [PATCH v4 1/4] media: uapi: Add meta formats for PiSP FE config and stats Tomi Valkeinen
2024-09-04 11:19 ` [PATCH v4 2/4] dt-bindings: media: Add bindings for raspberrypi,rp1-cfe Tomi Valkeinen
2024-09-04 11:19 ` [PATCH v4 3/4] media: raspberrypi: Add support for RP1-CFE Tomi Valkeinen
2024-09-05 10:50 ` kernel test robot
2024-09-05 11:11 ` Laurent Pinchart
2024-09-09 5:08 ` Tomi Valkeinen
2024-09-09 5:22 ` Tomi Valkeinen
2024-09-09 9:13 ` Jacopo Mondi
2024-09-09 10:04 ` Tomi Valkeinen
2024-09-09 13:29 ` Jacopo Mondi
2024-09-09 13:45 ` Laurent Pinchart
2024-09-09 15:52 ` Sakari Ailus
2024-09-10 9:19 ` Jacopo Mondi
2024-09-10 9:25 ` Sakari Ailus
2024-09-10 9:42 ` Jacopo Mondi
2024-09-10 9:55 ` Sakari Ailus
2024-09-10 10:06 ` Laurent Pinchart [this message]
2024-09-10 10:12 ` Tomi Valkeinen
2024-09-10 9:56 ` Tomi Valkeinen
2024-09-10 10:11 ` Laurent Pinchart
2024-09-10 10:21 ` Sakari Ailus
2024-09-10 10:26 ` Tomi Valkeinen
2024-09-10 10:18 ` Jacopo Mondi
2024-09-10 10:28 ` Tomi Valkeinen
2024-09-04 11:19 ` [PATCH v4 4/4] media: admin-guide: Document the Raspberry Pi CFE (rp1-cfe) Tomi Valkeinen
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=20240910100608.GC6996@pendragon.ideasonboard.com \
--to=laurent.pinchart@ideasonboard.com \
--cc=bcm-kernel-feedback-list@broadcom.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=florian.fainelli@broadcom.com \
--cc=jacopo.mondi@ideasonboard.com \
--cc=kernel-list@raspberrypi.com \
--cc=kieran.bingham@ideasonboard.com \
--cc=krzk@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=linux-rpi-kernel@lists.infradead.org \
--cc=lkp@intel.com \
--cc=mchehab@kernel.org \
--cc=naush@raspberrypi.com \
--cc=oe-kbuild-all@lists.linux.dev \
--cc=robh+dt@kernel.org \
--cc=sakari.ailus@linux.intel.com \
--cc=tomi.valkeinen@ideasonboard.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