On Sunday, July 08, 2012, Moore, Robert wrote: > > Bob, I think we should incorporate this into ACPICA, shouldn't we? > > > > Rafael > > We are looking at it. Probably one of the Linux/ACPICA divergences that end > up causing us grief. Well, in this particular case it seems that what Linux did before commit 2feec47d4c5f (ACPICA: ACPI 5: Support for new FADT SleepStatus, SleepControl registers) was actually correct, though. Thanks, Rafael > > -----Original Message----- > > From: linux-acpi-owner@xxxxxxxxxxxxxxx [mailto:linux-acpi- > > owner@xxxxxxxxxxxxxxx] On Behalf Of Rafael J. Wysocki > > Sent: Sunday, July 08, 2012 1:08 PM > > To: Jonathan Nieder; Moore, Robert > > Cc: Octavio Alvarez; Adrian Knoth; Shaohua Li; Brown, Len; linux- > > acpi@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx > > Subject: Re: [PATCH v2] ACPI: Leave Bus Master Arbitration enabled for > > suspend/resume > > > > On Sunday, July 08, 2012, Jonathan Nieder wrote: > > > This is an old suspend/resume lockup fix: > > > > > > commit 2780cc4660e1 > > > Author: Len Brown <len.brown@xxxxxxxxx> > > > Date: Thu Dec 23 13:43:30 2004 -0500 > > > > > > [ACPI] Fix suspend/resume lockup issue > > > by leaving Bus Master Arbitration enabled. > > > The ACPI spec mandates it be disabled only for C3. > > > > > > http://bugzilla.kernel.org/show_bug.cgi?id=3599 > > > > > > Signed-off-by: David Shaohua Li <shaohua.li@xxxxxxxxx> > > > Signed-off-by: Len Brown <len.brown@xxxxxxxxx> > > > > > > The bug snuck back in in commit 2feec47d4c5f (ACPICA: ACPI 5: Support > > > for new FADT SleepStatus, SleepControl registers, 2012-02-14), > > > presumably by copy/pasting a copy of the code without that fix for > > the > > > legacy case. > > > > > > On affected machines, after that commit, the machine locks up hard on > > > resume from suspend. The same fix as seven years ago still works. > > > > > > Addresses <https://bugzilla.kernel.org/show_bug.cgi?id=43641>. > > > > > > Reported-bisected-and-tested-by: Octavio Alvarez > > > <alvarezp@xxxxxxxxxxxx> > > > Reported-by: Adrian Knoth <adi@xxxxxxxxxxxxxxxxxxxxx> > > > Signed-off-by: Jonathan Nieder <jrnieder@xxxxxxxxx> > > > Cc: <stable@xxxxxxxxxxxxxxx> # 3.4 > > > --- > > > Rafael J. Wysocki wrote: > > > > > > > Can you please repost it with _both_ the changelog and the patch? > > > > > > Here you go. Sorry about that. > > > > Thanks! > > > > Applied to the linux-next branch of the linux-pm.git tree. > > > > I think I'll push it for v3.6, since the bug is serious and is a > > regression. > > > > Bob, I think we should incorporate this into ACPICA, shouldn't we? > > > > Rafael > > > > > > > drivers/acpi/acpica/hwsleep.c | 22 ---------------------- > > > 1 file changed, 22 deletions(-) > > > > > > diff --git a/drivers/acpi/acpica/hwsleep.c > > > b/drivers/acpi/acpica/hwsleep.c index 0ed85cac3231..615996a36bed > > > 100644 > > > --- a/drivers/acpi/acpica/hwsleep.c > > > +++ b/drivers/acpi/acpica/hwsleep.c > > > @@ -95,18 +95,6 @@ acpi_status acpi_hw_legacy_sleep(u8 sleep_state, > > u8 flags) > > > return_ACPI_STATUS(status); > > > } > > > > > > - if (sleep_state != ACPI_STATE_S5) { > > > - /* > > > - * Disable BM arbitration. This feature is contained within > > an > > > - * optional register (PM2 Control), so ignore a BAD_ADDRESS > > > - * exception. > > > - */ > > > - status = acpi_write_bit_register(ACPI_BITREG_ARB_DISABLE, > > 1); > > > - if (ACPI_FAILURE(status) && (status != AE_BAD_ADDRESS)) { > > > - return_ACPI_STATUS(status); > > > - } > > > - } > > > - > > > /* > > > * 1) Disable/Clear all GPEs > > > * 2) Enable all wakeup GPEs > > > @@ -364,16 +352,6 @@ acpi_status acpi_hw_legacy_wake(u8 sleep_state, > > u8 flags) > > > [ACPI_EVENT_POWER_BUTTON]. > > > status_register_id, ACPI_CLEAR_STATUS); > > > > > > - /* > > > - * Enable BM arbitration. This feature is contained within an > > > - * optional register (PM2 Control), so ignore a BAD_ADDRESS > > > - * exception. > > > - */ > > > - status = acpi_write_bit_register(ACPI_BITREG_ARB_DISABLE, 0); > > > - if (ACPI_FAILURE(status) && (status != AE_BAD_ADDRESS)) { > > > - return_ACPI_STATUS(status); > > > - } > > > - > > > acpi_hw_execute_sleep_method(METHOD_PATHNAME__SST, > > ACPI_SST_WORKING); > > > return_ACPI_STATUS(status); > > > } > > > > > > > -- > > 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 > > -- 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