return 0;
 }
 
-static int bnxt_hwrm_func_qcaps(struct bnxt *bp)
+int bnxt_hwrm_func_qcaps(struct bnxt *bp)
 {
        int rc = 0;
        struct hwrm_func_qcaps_input req = {0};
                pf->max_rsscos_ctxs = le16_to_cpu(resp->max_rsscos_ctx);
                pf->max_cp_rings = le16_to_cpu(resp->max_cmpl_rings);
                pf->max_tx_rings = le16_to_cpu(resp->max_tx_rings);
-               pf->max_pf_tx_rings = pf->max_tx_rings;
                pf->max_rx_rings = le16_to_cpu(resp->max_rx_rings);
-               pf->max_pf_rx_rings = pf->max_rx_rings;
                pf->max_l2_ctxs = le16_to_cpu(resp->max_l2_ctxs);
                pf->max_vnics = le16_to_cpu(resp->max_vnics);
                pf->max_stat_ctxs = le16_to_cpu(resp->max_stat_ctx);
        int max_rings = 0;
 
        if (BNXT_PF(bp)) {
-               *max_tx = bp->pf.max_pf_tx_rings;
-               *max_rx = bp->pf.max_pf_rx_rings;
+               *max_tx = bp->pf.max_tx_rings;
+               *max_rx = bp->pf.max_rx_rings;
                max_rings = min_t(int, bp->pf.max_irqs, bp->pf.max_cp_rings);
                max_rings = min_t(int, max_rings, bp->pf.max_stat_ctxs);
        } else {
 
        u16     max_rsscos_ctxs;
        u16     max_cp_rings;
        u16     max_tx_rings; /* HW assigned max tx rings for this PF */
-       u16     max_pf_tx_rings; /* runtime max tx rings owned by PF */
        u16     max_rx_rings; /* HW assigned max rx rings for this PF */
-       u16     max_pf_rx_rings; /* runtime max rx rings owned by PF */
        u16     max_irqs;
        u16     max_l2_ctxs;
        u16     max_vnics;
 int _hwrm_send_message(struct bnxt *, void *, u32, int);
 int hwrm_send_message(struct bnxt *, void *, u32, int);
 int bnxt_hwrm_set_coal(struct bnxt *);
+int bnxt_hwrm_func_qcaps(struct bnxt *);
 int bnxt_hwrm_set_pause(struct bnxt *);
 int bnxt_hwrm_set_link_setting(struct bnxt *, bool);
 int bnxt_open_nic(struct bnxt *, bool, bool);
 
        }
        mutex_unlock(&bp->hwrm_cmd_lock);
        if (!rc) {
-               pf->max_pf_tx_rings = bp->tx_nr_rings;
-               if (bp->flags & BNXT_FLAG_AGG_RINGS)
-                       pf->max_pf_rx_rings = bp->rx_nr_rings * 2;
-               else
-                       pf->max_pf_rx_rings = bp->rx_nr_rings;
+               pf->max_tx_rings -= vf_tx_rings * num_vfs;
+               pf->max_rx_rings -= vf_rx_rings * num_vfs;
+               pf->max_cp_rings -= vf_cp_rings * num_vfs;
+               pf->max_rsscos_ctxs -= num_vfs;
+               pf->max_stat_ctxs -= vf_stat_ctx * num_vfs;
+               pf->max_vnics -= vf_vnics * num_vfs;
        }
        return rc;
 }
        bnxt_free_vf_resources(bp);
 
        bp->pf.active_vfs = 0;
-       bp->pf.max_pf_rx_rings = bp->pf.max_rx_rings;
-       bp->pf.max_pf_tx_rings = bp->pf.max_tx_rings;
+       /* Reclaim all resources for the PF. */
+       bnxt_hwrm_func_qcaps(bp);
 }
 
 int bnxt_sriov_configure(struct pci_dev *pdev, int num_vfs)