forked from luck/tmp_suning_uos_patched
be2net: use mutex instead of spin lock for mbox_lock
Since the mbox polling uses the schedule_timeout, the mbox_lock should be
a mutex and not a spin lock.
The commit f25b03a
replaced udelay() with schedule_timeout() but didn't
change mbox_lock to semaphore or mutex.
Signed-off-by: Ivan Vecera <ivecera@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f88a4a9b65
commit
2984961c38
@ -234,7 +234,7 @@ struct be_adapter {
|
|||||||
u8 __iomem *db; /* Door Bell */
|
u8 __iomem *db; /* Door Bell */
|
||||||
u8 __iomem *pcicfg; /* PCI config space */
|
u8 __iomem *pcicfg; /* PCI config space */
|
||||||
|
|
||||||
spinlock_t mbox_lock; /* For serializing mbox cmds to BE card */
|
struct mutex mbox_lock; /* For serializing mbox cmds to BE card */
|
||||||
struct be_dma_mem mbox_mem;
|
struct be_dma_mem mbox_mem;
|
||||||
/* Mbox mem is adjusted to align to 16 bytes. The allocated addr
|
/* Mbox mem is adjusted to align to 16 bytes. The allocated addr
|
||||||
* is stored for freeing purpose */
|
* is stored for freeing purpose */
|
||||||
|
@ -462,7 +462,8 @@ int be_cmd_fw_init(struct be_adapter *adapter)
|
|||||||
u8 *wrb;
|
u8 *wrb;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = (u8 *)wrb_from_mbox(adapter);
|
wrb = (u8 *)wrb_from_mbox(adapter);
|
||||||
*wrb++ = 0xFF;
|
*wrb++ = 0xFF;
|
||||||
@ -476,7 +477,7 @@ int be_cmd_fw_init(struct be_adapter *adapter)
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -491,7 +492,8 @@ int be_cmd_fw_clean(struct be_adapter *adapter)
|
|||||||
if (adapter->eeh_err)
|
if (adapter->eeh_err)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = (u8 *)wrb_from_mbox(adapter);
|
wrb = (u8 *)wrb_from_mbox(adapter);
|
||||||
*wrb++ = 0xFF;
|
*wrb++ = 0xFF;
|
||||||
@ -505,7 +507,7 @@ int be_cmd_fw_clean(struct be_adapter *adapter)
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
int be_cmd_eq_create(struct be_adapter *adapter,
|
int be_cmd_eq_create(struct be_adapter *adapter,
|
||||||
@ -516,7 +518,8 @@ int be_cmd_eq_create(struct be_adapter *adapter,
|
|||||||
struct be_dma_mem *q_mem = &eq->dma_mem;
|
struct be_dma_mem *q_mem = &eq->dma_mem;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -546,7 +549,7 @@ int be_cmd_eq_create(struct be_adapter *adapter,
|
|||||||
eq->created = true;
|
eq->created = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -558,7 +561,8 @@ int be_cmd_mac_addr_query(struct be_adapter *adapter, u8 *mac_addr,
|
|||||||
struct be_cmd_req_mac_query *req;
|
struct be_cmd_req_mac_query *req;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -583,7 +587,7 @@ int be_cmd_mac_addr_query(struct be_adapter *adapter, u8 *mac_addr,
|
|||||||
memcpy(mac_addr, resp->mac.addr, ETH_ALEN);
|
memcpy(mac_addr, resp->mac.addr, ETH_ALEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -667,7 +671,8 @@ int be_cmd_cq_create(struct be_adapter *adapter,
|
|||||||
void *ctxt;
|
void *ctxt;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -701,7 +706,7 @@ int be_cmd_cq_create(struct be_adapter *adapter,
|
|||||||
cq->created = true;
|
cq->created = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -724,7 +729,8 @@ int be_cmd_mccq_create(struct be_adapter *adapter,
|
|||||||
void *ctxt;
|
void *ctxt;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -754,7 +760,7 @@ int be_cmd_mccq_create(struct be_adapter *adapter,
|
|||||||
mccq->id = le16_to_cpu(resp->id);
|
mccq->id = le16_to_cpu(resp->id);
|
||||||
mccq->created = true;
|
mccq->created = true;
|
||||||
}
|
}
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -769,7 +775,8 @@ int be_cmd_txq_create(struct be_adapter *adapter,
|
|||||||
void *ctxt;
|
void *ctxt;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -801,7 +808,7 @@ int be_cmd_txq_create(struct be_adapter *adapter,
|
|||||||
txq->created = true;
|
txq->created = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -816,7 +823,8 @@ int be_cmd_rxq_create(struct be_adapter *adapter,
|
|||||||
struct be_dma_mem *q_mem = &rxq->dma_mem;
|
struct be_dma_mem *q_mem = &rxq->dma_mem;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -843,7 +851,7 @@ int be_cmd_rxq_create(struct be_adapter *adapter,
|
|||||||
*rss_id = resp->rss_id;
|
*rss_id = resp->rss_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -862,7 +870,8 @@ int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q,
|
|||||||
if (adapter->eeh_err)
|
if (adapter->eeh_err)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -899,7 +908,7 @@ int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q,
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -915,7 +924,8 @@ int be_cmd_if_create(struct be_adapter *adapter, u32 cap_flags, u32 en_flags,
|
|||||||
struct be_cmd_req_if_create *req;
|
struct be_cmd_req_if_create *req;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -941,7 +951,7 @@ int be_cmd_if_create(struct be_adapter *adapter, u32 cap_flags, u32 en_flags,
|
|||||||
*pmac_id = le32_to_cpu(resp->pmac_id);
|
*pmac_id = le32_to_cpu(resp->pmac_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -955,7 +965,8 @@ int be_cmd_if_destroy(struct be_adapter *adapter, u32 interface_id)
|
|||||||
if (adapter->eeh_err)
|
if (adapter->eeh_err)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -970,7 +981,7 @@ int be_cmd_if_destroy(struct be_adapter *adapter, u32 interface_id)
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -1060,7 +1071,8 @@ int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver)
|
|||||||
struct be_cmd_req_get_fw_version *req;
|
struct be_cmd_req_get_fw_version *req;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -1077,7 +1089,7 @@ int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver)
|
|||||||
strncpy(fw_ver, resp->firmware_version_string, FW_VER_LEN);
|
strncpy(fw_ver, resp->firmware_version_string, FW_VER_LEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1322,7 +1334,8 @@ int be_cmd_query_fw_cfg(struct be_adapter *adapter, u32 *port_num,
|
|||||||
struct be_cmd_req_query_fw_cfg *req;
|
struct be_cmd_req_query_fw_cfg *req;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -1341,7 +1354,7 @@ int be_cmd_query_fw_cfg(struct be_adapter *adapter, u32 *port_num,
|
|||||||
*caps = le32_to_cpu(resp->function_caps);
|
*caps = le32_to_cpu(resp->function_caps);
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1352,7 +1365,8 @@ int be_cmd_reset_function(struct be_adapter *adapter)
|
|||||||
struct be_cmd_req_hdr *req;
|
struct be_cmd_req_hdr *req;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -1365,7 +1379,7 @@ int be_cmd_reset_function(struct be_adapter *adapter)
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1376,7 +1390,8 @@ int be_cmd_rss_config(struct be_adapter *adapter, u8 *rsstable, u16 table_size)
|
|||||||
u32 myhash[10];
|
u32 myhash[10];
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
spin_lock(&adapter->mbox_lock);
|
if (mutex_lock_interruptible(&adapter->mbox_lock))
|
||||||
|
return -1;
|
||||||
|
|
||||||
wrb = wrb_from_mbox(adapter);
|
wrb = wrb_from_mbox(adapter);
|
||||||
req = embedded_payload(wrb);
|
req = embedded_payload(wrb);
|
||||||
@ -1396,7 +1411,7 @@ int be_cmd_rss_config(struct be_adapter *adapter, u8 *rsstable, u16 table_size)
|
|||||||
|
|
||||||
status = be_mbox_notify_wait(adapter);
|
status = be_mbox_notify_wait(adapter);
|
||||||
|
|
||||||
spin_unlock(&adapter->mbox_lock);
|
mutex_unlock(&adapter->mbox_lock);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2677,7 +2677,7 @@ static int be_ctrl_init(struct be_adapter *adapter)
|
|||||||
}
|
}
|
||||||
memset(mc_cmd_mem->va, 0, mc_cmd_mem->size);
|
memset(mc_cmd_mem->va, 0, mc_cmd_mem->size);
|
||||||
|
|
||||||
spin_lock_init(&adapter->mbox_lock);
|
mutex_init(&adapter->mbox_lock);
|
||||||
spin_lock_init(&adapter->mcc_lock);
|
spin_lock_init(&adapter->mcc_lock);
|
||||||
spin_lock_init(&adapter->mcc_cq_lock);
|
spin_lock_init(&adapter->mcc_cq_lock);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user