On Sun, 18 Jun 2006 20:14:22 +0100
Matthew Garrett <[email protected]> wrote:
> Some VIA southbridges contain a flag in the ACPI register space that
> indicates whether an abnormal poweroff has occured, presumably with the
> intention that it can be cleared on clean shutdown. Some BIOSes check
> this flag at resume time, and will re-POST the system rather than jump
> back to the OS if it's set. Clearing it at boot time appears to be
> sufficient. I'm not sure if drivers/pci/quirks.c is the right place to
> do it, but I'm not sure where would be cleaner.
>
> Signed-off-by: Matthew Garrett <[email protected]>
>
> diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
> index 7537260..2f9f996 100644
> --- a/drivers/pci/quirks.c
> +++ b/drivers/pci/quirks.c
> @@ -660,6 +660,33 @@ static void __devinit quirk_vt82c598_id(
> }
> DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C597_0, quirk_vt82c598_id );
>
> +#ifdef CONFIG_ACPI
> +
> +/* Some VIA systems boot with the abnormal status flag set. This can cause
> + * the BIOS to re-POST the system on resume rather than passing control
> + * back to the OS. Clear the flag on boot
> + */
> +
> +static void __devinit quirk_via_abnormal_poweroff(struct pci_dev *dev)
> +{
> + u32 register;
> +
> + acpi_hw_register_read (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS,
> + ®ister);
> +
> + if (register & 0x800) {
> + printk ("Clearing abnormal poweroff flag\n");
> + acpi_hw_register_write (ACPI_MTX_DO_NOT_LOCK,
> + ACPI_REGISTER_PM1_STATUS,
> + (u16)0x800);
> + }
> +}
> +
> +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_VIA, PCI_DEVICE_ID_VIA_8235, quirk_via_abnormal_poweroff);
> +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_VIA, PCI_DEVICE_ID_VIA_8237, quirk_via_abnormal_poweroff);
> +
> +#endif
Is CONFIG_ACPI the right thing to use here? As opposed to, say, CONFIG_PM?
Or CONFIG_ACPI_SLEEP??
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]