Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit aefd90e4 authored by Michael Chan's avatar Michael Chan Committed by David S. Miller
Browse files

bnx2: Read PCI function number from internal register



so that it will work on any hypervisor.

Signed-off-by: default avatarMichael Chan <mchan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 13e63517
Loading
Loading
Loading
Loading
+5 −2
Original line number Diff line number Diff line
@@ -7903,7 +7903,7 @@ bnx2_get_5709_media(struct bnx2 *bp)
	else
		strap = (val & BNX2_MISC_DUAL_MEDIA_CTRL_PHY_CTRL_STRAP) >> 8;

	if (PCI_FUNC(bp->pdev->devfn) == 0) {
	if (bp->func == 0) {
		switch (strap) {
		case 0x4:
		case 0x5:
@@ -8202,9 +8202,12 @@ bnx2_init_board(struct pci_dev *pdev, struct net_device *dev)

	reg = bnx2_reg_rd_ind(bp, BNX2_SHM_HDR_SIGNATURE);

	if (bnx2_reg_rd_ind(bp, BNX2_MCP_TOE_ID) & BNX2_MCP_TOE_ID_FUNCTION_ID)
		bp->func = 1;

	if ((reg & BNX2_SHM_HDR_SIGNATURE_SIG_MASK) ==
	    BNX2_SHM_HDR_SIGNATURE_SIG) {
		u32 off = PCI_FUNC(pdev->devfn) << 2;
		u32 off = bp->func << 2;

		bp->shmem_base = bnx2_reg_rd_ind(bp, BNX2_SHM_HDR_ADDR_0 + off);
	} else
+2 −0
Original line number Diff line number Diff line
@@ -6971,6 +6971,8 @@ struct bnx2 {
	struct bnx2_irq		irq_tbl[BNX2_MAX_MSIX_VEC];
	int			irq_nvecs;

	u8			func;

	u8			num_tx_rings;
	u8			num_rx_rings;