Date: Sun, 02 Jan 2005 16:35:43 -0800 From: Nate Lawson <nate@root.org> To: John Baldwin <jhb@FreeBSD.org> Cc: freebsd-current@FreeBSD.org Subject: Re: page fault panic in device_get_softc/acpi_pcib_route_interrupt Message-ID: <41D8935F.20505@root.org> In-Reply-To: <200412301527.07327.jhb@FreeBSD.org> References: <20587818.1102626838092.JavaMail.tomcat@pne-ps4-sn1> <200412291715.51125.jhb@FreeBSD.org> <41D33B86.3060109@root.org> <200412301527.07327.jhb@FreeBSD.org>
next in thread | previous in thread | raw e-mail | index | archive | help
John Baldwin wrote: > On Wednesday 29 December 2004 06:19 pm, Nate Lawson wrote: > >>John Baldwin wrote: >> >>>On Tuesday 28 December 2004 06:32 pm, Pawel Worach wrote: >>> >>>>John Baldwin wrote: >>>> >>>>>Are you still seeing this? >>>> >>>>Yes I am, updated boot -v with debug.rman_debug=1 below. >>>>Sources are from 16:00 UTC today. Last working kernel I >>>>have is from November 20, I can start a binary search if >>>>you want. >>> >>>No, I'm fairly sure I know what the search would find. :) Nate, I think >>>the problem here is that his link device doesn't have an associated >>>device_t yet when he gets to this point. Can we force ACPI to enumerate >>>all its devices and assign the associated device_t's via the >>>GetData/SetData stuff before we actually probe any of the children, or do >>>we do that already? >> >>What you want, my friend, is multi-pass newbus. Oh wait, you were one >>of the proponents of that. :) >> >>You can overload the hack I have in acpi_probe_order() for sysresource >>objects. Just do a manual check for the PNPID for PCI links and have >>them probe first. > > > I don't need them to probe first, I just need them to have a device_t > associated with each ACPI handle (even an unprobed one) before any of the > child devices are probed and attached. It actually wouldn't hurt to go ahead > and probe them up front if that is easy to do though. We already associate handles and devices in sys/dev/acpica/acpi.c:acpi_probe_child() before probing anything. See the AcpiAttachData() step. I don't think that's the problem. I do think the problem is that his link devices are not being probed (and thus lack a softc) before the device that wants to route interrupts via that link. The acpi_probe_order() hack would make sure that this happens. Since all acpi devices are ordered by default based on the AML tree hammered flat, dependencies have to be set by the bus drivers. PCI does this correctly and I updated FDC to do this. ATA and others currently do not but they don't use acpi yet. -- Nate
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?41D8935F.20505>