mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-10 14:43:54 +08:00
bnxt_en: Always forward VF MAC address to the PF.
The current code already forwards the VF MAC address to the PF, except in one case. If the VF driver gets a valid MAC address from the firmware during probe time, it will not forward the MAC address to the PF, incorrectly assuming that the PF already knows the MAC address. This causes "ip link show" to show zero VF MAC addresses for this case. This assumption is not correct. Newer firmware remembers the VF MAC address last used by the VF and provides it to the VF driver during probe. So we need to always forward the VF MAC address to the PF. The forwarded MAC address may now be the PF assigned MAC address and so we need to make sure we approve it for this case. Signed-off-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7328a23c06
commit
707e7e9660
@ -8678,8 +8678,8 @@ static int bnxt_init_mac_addr(struct bnxt *bp)
|
|||||||
memcpy(bp->dev->dev_addr, vf->mac_addr, ETH_ALEN);
|
memcpy(bp->dev->dev_addr, vf->mac_addr, ETH_ALEN);
|
||||||
} else {
|
} else {
|
||||||
eth_hw_addr_random(bp->dev);
|
eth_hw_addr_random(bp->dev);
|
||||||
rc = bnxt_approve_mac(bp, bp->dev->dev_addr);
|
|
||||||
}
|
}
|
||||||
|
rc = bnxt_approve_mac(bp, bp->dev->dev_addr);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -923,7 +923,8 @@ static int bnxt_vf_configure_mac(struct bnxt *bp, struct bnxt_vf_info *vf)
|
|||||||
if (req->enables & cpu_to_le32(FUNC_VF_CFG_REQ_ENABLES_DFLT_MAC_ADDR)) {
|
if (req->enables & cpu_to_le32(FUNC_VF_CFG_REQ_ENABLES_DFLT_MAC_ADDR)) {
|
||||||
if (is_valid_ether_addr(req->dflt_mac_addr) &&
|
if (is_valid_ether_addr(req->dflt_mac_addr) &&
|
||||||
((vf->flags & BNXT_VF_TRUST) ||
|
((vf->flags & BNXT_VF_TRUST) ||
|
||||||
(!is_valid_ether_addr(vf->mac_addr)))) {
|
!is_valid_ether_addr(vf->mac_addr) ||
|
||||||
|
ether_addr_equal(req->dflt_mac_addr, vf->mac_addr))) {
|
||||||
ether_addr_copy(vf->vf_mac_addr, req->dflt_mac_addr);
|
ether_addr_copy(vf->vf_mac_addr, req->dflt_mac_addr);
|
||||||
return bnxt_hwrm_exec_fwd_resp(bp, vf, msg_size);
|
return bnxt_hwrm_exec_fwd_resp(bp, vf, msg_size);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user