lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Thu, 10 Apr 2008 18:40:57 +0800
From:	Zhao Yakui <yakui.zhao@...el.com>
To:	NoWhereMan <uncommonnonsense@...il.com>
Cc:	Andrew Morton <akpm@...ux-foundation.org>,
	linux-kernel@...r.kernel.org, linux-acpi@...r.kernel.org,
	Len Brown <lenb@...nel.org>
Subject: Re: [PATCH 2.6.25-rc7 001/001] ACPI: workaround for buggy BIOS to
	ignore error LINK CRS method

On Wed, 2008-04-09 at 16:12 -0700, Andrew Morton wrote:
> On Wed, 9 Apr 2008 17:42:34 +0200
> NoWhereMan <uncommonnonsense@...il.com> wrote:
> 
> > >From : Edoardo Vacchi <uncommonnonsense@...il.com>
> > 
> > When acpi_pci_link_crs_ignore is passed at boot to the kernel,
> > ignores the error about the _CRS method of LINK device and selects
> > IRQ from possible IRQ list returned by _PRS method.
> > 
> > Signed-off-by: Edoardo Vacchi <uncommonnonsense@...il.com>
> > 
> 
> Let's add some cc's.
> 
> > 
> > This is nothing more than the patch on comment #127 on bug #8896
> > http://bugzilla.kernel.org/show_bug.cgi?id=8896#c127
> > 
> > originally by Zhao Yakui <yakui.zhao@...el.com>
> > 
> > ported to 2.6.25 and wrapped into an additional check for the kernel parameter
> > (plus of course the defintion of the kernel param itself)
> > 
> > The patch provides a workaround for some buggy BIOSes such as Insyde
> > in Packard Bell EasyNote r1938 (of which I'm an unfortunate owner),
> > while still keeping boot safe for people not suffering from this bug
> > 
> 
> That patch is about four months old.  Hopefully there was a reason why we
> dodn't proceed with it?
It seems that the system can work after applying the patch. 
But the patch depends on the returned result(-ENODEV).
> if (ACPI_FAILURE(status)) {
>               ACPI_EXCEPTION((AE_INFO, status, "Evaluating _CRS"));
>                result = -ENODEV;
 >               goto end;
 >       }
Now I am writing another workaround patch about this problem.
> 
> > diff --git a/drivers/acpi/pci_link.c b/drivers/acpi/pci_link.c
> > index 233c40c..ed54c63 100644
> > --- a/drivers/acpi/pci_link.c
> > +++ b/drivers/acpi/pci_link.c
> > @@ -297,6 +297,16 @@ static int acpi_pci_link_get_current(struct
> > acpi_pci_link *link)
> >         return result;
> >  }
> > 
> > +
> > +/*
> > + * this is set when acpi_pci_link_crs_ignore is passed on boot
> > + * it will ignore the -ENODEV error on buggy BIOSes
> > + *
> > + * workaround for bug #8896
> > + *
> > + */
> > +static int acpi_pci_link_crs_ignore; /* 0 or 1*/
> > +
> >  static int acpi_pci_link_set(struct acpi_pci_link *link, int irq)
> >  {
> >         int result = 0;
> > @@ -385,9 +395,16 @@ static int acpi_pci_link_set(struct acpi_pci_link
> > *link, int irq)
> > 
> >         /* Query _CRS, set link->irq.active */
> >         result = acpi_pci_link_get_current(link);
> > -       if (result) {
> > -               goto end;
> > -       }
> > +       if (acpi_pci_link_crs_ignore && result == -ENODEV) {
> > +               /*
> > +                * Ignore the error about the _CRS method of Link device and
> > +                * select IRQ from the Possible IRQ list
> > +                * returned by _PRS method.
> > +                */
> > +                printk(KERN_WARNING "Ignore error LINK CRS method.\n");
> > +                link->irq.active = irq;
> > +                result = 0;
> > +        }
> > 
> >         /*
> >          * Is current setting not what we set?
> > @@ -412,7 +429,16 @@ static int acpi_pci_link_set(struct acpi_pci_link
> > *link, int irq)
> >         return result;
> >  }
> > 
> > -/* --------------------------------------------------------------------------
> > +int __init acpi_pci_link_crs_ignore_set(char *str)
> > +{
> > +       acpi_pci_link_crs_ignore = 1;
> > +       return 1;
> > +}
> > +
> > +__setup("acpi_pci_link_crs_ignore", acpi_pci_link_crs_ignore_set);
> > +
> > +
> > + /* --------------------------------------------------------------------------
> >                              PCI Link IRQ Management
> >     --------------------------------------------------------------------------
> > */
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> > the body of a message to majordomo@...r.kernel.org
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> > Please read the FAQ at  http://www.tux.org/lkml/

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists