Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 25 Apr 2013 02:28:25 +0000
From:      "Moore, Robert" <robert.moore@intel.com>
To:        Benjamin Lee <ben@b1c1l1.com>, John Baldwin <jhb@freebsd.org>
Cc:        "freebsd-acpi@freebsd.org" <freebsd-acpi@freebsd.org>, "Zheng, Lv" <lv.zheng@intel.com>, "Guan, Chao" <chao.guan@intel.com>
Subject:   RE: panic: acpi_pci_link_srs_from_crs: can't put non-ISA IRQ 20 in legacy IRQ resource type)
Message-ID:  <94F2FBAB4432B54E8AACC7DFDE6C92E36FE43F55@FMSMSX153.amr.corp.intel.com>
In-Reply-To: <20130421101728.6fc33a96@b1c1l1.com>
References:  <20130418124940.47e3618a@b1c1l1.com> <201304191726.31089.jhb@freebsd.org> <20130419152110.213c7fbb@b1c1l1.com> <201304200817.15189.jhb@freebsd.org> <20130421101728.6fc33a96@b1c1l1.com>

next in thread | previous in thread | raw e-mail | index | archive | help
> Thank you!  I backed out my hacks and with your 2 patches 10-CURRENT boot=
s
> successfully (with functional devices).  Loading a custom ASL is not
> necessary.

Do you mean that the change of a WORD field to a BYTE field is no longer ne=
cessary?

If so, I would really like to see the buffer that is being sent to _SRS.

Thanks,
Bob


> -----Original Message-----
> From: owner-freebsd-acpi@freebsd.org [mailto:owner-freebsd-
> acpi@freebsd.org] On Behalf Of Benjamin Lee
> Sent: Sunday, April 21, 2013 10:17 AM
> To: John Baldwin
> Cc: freebsd-acpi@freebsd.org
> Subject: Re: panic: acpi_pci_link_srs_from_crs: can't put non-ISA IRQ 20
> in legacy IRQ resource type)
>=20
> On Sat, 20 Apr 2013 08:17:15 -0400, John Baldwin <jhb@freebsd.org> wrote:
> > On Friday, April 19, 2013 06:21:10 PM Benjamin Lee wrote:
> > > On Fri, 19 Apr 2013 17:26:31 -0400, John Baldwin <jhb@freebsd.org>
> wrote:
> > > > On Friday, April 19, 2013 4:18:49 pm Benjamin Lee wrote:
> > > > > On Fri, 19 Apr 2013 11:31:49 -0400, John Baldwin
> > > > > <jhb@freebsd.org>
> > wrote:
> > > > > > On Thursday, April 18, 2013 3:49:40 pm Benjamin Lee wrote:
> > > > > > > I have a system that panics on boot with 10-CURRENT and
> > > > > > > boots with many ACPI error messages and non-functional
> > > > > > > devices with 9.1-RELEASE.
> > > > > > >
> > > > > > > Motherboard is Foxconn C51XEM2AA (NVIDIA nForce 590) desktop
> board.
> > > > >
> > > > > [...]
> > > > >
> > > > > > > Even though 9.1-RELEASE boots successfully, devices such as
> > > > > > > the ehci USB controller and SATA controller do not work.
> > > > > >
> > > > > > Ugh, your BIOS does unexpected things.  It uses a _CRS for
> > > > > > these pci link devices that uses a "short" IRQ resource, but
> > > > > > uses an extended IRQ
> > > >
> > > > resource in
> > > >
> > > > > > _PRS (and expects an extended one in _SRS).  We use _CRS as a
> > > > > > template for
> > > >
> > > > the
> > > >
> > > > > > resource to build.
> > > > > >
> > > > > > Try this patch.  It's a bit hackish, but it forces us to not
> > > > > > use _CRS as a template if _CRS uses a "short" IRQ resource,
> > > > > > but the link supports non-
> > > >
> > > > ISA
> > > >
> > > > > > IRQs.
> > > > >
> > > > > [...]
> > > > >
> > > > > Thanks, that fixed the panic and the system boots.  Now it is
> > > > > complaining about AE_AML_BAD_RESOURCE_LENGTH and still unable to
> > > > > route IRQs, but it definitely looks better than the ACPI parsing
> errors in 9:
> > > > >
> > > > > pcib0: allocated type 3 (0xdffff000-0xdfffffff) for rid 10 of
> > > > > pci0:0:10:0 pcib0: matched entry for 0.10.INTA (src
> > > > > \_SB_.PCI0.AUBA:0)
> > > > > pci_link26: Picked IRQ 20 with weight 0
> > > > > pci_link26: Unable to route IRQs: AE_AML_BAD_RESOURCE_LENGTH
> > > > >
> > > > > Full boot -v output:
> > > > > http://www.b1c1l1.com/media/debug/20130419-10-patched-
> > > >
> > > > boot.txt.gz
> > > >
> > > > Can you add some printfs to the places that return the
> > > > AE_AML_BAD_RESOURCE_LENGTH to see which one is being triggered?
> > > > (Just look for that constant in sys/contrib/dev/acpica to find the
> > > > possible
> > > > places.)
> > >
> > > Is there a macro for dumping information about Resource or
> > > Resource->Data?  Here's what I have for now at
> > > sys/contrib/dev/acpica/resources/rscalc.c line 237:
> > >
> > > pcib0: matched entry for 0.10.INTA (src \_SB_.PCI0.AUBA:0)
> > > pci_link26: Picked IRQ 20 with weight 0
> > > rscalc.c:237
> > > Resource->Type: 7
> > > Resource->Length: 0
> > > pci_link26: Unable to route IRQs: AE_AML_BAD_RESOURCE_LENGTH
> > >
> > > All of the errors are from there and look identical (Type 7, Length
> 0).
> > > Type 7 appears to be ACPI_RESOURCE_TYPE_END_TAG.
> >
> > Ah, this is easy to fix then.  It seems in sys/dev/acpica/acpi.c in
> > acpi_AppendBufferResource() we didn't create the end tag correctly.
> > Can you try this in addition to the patch to acpi_pci_link.c:
> >
> > Index: sys/dev/acpica/acpi.c
> > =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> > --- acpi.c	(revision 249195)
> > +++ acpi.c	(working copy)
> > @@ -2384,7 +2384,7 @@
> >      /* And add the terminator. */
> >      rp =3D ACPI_NEXT_RESOURCE(rp);
> >      rp->Type =3D ACPI_RESOURCE_TYPE_END_TAG;
> > -    rp->Length =3D 0;
> > +    rp->Length =3D ACPI_RS_SIZE_MIN;
> >
> >      return (AE_OK);
> >  }
>=20
> Thank you!  I backed out my hacks and with your 2 patches 10-CURRENT boot=
s
> successfully (with functional devices).  Loading a custom ASL is not
> necessary.
>=20
>=20
> --
> Benjamin Lee
> http://www.b1c1l1.com/



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?94F2FBAB4432B54E8AACC7DFDE6C92E36FE43F55>