bnx2x: set VF DMAE when first function has 0 supported VFs
There are possible HW configurations in which PFs will have SR-IOV capability but will have Max VFs set to 0 - this happens when there are Multi-Function devices where the VFs are allocated to only some of the PFs. DMAE is configured to support VFs only if the configuring PF has supported VFs. In case the first PF to be loaded will be one without supported VFs, it will not configure DMAE to the VF-supporting mode. When VFs of other PFs will be loaded later on, they will not be able to communicate with their PF. This changes the requirement for configuring DMAE for VF-supporting mode; If the device has SR-IOV capabilities there must be some PF that has max supported VFs > 0, thus it will configure the DMAE for supporting VFs. Signed-off-by: Ariel Elior <ariele@broadcom.com> Signed-off-by: Yuval Mintz <yuvalmin@broadcom.com> Signed-off-by: Eilon Greenstein <eilong@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
5ae30d7804
commit
49baea8816
@ -1747,11 +1747,8 @@ void bnx2x_iov_init_dq(struct bnx2x *bp)
|
|||||||
|
|
||||||
void bnx2x_iov_init_dmae(struct bnx2x *bp)
|
void bnx2x_iov_init_dmae(struct bnx2x *bp)
|
||||||
{
|
{
|
||||||
DP(BNX2X_MSG_IOV, "SRIOV is %s\n", IS_SRIOV(bp) ? "ON" : "OFF");
|
if (pci_find_ext_capability(bp->pdev, PCI_EXT_CAP_ID_SRIOV))
|
||||||
if (!IS_SRIOV(bp))
|
REG_WR(bp, DMAE_REG_BACKWARD_COMP_EN, 0);
|
||||||
return;
|
|
||||||
|
|
||||||
REG_WR(bp, DMAE_REG_BACKWARD_COMP_EN, 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bnx2x_vf_bus(struct bnx2x *bp, int vfid)
|
static int bnx2x_vf_bus(struct bnx2x *bp, int vfid)
|
||||||
|
Loading…
Reference in New Issue
Block a user