Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 19 Jan 2010 14:11:49 +0100 (CET)
From:      Oliver Fromme <olli@lurza.secnetix.de>
To:        freebsd-current@FreeBSD.ORG, pyunyh@gmail.com
Subject:   Re: bce(4) on IBM BladeCenter HS22
Message-ID:  <201001191311.o0JDBnT0045509@lurza.secnetix.de>
In-Reply-To: <20100118202805.GB1336@michelle.cdnetworks.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Ok, I've got more information.  Maybe this is helpful.
I enabled BCE_DEBUG and set bce_debug = BCE_INSANE_PHY.
At first I got a compile error and had to apply this patch:

--- src/sys/dev/bce/if_bce.c.orig	2009-10-21 14:47:09.000000000 +0200
+++ src/sys/dev/bce/if_bce.c	2010-01-19 13:13:36.000000000 +0100
@@ -10038,9 +10045,9 @@
 	BCE_PRINTF("0x%08X - (0x%06X) state\n",
 		val, BCE_BC_STATE);
 
-	val = bce_shmem_rd(sc, BCE_BC_CONDITION);
+	val = bce_shmem_rd(sc, BCE_BC_STATE_CONDITION);
 	BCE_PRINTF("0x%08X - (0x%06X) condition\n",
-		val, BCE_BC_CONDITION);
+		val, BCE_BC_STATE_CONDITION);
 
 	val = bce_shmem_rd(sc, BCE_BC_STATE_DEBUG_CMD);
 	BCE_PRINTF("0x%08X - (0x%06X) debug_cmd\n",

Then I got this output during boot:

bce0: <Broadcom NetXtreme II BCM5709 1000Base-SX (C0)> mem 0x92000000-0x93ffffff irq 30 at device 0.0 on pci16
bce0: attempting to allocate 1 MSI vectors (16 supported)
msi: routing MSI IRQ 260 to local APIC 0 vector 112
bce0: using IRQ 260 for MSI
bce0: bce_get_media(enter)
bce0: Using PHY address 2.
bce0: bce_get_media(exit)
bce0: bce_dma_alloc(): status_block_paddr = 0xCE36480
bce0: bce_dma_alloc(): stats_block_paddr = 0xCE21800
bce0: bce_dma_alloc(): ctx_paddr[0] = 0xCE77000
bce0: bce_dma_alloc(): ctx_paddr[1] = 0xCE37000
bce0: bce_dma_alloc(): tx_bd_chain_paddr[0] = 0x7D9F8000
bce0: bce_dma_alloc(): tx_bd_chain_paddr[1] = 0x7D9F9000
bce0: bce_dma_alloc(): rx_bd_chain_paddr[0] = 0x7D9FA000
bce0: bce_dma_alloc(): rx_bd_chain_paddr[1] = 0x7D9FB000
bce0: bce_dma_alloc(): Creating rx_mbuf_tag (max size = 0x2400 max segments = 1, max segment size = 0x2400)
bce0: Invalid PHY address 0 for PHY read!
bce0: Invalid PHY address 1 for PHY read!
bce0: bce_miibus_read_reg(): phy = 2, reg = 0x0001 (BMSR   ), val = 0x0
bce0: Invalid PHY address 3 for PHY read!
bce0: Invalid PHY address 4 for PHY read!
bce0: Invalid PHY address 5 for PHY read!
bce0: Invalid PHY address 6 for PHY read!
bce0: Invalid PHY address 7 for PHY read!
bce0: Invalid PHY address 8 for PHY read!
bce0: Invalid PHY address 9 for PHY read!
bce0: Invalid PHY address 10 for PHY read!
bce0: Invalid PHY address 11 for PHY read!
bce0: Invalid PHY address 12 for PHY read!
bce0: Invalid PHY address 13 for PHY read!
bce0: Invalid PHY address 14 for PHY read!
bce0: Invalid PHY address 15 for PHY read!
bce0: Invalid PHY address 16 for PHY read!
bce0: Invalid PHY address 17 for PHY read!
bce0: Invalid PHY address 18 for PHY read!
bce0: Invalid PHY address 19 for PHY read!
bce0: Invalid PHY address 20 for PHY read!
bce0: Invalid PHY address 21 for PHY read!
bce0: Invalid PHY address 22 for PHY read!
bce0: Invalid PHY address 23 for PHY read!
bce0: Invalid PHY address 24 for PHY read!
bce0: Invalid PHY address 25 for PHY read!
bce0: Invalid PHY address 26 for PHY read!
bce0: Invalid PHY address 27 for PHY read!
bce0: Invalid PHY address 28 for PHY read!
bce0: Invalid PHY address 29 for PHY read!
bce0: Invalid PHY address 30 for PHY read!
bce0: Invalid PHY address 31 for PHY read!
bce0: /usr/src/sys/dev/bce/if_bce.c(1098): No PHY found on child MII bus!
bce0: bce_miibus_read_reg(): phy = 2, reg = 0x0002, val = 0x0000
PHYID1: 0x0000
bce0: bce_miibus_read_reg(): phy = 2, reg = 0x0003, val = 0x0000
PHYID2: 0x0000
device_attach: bce0 attach returned 6
bce1: <Broadcom NetXtreme II BCM5709 1000Base-SX (C0)> mem 0x94000000-0x95ffffff irq 37 at device 0.1 on pci16
bce1: attempting to allocate 1 MSI vectors (16 supported)
msi: routing MSI IRQ 260 to local APIC 0 vector 112
bce1: using IRQ 260 for MSI
bce1: bce_get_media(enter)
bce1: Using PHY address 2.
bce1: bce_get_media(exit)
bce1: bce_dma_alloc(): status_block_paddr = 0xCE362C0
bce1: bce_dma_alloc(): stats_block_paddr = 0xCE21800
bce1: bce_dma_alloc(): ctx_paddr[0] = 0xCE77000
bce1: bce_dma_alloc(): ctx_paddr[1] = 0xCE37000
bce1: bce_dma_alloc(): tx_bd_chain_paddr[0] = 0xCE58000
bce1: bce_dma_alloc(): tx_bd_chain_paddr[1] = 0xCE59000
bce1: bce_dma_alloc(): rx_bd_chain_paddr[0] = 0xCE5A000
bce1: bce_dma_alloc(): rx_bd_chain_paddr[1] = 0xCE5B000
bce1: bce_dma_alloc(): Creating rx_mbuf_tag (max size = 0x2400 max segments = 1, max segment size = 0x2400)
bce1: Invalid PHY address 0 for PHY read!
bce1: Invalid PHY address 1 for PHY read!
bce1: bce_miibus_read_reg(): phy = 2, reg = 0x0001 (BMSR   ), val = 0x0
bce1: Invalid PHY address 3 for PHY read!
bce1: Invalid PHY address 4 for PHY read!
bce1: Invalid PHY address 5 for PHY read!
bce1: Invalid PHY address 6 for PHY read!
bce1: Invalid PHY address 7 for PHY read!
bce1: Invalid PHY address 8 for PHY read!
bce1: Invalid PHY address 9 for PHY read!
bce1: Invalid PHY address 10 for PHY read!
bce1: Invalid PHY address 11 for PHY read!
bce1: Invalid PHY address 12 for PHY read!
bce1: Invalid PHY address 13 for PHY read!
bce1: Invalid PHY address 14 for PHY read!
bce1: Invalid PHY address 15 for PHY read!
bce1: Invalid PHY address 16 for PHY read!
bce1: Invalid PHY address 17 for PHY read!
bce1: Invalid PHY address 18 for PHY read!
bce1: Invalid PHY address 19 for PHY read!
bce1: Invalid PHY address 20 for PHY read!
bce1: Invalid PHY address 21 for PHY read!
bce1: Invalid PHY address 22 for PHY read!
bce1: Invalid PHY address 23 for PHY read!
bce1: Invalid PHY address 24 for PHY read!
bce1: Invalid PHY address 25 for PHY read!
bce1: Invalid PHY address 26 for PHY read!
bce1: Invalid PHY address 27 for PHY read!
bce1: Invalid PHY address 28 for PHY read!
bce1: Invalid PHY address 29 for PHY read!
bce1: Invalid PHY address 30 for PHY read!
bce1: Invalid PHY address 31 for PHY read!
bce1: /usr/src/sys/dev/bce/if_bce.c(1098): No PHY found on child MII bus!
bce1: bce_miibus_read_reg(): phy = 2, reg = 0x0002, val = 0x0000
PHYID1: 0x0000
bce1: bce_miibus_read_reg(): phy = 2, reg = 0x0003, val = 0x0000
PHYID2: 0x0000
device_attach: bce1 attach returned 6

Best regards
   Oliver

-- 
Oliver Fromme, secnetix GmbH & Co. KG, Marktplatz 29, 85567 Grafing b. M.
Handelsregister: Registergericht Muenchen, HRA 74606,  Geschäftsfuehrung:
secnetix Verwaltungsgesellsch. mbH, Handelsregister: Registergericht Mün-
chen, HRB 125758,  Geschäftsführer: Maik Bachmann, Olaf Erb, Ralf Gebhart

FreeBSD-Dienstleistungen, -Produkte und mehr:  http://www.secnetix.de/bsd

"I made up the term 'object-oriented', and I can tell you
I didn't have C++ in mind."
        -- Alan Kay, OOPSLA '97



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201001191311.o0JDBnT0045509>