62 lines
2.2 KiB
Diff
62 lines
2.2 KiB
Diff
|
commit 65ca78fdf9a684743bfca278cf1fcfea4603931d
|
||
|
Author: Nelson Escobar <neescoba@cisco.com>
|
||
|
Date: Fri Mar 18 11:33:34 2016 -0700
|
||
|
|
||
|
enic: fix Rx descriptor limit
|
||
|
|
||
|
On initialization, the rq descriptor count was set to the limit
|
||
|
of the vic. When the requested number of rx descriptors was
|
||
|
less than this count, enic_alloc_rq() was incorrectly setting
|
||
|
the count to the lower value. This results in later calls to
|
||
|
enic_alloc_rq() incorrectly using the lower value as the adapter
|
||
|
limit.
|
||
|
|
||
|
Fixes: fefed3d1e62c ("enic: new driver")
|
||
|
|
||
|
Signed-off-by: Nelson Escobar <neescoba@cisco.com>
|
||
|
Reviewed-by: John Daley <johndale@cisco.com>
|
||
|
|
||
|
diff --git a/drivers/net/enic/enic_main.c b/drivers/net/enic/enic_main.c
|
||
|
index e30672c..2f79cf0 100644
|
||
|
--- a/drivers/net/enic/enic_main.c
|
||
|
+++ b/drivers/net/enic/enic_main.c
|
||
|
@@ -524,24 +524,22 @@ int enic_alloc_rq(struct enic *enic, uint16_t queue_idx,
|
||
|
"policy. Applying the value in the adapter "\
|
||
|
"policy (%d).\n",
|
||
|
queue_idx, nb_desc, enic->config.rq_desc_count);
|
||
|
- } else if (nb_desc != enic->config.rq_desc_count) {
|
||
|
- enic->config.rq_desc_count = nb_desc;
|
||
|
- dev_info(enic,
|
||
|
- "RX Queues - effective number of descs:%d\n",
|
||
|
- nb_desc);
|
||
|
+ nb_desc = enic->config.rq_desc_count;
|
||
|
}
|
||
|
+ dev_info(enic, "RX Queues - effective number of descs:%d\n",
|
||
|
+ nb_desc);
|
||
|
}
|
||
|
|
||
|
/* Allocate queue resources */
|
||
|
rc = vnic_rq_alloc(enic->vdev, rq, queue_idx,
|
||
|
- enic->config.rq_desc_count, sizeof(struct rq_enet_desc));
|
||
|
+ nb_desc, sizeof(struct rq_enet_desc));
|
||
|
if (rc) {
|
||
|
dev_err(enic, "error in allocation of rq\n");
|
||
|
goto err_exit;
|
||
|
}
|
||
|
|
||
|
rc = vnic_cq_alloc(enic->vdev, &enic->cq[queue_idx], queue_idx,
|
||
|
- socket_id, enic->config.rq_desc_count,
|
||
|
+ socket_id, nb_desc,
|
||
|
sizeof(struct cq_enet_rq_desc));
|
||
|
if (rc) {
|
||
|
dev_err(enic, "error in allocation of cq for rq\n");
|
||
|
@@ -550,7 +548,7 @@ int enic_alloc_rq(struct enic *enic, uint16_t queue_idx,
|
||
|
|
||
|
/* Allocate the mbuf ring */
|
||
|
rq->mbuf_ring = (struct rte_mbuf **)rte_zmalloc_socket("rq->mbuf_ring",
|
||
|
- sizeof(struct rte_mbuf *) * enic->config.rq_desc_count,
|
||
|
+ sizeof(struct rte_mbuf *) * nb_desc,
|
||
|
RTE_CACHE_LINE_SIZE, rq->socket_id);
|
||
|
|
||
|
if (rq->mbuf_ring != NULL)
|