diff options
author | Sathya Perla <sathyap@serverengines.com> | 2010-02-16 20:35:11 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-17 16:35:39 -0500 |
commit | 7a1e9b2059d147461cff3dfbabbfb43f296a1eef (patch) | |
tree | 96cede2e32bf278b86a06faab7c7940ee5d776b3 /drivers/net/benet/be_cmds.c | |
parent | a058a632747dd0f1799b12f4ecd54e43f5b5f10d (diff) |
be2net: don't rearm mcc cq when device is not open
When an MCC cmd is issued (via a netdev/ethtool op)
while the device is not open, the MCC CQ gets processed but the EQ
is not processed (as isr is not registered.) This can cause the EQ
to become full. So, while the device is not open, CQ must not be re-armed
to prevent EQ entries.
Signed-off-by: Sathya Perla <sathyap@serverengines.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/benet/be_cmds.c')
-rw-r--r-- | drivers/net/benet/be_cmds.c | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/drivers/net/benet/be_cmds.c b/drivers/net/benet/be_cmds.c index 477f82bc647e..d7546b450505 100644 --- a/drivers/net/benet/be_cmds.c +++ b/drivers/net/benet/be_cmds.c | |||
@@ -104,10 +104,26 @@ static struct be_mcc_compl *be_mcc_compl_get(struct be_adapter *adapter) | |||
104 | return NULL; | 104 | return NULL; |
105 | } | 105 | } |
106 | 106 | ||
107 | void be_async_mcc_enable(struct be_adapter *adapter) | ||
108 | { | ||
109 | spin_lock_bh(&adapter->mcc_cq_lock); | ||
110 | |||
111 | be_cq_notify(adapter, adapter->mcc_obj.cq.id, true, 0); | ||
112 | adapter->mcc_obj.rearm_cq = true; | ||
113 | |||
114 | spin_unlock_bh(&adapter->mcc_cq_lock); | ||
115 | } | ||
116 | |||
117 | void be_async_mcc_disable(struct be_adapter *adapter) | ||
118 | { | ||
119 | adapter->mcc_obj.rearm_cq = false; | ||
120 | } | ||
121 | |||
107 | int be_process_mcc(struct be_adapter *adapter) | 122 | int be_process_mcc(struct be_adapter *adapter) |
108 | { | 123 | { |
109 | struct be_mcc_compl *compl; | 124 | struct be_mcc_compl *compl; |
110 | int num = 0, status = 0; | 125 | int num = 0, status = 0; |
126 | struct be_mcc_obj *mcc_obj = &adapter->mcc_obj; | ||
111 | 127 | ||
112 | spin_lock_bh(&adapter->mcc_cq_lock); | 128 | spin_lock_bh(&adapter->mcc_cq_lock); |
113 | while ((compl = be_mcc_compl_get(adapter))) { | 129 | while ((compl = be_mcc_compl_get(adapter))) { |
@@ -120,14 +136,14 @@ int be_process_mcc(struct be_adapter *adapter) | |||
120 | (struct be_async_event_link_state *) compl); | 136 | (struct be_async_event_link_state *) compl); |
121 | } else if (compl->flags & CQE_FLAGS_COMPLETED_MASK) { | 137 | } else if (compl->flags & CQE_FLAGS_COMPLETED_MASK) { |
122 | status = be_mcc_compl_process(adapter, compl); | 138 | status = be_mcc_compl_process(adapter, compl); |
123 | atomic_dec(&adapter->mcc_obj.q.used); | 139 | atomic_dec(&mcc_obj->q.used); |
124 | } | 140 | } |
125 | be_mcc_compl_use(compl); | 141 | be_mcc_compl_use(compl); |
126 | num++; | 142 | num++; |
127 | } | 143 | } |
128 | 144 | ||
129 | if (num) | 145 | if (num) |
130 | be_cq_notify(adapter, adapter->mcc_obj.cq.id, true, num); | 146 | be_cq_notify(adapter, mcc_obj->cq.id, mcc_obj->rearm_cq, num); |
131 | 147 | ||
132 | spin_unlock_bh(&adapter->mcc_cq_lock); | 148 | spin_unlock_bh(&adapter->mcc_cq_lock); |
133 | return status; | 149 | return status; |