--- Matthew Garrett <mjg59@xxxxxxxxxxxxx> schrieb: > 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 (intel defines this bit as being set, when poweroff-button is pressed for > 4s. They say, BIOS is responsible for handling it.) > 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 <mjg59@xxxxxxxxxxxxx> > > 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; register is a keword for gcc here.... > + > + 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); and here it should be PCI_VENDOR_ID_VIA. > + > +#endif > + > /* > * CardBus controllers have a legacy base address that enables them > * to respond as i82365 pcmcia controllers. We don't want them to > > -- with above comments applied it works on this VIA K8T800 mobo. Please repost. Thanks! ACKed-by: Karsten Wiese <annabellesgarden@xxxxxxxx> ___________________________________________________________ Gesendet von Yahoo! Mail - Jetzt mit 1GB Speicher kostenlos - Hier anmelden: http://mail.yahoo.de - To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html