ACPI / EC: Do not use acpi_set_gpe
The EC driver is the last user of acpi_set_gpe() and since it is guaranteed that the EC GPE will not be shared, acpi_disable_gpe() and acpi_enable_gpe() may be used for disabling the GPE temporarilty if a GPE storm is detected and re-enabling it during EC transactions. Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl> Signed-off-by: Len Brown <len.brown@intel.com>
This commit is contained in:
parent
b63559f5ce
commit
3784730b02
@ -313,11 +313,8 @@ static int acpi_ec_transaction(struct acpi_ec *ec, struct transaction *t)
|
|||||||
pr_debug(PREFIX "transaction start\n");
|
pr_debug(PREFIX "transaction start\n");
|
||||||
/* disable GPE during transaction if storm is detected */
|
/* disable GPE during transaction if storm is detected */
|
||||||
if (test_bit(EC_FLAGS_GPE_STORM, &ec->flags)) {
|
if (test_bit(EC_FLAGS_GPE_STORM, &ec->flags)) {
|
||||||
/*
|
/* It has to be disabled, so that it doesn't trigger. */
|
||||||
* It has to be disabled at the hardware level regardless of the
|
acpi_disable_gpe(NULL, ec->gpe);
|
||||||
* GPE reference counting, so that it doesn't trigger.
|
|
||||||
*/
|
|
||||||
acpi_set_gpe(NULL, ec->gpe, ACPI_GPE_DISABLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
status = acpi_ec_transaction_unlocked(ec, t);
|
status = acpi_ec_transaction_unlocked(ec, t);
|
||||||
@ -326,12 +323,8 @@ static int acpi_ec_transaction(struct acpi_ec *ec, struct transaction *t)
|
|||||||
ec_check_sci_sync(ec, acpi_ec_read_status(ec));
|
ec_check_sci_sync(ec, acpi_ec_read_status(ec));
|
||||||
if (test_bit(EC_FLAGS_GPE_STORM, &ec->flags)) {
|
if (test_bit(EC_FLAGS_GPE_STORM, &ec->flags)) {
|
||||||
msleep(1);
|
msleep(1);
|
||||||
/*
|
/* It is safe to enable the GPE outside of the transaction. */
|
||||||
* It is safe to enable the GPE outside of the transaction. Use
|
acpi_enable_gpe(NULL, ec->gpe);
|
||||||
* acpi_set_gpe() for that, since we used it to disable the GPE
|
|
||||||
* above.
|
|
||||||
*/
|
|
||||||
acpi_set_gpe(NULL, ec->gpe, ACPI_GPE_ENABLE);
|
|
||||||
} else if (t->irq_count > ACPI_EC_STORM_THRESHOLD) {
|
} else if (t->irq_count > ACPI_EC_STORM_THRESHOLD) {
|
||||||
pr_info(PREFIX "GPE storm detected, "
|
pr_info(PREFIX "GPE storm detected, "
|
||||||
"transactions will use polling mode\n");
|
"transactions will use polling mode\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user