Commit 36b15875 authored by Puneet Kumar's avatar Puneet Kumar Committed by Rafael J. Wysocki

ACPI / EC: Ensure lock is acquired before accessing ec struct members

A bug was introduced by commit b76b51ba ('ACPI / EC: Add more debug
info and trivial code cleanup') that erroneously caused the struct member
to be accessed before acquiring the required lock.  This change fixes
it by ensuring the lock acquisition is done first.

Found by Aaron Durbin <adurbin@chromium.org>

Fixes: b76b51ba ('ACPI / EC: Add more debug info and trivial code cleanup')
References: http://crbug.com/319019Signed-off-by: default avatarPuneet Kumar <puneetster@chromium.org>
Reviewed-by: default avatarAaron Durbin <adurbin@chromium.org>
[olof: Commit message reworded a bit]
Signed-off-by: default avatarOlof Johansson <olof@lixom.net>
Cc: 3.8+ <stable@vger.kernel.org> # 3.8+
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 5e01dc7b
...@@ -175,9 +175,10 @@ static void start_transaction(struct acpi_ec *ec) ...@@ -175,9 +175,10 @@ static void start_transaction(struct acpi_ec *ec)
static void advance_transaction(struct acpi_ec *ec, u8 status) static void advance_transaction(struct acpi_ec *ec, u8 status)
{ {
unsigned long flags; unsigned long flags;
struct transaction *t = ec->curr; struct transaction *t;
spin_lock_irqsave(&ec->lock, flags); spin_lock_irqsave(&ec->lock, flags);
t = ec->curr;
if (!t) if (!t)
goto unlock; goto unlock;
if (t->wlen > t->wi) { if (t->wlen > t->wi) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment