bnxt_en: Reserve 1 stat_ctx for RDMA driver.
bnxt_en requires same number of stat_ctxs as CP rings but RDMA requires only 1 stat_ctx. Also add a new parameter resv_stat_ctxs to better keep track of stat_ctxs reserved including resources used by RDMA. Add a stat_ctxs parameter to all the relevant resource reservation functions so we can reserve the correct number of stat_ctxs. Prior to this patch, we were not reserving the extra stat_ctx for RDMA and RDMA would not work on the new 57500 chips. Signed-off-by: Vasundhara Volam <vasundhara-v.volam@broadcom.com> Signed-off-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f4e896142d
commit
780baad44f
@ -5161,7 +5161,6 @@ static int bnxt_hwrm_get_rings(struct bnxt *bp)
|
|||||||
hw_resc->resv_vnics = le16_to_cpu(resp->alloc_vnics);
|
hw_resc->resv_vnics = le16_to_cpu(resp->alloc_vnics);
|
||||||
cp = le16_to_cpu(resp->alloc_cmpl_rings);
|
cp = le16_to_cpu(resp->alloc_cmpl_rings);
|
||||||
stats = le16_to_cpu(resp->alloc_stat_ctx);
|
stats = le16_to_cpu(resp->alloc_stat_ctx);
|
||||||
cp = min_t(u16, cp, stats);
|
|
||||||
hw_resc->resv_irqs = cp;
|
hw_resc->resv_irqs = cp;
|
||||||
if (bp->flags & BNXT_FLAG_CHIP_P5) {
|
if (bp->flags & BNXT_FLAG_CHIP_P5) {
|
||||||
int rx = hw_resc->resv_rx_rings;
|
int rx = hw_resc->resv_rx_rings;
|
||||||
@ -5180,6 +5179,7 @@ static int bnxt_hwrm_get_rings(struct bnxt *bp)
|
|||||||
hw_resc->resv_hw_ring_grps = rx;
|
hw_resc->resv_hw_ring_grps = rx;
|
||||||
}
|
}
|
||||||
hw_resc->resv_cp_rings = cp;
|
hw_resc->resv_cp_rings = cp;
|
||||||
|
hw_resc->resv_stat_ctxs = stats;
|
||||||
}
|
}
|
||||||
mutex_unlock(&bp->hwrm_cmd_lock);
|
mutex_unlock(&bp->hwrm_cmd_lock);
|
||||||
return 0;
|
return 0;
|
||||||
@ -5209,7 +5209,7 @@ static bool bnxt_rfs_supported(struct bnxt *bp);
|
|||||||
static void
|
static void
|
||||||
__bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, struct hwrm_func_cfg_input *req,
|
__bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, struct hwrm_func_cfg_input *req,
|
||||||
int tx_rings, int rx_rings, int ring_grps,
|
int tx_rings, int rx_rings, int ring_grps,
|
||||||
int cp_rings, int vnics)
|
int cp_rings, int stats, int vnics)
|
||||||
{
|
{
|
||||||
u32 enables = 0;
|
u32 enables = 0;
|
||||||
|
|
||||||
@ -5251,7 +5251,7 @@ __bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, struct hwrm_func_cfg_input *req,
|
|||||||
req->num_rsscos_ctxs =
|
req->num_rsscos_ctxs =
|
||||||
cpu_to_le16(ring_grps + 1);
|
cpu_to_le16(ring_grps + 1);
|
||||||
}
|
}
|
||||||
req->num_stat_ctxs = req->num_cmpl_rings;
|
req->num_stat_ctxs = cpu_to_le16(stats);
|
||||||
req->num_vnics = cpu_to_le16(vnics);
|
req->num_vnics = cpu_to_le16(vnics);
|
||||||
}
|
}
|
||||||
req->enables = cpu_to_le32(enables);
|
req->enables = cpu_to_le32(enables);
|
||||||
@ -5261,7 +5261,7 @@ static void
|
|||||||
__bnxt_hwrm_reserve_vf_rings(struct bnxt *bp,
|
__bnxt_hwrm_reserve_vf_rings(struct bnxt *bp,
|
||||||
struct hwrm_func_vf_cfg_input *req, int tx_rings,
|
struct hwrm_func_vf_cfg_input *req, int tx_rings,
|
||||||
int rx_rings, int ring_grps, int cp_rings,
|
int rx_rings, int ring_grps, int cp_rings,
|
||||||
int vnics)
|
int stats, int vnics)
|
||||||
{
|
{
|
||||||
u32 enables = 0;
|
u32 enables = 0;
|
||||||
|
|
||||||
@ -5294,7 +5294,7 @@ __bnxt_hwrm_reserve_vf_rings(struct bnxt *bp,
|
|||||||
req->num_hw_ring_grps = cpu_to_le16(ring_grps);
|
req->num_hw_ring_grps = cpu_to_le16(ring_grps);
|
||||||
req->num_rsscos_ctxs = cpu_to_le16(BNXT_VF_MAX_RSS_CTX);
|
req->num_rsscos_ctxs = cpu_to_le16(BNXT_VF_MAX_RSS_CTX);
|
||||||
}
|
}
|
||||||
req->num_stat_ctxs = req->num_cmpl_rings;
|
req->num_stat_ctxs = cpu_to_le16(stats);
|
||||||
req->num_vnics = cpu_to_le16(vnics);
|
req->num_vnics = cpu_to_le16(vnics);
|
||||||
|
|
||||||
req->enables = cpu_to_le32(enables);
|
req->enables = cpu_to_le32(enables);
|
||||||
@ -5302,13 +5302,13 @@ __bnxt_hwrm_reserve_vf_rings(struct bnxt *bp,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
||||||
int ring_grps, int cp_rings, int vnics)
|
int ring_grps, int cp_rings, int stats, int vnics)
|
||||||
{
|
{
|
||||||
struct hwrm_func_cfg_input req = {0};
|
struct hwrm_func_cfg_input req = {0};
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
__bnxt_hwrm_reserve_pf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
__bnxt_hwrm_reserve_pf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
||||||
cp_rings, vnics);
|
cp_rings, stats, vnics);
|
||||||
if (!req.enables)
|
if (!req.enables)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -5325,7 +5325,7 @@ bnxt_hwrm_reserve_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
bnxt_hwrm_reserve_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
bnxt_hwrm_reserve_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
||||||
int ring_grps, int cp_rings, int vnics)
|
int ring_grps, int cp_rings, int stats, int vnics)
|
||||||
{
|
{
|
||||||
struct hwrm_func_vf_cfg_input req = {0};
|
struct hwrm_func_vf_cfg_input req = {0};
|
||||||
int rc;
|
int rc;
|
||||||
@ -5336,7 +5336,7 @@ bnxt_hwrm_reserve_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
}
|
}
|
||||||
|
|
||||||
__bnxt_hwrm_reserve_vf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
__bnxt_hwrm_reserve_vf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
||||||
cp_rings, vnics);
|
cp_rings, stats, vnics);
|
||||||
rc = hwrm_send_message(bp, &req, sizeof(req), HWRM_CMD_TIMEOUT);
|
rc = hwrm_send_message(bp, &req, sizeof(req), HWRM_CMD_TIMEOUT);
|
||||||
if (rc)
|
if (rc)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
@ -5346,12 +5346,14 @@ bnxt_hwrm_reserve_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int bnxt_hwrm_reserve_rings(struct bnxt *bp, int tx, int rx, int grp,
|
static int bnxt_hwrm_reserve_rings(struct bnxt *bp, int tx, int rx, int grp,
|
||||||
int cp, int vnic)
|
int cp, int stat, int vnic)
|
||||||
{
|
{
|
||||||
if (BNXT_PF(bp))
|
if (BNXT_PF(bp))
|
||||||
return bnxt_hwrm_reserve_pf_rings(bp, tx, rx, grp, cp, vnic);
|
return bnxt_hwrm_reserve_pf_rings(bp, tx, rx, grp, cp, stat,
|
||||||
|
vnic);
|
||||||
else
|
else
|
||||||
return bnxt_hwrm_reserve_vf_rings(bp, tx, rx, grp, cp, vnic);
|
return bnxt_hwrm_reserve_vf_rings(bp, tx, rx, grp, cp, stat,
|
||||||
|
vnic);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bnxt_nq_rings_in_use(struct bnxt *bp)
|
static int bnxt_nq_rings_in_use(struct bnxt *bp)
|
||||||
@ -5380,12 +5382,17 @@ static int bnxt_cp_rings_in_use(struct bnxt *bp)
|
|||||||
return cp;
|
return cp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int bnxt_get_func_stat_ctxs(struct bnxt *bp)
|
||||||
|
{
|
||||||
|
return bp->cp_nr_rings + bnxt_get_ulp_stat_ctxs(bp);
|
||||||
|
}
|
||||||
|
|
||||||
static bool bnxt_need_reserve_rings(struct bnxt *bp)
|
static bool bnxt_need_reserve_rings(struct bnxt *bp)
|
||||||
{
|
{
|
||||||
struct bnxt_hw_resc *hw_resc = &bp->hw_resc;
|
struct bnxt_hw_resc *hw_resc = &bp->hw_resc;
|
||||||
int cp = bnxt_cp_rings_in_use(bp);
|
int cp = bnxt_cp_rings_in_use(bp);
|
||||||
int nq = bnxt_nq_rings_in_use(bp);
|
int nq = bnxt_nq_rings_in_use(bp);
|
||||||
int rx = bp->rx_nr_rings;
|
int rx = bp->rx_nr_rings, stat;
|
||||||
int vnic = 1, grp = rx;
|
int vnic = 1, grp = rx;
|
||||||
|
|
||||||
if (bp->hwrm_spec_code < 0x10601)
|
if (bp->hwrm_spec_code < 0x10601)
|
||||||
@ -5398,9 +5405,11 @@ static bool bnxt_need_reserve_rings(struct bnxt *bp)
|
|||||||
vnic = rx + 1;
|
vnic = rx + 1;
|
||||||
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
||||||
rx <<= 1;
|
rx <<= 1;
|
||||||
|
stat = bnxt_get_func_stat_ctxs(bp);
|
||||||
if (BNXT_NEW_RM(bp) &&
|
if (BNXT_NEW_RM(bp) &&
|
||||||
(hw_resc->resv_rx_rings != rx || hw_resc->resv_cp_rings != cp ||
|
(hw_resc->resv_rx_rings != rx || hw_resc->resv_cp_rings != cp ||
|
||||||
hw_resc->resv_irqs < nq || hw_resc->resv_vnics != vnic ||
|
hw_resc->resv_irqs < nq || hw_resc->resv_vnics != vnic ||
|
||||||
|
hw_resc->resv_stat_ctxs != stat ||
|
||||||
(hw_resc->resv_hw_ring_grps != grp &&
|
(hw_resc->resv_hw_ring_grps != grp &&
|
||||||
!(bp->flags & BNXT_FLAG_CHIP_P5))))
|
!(bp->flags & BNXT_FLAG_CHIP_P5))))
|
||||||
return true;
|
return true;
|
||||||
@ -5414,8 +5423,8 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
|||||||
int tx = bp->tx_nr_rings;
|
int tx = bp->tx_nr_rings;
|
||||||
int rx = bp->rx_nr_rings;
|
int rx = bp->rx_nr_rings;
|
||||||
int grp, rx_rings, rc;
|
int grp, rx_rings, rc;
|
||||||
|
int vnic = 1, stat;
|
||||||
bool sh = false;
|
bool sh = false;
|
||||||
int vnic = 1;
|
|
||||||
|
|
||||||
if (!bnxt_need_reserve_rings(bp))
|
if (!bnxt_need_reserve_rings(bp))
|
||||||
return 0;
|
return 0;
|
||||||
@ -5427,8 +5436,9 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
|||||||
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
||||||
rx <<= 1;
|
rx <<= 1;
|
||||||
grp = bp->rx_nr_rings;
|
grp = bp->rx_nr_rings;
|
||||||
|
stat = bnxt_get_func_stat_ctxs(bp);
|
||||||
|
|
||||||
rc = bnxt_hwrm_reserve_rings(bp, tx, rx, grp, cp, vnic);
|
rc = bnxt_hwrm_reserve_rings(bp, tx, rx, grp, cp, stat, vnic);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
@ -5438,6 +5448,7 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
|||||||
cp = hw_resc->resv_irqs;
|
cp = hw_resc->resv_irqs;
|
||||||
grp = hw_resc->resv_hw_ring_grps;
|
grp = hw_resc->resv_hw_ring_grps;
|
||||||
vnic = hw_resc->resv_vnics;
|
vnic = hw_resc->resv_vnics;
|
||||||
|
stat = hw_resc->resv_stat_ctxs;
|
||||||
}
|
}
|
||||||
|
|
||||||
rx_rings = rx;
|
rx_rings = rx;
|
||||||
@ -5456,6 +5467,10 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
rx_rings = min_t(int, rx_rings, grp);
|
rx_rings = min_t(int, rx_rings, grp);
|
||||||
|
cp = min_t(int, cp, bp->cp_nr_rings);
|
||||||
|
if (stat > bnxt_get_ulp_stat_ctxs(bp))
|
||||||
|
stat -= bnxt_get_ulp_stat_ctxs(bp);
|
||||||
|
cp = min_t(int, cp, stat);
|
||||||
rc = bnxt_trim_rings(bp, &rx_rings, &tx, cp, sh);
|
rc = bnxt_trim_rings(bp, &rx_rings, &tx, cp, sh);
|
||||||
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
||||||
rx = rx_rings << 1;
|
rx = rx_rings << 1;
|
||||||
@ -5464,14 +5479,15 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
|||||||
bp->rx_nr_rings = rx_rings;
|
bp->rx_nr_rings = rx_rings;
|
||||||
bp->cp_nr_rings = cp;
|
bp->cp_nr_rings = cp;
|
||||||
|
|
||||||
if (!tx || !rx || !cp || !grp || !vnic)
|
if (!tx || !rx || !cp || !grp || !vnic || !stat)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bnxt_hwrm_check_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
static int bnxt_hwrm_check_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
||||||
int ring_grps, int cp_rings, int vnics)
|
int ring_grps, int cp_rings, int stats,
|
||||||
|
int vnics)
|
||||||
{
|
{
|
||||||
struct hwrm_func_vf_cfg_input req = {0};
|
struct hwrm_func_vf_cfg_input req = {0};
|
||||||
u32 flags;
|
u32 flags;
|
||||||
@ -5481,7 +5497,7 @@ static int bnxt_hwrm_check_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
__bnxt_hwrm_reserve_vf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
__bnxt_hwrm_reserve_vf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
||||||
cp_rings, vnics);
|
cp_rings, stats, vnics);
|
||||||
flags = FUNC_VF_CFG_REQ_FLAGS_TX_ASSETS_TEST |
|
flags = FUNC_VF_CFG_REQ_FLAGS_TX_ASSETS_TEST |
|
||||||
FUNC_VF_CFG_REQ_FLAGS_RX_ASSETS_TEST |
|
FUNC_VF_CFG_REQ_FLAGS_RX_ASSETS_TEST |
|
||||||
FUNC_VF_CFG_REQ_FLAGS_CMPL_ASSETS_TEST |
|
FUNC_VF_CFG_REQ_FLAGS_CMPL_ASSETS_TEST |
|
||||||
@ -5499,14 +5515,15 @@ static int bnxt_hwrm_check_vf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int bnxt_hwrm_check_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
static int bnxt_hwrm_check_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
||||||
int ring_grps, int cp_rings, int vnics)
|
int ring_grps, int cp_rings, int stats,
|
||||||
|
int vnics)
|
||||||
{
|
{
|
||||||
struct hwrm_func_cfg_input req = {0};
|
struct hwrm_func_cfg_input req = {0};
|
||||||
u32 flags;
|
u32 flags;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
__bnxt_hwrm_reserve_pf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
__bnxt_hwrm_reserve_pf_rings(bp, &req, tx_rings, rx_rings, ring_grps,
|
||||||
cp_rings, vnics);
|
cp_rings, stats, vnics);
|
||||||
flags = FUNC_CFG_REQ_FLAGS_TX_ASSETS_TEST;
|
flags = FUNC_CFG_REQ_FLAGS_TX_ASSETS_TEST;
|
||||||
if (BNXT_NEW_RM(bp)) {
|
if (BNXT_NEW_RM(bp)) {
|
||||||
flags |= FUNC_CFG_REQ_FLAGS_RX_ASSETS_TEST |
|
flags |= FUNC_CFG_REQ_FLAGS_RX_ASSETS_TEST |
|
||||||
@ -5527,17 +5544,19 @@ static int bnxt_hwrm_check_pf_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int bnxt_hwrm_check_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
static int bnxt_hwrm_check_rings(struct bnxt *bp, int tx_rings, int rx_rings,
|
||||||
int ring_grps, int cp_rings, int vnics)
|
int ring_grps, int cp_rings, int stats,
|
||||||
|
int vnics)
|
||||||
{
|
{
|
||||||
if (bp->hwrm_spec_code < 0x10801)
|
if (bp->hwrm_spec_code < 0x10801)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (BNXT_PF(bp))
|
if (BNXT_PF(bp))
|
||||||
return bnxt_hwrm_check_pf_rings(bp, tx_rings, rx_rings,
|
return bnxt_hwrm_check_pf_rings(bp, tx_rings, rx_rings,
|
||||||
ring_grps, cp_rings, vnics);
|
ring_grps, cp_rings, stats,
|
||||||
|
vnics);
|
||||||
|
|
||||||
return bnxt_hwrm_check_vf_rings(bp, tx_rings, rx_rings, ring_grps,
|
return bnxt_hwrm_check_vf_rings(bp, tx_rings, rx_rings, ring_grps,
|
||||||
cp_rings, vnics);
|
cp_rings, stats, vnics);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bnxt_hwrm_coal_params_qcaps(struct bnxt *bp)
|
static void bnxt_hwrm_coal_params_qcaps(struct bnxt *bp)
|
||||||
@ -7839,6 +7858,7 @@ static int bnxt_hwrm_if_change(struct bnxt *bp, bool up)
|
|||||||
|
|
||||||
rc = bnxt_hwrm_func_resc_qcaps(bp, true);
|
rc = bnxt_hwrm_func_resc_qcaps(bp, true);
|
||||||
hw_resc->resv_cp_rings = 0;
|
hw_resc->resv_cp_rings = 0;
|
||||||
|
hw_resc->resv_stat_ctxs = 0;
|
||||||
hw_resc->resv_irqs = 0;
|
hw_resc->resv_irqs = 0;
|
||||||
hw_resc->resv_tx_rings = 0;
|
hw_resc->resv_tx_rings = 0;
|
||||||
hw_resc->resv_rx_rings = 0;
|
hw_resc->resv_rx_rings = 0;
|
||||||
@ -8644,12 +8664,12 @@ static bool bnxt_rfs_capable(struct bnxt *bp)
|
|||||||
if (vnics == bp->hw_resc.resv_vnics)
|
if (vnics == bp->hw_resc.resv_vnics)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
bnxt_hwrm_reserve_rings(bp, 0, 0, 0, 0, vnics);
|
bnxt_hwrm_reserve_rings(bp, 0, 0, 0, 0, 0, vnics);
|
||||||
if (vnics <= bp->hw_resc.resv_vnics)
|
if (vnics <= bp->hw_resc.resv_vnics)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
netdev_warn(bp->dev, "Unable to reserve resources to support NTUPLE filters.\n");
|
netdev_warn(bp->dev, "Unable to reserve resources to support NTUPLE filters.\n");
|
||||||
bnxt_hwrm_reserve_rings(bp, 0, 0, 0, 0, 1);
|
bnxt_hwrm_reserve_rings(bp, 0, 0, 0, 0, 0, 1);
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
return false;
|
return false;
|
||||||
@ -9060,7 +9080,7 @@ int bnxt_check_rings(struct bnxt *bp, int tx, int rx, bool sh, int tcs,
|
|||||||
int tx_xdp)
|
int tx_xdp)
|
||||||
{
|
{
|
||||||
int max_rx, max_tx, tx_sets = 1;
|
int max_rx, max_tx, tx_sets = 1;
|
||||||
int tx_rings_needed;
|
int tx_rings_needed, stats;
|
||||||
int rx_rings = rx;
|
int rx_rings = rx;
|
||||||
int cp, vnics, rc;
|
int cp, vnics, rc;
|
||||||
|
|
||||||
@ -9085,10 +9105,13 @@ int bnxt_check_rings(struct bnxt *bp, int tx, int rx, bool sh, int tcs,
|
|||||||
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
if (bp->flags & BNXT_FLAG_AGG_RINGS)
|
||||||
rx_rings <<= 1;
|
rx_rings <<= 1;
|
||||||
cp = sh ? max_t(int, tx_rings_needed, rx) : tx_rings_needed + rx;
|
cp = sh ? max_t(int, tx_rings_needed, rx) : tx_rings_needed + rx;
|
||||||
if (BNXT_NEW_RM(bp))
|
stats = cp;
|
||||||
|
if (BNXT_NEW_RM(bp)) {
|
||||||
cp += bnxt_get_ulp_msix_num(bp);
|
cp += bnxt_get_ulp_msix_num(bp);
|
||||||
|
stats += bnxt_get_ulp_stat_ctxs(bp);
|
||||||
|
}
|
||||||
return bnxt_hwrm_check_rings(bp, tx_rings_needed, rx_rings, rx, cp,
|
return bnxt_hwrm_check_rings(bp, tx_rings_needed, rx_rings, rx, cp,
|
||||||
vnics);
|
stats, vnics);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bnxt_unmap_bars(struct bnxt *bp, struct pci_dev *pdev)
|
static void bnxt_unmap_bars(struct bnxt *bp, struct pci_dev *pdev)
|
||||||
|
@ -927,6 +927,7 @@ struct bnxt_hw_resc {
|
|||||||
u16 resv_vnics;
|
u16 resv_vnics;
|
||||||
u16 min_stat_ctxs;
|
u16 min_stat_ctxs;
|
||||||
u16 max_stat_ctxs;
|
u16 max_stat_ctxs;
|
||||||
|
u16 resv_stat_ctxs;
|
||||||
u16 max_nqs;
|
u16 max_nqs;
|
||||||
u16 max_irqs;
|
u16 max_irqs;
|
||||||
u16 resv_irqs;
|
u16 resv_irqs;
|
||||||
|
Loading…
Reference in New Issue
Block a user