summaryrefslogtreecommitdiff
path: root/drivers/net/atl1c/atl1c.h
diff options
context:
space:
mode:
authorTim Gardner <timg@tpi.com>2011-04-20 09:00:49 +0000
committerDavid S. Miller <davem@davemloft.net>2011-04-21 21:04:32 -0700
commitcb771838715b1c470bc5735bdae709b33b18e0ad (patch)
tree9de4b9a992aa2a521bfba73b941310dd8e09ea60 /drivers/net/atl1c/atl1c.h
parente74fbd030223e29d269f4be17e3dce6de38f4c28 (diff)
downloadlwn-cb771838715b1c470bc5735bdae709b33b18e0ad.tar.gz
lwn-cb771838715b1c470bc5735bdae709b33b18e0ad.zip
atl1c: Fix work event interrupt/task races
The mechanism used to initiate work events from the interrupt handler has a classic read/modify/write race between the interrupt handler that sets the condition, and the worker task that reads and clears the condition. Close these races by using atomic bit fields. Cc: stable@kernel.org Cc: Jie Yang <jie.yang@atheros.com> Signed-off-by: Tim Gardner <tim.gardner@canonical.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/atl1c/atl1c.h')
-rw-r--r--drivers/net/atl1c/atl1c.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/net/atl1c/atl1c.h b/drivers/net/atl1c/atl1c.h
index 7cb375e0e29c..925929d764ca 100644
--- a/drivers/net/atl1c/atl1c.h
+++ b/drivers/net/atl1c/atl1c.h
@@ -566,9 +566,9 @@ struct atl1c_adapter {
#define __AT_TESTING 0x0001
#define __AT_RESETTING 0x0002
#define __AT_DOWN 0x0003
- u8 work_event;
-#define ATL1C_WORK_EVENT_RESET 0x01
-#define ATL1C_WORK_EVENT_LINK_CHANGE 0x02
+ unsigned long work_event;
+#define ATL1C_WORK_EVENT_RESET 0
+#define ATL1C_WORK_EVENT_LINK_CHANGE 1
u32 msg_enable;
bool have_msi;