Commit fd98d896 authored by Selvin Xavier's avatar Selvin Xavier Committed by Doug Ledford

RDMA/ocrdma: Initialize stats resources in the driver before ib device registration.

In the latest kernel, process_mad hook of the driver can be invoked as
soon as device is registered. In this hook, ocrdma driver is issuing a
command to get the stats counters from the HW. This is triggering system
crash since the statistics command resources are not allocated by the driver.
Changing the sequence of initialization to avoid this crash.
Signed-off-by: default avatarSelvin Xavier <selvin.xavier@broadcom.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent 9f780dab
...@@ -228,6 +228,11 @@ static int ocrdma_alloc_resources(struct ocrdma_dev *dev) ...@@ -228,6 +228,11 @@ static int ocrdma_alloc_resources(struct ocrdma_dev *dev)
ocrdma_alloc_pd_pool(dev); ocrdma_alloc_pd_pool(dev);
if (!ocrdma_alloc_stats_resources(dev)) {
pr_err("%s: stats resource allocation failed\n", __func__);
goto alloc_err;
}
spin_lock_init(&dev->av_tbl.lock); spin_lock_init(&dev->av_tbl.lock);
spin_lock_init(&dev->flush_q_lock); spin_lock_init(&dev->flush_q_lock);
return 0; return 0;
...@@ -238,6 +243,7 @@ static int ocrdma_alloc_resources(struct ocrdma_dev *dev) ...@@ -238,6 +243,7 @@ static int ocrdma_alloc_resources(struct ocrdma_dev *dev)
static void ocrdma_free_resources(struct ocrdma_dev *dev) static void ocrdma_free_resources(struct ocrdma_dev *dev)
{ {
ocrdma_release_stats_resources(dev);
kfree(dev->stag_arr); kfree(dev->stag_arr);
kfree(dev->qp_tbl); kfree(dev->qp_tbl);
kfree(dev->cq_tbl); kfree(dev->cq_tbl);
......
...@@ -64,10 +64,11 @@ static int ocrdma_add_stat(char *start, char *pcur, ...@@ -64,10 +64,11 @@ static int ocrdma_add_stat(char *start, char *pcur,
return cpy_len; return cpy_len;
} }
static bool ocrdma_alloc_stats_mem(struct ocrdma_dev *dev) bool ocrdma_alloc_stats_resources(struct ocrdma_dev *dev)
{ {
struct stats_mem *mem = &dev->stats_mem; struct stats_mem *mem = &dev->stats_mem;
mutex_init(&dev->stats_lock);
/* Alloc mbox command mem*/ /* Alloc mbox command mem*/
mem->size = max_t(u32, sizeof(struct ocrdma_rdma_stats_req), mem->size = max_t(u32, sizeof(struct ocrdma_rdma_stats_req),
sizeof(struct ocrdma_rdma_stats_resp)); sizeof(struct ocrdma_rdma_stats_resp));
...@@ -91,13 +92,14 @@ static bool ocrdma_alloc_stats_mem(struct ocrdma_dev *dev) ...@@ -91,13 +92,14 @@ static bool ocrdma_alloc_stats_mem(struct ocrdma_dev *dev)
return true; return true;
} }
static void ocrdma_release_stats_mem(struct ocrdma_dev *dev) void ocrdma_release_stats_resources(struct ocrdma_dev *dev)
{ {
struct stats_mem *mem = &dev->stats_mem; struct stats_mem *mem = &dev->stats_mem;
if (mem->va) if (mem->va)
dma_free_coherent(&dev->nic_info.pdev->dev, mem->size, dma_free_coherent(&dev->nic_info.pdev->dev, mem->size,
mem->va, mem->pa); mem->va, mem->pa);
mem->va = NULL;
kfree(mem->debugfs_mem); kfree(mem->debugfs_mem);
} }
...@@ -838,15 +840,9 @@ void ocrdma_add_port_stats(struct ocrdma_dev *dev) ...@@ -838,15 +840,9 @@ void ocrdma_add_port_stats(struct ocrdma_dev *dev)
&dev->reset_stats, &ocrdma_dbg_ops)) &dev->reset_stats, &ocrdma_dbg_ops))
goto err; goto err;
/* Now create dma_mem for stats mbx command */
if (!ocrdma_alloc_stats_mem(dev))
goto err;
mutex_init(&dev->stats_lock);
return; return;
err: err:
ocrdma_release_stats_mem(dev);
debugfs_remove_recursive(dev->dir); debugfs_remove_recursive(dev->dir);
dev->dir = NULL; dev->dir = NULL;
} }
...@@ -856,8 +852,6 @@ void ocrdma_rem_port_stats(struct ocrdma_dev *dev) ...@@ -856,8 +852,6 @@ void ocrdma_rem_port_stats(struct ocrdma_dev *dev)
if (!dev->dir) if (!dev->dir)
return; return;
debugfs_remove(dev->dir); debugfs_remove(dev->dir);
mutex_destroy(&dev->stats_lock);
ocrdma_release_stats_mem(dev);
} }
void ocrdma_init_debugfs(void) void ocrdma_init_debugfs(void)
......
...@@ -65,6 +65,8 @@ enum OCRDMA_STATS_TYPE { ...@@ -65,6 +65,8 @@ enum OCRDMA_STATS_TYPE {
void ocrdma_rem_debugfs(void); void ocrdma_rem_debugfs(void);
void ocrdma_init_debugfs(void); void ocrdma_init_debugfs(void);
bool ocrdma_alloc_stats_resources(struct ocrdma_dev *dev);
void ocrdma_release_stats_resources(struct ocrdma_dev *dev);
void ocrdma_rem_port_stats(struct ocrdma_dev *dev); void ocrdma_rem_port_stats(struct ocrdma_dev *dev);
void ocrdma_add_port_stats(struct ocrdma_dev *dev); void ocrdma_add_port_stats(struct ocrdma_dev *dev);
int ocrdma_pma_counters(struct ocrdma_dev *dev, int ocrdma_pma_counters(struct ocrdma_dev *dev,
......
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