summaryrefslogtreecommitdiffstats
path: root/firmware
diff options
context:
space:
mode:
authorLv Zheng <lv.zheng@intel.com>2014-06-15 02:42:07 +0200
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2014-07-07 12:55:32 +0200
commitc0d653412fc8450370167a3268b78fc772ff9c87 (patch)
tree043cf8a830a99c488aa7ce67bd5ff7d7d5831727 /firmware
parentACPI / EC: Remove duplicated ec_wait_ibf0() waiter (diff)
downloadlinux-c0d653412fc8450370167a3268b78fc772ff9c87.tar.xz
linux-c0d653412fc8450370167a3268b78fc772ff9c87.zip
ACPI / EC: Fix race condition in ec_transaction_completed()
There is a race condition in ec_transaction_completed(). When ec_transaction_completed() is called in the GPE handler, it could return true because of (ec->curr == NULL). Then the wake_up() invocation could complete the next command unexpectedly since there is no lock between the 2 invocations. With the previous cleanup, the IBF=0 waiter race need not be handled any more. It's now safe to return a flag from advance_condition() to indicate the requirement of wakeup, the flag is returned from a locked context. The ec_transaction_completed() is now only invoked by the ec_poll() where the ec->curr is ensured to be different from NULL. After cleaning up, the EVT_SCI=1 check should be moved out of the wakeup condition so that an EVT_SCI raised with (ec->curr == NULL) can trigger a QR_SC command. Link: https://bugzilla.kernel.org/show_bug.cgi?id=70891 Link: https://bugzilla.kernel.org/show_bug.cgi?id=63931 Link: https://bugzilla.kernel.org/show_bug.cgi?id=59911 Reported-and-tested-by: Gareth Williams <gareth@garethwilliams.me.uk> Reported-and-tested-by: Hans de Goede <jwrdegoede@fedoraproject.org> Reported-by: Barton Xu <tank.xuhan@gmail.com> Tested-by: Steffen Weber <steffen.weber@gmail.com> Tested-by: Arthur Chen <axchen@nvidia.com> Signed-off-by: Lv Zheng <lv.zheng@intel.com> Cc: All applicable <stable@vger.kernel.org> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'firmware')
0 files changed, 0 insertions, 0 deletions