public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Ram Pai <linuxram@us.ibm.com>
To: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: Ram Pai <linuxram@us.ibm.com>,
	linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org,
	clemens@ladisch.de, Yinghai Lu <yinghai@kernel.org>,
	Jesse Barnes <jbarnes@virtuousgeek.org>,
	Linus Torvalds <torvalds@linux-foundation.org>
Subject: Re: [RFC v2 PATCH 1/1] PCI: override BIOS/firmware resource allocation
Date: Tue, 12 Oct 2010 00:05:15 -0700	[thread overview]
Message-ID: <20101012070515.GA549@ram-laptop> (raw)
In-Reply-To: <201010081416.57454.bjorn.helgaas@hp.com>

On Fri, Oct 08, 2010 at 02:16:57PM -0600, Bjorn Helgaas wrote:
> On Friday, October 08, 2010 11:32:24 am Ram Pai wrote:
> > On Thu, Oct 07, 2010 at 03:41:04PM -0600, Bjorn Helgaas wrote:
> > > On Thursday, October 07, 2010 02:42:13 pm Ram Pai wrote:
> > > > On Wed, Oct 06, 2010 at 10:13:02PM -0600, Bjorn Helgaas wrote:
> > > > > On Wed, Oct 06, 2010 at 05:30:41PM -0700, Ram Pai wrote:
> > > > > > On Wed, Oct 06, 2010 at 05:39:53PM -0600, Bjorn Helgaas wrote:
> > > > > > > On Wed, Oct 06, 2010 at 03:58:34PM -0700, Ram Pai wrote:
> > > > > > > >         PCI: override BIOS/firmware memory resource allocation
> > > > > > > > 		through command line parameters
> > > > > > > > 
> > > > > > > > 	Platforms that are unaware of  SRIOV  BARs  fail to allocate MMIO
> > > > > > > > 	resources  to SRIOV PCIe  devices. Hence  on  such  platforms the
> > > > > > > > 	OS fails to  enable  SRIOV.
> > > > > > > > 	Some  platforms  where  BIOS/uEFI resource   allocations  conflict
> > > > > > > > 	the conflicting devices are disabled.
> > > > > > > > 
> > > > > > > > 	Ideally we  would  want  the  OS  to detect and fix automatically
> > > > > > > > 	such problems and conflicts.  However previous  attempts to do so
> > > > > > > > 	have led to regression on legacy platforms.
> > > > > > > 
> > > > > > > I'm sorry to be a nay-sayer, but I think we just haven't tried hard
> > > > > > > enough.  Our ACPI/PCI/e820 resource management is not well integrated,
> > > > > > > and I suspect if we straightened that out, we could avoid some of the
> > > > > > > regressions we saw with previous attempts.
> > > > > > 
> > > > > > Can you be more specific as to what can be done to fix it automatically?
> > > > > > 
> > > > > > Neither accepting this approach nor telling what needs to be straightened out
> > > > > > to automatically fix all the systems out there, is just a deadend.
> > > > > 
> > > > > Yeah, I guess that wasn't really fair, sorry.  And keep in mind that I'm
> > > > > not the PCI maintainer, so these are just my opinions, nothing like an
> > > > > official "nack."
> > > > > 
> > > > > I did look at this dmesg log from the thread you referenced:
> > > > >     http://marc.info/?l=linux-kernel&m=127178918128740&w=2
> > > > > but it looks to me like we just completely botched it.  I don't see an
> > > > > SRIOV device or anything else that didn't have resources, so as far as I
> > > > > can tell, we started with working resource assignments from the BIOS,
> > > > > threw them away, and started over from scratch.  We failed because we
> > > > > tried to assign I/O port space to bridges with nothing behind them, and
> > > > > there was nothing left by the time we got to the 0000:09:04.0 device
> > > > > that actually *did* need the space.
> > > > 
> > > > hmm.. is that possible? Yinghai's patch sized the resource requirement of each
> > > > of the bridges, before actually allocating them. Which means a bridge with
> > > > no device behind it would not get any i/o space.
> > > 
> > > Here's what I see in the dmesg log referenced above:
> > > 
> > >     ACPI: PCI Root Bridge [PCI0] (0000:00)
> > >     pci_root PNP0A08:00: host bridge window [io 0x0000-0x0cf7]
> > >     pci_root PNP0A08:00: host bridge window [io 0x0d00-0xffff]
> > >     pci 0000:00:1c.0: PCI bridge to [bus 04-09]
> > >     pci 0000:00:1c.0:   bridge window [io 0xd000-0xdfff]
> > >     pci 0000:04:00.0: PCI bridge to [bus 05-09]
> > >     pci 0000:04:00.0:   bridge window [io 0xd000-0xdfff]
> > >     pci 0000:05:01.0: PCI bridge to [bus 08-09]
> > >     pci 0000:05:01.0:   bridge window [io 0xd000-0xdfff]
> > >     pci 0000:08:00.0: PCI bridge to [bus 09-09]
> > >     pci 0000:08:00.0:   bridge window [io 0xd000-0xdfff]
> > >     pci 0000:09:04.0: found [13f6:8788] class 000401 header type 00
> > >     pci 0000:09:04.0: reg 10: [io  0xd800-0xd8ff]
> > >     pci 0000:05:02.0: PCI bridge to [bus 07-07]
> > >     pci 0000:05:02.0:   bridge window [io 0xf000-0x0000] (disabled)
> > >     pci 0000:05:03.0: PCI bridge to [bus 06-06]
> > >     pci 0000:05:03.0:   bridge window [io 0xf000-0x0000] (disabled)
> > >     
> > > The above is the state as we got it from BIOS.  Despite all the bridges,
> > > 09:04.0 is the only device below the 00:1c.0 bridge, and it requires only
> > > 0x100 I/O ports.
> > > 
> > > There are no devices on buses 06 (below 05:03.0) or 07 (below 05:02.0).
> > > 
> > > I didn't look at Yinghai's patch to figure out *why*, but it sure looks like
> > > we released the 09:04.0 space, then tried to assign 0x2000 ports to 05:01.0 
> > > (which needs 0x100 and had 0x1000 originally), 0x1000 to 05:02.0 (which needs
> > > none), and 0x1000 to 05:03.0 (which also needs none):
> > > 
> > >     PCI: No. 3 try to assign unassigned res
> > >     release child resource [io  0xd800-0xd8ff]
> > >     pci 0000:08:00.0: resource 7 [io 0xd000-0xdfff] released
> > >     pci 0000:04:00.0: BAR 7: can't assign io (size 0x4000)
> > >     pci 0000:05:01.0: BAR 7: can't assign io (size 0x2000)
> > >     pci 0000:05:02.0: BAR 7: can't assign io (size 0x1000)
> > >     pci 0000:05:03.0: BAR 7: can't assign io (size 0x1000)
> > >     pci 0000:08:00.0: BAR 7: can't assign io (size 0x1000)
> > 
> > Actually the message preceeding to them  are even more surprising:
> > 
> > Apr 20 20:31:42 [kernel] pci 0000:04:00.0: BAR 8: can't assign mem (size
> > 0xc00000)
> > Apr 20 20:31:42 [kernel] pci 0000:05:01.0: BAR 8: can't assign mem (size
> > 0x200000)
> > Apr 20 20:31:42 [kernel] pci 0000:05:01.0: BAR 9: can't assign mem pref
> > (size 0x200000)
> > Apr 20 20:31:42 [kernel] pci 0000:05:02.0: BAR 8: can't assign mem (size
> > 0x400000)
> > Apr 20 20:31:42 [kernel] pci 0000:05:03.0: BAR 7: can't assign io (size
> > 0x1000)
> > 
> > Do these bridges have IOV BARs and those BARs are demanding i/o resources?
> > Something is really funny with this machine. Or I am reading this wrong?
> 
> I don't see anything strange about the machine, but I don't understand
> what Yinghai's patch was doing.  The lspci output is here:
>     http://marc.info/?l=linux-pci&m=127184080929189&w=2
> 
> I don't see any SRIOV devices, and this kernel wasn't built with IOV
> support anyway.  The messages above are attempts to assign resources
> for bridge windows.
> 
> But the only real device in the whole hierarchy behind 00:1c.0
> is 09:04.0, which doesn't require memory space, so I have no idea
> why we're trying to open memory windows.

I dont understand the code much. But there is some alignment 
constraints on the memory and io space dictated by the PCI code in 
pbus_size_io() and pbus_size_mem(), a constraint that ends up 
associating a minimum of 4096 bytes io window and 
nearly about 2MB mem window to a bridge irrespective of the 
requirements of the devices behind the bridge. That sounds like a
bug to me. But I don't know if those are valid constraints either.
Any idea?

> 
> This is what I meant about "we haven't tried hard enough yet."  I'd
> rather spend time fixing the problems like this, than just putting the
> buggy code in and adding a kernel parameter to enable it.  That
> guarantees that we'll never get enough testing to really shake it
> out.

Ok. I am no fan of kernel parameters either. However I am afraid 
we will attract furious looks as and when someone regresses. 

RP

  reply	other threads:[~2010-10-12  7:05 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-10-06 22:58 [RFC v2 PATCH 1/1] PCI: override BIOS/firmware resource allocation Ram Pai
2010-10-06 23:39 ` Bjorn Helgaas
2010-10-07  0:30   ` Ram Pai
2010-10-07  4:13     ` Bjorn Helgaas
2010-10-07 20:42       ` Ram Pai
2010-10-07 21:41         ` Bjorn Helgaas
2010-10-08 17:32           ` Ram Pai
2010-10-08 20:16             ` Bjorn Helgaas
2010-10-12  7:05               ` Ram Pai [this message]
2010-10-12 19:01                 ` Bjorn Helgaas
2010-10-18 20:10                   ` Jesse Barnes
2010-10-19 17:17                     ` Ram Pai
2010-10-19 18:24                       ` Jesse Barnes
2010-10-22  0:28                         ` Ram Pai
2010-10-22 17:55                           ` Bjorn Helgaas
2010-10-22 18:59                             ` Ram Pai
2010-10-22 21:49                               ` Bjorn Helgaas
2010-10-22 17:16                         ` [PATCH 1/1] PCI: ignore failure to preallocate minimal resources to hotplug bridges Ram Pai
2010-10-22 22:16                           ` Bjorn Helgaas
2011-01-07 22:32                           ` Jesse Barnes
2011-01-11 21:10                             ` Ram Pai
2011-01-14 18:19                               ` [PATCH 1/1] PCI: allocate essential resources before reserving hotplug resources Ram Pai
2011-01-18 20:52                                 ` Bjorn Helgaas
2011-01-18 21:42                                   ` Ram Pai
2011-01-18 22:11                                     ` Bjorn Helgaas
2011-01-19 19:58                                       ` [PATCH 1/1 v3] " Ram Pai
2011-01-20  1:00                                         ` [PATCH 1/1 v4] " Ram Pai
2011-01-21  1:22                                           ` Yinghai Lu
2011-01-21  7:17                                             ` Ram Pai
2011-01-18 21:30                                 ` [PATCH 1/1 Version 2.0] " Ram Pai
2011-01-18 21:46                                   ` Bjorn Helgaas
2011-01-18 22:03                                     ` Ram Pai

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=20101012070515.GA549@ram-laptop \
    --to=linuxram@us.ibm.com \
    --cc=bjorn.helgaas@hp.com \
    --cc=clemens@ladisch.de \
    --cc=jbarnes@virtuousgeek.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pci@vger.kernel.org \
    --cc=torvalds@linux-foundation.org \
    --cc=yinghai@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