public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Philipp Stanner <pstanner@redhat.com>
To: Guenter Roeck <linux@roeck-us.net>
Cc: Hans de Goede <hdegoede@redhat.com>,
	Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
	Maxime Ripard <mripard@kernel.org>,
	 Thomas Zimmermann <tzimmermann@suse.de>,
	David Airlie <airlied@gmail.com>, Daniel Vetter <daniel@ffwll.ch>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Sam Ravnborg <sam@ravnborg.org>,
	dakr@redhat.com,  dri-devel@lists.freedesktop.org,
	linux-kernel@vger.kernel.org,  linux-pci@vger.kernel.org,
	linux-parisc@vger.kernel.org, Helge Deller <deller@gmx.de>
Subject: Re: [PATCH v9 02/13] PCI: Add devres helpers for iomap table [resulting in backtraces on HPPA]
Date: Tue, 25 Nov 2025 17:28:55 +0100	[thread overview]
Message-ID: <6e43c821658de1f388de99aac9cbbbbfdccb7ffd.camel@redhat.com> (raw)
In-Reply-To: <6c749a78-2c98-45a8-b9d4-47f79b56c918@roeck-us.net>

On Tue, 2025-11-25 at 08:12 -0800, Guenter Roeck wrote:
> On 11/25/25 07:48, Philipp Stanner wrote:
> > On Sun, 2025-11-23 at 08:42 -0800, Guenter Roeck wrote:
> > > Hi,
> > > 
> > > On Thu, Jun 13, 2024 at 01:50:15PM +0200, Philipp Stanner wrote:
> > > > The pcim_iomap_devres.table administrated by pcim_iomap_table() has its
> > > > entries set and unset at several places throughout devres.c using manual
> > > > iterations which are effectively code duplications.
> > > > 
> > > > Add pcim_add_mapping_to_legacy_table() and
> > > > pcim_remove_mapping_from_legacy_table() helper functions and use them where
> > > > possible.
> > > > 
> > > > Link: https://lore.kernel.org/r/20240605081605.18769-4-pstanner@redhat.com
> > > > Signed-off-by: Philipp Stanner <pstanner@redhat.com>
> > > > [bhelgaas: s/short bar/int bar/ for consistency]
> > > > Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
> > > > ---
> > > >   drivers/pci/devres.c | 77 +++++++++++++++++++++++++++++++++-----------
> > > >   1 file changed, 58 insertions(+), 19 deletions(-)
> > > > 
> > > > diff --git a/drivers/pci/devres.c b/drivers/pci/devres.c
> > > > index f13edd4a3873..845d6fab0ce7 100644
> > > > --- a/drivers/pci/devres.c
> > > > +++ b/drivers/pci/devres.c
> > > > @@ -297,6 +297,52 @@ void __iomem * const *pcim_iomap_table(struct pci_dev *pdev)
> > > >   }
> > > >   EXPORT_SYMBOL(pcim_iomap_table);
> > > >   
> > > > +/*
> > > > + * Fill the legacy mapping-table, so that drivers using the old API can
> > > > + * still get a BAR's mapping address through pcim_iomap_table().
> > > > + */
> > > > +static int pcim_add_mapping_to_legacy_table(struct pci_dev *pdev,
> > > > +					    void __iomem *mapping, int bar)
> > > > +{
> > > > +	void __iomem **legacy_iomap_table;
> > > > +
> > > > +	if (bar >= PCI_STD_NUM_BARS)
> > > > +		return -EINVAL;
> > > > +
> > > > +	legacy_iomap_table = (void __iomem **)pcim_iomap_table(pdev);
> > > > +	if (!legacy_iomap_table)
> > > > +		return -ENOMEM;
> > > > +
> > > > +	/* The legacy mechanism doesn't allow for duplicate mappings. */
> > > > +	WARN_ON(legacy_iomap_table[bar]);
> > > > +
> > > 
> > > Ever since this patch has been applied, I see this warning on all hppa
> > > (parisc) systems.
> > > 
> > > [    0.978177] WARNING: CPU: 0 PID: 1 at drivers/pci/devres.c:473 pcim_add_mapping_to_legacy_table.part.0+0x54/0x80
> > > [    0.978850] Modules linked in:
> > > [    0.979277] CPU: 0 UID: 0 PID: 1 Comm: swapper/0 Not tainted 6.18.0-rc6-64bit+ #1 NONE
> > > [    0.979519] Hardware name: 9000/785/C3700
> > > [    0.979715]
> > > [    0.979768]      YZrvWESTHLNXBCVMcbcbcbcbOGFRQPDI
> > > [    0.979886] PSW: 00001000000001000000000000001111 Not tainted
> > > [    0.980006] r00-03  000000000804000f 00000000414e10a0 0000000040acb300 00000000434b1440
> > > [    0.980167] r04-07  00000000414a78a0 0000000000029000 0000000000000000 0000000043522000
> > > [    0.980314] r08-11  0000000000000000 0000000000000008 0000000000000000 00000000434b0de8
> > > [    0.980461] r12-15  00000000434b11b0 000000004156a8a0 0000000043c655a0 0000000000000000
> > > [    0.980608] r16-19  000000004016e080 000000004019e7d8 0000000000000030 0000000043549780
> > > [    0.981106] r20-23  0000000020000000 0000000000000000 000000000800000e 0000000000000000
> > > [    0.981317] r24-27  0000000000000000 000000000800000f 0000000043522260 00000000414a78a0
> > > [    0.981480] r28-31  00000000436af480 00000000434b1680 00000000434b14d0 0000000000027000
> > > [    0.981641] sr00-03  0000000000000000 0000000000000000 0000000000000000 0000000000000000
> > > [    0.981805] sr04-07  0000000000000000 0000000000000000 0000000000000000 0000000000000000
> > > [    0.981972]
> > > [    0.982024] IASQ: 0000000000000000 0000000000000000 IAOQ: 0000000040acb31c 0000000040acb320
> > > [    0.982185]  IIR: 03ffe01f    ISR: 0000000000000000  IOR: 00000000436af410
> > > [    0.982322]  CPU:        0   CR30: 0000000043549780 CR31: 0000000000000000
> > > [    0.982458]  ORIG_R28: 00000000434b16b0
> > > [    0.982548]  IAOQ[0]: pcim_add_mapping_to_legacy_table.part.0+0x54/0x80
> > > [    0.982733]  IAOQ[1]: pcim_add_mapping_to_legacy_table.part.0+0x58/0x80
> > > [    0.982871]  RP(r2): pcim_add_mapping_to_legacy_table.part.0+0x38/0x80
> > > [    0.983100] Backtrace:
> > > [    0.983439]  [<0000000040acba1c>] pcim_iomap+0xc4/0x170
> > > [    0.983577]  [<0000000040ba3e4c>] serial8250_pci_setup_port+0x8c/0x168
> > > [    0.983725]  [<0000000040ba7588>] setup_port+0x38/0x50
> > > [    0.983837]  [<0000000040ba7d94>] pci_hp_diva_setup+0x8c/0xd8
> > > [    0.983957]  [<0000000040baa47c>] pciserial_init_ports+0x2c4/0x358
> > > [    0.984088]  [<0000000040baa8bc>] pciserial_init_one+0x31c/0x330
> > > [    0.984214]  [<0000000040abfab4>] pci_device_probe+0x194/0x270
> > > 
> > > Looking into serial8250_pci_setup_port():
> > > 
> > >          if (pci_resource_flags(dev, bar) & IORESOURCE_MEM) {
> > >                  if (!pcim_iomap(dev, bar, 0) && !pcim_iomap_table(dev))
> > >                          return -ENOMEM;
> > 
> > Strange. From the code I see here the WARN_ON in
> > pcim_add_mapping_to_legacy_table() should not fire. I suspect that it's
> > actually triggered somewhere else.
> > 
> 
> pcim_iomap() calls pcim_add_mapping_to_legacy_table() which triggers the traceback.
> The caller uses the returned error to determine that it needs to call pcim_iomap_table()
> instead. As you point out below, that may not be necessary, but then it is already
> too late and the warning was triggered.
> 
> > > 
> > > This suggests that the failure is expected. I can see that pcim_iomap_table()
> > > is deprecated, and that one is supposed to use pcim_iomap() instead. However,
> > > pcim_iomap() _is_ alrady used, and I don't see a function which lets the
> > > caller replicate what is done above (attach multiple serial ports to the
> > > same PCI bar).
> > 
> > Is serial8250_pci_setup_port() invoked in a loop somewhere? Where does
> > the "attach multiple" happen?
> > 
> 
> It is called for multiple serial ports, each of which are in the same bar but
> with different offset into the bar.
> 
> > > 
> > > How would you suggest to fix the problem ?
> > 
> > I suggest you try to remove the `&& pcim_iomap_table(dev)` from above
> > to see if that's really the cause. pcim_iomap() already creates the
> > table, and if it succeeds the table has been created with absolute
> > certainty. The entries will also be present. So the table-check is
> > surplus.
> > 
> 
> How would that fix anything ? The warning would still be triggered from the
> failed call to pcim_iomap() for the 2nd and subsequent serial port on the
> same bar.

OK, I failed to see that it's really pcim_iomap() which is called
multiple times for the same bar.

The warning itself is harmless, so it's not urgent.
Cleanup is always done through devres callbacks, one per resource. The
table is not used for that, just for accessors of existing mappings. So
at first glance I think that removing the WARN_ON would be OK. I'd like
to hear Bjorn's opinion on that, though.

Maybe you could investigate removing pcim_iomap_table() from this
driver, obtaining the mappings directly from calls to pcim_iomap().
Calling it multiple times for the same BAR is valid, it's just the
table which complains. Since you are the first party I ever hear from
about that WARN_ON. So with this driver ported one could argue that
removing it is justified..

Another possiblity could be to switch to unmanaged PCI. Use pci_iomap()
and pci_enable_device() etc.

In case you have lots of spare cycles, the cleanest way would be to
remove the legacy table altogether. To do so, one would have to port
all users of pcim_iomap_table(). I have worked on that for a while and
have removed many of them. The most difficult remaining users are AFAIR
in drivers/ata/


P.


  reply	other threads:[~2025-11-25 16:29 UTC|newest]

Thread overview: 37+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-06-13 11:50 [PATCH v9 00/13] Make PCI's devres API more consistent Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 01/13] PCI: Add and use devres helper for bit masks Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 02/13] PCI: Add devres helpers for iomap table Philipp Stanner
2025-11-23 16:42   ` [PATCH v9 02/13] PCI: Add devres helpers for iomap table [resulting in backtraces on HPPA] Guenter Roeck
2025-11-25 15:48     ` Philipp Stanner
2025-11-25 16:12       ` Guenter Roeck
2025-11-25 16:28         ` Philipp Stanner [this message]
2025-11-25 18:49           ` Guenter Roeck
2024-06-13 11:50 ` [PATCH v9 03/13] PCI: Add partial-BAR devres support Philipp Stanner
2024-06-13 21:28   ` Bjorn Helgaas
2024-06-14  8:01     ` Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 04/13] PCI: Deprecate two surplus devres functions Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 05/13] PCI: Make devres region requests consistent Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 06/13] PCI: Warn users about complicated devres nature Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 07/13] PCI: Remove enabled status bit from pci_devres Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 08/13] PCI: Move pinned status bit to struct pci_dev Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 09/13] PCI: Give pcim_set_mwi() its own devres callback Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 10/13] PCI: Give pci_intx() " Philipp Stanner
2024-06-13 21:06   ` Bjorn Helgaas
2024-06-14  8:09     ` Philipp Stanner
2024-06-14 16:14       ` Bjorn Helgaas
2024-06-17  8:21         ` Philipp Stanner
2024-06-17 16:46           ` Bjorn Helgaas
2024-06-18  7:56             ` Philipp Stanner
2024-07-08 21:46   ` Ashish Kalra
2024-07-09  7:21     ` Philipp Stanner
2024-07-09  8:12       ` Kalra, Ashish
2024-07-09  8:56     ` Philipp Stanner
2024-07-09 18:46       ` Kalra, Ashish
2024-07-10  4:08         ` Krzysztof Wilczyński
2024-07-10  4:43       ` Krzysztof Wilczyński
2024-06-13 11:50 ` [PATCH v9 11/13] PCI: Remove legacy pcim_release() Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 12/13] PCI: Add pcim_iomap_range() Philipp Stanner
2024-06-13 11:50 ` [PATCH v9 13/13] drm/vboxvideo: fix mapping leaks Philipp Stanner
2024-06-13 21:57 ` [PATCH v9 00/13] Make PCI's devres API more consistent Bjorn Helgaas
2024-06-14 11:38   ` Philipp Stanner
2024-06-14 16:16     ` Bjorn Helgaas

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=6e43c821658de1f388de99aac9cbbbbfdccb7ffd.camel@redhat.com \
    --to=pstanner@redhat.com \
    --cc=airlied@gmail.com \
    --cc=bhelgaas@google.com \
    --cc=dakr@redhat.com \
    --cc=daniel@ffwll.ch \
    --cc=deller@gmx.de \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=hdegoede@redhat.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-parisc@vger.kernel.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=linux@roeck-us.net \
    --cc=maarten.lankhorst@linux.intel.com \
    --cc=mripard@kernel.org \
    --cc=sam@ravnborg.org \
    --cc=tzimmermann@suse.de \
    /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