From owner-freebsd-sparc64@FreeBSD.ORG Wed Jun 11 07:37:54 2003 Return-Path: Delivered-To: freebsd-sparc64@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id C76EE37B401; Wed, 11 Jun 2003 07:37:54 -0700 (PDT) Received: from harmony.village.org (rover.bsdimp.com [204.144.255.66]) by mx1.FreeBSD.org (Postfix) with ESMTP id 5E9CB43FA3; Wed, 11 Jun 2003 07:37:52 -0700 (PDT) (envelope-from imp@bsdimp.com) Received: from localhost (warner@rover2.village.org [10.0.0.1]) by harmony.village.org (8.12.8/8.12.3) with ESMTP id h5BEa8kA021599; Wed, 11 Jun 2003 08:36:08 -0600 (MDT) (envelope-from imp@bsdimp.com) Date: Wed, 11 Jun 2003 08:34:39 -0600 (MDT) Message-Id: <20030611.083439.57255263.imp@bsdimp.com> To: t.moestl@tu-bs.de From: "M. Warner Losh" In-Reply-To: <20030611142627.GB634@crow.dom2ip.de> References: <20030610230230.GC734@crow.dom2ip.de> <20030610234144.GA39701@funkthat.com> <20030611142627.GB634@crow.dom2ip.de> X-Mailer: Mew version 2.1 on Emacs 21.3 / Mule 5.0 (SAKAKI) Mime-Version: 1.0 Content-Type: Text/Plain; charset=us-ascii Content-Transfer-Encoding: 7bit cc: ticso@cicely12.cicely.de cc: freebsd-current@freebsd.org cc: ticso@cicely.de cc: freebsd-sparc64@freebsd.org Subject: Re: PCI bus numbering and orphaned devices X-BeenThere: freebsd-sparc64@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Porting FreeBSD to the Sparc List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 11 Jun 2003 14:37:55 -0000 In message: <20030611142627.GB634@crow.dom2ip.de> Thomas Moestl writes: : On Tue, 2003/06/10 at 16:41:44 -0700, John-Mark Gurney wrote: : > Thomas Moestl wrote this message on Wed, Jun 11, 2003 at 01:02 +0200: : > > On Tue, 2003/06/10 at 15:34:36 -0700, John-Mark Gurney wrote: : > > There's a similar problem with hme devices in some Netra models, and : > > so far I have just ignored this because of the ugliness involved : > > (there were patches floating around at one point, but I did not commit : > > them). : > > : > > The real fix (and the way I wanted to implement things from the : > > beginning) is to write an OFW PCI bus, analogous to the ACPI one. This : > > is high on my list, waiting for time to become available :) : > : > Yikes, I just started looking at the acpi code, and there's a lot of : > code in it! : : There's much setup to be done that the firmware is too lazy to do for : us. : : > > > Is this why pciconf -r is returning 0xffffffff when reading the ebus : > > > and firewire parts of the SME2300BGA? Simply because it isn't in : > > > the ofw tree? : > > : > > Could be. We just cannot handle devices without firmware nodes - we : > > don't know whether we can safely access them, cannot assign interrupts : > > etc. : > : > Ok, the only problem is that is then we have the same problem the ACPI : > code does in that hot swapping cards would have a problem. Since it : > appears to me that the OFW tree doesn't get updated upon a swap. (At : > least the usb part of the tree doesn't.) : : We do not support hotplugging at the moment anyway. If a bridge driver : would implement that in the future without using any firmware support : however, it will then need to know everything information about the : interrupt routing required for its devices if it cannot use the : firmware for this. in that case, it can just prevent the ofw_pci bus : from attaching to it (this will be easily possible). : I'd hope that machines that support hot-plugging of PCI devices would : have firmware methods available to support that though. We'll need to do so for the cardbus bridges. However, the interupt is routed to the bridge and has to be shared with the cardbus/pccard cards. : > Does this mean that we should eliminate most of the Sun specific pci : > bus drivers in favor of OFW specific ones like ACPI? or? : : No, it means introducing an OFW bus driver, which uses the firmware to : enumerate the devices and to support interrupt routing. The bridge : drivers would be mostly unaffected by this. : The only problem with this approach is that it can change the device : enumeration; I hope that the resulting one will be the same one that is : printed on the boxen, so it should be advantageous for new : installations, but a minor migration problem for old ones. : : I've got some code for this already, it just isn't done yet. So are you talking about doing something akin to the acpi bridge code or something else? Would this more properly be called a OFW PCI bus driver, or would the OFW 'bus' reach over into other busses to add children? Warner