Commit c73d2e84 authored by Carolyn Wyborny's avatar Carolyn Wyborny Committed by Jeff Kirsher

i40e: Fix client interaction

This patch fixes a problem in the client interface that
was causing random stack traces in RDMA driver load and
unload tests.  This patch fixes the problem by checking
for an existing client before trying to open it.  Without
this patch, there is a timing related null pointer deref.

Change-ID: Ib73d30671a27f6f9770dd53b3e5292b88d6b62da
Signed-off-by: default avatarCarolyn Wyborny <carolyn.wyborny@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent b09edbd0
...@@ -565,7 +565,7 @@ void i40e_client_subtask(struct i40e_pf *pf) ...@@ -565,7 +565,7 @@ void i40e_client_subtask(struct i40e_pf *pf)
if (test_bit(__I40E_DOWN, &pf->vsi[pf->lan_vsi]->state)) if (test_bit(__I40E_DOWN, &pf->vsi[pf->lan_vsi]->state))
continue; continue;
} else { } else {
dev_warn(&pf->pdev->dev, "This client %s is being instanciated at probe\n", dev_warn(&pf->pdev->dev, "This client %s is being instantiated at probe\n",
client->name); client->name);
} }
...@@ -582,25 +582,22 @@ void i40e_client_subtask(struct i40e_pf *pf) ...@@ -582,25 +582,22 @@ void i40e_client_subtask(struct i40e_pf *pf)
dev_info(&pf->pdev->dev, "Added instance of Client %s to PF%d bus=0x%02x func=0x%02x\n", dev_info(&pf->pdev->dev, "Added instance of Client %s to PF%d bus=0x%02x func=0x%02x\n",
client->name, pf->hw.pf_id, client->name, pf->hw.pf_id,
pf->hw.bus.device, pf->hw.bus.func); pf->hw.bus.device, pf->hw.bus.func);
}
mutex_lock(&i40e_client_instance_mutex); mutex_lock(&i40e_client_instance_mutex);
/* Send an Open request to the client */
atomic_inc(&cdev->ref_cnt); atomic_inc(&cdev->ref_cnt);
if (client->ops && client->ops->open) if (client->ops && client->ops->open)
ret = client->ops->open(&cdev->lan_info, client); ret = client->ops->open(&cdev->lan_info,
client);
atomic_dec(&cdev->ref_cnt); atomic_dec(&cdev->ref_cnt);
if (!ret) { if (ret < 0) {
set_bit(__I40E_CLIENT_INSTANCE_OPENED, &cdev->state);
} else {
/* remove client instance */
mutex_unlock(&i40e_client_instance_mutex); mutex_unlock(&i40e_client_instance_mutex);
i40e_client_del_instance(pf, client); i40e_client_del_instance(pf, client);
atomic_dec(&client->ref_cnt); atomic_dec(&client->ref_cnt);
continue; continue;
} }
set_bit(__I40E_CLIENT_INSTANCE_OPENED, &cdev->state);
mutex_unlock(&i40e_client_instance_mutex); mutex_unlock(&i40e_client_instance_mutex);
} }
}
mutex_unlock(&i40e_client_mutex); mutex_unlock(&i40e_client_mutex);
} }
......
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