Back to Contents Page

User Diagnostics: Broadcom NetXtreme® 57XX User Guide

Introduction

System Requirements

Running Broadcom NetXtreme User Diagnostics

Diagnostic Test Descriptions

Diagnostic Test Messages


Introduction

Broadcom NetXtreme User Diagnostics is an MS-DOS based application that runs a series of diagnostic tests (see Table 3) on the Broadcom NetXtreme Gigabit Ethernet adapter(s) in your computer. Broadcom NetXtreme User Diagnostics also allows you to update device firmware and view and change settings for available adapter properties. Broadcom NetXtreme User Diagnostics can be run in either of the following modes:

In either mode, you can view the version of the adapter software and specify which adapter to test and which tests to perform. The MS-DOS Command Prompt mode is useful for viewing and changing the settings for available properties, updating and loading device firmware, viewing the version of and printing the error log (if any) to a file. The Broadcom CLI mode is useful for enabling/disabling available properties and enabling/disabling/selecting and setting the speed and duplex mode of available protocols.

To run B57udiag, create an MS-DOS 6.22 bootable floppy disk containing the B57udiag.exe file. Next, start the computer with the boot disk in the floppy disk drive. See either Running in MS-DOS Command Prompt Mode or Running in Broadcom Command Line Interface Mode for further instructions.

NOTE: The B57udiag.exe file is on the installation CD.

System Requirements

Operating System: DOS 6.22

Software: b57udiag.exe


Running Broadcom NetXtreme User Diagnostics

Running in MS-DOS Command Prompt Mode

At the MS-DOS prompt, type b57udiag using the command options as shown Table 1.

NOTE: In MS-DOS Command Prompt mode, you must include b57udiag at the beginning of the command string each time you type a command.

Table 1. MS-DOS Command Prompt Mode Command Options

Command Options Description
b57udiag Performs all of the tests on all of the Broadcom NetXtreme 57XX adapters.
b57udiag -c <num> Specifies the adapter to test, or the adapter on which to update the firmware or to view or change the settings for available properties.
b57udiag -cmd Changes to the Broadcom CLI mode.
b57udiag -w <value>

Enables/disables the Wake on LAN (WOL) property.

1 = Enable

0 = Disable

b57udiag -mba <value>

Enables/disables Multi-Boot Agent (MBA) protocol.

1 = Enable

0 = Disable

b57udiag -mbap <value>

Selects the MBA protocol.

0 = Preboot Execution Environment (PXE)

1 = Remote Program Load (RPL)

2 = Boot Protocol (BootP)

b57udiag -mbas <value>

Selects the MBA speed and duplex mode.

0 = Auto

1 = 10 Mbps speed, half-duplex operation

2 = 10 Mbps speed, full-duplex operation

3 = 100 Mbps speed, half-duplex operation

4 = 100 Mbps speed, full-duplex operation

6 = 1000 Mbps speed, full-duplex (fiber)

b57udiag -firm <file> Updates the EEPROM of the selected adapter based on the <file name> image match to the hardware.
b57udiag -firmall <file> Updates the EEPROM of all of the adapters based on the <file name> image match.
b57udiag -ver Displays the version of the software/eeprom.bin file.
b57udiag -pxe <file> Loads the PXE firmware from a file.
b57udiag -elog <file> Prints the error log to a file.
b57udiag -pipmi <file>

Loads the Intelligent Platform Management Interface (IPMI) firmware from a file.

Do not use. Intelligent Platform Management Interface (IPMI) is not supported on this platform.

b57udiag -ipmi <value>

Enables/disables IPMI.

Do not use. Intelligent Platform Management Interface (IPMI) is not supported on this platform.

b57udiag -help Displays this table of MS-DOS Command Prompt Mode Command Options.

Running in Broadcom Command Line Interface Mode

At the MS-DOS prompt, type b57udiag -cmd, and use the command options as shown in Table 2.

Table 2. Broadcom Command Line Interface (CLI) Mode Commands

NOTE: The values for settings are in decimal notation unless otherwise indicated.
Command Description
upgfrm Updates the PXE or Boot Code from a file.
dir Displays the file directory in NVRAM.

Example:

Entry Type SRAM Addr EEP Offset Length Execute Version
  ------------ ----------- ----------- -------- ------- --------------
  BootCode 08003000 00000200 000011B0 CPUA(2) 5705-v3.27
0 PXE 00010000 000013Bo 0000C854 NO 7.0.1
1 ASF CFG 00000000 0001027C 000001D4 NO ASFIPMIc V2.15
2 ASF CPUB C0034000 00010450 00002654 NO ASFIPMIc V2.15
3 ASF CPUA 08000000 00012AA4 000035B4 NO ASFIPMIc V2.15
4 INIT C0034000 00016058 00001A94 CPUB ASFIPMIc V2.15
setwol

Enables/disables the Wake on LAN (WOL) property.

setwol e = Enable WOL

setwol d = Disable WOL

setpxe

Enables/disables Preboot Exchange Environment (PXE) and sets PXE speed.

setpxe e = Enable PXE

setpxe d = Disable PXE

setpxe s 0 = Auto (Default)

setpxe s 1 = 10 Mbps speed, half-duplex operation

setpxe s 2 = 10 Mbps speed, full-duplex operation

setpxe s 3 = 100 Mbps speed, half-duplex operation

setpxe s 4 = 100 Mbps speed,full-duplex operation

setasf

Enables/disables Alert Standard Format (ASF).

Do not use. Alert Standard Format (ASF) is not supported on this platform.

setmba

Enables/disables Multi-boot Agent (MBA) and selects the MBA protocol.

setmba d = Disable MBA

setmba e 0 = Enable Preboot Execution Environment (PXE) MBA (default)

setmba e 1 = Enable Remote Program Load (RPL) MBA

setmba e 2 = Enable Boot Protocol (BootP) MBA

setmba s 0 = Auto speed and duplex (default)

setmba s 1 = 10 Mbps speed, half-duplex operation

setmba s 2 = 10 Mbps speed, full-duplex operation

setmba s 3 = 100 Mbps speed, half-duplex operation

setmba s 4 = 100 Mbps speed, full-duplex operation

setmba s 6 = 1000 Mbps full-duplex (fiber)

setipmi

Enables/disables Intelligent Platform Management Interface (IPMI).

Do not use. Intelligent Platform Management Interface (IPMI) is not supported on this platform.

nictest

Runs the specified diagnostic tests.

Specify which individual test(s) within a group or which group(s) of tests to run by including the test designation or group designation in the command string, as shown in the examples below:

nictest abcd = Run all tests

nictest b = Run all tests in group B

nictest a3b1 = Run tests A3 and B1 only

nictest a124b2 = Run tests A1, A2, A4, and B2

exit Changes from the Broadcom CLI mode to the MS-DOS command prompt mode.
device

Selects the device (adapter).

device <n> = Device number in hexadecimal notation (default = 00000000)

device r = Remove all current Broadcom adapters and rescan available adapters

device s = Silent mode (Broadcom adapters are not displayed)

version Displays the version of the adapter software.
help Displays this list of commands.
reset

Resets the Broadcom NetXtreme Gigabit Ethernet adapter chip.

reset c = Simulate a cold reset

reset w = Wait for firmware signature

reset t = Display the time from reset to firmware invert signature

cls Clears the screen.
asfprg

Loads Alert Standard Format (ASF) firmware into NVRAM.

Do not use. Alert Standard Format (ASF) is not supported on this platform.


Diagnostic Test Descriptions

The diagnostic tests are divided into 4 groups: Register Tests (Group A), Memory Tests (Group B), Miscellaneous Tests (Group C), and Driver Associated Tests (Group D). The diagnostic tests are listed and described in Table 3.

Table 3. Diagnostic Tests

Test Description
Number Name
Group A: Register Tests
A1 Indirect Register This test uses an indirect addressing method to write an increment of data to the MAC hash register table and read back data for verification. The memory read/write is done 100 times while incrementing test data.
A2 Control Register

Each register specified in the configuration content defines the read-only bit and the read/write bits. The test writes 0s and 1s to the test bits to ensure the read-only bits are not changed, and that read/write bits are changed.

This test attempts to read the register configuration file (Ctrlreg.txt) for the register definitions. If the file does not exist, a default register offset and mask bits are used.

Offset Read-Only Mask Read/Write Mask
0x00000400 0x00000000 0x007FFF8C
0x00000404 0x03800107 0x00000000
A3 Interrupt This test verifies the interrupt functionality. It enables an interrupt and waits 500 ms for the interrupt to occur and reports an error if it cannot generate the interrupt.
A4 Built-In Self-Test This is the hardware built-in self-test (BIST).
A5 PCI Cfg Register This test verifies the access integrity of the PCI configuration registers.
Group B: Memory Tests
B1
Scratch Pad

This test tests the onboard scratchpad SRAM. The following tests are performed:

Address Test: This test writes each address with a unique increment of data and reads back data to ensure data is correct. After filling the entire address with the unique data, the program reads back the data again to ensure that the data is still correct.

Walking bit. For each address, data one is written and read back for testing. Then it shifts the data left one bit, so the data becomes two and repeats the same test. It repeats the test 32 times until the test bit is shifted out of the test address. The same test is repeated for entire test range.

Pseudo-Random Data. A precalculated pseudo-random data set is used to write unique data to each test RAM. After passing the test, the program reads back the data one more time to ensure that the data is still correct.

Data Read/Write Test: This test writes test data to the SRAM and reads it back to ensure that the data is correct. The test data used is 0x00000000, 0xFFFFFFFF, 0xAA55AA55, and 0x55AA55AA.

Alternate Data Pattern Test: This test writes test data into the SRAM, writes complement test data to the next address, and reads back both to ensure the data is correct. After the test, the program reads back data one more time to ensure that the data is still correct. The test data used is 0x00000000, 0xFFFFFFFF, 0xAA55AA55, and 0x55AA55AA.

B2 BD SRAM This test tests the Buffer Descriptor (BD) SRAM. This test performs in the same way as the Scratch Pad Test described in B1.
B3 DMA SRAM This test tests the direct memory access (DMA) SRAM by performing the Scratch Pad Test described in test B1.
B4 MBUF SRAM This test tests the memory access buffer (MBUF) SRAM by performing the Scratch Pad Test described in test B1.
B5 MBUF SRAM via DMA

This test uses 8 data test patterns. A 0x1000-sized data buffer is used for this test. Before each pattern test, the buffer is initialized and filled with the test pattern. It then performs a 0x1000-sized transmit DMA from the host buffer to the adapter MBUF memory.

The test verifies the data integrity in the adapter MBUF memory against the host memory and repeats the DMA for the entire MBUF buffer. Then, the test performs a receive DMA from the adapter to the host. The 0x1000-byte test buffer is cleared to 0 before each receive DMA. After the test verifies the integrity of the data, the test is repeated for the entire MBUF SRAM range. The 8 test patterns are described below.

Test Pattern Description
16 00s and 16 FF's Fills the entire host DMA buffer with 16 bytes of 00s and then 16 bytes of FF's.
16 FF's and 16 00s Fills the entire host DMA buffer with 16 bytes of FF's and then 16 bytes of 00s.
32 00s and 32 FF's Fills the entire host DMA buffer with 32 bytes of 00s and then 32 bytes of FF's.
32 FF's and 32 00s Fills the entire host DMA buffer with 32 bytes of FF's and then 32 bytes of 00s.
00000000 Fills the entire host DMA buffer with all 00s.
FFFFFFFF Fills the entire host DMA buffer with all FF's.
AA55AA55 Fills the entire host DMA buffer with data 0xAA55AA55.
55AA55AA Fills the entire host DMA buffer with data 0x55AA55AA.
B7 CPU GPR This test tests the CPU General Purpose registers and performs in the same way as the Scratch Pad Test (B1) over 3 different voltages (1.1V, 1.2V, and 1.3V).
Group C: Miscellaneous Tests
C1 NVRAM Incremental test data is used in the electrically erasable programmable read-only memory (EEPROM) test. The test fills the test range with test data and reads the data back to verify the content. Afterwards, the test fills the test range with 0s to clear the memory.
C2 CPU This test opens the Cpu.bin file. If the file exists and content is good, the test loads code to the RX CPU and TX CPU and verifies the CPU execution.
C3 DMA This test tests both high-priority direct memory access (DMA) and low-priority DMA. The test moves data from the host memory to the adapter SRAM and verifies the data. The test then moves data back to the host memory to again verify the data.
C4 MII

The medium independent interface (MII) test function is identical to that of the Control Register Test (A2). Each register specified in the configuration contents defines the read-only and read/write bits. The test writes 0s and 1s to the test bits to ensure that the read-only bit values are not changed and that the read/write bits are changed.

The test attempts to read the register configuration file (Miireg.txt) for the register definitions. If the file does not exist, the following table is used:

Offset Read-Only Mask Read/Write Mask

0x00

0x0000

0x7180

0x02

0xFFFF

0x0000

0x03

0xFFFF

0x0000

0x04

0x0000

0xFFFF

0x05

0xEFFF

0x0000

0x06

0x0001

0x0000

0x07

0x0800

0xB7FF

0x08

0xFFFF

0x0000

0x09

0x0000

0xFF00

0x0A

0x7C00

0x0000

0x10

0x0000

0xFFBF

0x11

0x7C00

0x0000

0x19

0x7C00

0x0000

0x1E

0x0000

0xFFFF

0x1F

0x0000

0xFFFF

C5 VPD The VPD test first saves the contents of the vital product data (VPD) memory before performing the test. The test then writes 1 of the 5 test data patterns (0xFF, 0xAA, 0x55, increment data, or decrement data) into VPD memory. By default, an incremental data pattern is used. The test writes and reads back the data for the entire test range, and then restores the original contents of the VPD memory.
C6 ASF Hardware

Reset Test. This test sets the reset bit and polls for self-clearing bits. This test verifies the reset value of the registers.

Event Mapping Test. This test sets the SMB_ATTN bit. By changing ASF_ATTN_ LOC bits, the test verifies the mapping bits in TX_CPU or RX_CPU event bits.

Counter Test

  • Clears WG_TO, HB_TO, PA_TO, PL_TO, RT_TO bits (by setting the bits) and ensures that the bits clear.
  • Clears the timestamp counter. Writes a 1 to each of the PL, PA, HB, WG, RT counters. Sets the TSC_EN bit.
  • Polls each PA_TO bit and counts up to 50. Checks if the PL_TO bit is set at the end of the count to 50. Continues to count up to 200. Checks if all other TO bits are set and verifies if the timestamp counter is incremented.
C7 Expansion ROM This test tests the ability to enable, disable, and access the expansion read-only memory (ROM) on the adapter.
Group D: Driver Associated Tests
D1 MAC Loopback This test is an internal loopback data transmit/receive test. It initializes the medium access control (MAC) into an internal loopback mode and transmits 100 packets. The data should be routed back to the receive channel and received by the receive routine, which verifies the integrity of data. A 100-Mbit/s data rate is used for this test unless Gigabit Ethernet is enabled.
D2 PHY Loopback This test is same as the MAC loopback test (D1), except that the data is routed back via a physical layer device (PHY). A 100-Mbit/s data rate is used for this test unless Gigabit Ethernet is enabled.
D5 MII Miscellaneous This test tests the autopolling and PHY interrupt capabilities. These are functions of the PHY.
D6 MSI This test tests the message signal interrupt (MSI) capability of the adapter. Refer to PCI Specification, version 2.3, for the MSI definition.

Diagnostic Test Messages

/* 0 */ 	"PASS",
 
/* 1 */ 	"Got 0x%08X @ 0x%08X. Expected 0x%08X",
 
/* 2 */ 	"Cannot perform task while chip is running",
 
/* 3 */ 	"Invalid NIC device",
 
/* 4 */ 	"Read-only bit %s got changed after writing zero at offset 0x%X",
 
/* 5 */ 	"Read-only bit %s got changed after writing one at offset 0x%X",
 
/* 6 */ 	"Read/Write bit %s did not get cleared after writing zero at offset 0x%X",
 
/* 7 */ 	"Read/Write bit %s did not get set after writing one at offset 0x%X",
 
/* 8 */ 	"BIST failed",
 
/* 9 */ 	"Could not generate interrupt",
 
/* 10 */ 	"Aborted by user",
 
/* 11 */ 	"TX DMA:Got 0x%08X @ 0x%08X. Expected 0x%08X",    
 
/* 12 */ 	"Rx DMA:Got 0x%08X @ 0x%08X. Expected 0x%08X",    
 
/* 13 */ 	"TX DMA failed",
 
/* 14 */ 	"Rx DMA failed",
 
/* 15 */ 	"Data error, got 0x%08X at 0x%08X, expected 0x%08X",
 
/* 16 */ 	"Second read error, got 0x%08X at 0x%08X, expected 0x%08X",
 
/* 17 */ 	"Failed writing EEPROM at 0x%04X",
 
/* 18 */ 	"Failed reading EEPROM at 0x%04X",
 
/* 19 */ 	"EEPROM data error, got 0x08X at 0x04X, expected 0x%08X",
 
/* 20 */ 	"Cannot open file %s",
 
/* 21 */ 	"Invalid CPU image file %s",
 
/* 22 */ 	"Invalid CPU image size %d",
 
/* 23 */ 	"Cannot allocate memory",
 
/* 24 */ 	"Cannot reset CPU",    
 
/* 25 */ 	"Cannot release CPU", 
 
/* 26 */ 	"CPU test failed",       
 
/* 27 */ 	"Invalid Test Address Range\nValid NIC address is 0x%08X-0x%08X and exclude 0x%08X-0x%08X",
 
/* 28 */  "DMA:Got 0x%08X @ 0x%08X. Expected 0x%08X", 
 
/* 29 */  "Unsupported PhyId %04X:%04X",
 
/* 30 */  "Too many registers specified in the file, max is %d",
 
/* 31 */ 	"Cannot write to VPD memory",
 
/* 32 */ 	"VPD data error, got %08X @ 0x04X, expected %08X",
 
/* 33 */ 	"No good link! Check Loopback plug",
 
/* 34 */ 	"Cannot TX Packet!", 
 
/* 35 */ 	"Requested to TX %d. Only %d is transmitted",       
 
/* 36 */	"Expected %d packets. Only %d good packet(s) have been received\n%d unknown packets have been received.\n%d bad packets have been received.",
 
/* 37 */ 	"%c%d is an invalid Test",
 
/* 38 */ 	"EEPROM checksum error",
 
/* 39 */ 	"Error in reading WOL/PXE",
 
/* 40 */ 	"Error in writing WOL/PXE",
 
/* 41 */ 	"No external memory detected",
 
/* 42 */ 	"DMA buffer %04X is large, size must be less than %04X",  
 
/* 43 */ 	"File size %d is too big, max is %d",
 
/* 44 */ 	"Invalid %s",
 
/* 45 */ 	"Failed writing 0x%x to 0x%x",
 
/* 46 */ 	"",
 
/* 47 */ 	"Ambiguous command",
 
/* 48 */ 	"Unknown command",
 
/* 49 */ 	"Invalid option",
 
/* 50 */ 	"Cannot perform task while chip is not running. (need driver)",
 
/* 51 */ 	"Cannot open register define file or content is bad",
 
/* 52 */ 	"ASF Reset bit did not self-clear",
 
/* 53 */ 	"ATTN_LOC %d cannot be mapped to %cX CPU event bit %d",
 
/* 54 */ 	"%s Register is not cleared to zero after reset",
 
/* 55 */ 	"Cannot start poll_ASF Timer",
 
/* 56 */ 	"poll_ASF bit did not get reset after acknowledged",
 
/* 57 */ 	"Timestamp Counter is not counting",
 
/* 58 */ 	"%s Timer is not working",
 
/* 59 */ 	"Cannot clear bit %s in %cx CPU event register",
 
/* 60 */ 	"Invalid "EEPROM_FILENAME" file size, expected %d but only can read %d bytes",
 
/* 61 */ 	"Invalid magic value in %s, expected %08x but found %08x",
 
/* 62 */ 	"Invalid manufacture revision, expected %c but found %c",
 
/* 63 */ 	"Invalid Boot Code revision, expected %d.%d but found %d.%d",
 
/* 64 */ 	"Cannot write to EEPROM",
 
/* 65 */ 	"Cannot read from EEPROM",
 
/* 66 */ 	"Invalid Checksum",
 
/* 67 */ 	"Invalid Magic Value",
 
/* 68 */ 	"Invalid MAC address, expected %02X-%02X-%02X-%02X-%02X-%02X",
 
/* 69 */ 	"Slot error, expected an UUT to be found at location %02X:%02X:00",
 
/* 70 */ 	"Adjacent memory has been corrupted while testing block 0x%08x-0x%08x\nGot 0x%08x @ address 0x%08x. Expected 0x%08x",
 
/* 71 */ 	"The function is not Supported in this chip",
 
/* 72 */ 	"Packets received with CRC error",
 
/* 73 */ 	"MII error bits set: %04x",
 
/* 74 */ 	"CPU does not initialize MAC address register correctly",
 
/* 75 */ 	"Invalid firmware file format",
 
/* 76 */ 	"Resetting TX CPU Failed",
 
/* 77 */ 	"Resetting RX CPU Failed",
 
/* 78 */ 	"Invalid MAC address",
 
/* 79 */ 	"Mac address registers are not initialized correctly",
 
/* 80 */ 	"EEPROM Bootstrap checksum error",

Back to Contents Page