linux-clk.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Herve Codina <herve.codina@bootlin.com>
To: Matti Vaittinen <mazziesaccount@gmail.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>,
	Kalle Niemi <kaleposti@gmail.com>, Rob Herring <robh@kernel.org>,
	linux-arm-kernel@lists.infradead.org,
	Andrew Lunn <andrew@lunn.ch>,
	Krzysztof Kozlowski <krzk+dt@kernel.org>,
	Conor Dooley <conor+dt@kernel.org>,
	Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	"Rafael J. Wysocki" <rafael@kernel.org>,
	Danilo Krummrich <dakr@kernel.org>,
	Shawn Guo <shawnguo@kernel.org>,
	Sascha Hauer <s.hauer@pengutronix.de>,
	Pengutronix Kernel Team <kernel@pengutronix.de>,
	Fabio Estevam <festevam@gmail.com>,
	Michael Turquette <mturquette@baylibre.com>,
	Stephen Boyd <sboyd@kernel.org>,
	Andi Shyti <andi.shyti@kernel.org>,
	Wolfram Sang <wsa+renesas@sang-engineering.com>,
	Peter Rosin <peda@axentia.se>, Arnd Bergmann <arnd@arndb.de>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Charles Keepax <ckeepax@opensource.cirrus.com>,
	Richard Fitzgerald <rf@opensource.cirrus.com>,
	David Rhodes <david.rhodes@cirrus.com>,
	Linus Walleij <linus.walleij@linaro.org>,
	Ulf Hansson <ulf.hansson@linaro.org>,
	Mark Brown <broonie@kernel.org>,
	Andy Shevchenko <andriy.shevchenko@linux.intel.com>,
	Daniel Scally <djrscally@gmail.com>,
	Heikki Krogerus <heikki.krogerus@linux.intel.com>,
	Sakari Ailus <sakari.ailus@linux.intel.com>,
	Len Brown <lenb@kernel.org>, Davidlohr Bueso <dave@stgolabs.net>,
	Jonathan Cameron <jonathan.cameron@huawei.com>,
	Dave Jiang <dave.jiang@intel.com>,
	Alison Schofield <alison.schofield@intel.com>,
	Vishal Verma <vishal.l.verma@intel.com>,
	Ira Weiny <ira.weiny@intel.com>,
	Dan Williams <dan.j.williams@intel.com>,
	Wolfram Sang <wsa@kernel.org>,
	devicetree@vger.kernel.org, linux-kernel@vger.kernel.org,
	imx@lists.linux.dev, linux-clk@vger.kernel.org,
	linux-i2c@vger.kernel.org, linux-pci@vger.kernel.org,
	linux-sound@vger.kernel.org, patches@opensource.cirrus.com,
	linux-gpio@vger.kernel.org, linux-pm@vger.kernel.org,
	linux-spi@vger.kernel.org, linux-acpi@vger.kernel.org,
	linux-cxl@vger.kernel.org,
	Allan Nielsen <allan.nielsen@microchip.com>,
	Horatiu Vultur <horatiu.vultur@microchip.com>,
	Steen Hegelund <steen.hegelund@microchip.com>,
	Luca Ceresoli <luca.ceresoli@bootlin.com>,
	Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Subject: Re: [PATCH v4 01/29] Revert "treewide: Fix probing of devices in DT overlays"
Date: Thu, 11 Dec 2025 13:20:44 +0100	[thread overview]
Message-ID: <20251211132044.10f5b1ea@bootlin.com> (raw)
In-Reply-To: <c50c40cc-69f6-436c-a94e-94a3a10f6727@gmail.com>

Hi Matti,

On Thu, 11 Dec 2025 10:34:46 +0200
Matti Vaittinen <mazziesaccount@gmail.com> wrote:

> Hi Dee Ho peeps,
> 
> I tried to create a minimal piece of code/dts to demonstrate the issue 
> seem in the ROHM automated testing.
> 
> On 10/12/2025 14:21, Herve Codina wrote:
> > Hi Geert, Kalle, Rob,
> > 
> > On Thu, 4 Dec 2025 11:49:13 +0100
> > Geert Uytterhoeven <geert@linux-m68k.org> wrote:  
> 
> //snip
> 
> > When a new node is added, a new device is created. Indeed, because the
> > driver is an MFD driver, it is a bus driver and handled by of_platform bus.  
> 
> We do also have an MFD device - but it is not a platform device but an 
> I2C device - thus it should be probed by the I2C bus (if I'm not 
> mistaken). So, I guess this is not bus-specific problem.
> https://elixir.bootlin.com/linux/v6.18/source/drivers/mfd/rohm-bd718x7.c#L206
> 
> 
> > My new node is considered by devlink as a node that will have a device ready
> > to work (driver attached and device probed). A link is created between this
> > node and the consumers of this node (i.e. the SPI controller). devlink is
> > waiting for this provider to be ready before allowing the its consumer to probe.
> > This node (simple pinmux description) will never lead to a device and devlink
> > will never see this "provider" ready.  
> 
> I believe Kalle did see the same "probe-not-called" -problem, even when 
> disabling the fw_devlink from the kernel commandline. (It's worth 
> mentioning that I am not sure if Kalle tried if probe was called with 
> "previously working" kernels when fw_devlink is disabled).
> 
> > Did a test with a Renesas RZ/N1D (r9a06g032) based board and built a similar
> > overlay involving I2C controller pinmux, I2C controller and an EEPROM.
> > 
> > Here, also the overlay didn't work but the issue is different.
> > 
> > The pinmux definition for pinctrl (i.e. pinctrl subnodes) are looked when
> > the pinctrl driver probes. Adding a new node later is not handled by the
> > pinctrl driver.
> > Applying the overlay leads to a simple:
> >    [   16.934168] rzn1-pinctrl 40067000.pinctrl: unable to find group for node /soc/pinctrl@40067000/pins_i2c2
> > 
> > Indeed, the 'pins_i2c2' has been added by the overlay and was not present
> > when the pinctrl probed.
> > 
> > Tried without adding a new pinmux node (pinctrl subnode) from the overlay
> > and used nodes already existing in the base DT.
> > 
> > On my Marvell Armada 3720 board, it works with or without my patches.
> > No regression detected due to my patches.
> > 
> > On my RZ/N1D board, it works also with or without my patches.
> > Here also, no regression detected.
> > 
> > Also, on my Marvell Armada 3720 board, I can plug my LAN966x PCI board.
> > The LAN966x PCI driver used an overlay to describe the LAN966x PCI board.
> > 
> > With the upstream patch not reverted, i.e. 1a50d9403fb9 ("treewide: Fix
> > probing of devices in DT overlays")" applied, devlinks created for the
> > LAN966x PCI board internal devices are incorrect and lead to crashes when
> > the LAN966x PCI driver is removed due to wrong provider/consumer dependencies.
> > 
> > When this patch is reverted and replaced by "of: dynamic: Fix overlayed
> > devices not probing because of fw_devlink", devlinks created for the LAN966x
> > PCI board internal devices are corrects and crashes are no more present on
> > removal.
> > 
> > Kalle, Geert, can you perform a test on your hardware with my patches
> > applied and moving your pinmux definition from the overlay to the base
> > device-tree?  
> 
> I got a bit lost regarding which patches to test :)

The next-20251127 tag has every patches needed for the test.
Tests you did with this kernel are perfectly valid. Many Thanks for that!

> 
> > The kernel you can use is for instance the kernel at the next-20251127 tag.
> > Needed patches for test are present in this kernel:
> >      - 76841259ac092 ("of: dynamic: Fix overlayed devices not probing because of fw_devlink")
> >      - 7d67ddc5f0148 ("Revert "treewide: Fix probing of devices in DT overlays"")
> >   
> 
> I did a minimal overlay test which can be ran on beaglebone black. I 
> assume the same can be done on any board where you have 
> (i2c/spi/xxx)-controller node with status="disabled". Doing this on BBB 
> requires recompiling the beaglebone black (base)device-tree with -@ 
> though, so that the overlay target nodes are found. I'll attach the 
> files for interested.
> 
> overlay-test.c:
> Is a 'device-driver' for device added in overlay. (simply a probe() with 
> print, extracted from the bd71847 driver).
> 
> overlay-test.dts:
> Is a minimal device-tree overlay describing the 'test device' matching 
> above overlay-test driver. When this is overlaid using next-20251121 
> (contains the 7d67ddc5f0148b3a03594a45bba5547e92640c89), probe in 
> overlay-test.c is not called. When 
> 7d67ddc5f0148b3a03594a45bba5547e92640c89 is reverted, the probe is called.
> 
> mva_overlay.c:
> Is simplified 'glue-code' for adding an overlay to running kernel by 
> feeding the compiled overlay to the bin_attribute - for example using:
> 
> dd if=/overlay-test.dtbo of=/sys/kernel/mva_overlay/overlay_add bs=4M
> 
> am335x-boneblack.dtb.dts.tmp and tps65217.dtsi:
> are (intermediate) beaglebone-black device-trees which can be recompiled 
> to a 'base device-tree' using:
> 
> dtc -O dtb -o am335x-boneblack.dtb -b 0 -@ am335x-boneblack.dtb.dts.tmp
>   - but I suggest you to use the dts from your kernel build. I provided 
> this just for the sake of the completeness.
> 
> Makefile:
> Off-tree build targets to build the above DTSes and modules. Requires 
> KERNEL_DIR and CC to be correctly set.
> 
> 
> My findings:
> The pinctrl node indeed plays a role. When the "pinctrl-0 = 
> <&i2c1_pins>;" (and fragment0) was removed from the dts, the 
> 'overlay-test' was probed with the "next-20251121".
> 
> With the pinctrl node, I see:
> [  104.098958] probe of 4802a000.i2c returned -517 (EPROBE_DEFER I 
> suppose) after 50 usecs
> - and the 'overlay-test' probe is not called.

Do you see the same trace with:
- "pinctrl-0 = <&i2c1_pins>;" in your overlay
- fragment0 removed from the overlay (i2c1_pins definition removed from
  the overlay.
- i2c1_pins node defined in your base DT.

In other word, is the issues related to adding a pinctrl sub-node (pinctrl
pins definition) in the overlay or is it something else?

Best regards,
Hervé




  reply	other threads:[~2025-12-11 12:21 UTC|newest]

Thread overview: 72+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-10-15  7:13 [PATCH v4 00/29] lan966x pci device: Add support for SFPs Herve Codina
2025-10-15  7:13 ` [PATCH v4 01/29] Revert "treewide: Fix probing of devices in DT overlays" Herve Codina
2025-11-24 13:03   ` Kalle Niemi
2025-11-24 14:53     ` Rob Herring
2025-11-24 15:07       ` Kalle Niemi
2025-11-24 17:01         ` Rob Herring
2025-11-25  6:42           ` Matti Vaittinen
2025-11-27  1:54             ` Rob Herring
2025-11-27  7:24               ` Herve Codina
2025-11-28  8:34               ` Kalle Niemi
2025-12-02  9:26                 ` Herve Codina
2025-12-02 11:21                   ` Kalle Niemi
2025-12-02 16:58                     ` Herve Codina
2025-12-03 10:11                       ` Kalle Niemi
2025-12-04  7:38                         ` Herve Codina
2025-12-04 10:49                           ` Geert Uytterhoeven
2025-12-04 12:06                             ` Andy Shevchenko
2025-12-10 12:21                             ` Herve Codina
2025-12-11  8:34                               ` Matti Vaittinen
2025-12-11 12:20                                 ` Herve Codina [this message]
2025-12-11 13:52                                   ` Matti Vaittinen
2025-12-11 15:19                                     ` Herve Codina
2025-12-04 12:04                           ` Andy Shevchenko
2025-12-02 16:35                   ` Geert Uytterhoeven
2025-12-02 17:28                     ` Herve Codina
2025-12-03 10:06                       ` Geert Uytterhoeven
2025-10-15  7:13 ` [PATCH v4 02/29] driver core: Rename get_dev_from_fwnode() wrapper to get_device_from_fwnode() Herve Codina
2025-10-21 10:36   ` Ulf Hansson
2025-10-15  7:13 ` [PATCH v4 03/29] of: dynamic: Fix overlayed devices not probing because of fw_devlink Herve Codina
2025-10-15  7:13 ` [PATCH v4 04/29] driver core: Avoid warning when removing a device while its supplier is unbinding Herve Codina
2025-10-15  7:13 ` [PATCH v4 05/29] dt-bindings: bus: Add simple-platform-bus Herve Codina
2025-10-30 14:14   ` Rob Herring
2025-10-31 15:20     ` Herve Codina
2025-11-12 14:26       ` Rob Herring
2025-11-12 19:29         ` Rob Herring
2025-11-14  7:30           ` Herve Codina
2025-10-31  8:52   ` Geert Uytterhoeven
2025-10-31 14:29     ` Herve Codina
2025-10-15  7:13 ` [PATCH v4 06/29] bus: Introduce simple-platorm-bus Herve Codina
2025-10-21 14:07   ` Andy Shevchenko
2025-10-15  7:13 ` [PATCH v4 07/29] misc: lan966x_pci: Use simple-platform-bus Herve Codina
2025-10-15  7:13 ` [PATCH v4 08/29] driver core: fw_devlink: Introduce fw_devlink_set_device() Herve Codina
2025-10-21 10:36   ` Ulf Hansson
2025-10-21 14:08   ` Andy Shevchenko
2025-10-15  7:13 ` [PATCH v4 09/29] drivers: core: Use fw_devlink_set_device() Herve Codina
2025-10-21 10:36   ` Ulf Hansson
2025-10-15  7:13 ` [PATCH v4 10/29] pinctrl: cs42l43: " Herve Codina
2025-10-15  7:13 ` [PATCH v4 11/29] cxl/test: Use device_set_node() Herve Codina
2025-10-15  7:13 ` [PATCH v4 12/29] cxl/test: Use fw_devlink_set_device() Herve Codina
2025-10-15  7:14 ` [PATCH v4 13/29] PCI: of: " Herve Codina
2025-10-15  7:14 ` [PATCH v4 14/29] PCI: of: Set fwnode device of newly created PCI device nodes Herve Codina
2025-10-15  7:14 ` [PATCH v4 15/29] PCI: of: Remove fwnode_dev_initialized() call for a PCI root bridge node Herve Codina
2025-10-15  7:14 ` [PATCH v4 16/29] i2c: core: Introduce i2c_get_adapter_physdev() Herve Codina
2025-10-15  7:14 ` [PATCH v4 17/29] i2c: mux: Set adapter physical device Herve Codina
2025-10-30 13:35   ` Andi Shyti
2025-10-15  7:14 ` [PATCH v4 18/29] i2c: mux: Create missing devlink between mux and " Herve Codina
2025-10-30 15:23   ` Andi Shyti
2025-10-30 17:45     ` Andy Shevchenko
2025-11-03 13:34     ` Herve Codina
2025-10-15  7:14 ` [PATCH v4 19/29] of: property: Allow fw_devlink device-tree on x86 Herve Codina
2025-10-30 14:46   ` Rob Herring
2025-10-15  7:14 ` [PATCH v4 20/29] clk: lan966x: Add MCHP_LAN966X_PCI dependency Herve Codina
2025-10-15  7:14 ` [PATCH v4 21/29] i2c: busses: at91: " Herve Codina
2025-10-15  7:14 ` [PATCH v4 22/29] misc: lan966x_pci: Fix dtso nodes ordering Herve Codina
2025-10-15  7:14 ` [PATCH v4 23/29] misc: lan966x_pci: Split dtso in dtsi/dtso Herve Codina
2025-10-15  7:14 ` [PATCH v4 24/29] misc: lan966x_pci: Rename lan966x_pci.dtso to lan966x_evb_lan9662_nic.dtso Herve Codina
2025-10-15  7:14 ` [PATCH v4 25/29] PCI: Add Microchip LAN9662 PCI Device ID Herve Codina
2025-10-15  7:14 ` [PATCH v4 26/29] misc: lan966x_pci: Introduce board specific data Herve Codina
2025-10-15  7:14 ` [PATCH v4 27/29] misc: lan966x_pci: Add dtsi/dtso nodes in order to support SFPs Herve Codina
2025-10-15  7:14 ` [PATCH v4 28/29] misc: lan966x_pci: Sort the drivers list in Kconfig help Herve Codina
2025-10-15  7:14 ` [PATCH v4 29/29] misc: lan966x_pci: Add drivers needed to support SFPs " Herve Codina
2025-11-14 17:48 ` [PATCH v4 00/29] lan966x pci device: Add support for SFPs Rob Herring

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=20251211132044.10f5b1ea@bootlin.com \
    --to=herve.codina@bootlin.com \
    --cc=alison.schofield@intel.com \
    --cc=allan.nielsen@microchip.com \
    --cc=andi.shyti@kernel.org \
    --cc=andrew@lunn.ch \
    --cc=andriy.shevchenko@linux.intel.com \
    --cc=arnd@arndb.de \
    --cc=bhelgaas@google.com \
    --cc=broonie@kernel.org \
    --cc=ckeepax@opensource.cirrus.com \
    --cc=conor+dt@kernel.org \
    --cc=dakr@kernel.org \
    --cc=dan.j.williams@intel.com \
    --cc=dave.jiang@intel.com \
    --cc=dave@stgolabs.net \
    --cc=david.rhodes@cirrus.com \
    --cc=devicetree@vger.kernel.org \
    --cc=djrscally@gmail.com \
    --cc=festevam@gmail.com \
    --cc=geert@linux-m68k.org \
    --cc=gregkh@linuxfoundation.org \
    --cc=heikki.krogerus@linux.intel.com \
    --cc=horatiu.vultur@microchip.com \
    --cc=imx@lists.linux.dev \
    --cc=ira.weiny@intel.com \
    --cc=jonathan.cameron@huawei.com \
    --cc=kaleposti@gmail.com \
    --cc=kernel@pengutronix.de \
    --cc=krzk+dt@kernel.org \
    --cc=lenb@kernel.org \
    --cc=linus.walleij@linaro.org \
    --cc=linux-acpi@vger.kernel.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-cxl@vger.kernel.org \
    --cc=linux-gpio@vger.kernel.org \
    --cc=linux-i2c@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=linux-sound@vger.kernel.org \
    --cc=linux-spi@vger.kernel.org \
    --cc=luca.ceresoli@bootlin.com \
    --cc=mazziesaccount@gmail.com \
    --cc=mturquette@baylibre.com \
    --cc=patches@opensource.cirrus.com \
    --cc=peda@axentia.se \
    --cc=rafael@kernel.org \
    --cc=rf@opensource.cirrus.com \
    --cc=robh@kernel.org \
    --cc=s.hauer@pengutronix.de \
    --cc=sakari.ailus@linux.intel.com \
    --cc=sboyd@kernel.org \
    --cc=shawnguo@kernel.org \
    --cc=steen.hegelund@microchip.com \
    --cc=thomas.petazzoni@bootlin.com \
    --cc=ulf.hansson@linaro.org \
    --cc=vishal.l.verma@intel.com \
    --cc=wsa+renesas@sang-engineering.com \
    --cc=wsa@kernel.org \
    /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).