Commit 8f2fd393 authored by David S. Miller's avatar David S. Miller

Merge branch 'hns3-fixes'

Guangbin Huang says:

====================
net: hns3: add some fixes for -net

This series adds some fixes for the HNS3 ethernet driver.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 3748939b 6dde452b
...@@ -839,6 +839,8 @@ struct hnae3_handle { ...@@ -839,6 +839,8 @@ struct hnae3_handle {
u8 netdev_flags; u8 netdev_flags;
struct dentry *hnae3_dbgfs; struct dentry *hnae3_dbgfs;
/* protects concurrent contention between debugfs commands */
struct mutex dbgfs_lock;
/* Network interface message level enabled bits */ /* Network interface message level enabled bits */
u32 msg_enable; u32 msg_enable;
......
...@@ -1226,6 +1226,7 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, ...@@ -1226,6 +1226,7 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer,
if (ret) if (ret)
return ret; return ret;
mutex_lock(&handle->dbgfs_lock);
save_buf = &hns3_dbg_cmd[index].buf; save_buf = &hns3_dbg_cmd[index].buf;
if (!test_bit(HNS3_NIC_STATE_INITED, &priv->state) || if (!test_bit(HNS3_NIC_STATE_INITED, &priv->state) ||
...@@ -1238,15 +1239,15 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, ...@@ -1238,15 +1239,15 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer,
read_buf = *save_buf; read_buf = *save_buf;
} else { } else {
read_buf = kvzalloc(hns3_dbg_cmd[index].buf_len, GFP_KERNEL); read_buf = kvzalloc(hns3_dbg_cmd[index].buf_len, GFP_KERNEL);
if (!read_buf) if (!read_buf) {
return -ENOMEM; ret = -ENOMEM;
goto out;
}
/* save the buffer addr until the last read operation */ /* save the buffer addr until the last read operation */
*save_buf = read_buf; *save_buf = read_buf;
}
/* get data ready for the first time to read */ /* get data ready for the first time to read */
if (!*ppos) {
ret = hns3_dbg_read_cmd(dbg_data, hns3_dbg_cmd[index].cmd, ret = hns3_dbg_read_cmd(dbg_data, hns3_dbg_cmd[index].cmd,
read_buf, hns3_dbg_cmd[index].buf_len); read_buf, hns3_dbg_cmd[index].buf_len);
if (ret) if (ret)
...@@ -1255,8 +1256,10 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, ...@@ -1255,8 +1256,10 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer,
size = simple_read_from_buffer(buffer, count, ppos, read_buf, size = simple_read_from_buffer(buffer, count, ppos, read_buf,
strlen(read_buf)); strlen(read_buf));
if (size > 0) if (size > 0) {
mutex_unlock(&handle->dbgfs_lock);
return size; return size;
}
out: out:
/* free the buffer for the last read operation */ /* free the buffer for the last read operation */
...@@ -1265,6 +1268,7 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, ...@@ -1265,6 +1268,7 @@ static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer,
*save_buf = NULL; *save_buf = NULL;
} }
mutex_unlock(&handle->dbgfs_lock);
return ret; return ret;
} }
...@@ -1337,6 +1341,8 @@ int hns3_dbg_init(struct hnae3_handle *handle) ...@@ -1337,6 +1341,8 @@ int hns3_dbg_init(struct hnae3_handle *handle)
debugfs_create_dir(hns3_dbg_dentry[i].name, debugfs_create_dir(hns3_dbg_dentry[i].name,
handle->hnae3_dbgfs); handle->hnae3_dbgfs);
mutex_init(&handle->dbgfs_lock);
for (i = 0; i < ARRAY_SIZE(hns3_dbg_cmd); i++) { for (i = 0; i < ARRAY_SIZE(hns3_dbg_cmd); i++) {
if ((hns3_dbg_cmd[i].cmd == HNAE3_DBG_CMD_TM_NODES && if ((hns3_dbg_cmd[i].cmd == HNAE3_DBG_CMD_TM_NODES &&
ae_dev->dev_version <= HNAE3_DEVICE_VERSION_V2) || ae_dev->dev_version <= HNAE3_DEVICE_VERSION_V2) ||
...@@ -1363,6 +1369,7 @@ int hns3_dbg_init(struct hnae3_handle *handle) ...@@ -1363,6 +1369,7 @@ int hns3_dbg_init(struct hnae3_handle *handle)
return 0; return 0;
out: out:
mutex_destroy(&handle->dbgfs_lock);
debugfs_remove_recursive(handle->hnae3_dbgfs); debugfs_remove_recursive(handle->hnae3_dbgfs);
handle->hnae3_dbgfs = NULL; handle->hnae3_dbgfs = NULL;
return ret; return ret;
...@@ -1378,6 +1385,7 @@ void hns3_dbg_uninit(struct hnae3_handle *handle) ...@@ -1378,6 +1385,7 @@ void hns3_dbg_uninit(struct hnae3_handle *handle)
hns3_dbg_cmd[i].buf = NULL; hns3_dbg_cmd[i].buf = NULL;
} }
mutex_destroy(&handle->dbgfs_lock);
debugfs_remove_recursive(handle->hnae3_dbgfs); debugfs_remove_recursive(handle->hnae3_dbgfs);
handle->hnae3_dbgfs = NULL; handle->hnae3_dbgfs = NULL;
} }
......
...@@ -114,6 +114,7 @@ int hclgevf_send_mbx_msg(struct hclgevf_dev *hdev, ...@@ -114,6 +114,7 @@ int hclgevf_send_mbx_msg(struct hclgevf_dev *hdev,
memcpy(&req->msg, send_msg, sizeof(struct hclge_vf_to_pf_msg)); memcpy(&req->msg, send_msg, sizeof(struct hclge_vf_to_pf_msg));
if (test_bit(HCLGEVF_STATE_NIC_REGISTERED, &hdev->state))
trace_hclge_vf_mbx_send(hdev, req); trace_hclge_vf_mbx_send(hdev, req);
/* synchronous send */ /* synchronous send */
......
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