# digital

# Using the Digital Semiconductor 21041 with Boot ROM, Serial ROM, and External Register:

# An Application Note

Order Number: EC-QJLGB-TE

This application note provides information necessary to implement connections between the Digital Semiconductor 21041 Ethernet LAN Controller and boot ROM, serial ROM, and external register. It also describes a connection of several chips sharing one serial ROM and the format of the serial ROM programming.

**Revision/Update Information:** 

This document supersedes the Using the DECchip 21041 with Boot ROM, Serial ROM, and External Register: An Application Note (EC–QJLGA–TE).

Digital Equipment Corporation Maynard, Massachusetts

## **Important Notice**

As of May 17, 1998, Digital Equipment Corporation's StrongARM, PCI Bridge, and Networking component businesses, along with the chip fabrication facility in Hudson, Massachusetts, were acquired by Intel Corporation and transferred to Intel Massachusetts, Inc. As a result of this transaction, certain references to web sites, telephone numbers, and fax numbers have changed in the documentation. This information will be updated in the next version of this manual. Copies of documents that have an ordering number and are referenced in this document, or other Intel literature may be obtained by calling **1-800-332-2717** or by visiting Intel's website for developers at:

#### http://developer.intel.com

The Intel Massachusetts Customer Technology Center continues to service your StrongARM Product, Bridge Product, and Network Product technical inquiries. Please use the following information lines for support:

| For documentation and general informa   | tion:             |  |
|-----------------------------------------|-------------------|--|
| Intel Massachusetts Information Line    |                   |  |
| United States:                          | 1-800-332-2717    |  |
| Outside United States:                  | 1-303-675-2148    |  |
| Electronic mail address:                | techdoc@intel.com |  |
|                                         |                   |  |
| For technical support:                  |                   |  |
| Intel Massachusetts Customer Technologi | ogy Center        |  |
| Phone (U.S. and international):         | 1-978-568-7474    |  |
| Fax:                                    | 1-978-568-6698    |  |
| Electronic mail address:                | techsup@intel.com |  |

#### February 1996

While Digital believes the information included in this publication is correct as of the date of publication, it is subject to change without notice.

© Digital Equipment Corporation 1995, 1996. All rights reserved.

Digital, Digital Semiconductor, ThinWire, VAX DOCUMENT, and the DIGITAL logo are trademarks of Digital Equipment Corporation.

Digital Semiconductor is a Digital Equipment Corporation business.

IEEE is a registered trademark of The Institute of Electrical and Electronics Engineers, Inc. MicroWire is a registered trademark of BankAmerica Corporation.

All other trademarks and registered trademarks are the property of their respective owners.

This document was prepared using VAX DOCUMENT Version 2.1.

## Contents

| Overview                                            | 1                   |
|-----------------------------------------------------|---------------------|
| Functional Overview                                 | 1                   |
| Connection to Boot ROM                              | 2                   |
| Connection to Serial ROM                            | 3                   |
| Single Digital Semiconductor 21041 Connection       | 3                   |
| Multiple Digital Semiconductor 21041 Connection     | 3                   |
| External Register Connection                        | 5                   |
| Configuration of External Register Without Boot ROM | 5                   |
| Configuration of External Register with Boot ROM    | 7                   |
| Serial ROM Programming                              | 8                   |
|                                                     | Functional Overview |

## A Serial ROM Access — Software Description

## **B** Serial ROM CRC Calculation

| С | ID B | lock | CRC | Ca | lcu | lation |
|---|------|------|-----|----|-----|--------|
|---|------|------|-----|----|-----|--------|

## D Technical Support and Ordering Information

| D.1 | Obtaining Technical Support               | D–1 |
|-----|-------------------------------------------|-----|
|     | Ordering Digital Semiconductor Products   | D–1 |
| D.3 | Ordering Digital Semiconductor Literature | D–1 |
| D.4 | Ordering Third-Party Literature           | D–2 |

## Figures

| 1  | Boot ROM (256KB) Connection                               | 2  |
|----|-----------------------------------------------------------|----|
| 2  | Serial ROM (1024-Bit) Connection                          | 3  |
| 3  | Four Chips Sharing One Serial ROM                         | 4  |
| 4  | External Register Connection—Write Only (No Boot ROM)     | 5  |
| 5  | External Register Connection—Read Only (No Boot ROM)      | 6  |
| 6  | External Register Connection—Read and Write with Boot ROM | 7  |
| 7  | Serial ROM Structure                                      | 8  |
| 8  | Info Leaf Format                                          | 11 |
| 9  | Media Block Format                                        | 12 |
| 10 | Media-Specific Data Format                                | 13 |

## Tables

| 1 | Boot ROM, Serial ROM, and External Register Interface Pins | 1  |
|---|------------------------------------------------------------|----|
| 2 | Serial ROM Field Description                               | 9  |
| 3 | Info Leaf Description                                      | 11 |
| 4 | Media Block Description                                    | 12 |

#### **1** Overview

The information contained in this application note describes how to connect the Digital Semiconductor 21041 Ethernet LAN Controller (21041) to its boot ROM, serial ROM, and external register peripheral devices. Note that connection to either a boot ROM or to an external register is not a requirement for correct operation of the controller. You can use any combination of these connections.

The programming information supplied in this application note applies to device drivers supplied by Digital Semiconductor.

For detailed technical product requirements, the product developer should refer to the *Digital Semiconductor 21041 PCI Ethernet LAN Controller Data Sheet* and the *Digital Semiconductor 21041 PCI Ethernet LAN Controller Hardware Reference Manual.* 

## **2** Functional Overview

The 21041 allows connection to an upgradable boot ROM (flash or EPROM) of 64KB, 128KB, or 256KB. The boot ROM typically contains code that can be executed for device-specific initialization and, possibly, a system boot function.

The 21041 also supports connection to the serial ROM for read and write operations. The serial ROM contains the IEEE address and other optional system parameters.

Connection to a general-purpose external register can be done for read and write operations. This connection allows a general-purpose bidirectional port for various applications.

The 21041 provides a 12-pin interface for all the connections described in this application note. The access control to the different devices is done by software using CSR9 and CSR10.

Table 1 lists the 12 interface signals and their function in each connection.

| Signal              | Pin<br>Number | Boot ROM                                                | Function<br>Serial ROM | External Register                     |
|---------------------|---------------|---------------------------------------------------------|------------------------|---------------------------------------|
| br_ad<6:0>          | 113:119       | Address and<br>data lines,<br><b>we_l, oe_l</b>         | Not used               | Data lines                            |
| br_ad<7>/sr_din     | 93            | Address and data line                                   | Serial ROM<br>data in  | Data line bit 7                       |
| br_a<1>/sr_sk       | 80            | Address bit 1,<br>latch control for<br>external latches | Serial ROM<br>clock    | Not used                              |
| br_a<0>/sr_dout     | 79            | Address bits 16, 17, and 0                              | Serial ROM<br>data out | Read and write control                |
| mode_select/br_ce_l | 91            | Chip enable<br>control                                  | Not used               | Chip enable or read and write control |
| sr_cs               | 81            | Not used                                                | Chip select            | Not used                              |

Table 1 Boot ROM, Serial ROM, and External Register Interface Pins

## **3** Connection to Boot ROM

Figure 1 shows a connection of a 256KB flash boot ROM. The required components for this configuration are:

- Two 9-bit high edge-triggered latches (74FCT823)
- Flash ROM chip (28F020)

Figure 1 Boot ROM (256KB) Connection



LJ-04381.AI5

## 4 Connection to Serial ROM

The following sections describe connections to the serial ROM.

#### 4.1 Single Digital Semiconductor 21041 Connection

Figure 2 shows a connection between a single Digital Semiconductor 21041 and a MicroWire 1024-bit serial EEPROM. No additional components are needed for this connection.





LJ-04382.AI4

#### 4.2 Multiple Digital Semiconductor 21041 Connection

It is possible that one serial ROM device can be shared by multiple 21041 devices. For support, the serial ROM should contain specific information for each one of the chips. Section 6, Serial ROM Programming, provides the required details.

Figure 3 shows a connection of four 21041 chips sharing a single MicroWire 1024-bit serial EEPROM. The required components for this configuration are:

- Dual 4-input multiplexer chip (74F153)
- Quad 2-input OR gate chip (74F32)
- Serial ROM chip

This configuration assumes that:

- One 21041 will not try to access its boot ROM (or external register) while another 21041 has serial ROM access.
- Two 21041 chips will not have simultaneous access to the serial ROM.



#### Figure 3 Four Chips Sharing One Serial ROM

LJ-04383.AI4

## **5 External Register Connection**

This section describes two configuration types for using the general-purpose 8-bit external register.

- A minimum configuration without boot ROM and using the external register port in one direction only.
- A maximum configuration with boot ROM, using the external register as a bidirectional port.

#### 5.1 Configuration of External Register Without Boot ROM

This configuration assumes that boot ROM is not used, and the general-purpose external register is used for read-only or write-only operations.

Figure 4 shows a minimum type of configuration that uses the external register for write operations only.

#### Figure 4 External Register Connection—Write Only (No Boot ROM)



LJ-04384.AI4

Figure 5 shows a configuration that uses the external register for read operations only. Data read by the 21041 should be driven constantly on the 74FCT244 outputs.



Figure 5 External Register Connection—Read Only (No Boot ROM)

LJ-04385.AI4

#### 5.2 Configuration of External Register with Boot ROM

This connection assumes that both the external register and the boot ROM are used by the 21041. This connection also allows read and write accesses to the external register, making it a bidirectional general-purpose port. Note that Figure 1 shows the boot ROM connection.

Figure 6 describes the connection of the external register used for read and write operations with the boot ROM included on the adapter. The required components for this configuration are:

- 1-of-8 decoder
- Octal latched transceiver (3-state).





LJ-04386.AI4

#### 6 Serial ROM Programming

The definition for serial ROM programming that is described in this section supports multiple chips on a single board sharing a single serial ROM. It is applicable for Digital-supplied device drivers.

\_ Note

To optimize the ROM space usage, byte fields are used. Because the serial ROM supports only word accesses, Digital recommends that you first download the entire ROM into a memory shadow table.

Figure 7 shows the structure of the serial ROM, and Table 2 describes the byte fields.



#### Figure 7 Serial ROM Structure

LJ04873B.AI5

| Field                | Size (Bytes) | Definition                                                                                                                                                                                                                                                                                                                                           |
|----------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Subsystem Vendor ID  | 2            | Subsystem vendor ID of this adapter. Uniquely<br>identifies the adapter, distinguishing it from<br>other adapters, based on the 21041 chip. See<br>PCI specification.                                                                                                                                                                                |
| Subsystem ID         | 2            | Subsystem ID of this adapter. Uniquely<br>identifies the adapter, distinguishing it from<br>other adapters, based on the 21041 chip. See<br>PCI specification.                                                                                                                                                                                       |
| ID_reserved1         | 12           | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| ID_BLOCK_CRC         | 1            | CRC8 of the ID block, calculated on<br>word[0]word[8], inclusive. This includes<br>the ID_reserved2 field. See Appendix C.                                                                                                                                                                                                                           |
| ID_reserved2         | 1            | Reserved.                                                                                                                                                                                                                                                                                                                                            |
| SROM format version  | 1            | SROM format version. Current version is 0x03.                                                                                                                                                                                                                                                                                                        |
| Chip_count (n)       | 1            | Number of chips sharing this ROM. A single port board will have a value of 1 in this field.                                                                                                                                                                                                                                                          |
| IEEE network address | 6            | This is the IEEE address of the chip in a single chip board.                                                                                                                                                                                                                                                                                         |
|                      |              | In a multiple chip board, this is the base IEEE address. Every chip (0 <i>n</i> ) adds its index ( <i>n</i> ) to this base IEEE address.                                                                                                                                                                                                             |
| Chip_n device_number | 1            | There is one such field per chip sharing the SROM.                                                                                                                                                                                                                                                                                                   |
|                      |              | In a multiple chip board, this field contains the Device_Number value by which the <i>n</i> th chip's configuration space can be accessed on this board's secondary PCI bus. This value depends on the hardware routing of the board. The Device_Number is the <i>chip select</i> line routed from this chip to the PCI-to-PCI bridge chip on board. |
|                      |              | In a single chip board, this field has no meaning and should be ignored by the driver.                                                                                                                                                                                                                                                               |
| Chip_n info          | 2            | Byte offset (from beginning of SROM) where $chip_n$ info block is located. There is one such field per chip sharing the SROM.                                                                                                                                                                                                                        |
|                      |              | <b>Note:</b> If multiple chips have identical information blocks, a single leaf can be shared and all leaf pointers can be set to point to it. This is correct only if the user cannot select between multiple media ports for each chip (see the following details).                                                                                |
|                      |              | For example: A 4-TP port card can share one info block for all 4 chips.                                                                                                                                                                                                                                                                              |
| Reserved             | 1            | MBZ.                                                                                                                                                                                                                                                                                                                                                 |
|                      |              | Note that the location of this field depends on the number of chips supported by this card.                                                                                                                                                                                                                                                          |
|                      |              | (continued on next page)                                                                                                                                                                                                                                                                                                                             |
|                      |              |                                                                                                                                                                                                                                                                                                                                                      |

#### Table 2 Serial ROM Field Description

| Field                    | Size (Bytes)      | Definition                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip_ <i>n</i> info leaf | Chip<br>dependent | Chip-specific information. See Figure 8 and Table 3 for details.                                                                                                                                                                                                                                                                                                           |
| Manufacturer_reserved    | 2                 | This field is reserved for the adapter<br>manufacturers' use. Standard drivers do<br>not make use of this field. This field is always<br>located in the two bytes preceding the SROM_<br>CRC. When manufacturer-specific data is more<br>than two bytes, this field can be used as a<br>pointer to the data. When not used, this field<br>must be filled with zeros (MBZ). |
| SROM_CRC                 | 2                 | Is calculated on all the words of the SROM from word[0] to the word before the CRC (word[SROM_word_size -2]).                                                                                                                                                                                                                                                              |
|                          |                   | The CRC word is derived by calculating the CRC32 of all the SROM until the last word (not including it) and taking the two least significant bytes of the result. The bytes are written in little endian. The functional definition is in Appendix B.                                                                                                                      |

 Table 2 (Cont.)
 Serial ROM Field Description

Figure 8 shows the info leaf format, and Table 3 describes the byte fields.

#### Figure 8 Info Leaf Format



LJ-04388.AI5

Table 3 Info Leaf Description

| Field                    | Size (Bytes)       | Meaning                                                                                                                                                                                                                                                                                                               |
|--------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Selected connection type | 2                  | Usually, the connection type used by the<br>chip is selected by the user in the drivers'<br>configuration files. However, this field has<br>been provided to allow setup utilities that are<br>unable to modify the configuration files and<br>save this information in the SROM instead.<br>The possible values are: |
|                          |                    | 0x0000 - TP<br>0x0100 - TP with autonegotiation<br>0x0204 - TP full-duplex<br>0x0400 - TP without LinkPass test<br>0x0001 - BNC<br>0x0002 - AUI<br>0x0800 - AutoSense<br>0x0900 - AutoSense with autonegotiation                                                                                                      |
|                          |                    | If this field is not used, it must be set to<br>0xFFFF. Any other value is invalid and may<br>cause unpredictable results.                                                                                                                                                                                            |
| Media count (k)          | 1                  | The number of media blocks present for this chip.                                                                                                                                                                                                                                                                     |
| Media_k block            | Media<br>dependent | Describes one supported medium. There is one<br>such field per supported medium. See details<br>in Figure 9 and Table 4.                                                                                                                                                                                              |

Figure 9 shows the media block format, and Table 4 describes the byte fields.

#### Figure 9 Media Block Format



LJ-04389.AI5

| Field                  | Size    | Meaning                                                                                                                                                                                                                                              |
|------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Media code             | 6 bits  | Indicates to the driver that this medium is supported by the chip.                                                                                                                                                                                   |
|                        |         | Possible values are:                                                                                                                                                                                                                                 |
|                        |         | 00H - TP<br>01H - BNC<br>02H - AUI<br>04H - TP Full-Duplex                                                                                                                                                                                           |
| EXT                    | 1 bit   | When set to 1, indicates that the lower 16 bits of CSRs 13 through 15 (SIA registers) will be set via the SROM, and not by using the internal default values for this media type. The SIA setting values are given by the media-specific data field. |
| Reserved               | 1 bit   | Reserved.                                                                                                                                                                                                                                            |
| Media-specific<br>data | 6 bytes | Media-specific data. This field exists only when<br>the EXT bit is set. This field provides the values<br>of CSR13, CSR14, and CSR15 (Figure 10) to use<br>instead of the driver internal defaults for this<br>media type.                           |

#### Table 4 Media Block Description

Figure 10 shows the media-specific data format.

## Figure 10 Media-Specific Data Format

| 15 |              | 00 |
|----|--------------|----|
|    | CSR13 <15:0> |    |
|    | CSR14 <15:0> |    |
|    | CSR15 <15:0> |    |

LJ-04390.AI5

Α

## Serial ROM Access — Software Description

This appendix provides software code for both serial ROM read and write accesses. The routines that follow are written for the 39LC46B serial ROM device. Some modifications to the code may be required when supporting other devices.

```
** Constants, variables, functions prototypes & definitions.
* /
#define SROM_93LC46B_LAST_ADDRESS 0x3F
#define SROM_93LC46B_LAST_ADDRESS_BIT
                                           5
#define CSR9_READ 0x4000
#define CSR9 WRITE 0x2000
#define SEL_SROM 0x0800
#define DATA_1
                 0x0004
#define DATA_0
                 0x0000
#define CLK
                     0x0002
            0x0001
#define CS
enum WIDTH {Byte,Word,Dword};
#define Byte
                0
#define Word
               1
#define Dword
               2
typedef unsigned char
                       BYTE;
typedef unsigned short WORD;
typedef unsigned long DWORD;
#define FALSE
                0
#define TRUE
               1
void In32Bits(WORD port number, enum WIDTH width, DWORD *ret val);
void Out32Bits(WORD port_number, enum WIDTH width, DWORD value);
void Delay800nSec(void); /* Minimum time of clock high and clock low we apply
    ** to SROM. The 93LC46B device requires a minimum of
   ** 250nSec.
    */
WORD CSR9; /* Address of DC21140/DC21041 CSR9 in I/O space.
  ** This address is filled after locating DC21140/DC21041.
  */
```

```
/*
* *
    WriteCommandEWEN
**
     _____
**
* *
    Operation:
**
        Writes the Erase/Write Enable instruction to the serial ROM.
**
       This enables writing to the serial ROM.
*/
void WriteCommandEWEN(void)
WORD i;
 /*
 ** Write the EWEN command to enable write/erase commands
*/
                                     SEL_SROM |
Out32Bits(CSR9, Dword, CSR9_WRITE
                                               CS
                                                           DATA_1);
Out32Bits(CSR9, Dword, CSR9_WRITE
                                    SEL_SROM CS
                                                   CLK | DATA_1);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                           DATA 1);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9 WRITE
                                     SEL SROM
                                               CS
                                                           DATA 0);
Out32Bits(CSR9, Dword, CSR9_WRITE
                                    SEL_SROM | CS
                                                     CLK | DATA_0);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                           DATA 0);
Delay800nSec();
                                     SEL_SROM
Out32Bits(CSR9, Dword, CSR9_WRITE
                                               CS
                                                           DATA 0);
Out32Bits(CSR9, Dword, CSR9 WRITE
                                               CS | CLK | DATA 0);
                                    SEL SROM
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                           DATA_0);
Delay800nSec();
for (i=0; i<5; i++)
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM
                                                     CS
                                                                DATA_1);
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_1);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                DATA 1);
     Delay800nSec();
     }
Out32Bits(CSR9, Dword, CSR9_WRITE |
                                    SEL_SROM
                                               CS
                                                           DATA_1);
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_1);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM |
                                                           DATA 1);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9_WRITE
                                     SEL_SROM | CS );
Out32Bits(CSR9, Dword, CSR9_WRITE
                                    SEL_SROM | CS | CLK);
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS );
Delay800nSec();
Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM);
Delay800nSec();
}
```

```
/*
     WriteCommandEWDS
* *
     ------
**
**
     Operation:
* *
        Writes the Erase/Write Disable instruction to the serial ROM.
**
        This disables writing to the serial ROM.
*/
void WriteCommandEWDS(void)
WORD i;
 /*
 ** Write the EWDS command to disable write/erase commands
 */
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | DATA_1);
Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_1);
 Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                              DATA_1);
 Delay800nSec();
 for (i=0; i<7; i++)</pre>
      Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM |
                                                        CS
                                                                   DATA_0);
      Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_0);
      Delay800nSec();
      Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                   DATA_0);
      Delay800nSec();
     }
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS
                                                              DATA_0);
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_0);
 Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM |
                                                              DATA 0);
Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9_WRITE
                                       SEL_SROM | CS );
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK);
 Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS );
Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM);
Delay800nSec();
}
```

```
/*
    WriteSROM
**
     _____
**
**
    Operation:
**
       Writes the contents of a buffer to the SROM, word by word.
**
* *
    Input:
**
       ROM Address: Offset in SROM. Is auto incremented after write.
**
        It is number of WORD to which Data is written.
**
       Len:
                    Length in words.
* *
       Data:
                    Pointer to data buffer to write.
**
* *
    Output:
**
        If an error occurs, error message is printed.
**
**
    Return value:
**
       FALSE if an error occurs.
*/
int WriteSROM(WORD *ROM Address, WORD Len, WORD *Data)
WORD i, j;
DWORD Dbit;
DWORD Dout;
WORD ROM_WordAddress;
WORD WordData;
ROM_WordAddress = *ROM_Address;
/*
** Make sure the ROM_Address is not too big for this ROM
*/
if (ROM WordAddress + Len - 1 > SROM 93LC46B LAST ADDRESS)
    printf("Address or data length is too big for SROM\n");
    return(FALSE);
WriteCommandEWEN();
 /*
** Loop on all DATA words.
*/
for (j=0; j<Len; j++)</pre>
      /*
      ** Output the WRITE command to the SROM
      * /
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL SROM
                                                      CS
                                                                 DATA 1);
                                                     CS | CLK | DATA 1);
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                 DATA_1);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM
                                                     CS
                                                                 DATA_0);
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_0);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                 DATA 0);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM
                                                      CS
                                                                 DATA_1);
      Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM
                                                     CS |
                                                          CLK | DATA_1);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                 DATA_1);
     Delay800nSec();
```

```
** Output the WORD Address of the SROM
    */
   for (i=0; i<=SROM_93LC46B_LAST_ADDRESS_BIT; i++)</pre>
 Dbit = (DWORD)((ROM_WordAddress >> (SROM_93LC46B_LAST_ADDRESS_BIT-i)) & 1) << 2;
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                             Dbit);
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | Dbit);
 Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                             Dbit);
 Delay800nSec();
    /*
    ** Output the WORD of data to the SROM
    */
   WordData = *Data;
   for (i=0; i<=15; i++)</pre>
 Dbit = (DWORD)((WordData >> (15-i)) & 1) << 2;</pre>
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                             Dbit);
 Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | Dbit);
 Delay800nSec();
 Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM | CS |
                                                             Dbit);
 Delay800nSec();
}
    /*
    ** Point at next user buffer address
    */
   Data++;
    /*
    ** Point at next SROM Address
    */
   ROM WordAddress++;
    /*
    ** Negate the CS (chip select) to start the SROM write
    */
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM);
   Delay800nSec();
    /*
    ** Set the CS to continue the SROM write
    */
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS
                                                           );
    /*
    ** Verify that the SROM is in BUSY state by reading the Dout, if Dout=0.
    */
   In32Bits(CSR9, Dword, &Dout);
   Dout = (Dout>>3) & 1;
   if (Dout != 0)
{
printf("SROM did not become busy in write command\n");
return(FALSE);
}
```

```
** Wait for completion of WRITE command up to 10Msec.
      ** 10Msec = 11900 loops of 800nSec.
      */
      for (i=0; i<11900; i++)</pre>
   Delay800nSec();
   In32Bits(CSR9, Dword, &Dout);
    Dout = (Dout>>3) & 1;
    if (Dout == 1)
      break;
     if (Dout == 0)
  {
  printf("SROM did not end busy state in write command\n");
  return(FALSE);
  }
      /*
      ** Negate the CS to end the SROM command
     */
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM);
     Delay800nSec();
     }
WriteCommandEWDS();
 /*
** Save the ROM byte address for next use.
* /
*ROM_Address = ROM_WordAddress;
return 1;
/*
    ReadSROM
* *
     _____
**
* *
    Operation:
* *
       Reads the contents of the SROM (starting at a given offset),
**
        into a given buffer.
**
* *
     Input:
**
       ROM_Address: Offset in SROM. Is auto incremented after write.
**
        It is number of WORD to which Data is written.
**
       Len:
                Length in words.
**
       Data:
                    Pointer to data to buffer to read into.
**
**
    Output:
**
        If an error occurs, error message is printed.
**
**
    Return value:
**
       FALSE if an error occurs.
*/
int ReadSROM(WORD *ROM_Address,WORD Len,WORD *Data)
WORD i, j;
DWORD Dbit;
DWORD Dout;
WORD ROM_WordAddress;
WORD WordData;
ROM_WordAddress = *ROM_Address;
```

}

{

```
** Make sure the ROM Address is not too big for this ROM
* /
if (ROM_WordAddress + Len -1 > SROM_93LC46B_LAST_ADDRESS)
   printf("Address or data length is too big for SROM\n");
   return(FALSE);
   }
/*
* *
  Loop on all DATA words.
*/
for (j=0; j<Len; j++)</pre>
    ł
     /*
     ** Output the READ command to the SROM
     */
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM |
                                                     CS |
                                                                DATA_1);
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK | DATA_1);
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM | CS |
                                                                DATA 1);
    Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                                     CS
                                          SEL_SROM
                                                                DATA_1);
                                                     CS | CLK | DATA_1);
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                         SEL_SROM
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                DATA 1);
     Delay800nSec();
                                                     CS
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                          SEL_SROM
                                                                DATA_0);
                                                     CS | CLK | DATA_0);
     Out32Bits(CSR9, Dword, CSR9_WRITE
                                         SEL_SROM
     Delay800nSec();
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                                DATA 0);
     Delay800nSec();
     ** Output the WORD Address of the SROM
     */
     for (i=0; i<=SROM_93LC46B_LAST_ADDRESS_BIT; i++)</pre>
   Dbit = (DWORD)((ROM WordAddress >> (SROM 93LC46B LAST ADDRESS BIT-i)) & 1) << 2;
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                              Dbit);
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS |
                                                        CLK | Dbit);
   Delay800nSec();
   Out32Bits(CSR9, Dword, CSR9 WRITE | SEL SROM | CS |
                                                              Dbit);
   Delay800nSec();
     /*
     ** Verify that the SROM output data became now 0.
     */
     In32Bits(CSR9, Dword, &Dout);
     Dout = (Dout>>3) & 1;
     if (Dout != 0)
 {
 printf("SROM did not become busy in read command\n");
 return(FALSE);
 }
```

```
** Input the WORD of data from the SROM
     */
     for (i=0; i<=15; i++)
  {
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS | CLK);
   Delay800nSec();
   In32Bits(CSR9, Dword, &Dout);
   WordData |= ((Dout>>3) & 1) << (15-i);
   Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM | CS
                                                      );
   Delay800nSec();
  }
     /*
     ** Put our read data in user buffer
     */
     *Data = WordData;
     /*
     ** Point at next user buffer address
     */
     Data++;
     /*
     ** Point at next SROM Address
     */
     ROM WordAddress++;
     /*
     ** Negate the CS (chip select) to end the SROM command
     */
     Out32Bits(CSR9, Dword, CSR9_WRITE | SEL_SROM);
    Delay800nSec();
    }
/*
** Save the ROM byte address for next use.
*/
*ROM_Address = ROM_WordAddress;
return(TRUE);
```

}

# **Serial ROM CRC Calculation**

This appendix provides the routine for calculating the serial ROM CRC value.

```
unsigned short CalcSromCrc(unsigned char *SromData);
#define DATA LEN
                         126 // 1024 bits SROM
struct {
unsigned char SromData[DATA_LEN];
unsigned short SromCRC;
       } Srom;
main()
ł
Srom.SromCRC = CalcSromCrc(&Srom.SromData);
}
unsigned short CalcSromCrc(unsigned char *SromData)
#define POLY 0x04C11DB6L
   unsigned long crc = 0xFFFFFFF;
  unsigned long FlippedCRC = 0;
  unsigned char CurrentByte;
   unsigned Index;
   unsigned Bit;
   unsigned Msb;
   int i;
   for (Index = 0; Index < DATA_LEN; Index++)</pre>
   ł
      CurrentByte = SromData[Index];
      for (Bit = 0; Bit < 8; Bit++)
         Msb = (crc >> 31) & 1;
         crc <<= 1;
         if (Msb ^ (CurrentByte & 1))
         ł
            crc ^= POLY;
            crc |= 0x0000001;
         }
         CurrentByte >>= 1;
      }
   }
   for (i = 0; i < 32; i++)
   ł
      FlippedCRC <<= 1;</pre>
      Bit = crc & 1;
      crc >>= 1;
      FlippedCRC += Bit;
   }
```

```
crc = FlippedCRC ^ 0xFFFFFFF;
return (crc & 0xFFFF);
}
```

# D Block CRC Calculation

This appendix provides the routine for calculating the ID\_BLOCK\_CRC value.

```
/*
** This program calculates the CRC which sums the
** Serial ROM header. This serial ROM header of 9 words is read upon reset of
** the chip. If the CRC result of these 9 words equals 0, it means data read
** correctly.
**
                                   8
                                      2
                                             1
** CRC is a 8 bit crc. Polynom is X + X + X + 1.
** Note that in contrary to regular CRC, this CRC is calculated on data stream
^{\ast\ast} from MSB 1'st to LSB. This is because of the nature of the SROM data stream
** which goes this way.
**
** Predefined SROM header:
**
**
      WORD# Meaning
**
      ____
               _____
**
       0
               Subsystem vendor ID
**
      1
              Subsystem ID
* *
              reserved (value = 0)
      2
**
      3
              reserved (value = 0)
**
       4
              reserved (value = 0)
**
       5
              reserved (value = 0)
** 6 reserved (value = 0)
** 7 reserved (value = 0)
** 8 High byte is reserved (value = 0), Low byte = CRC
*/
main()
#define POLY 0x6
unsigned short DAT[9];
int i,Word,n;
char Bit;
unsigned char BitVal;
unsigned char crc;
n=0;
crc = -1;
for (Word=0; Word<9; Word++)</pre>
for (Bit=15; Bit>=0; Bit--)
if ((Word == 8) && (Bit == 7))
ſ
/*
** Insert the correct CRC result into input data stream in place.
*/
DAT[8] = (DAT[8] & 0xff00) | (unsigned short)crc;
break;
}
```

```
n++;
BitVal = ((DAT[Word] >> Bit) & 1) ^ ((crc >> 7) & 1);
crc = crc << 1;
if (BitVal == 1)
{
    crc ^= POLY;
        crc |= 0x01;
}
```

# **Technical Support and Ordering Information**

### **D.1 Obtaining Technical Support**

If you need technical support or help deciding which literature best meets your needs, call the Digital Semiconductor Information Line:

 United States and Canada
 1-800-332-2717

 Outside North America
 +1-508-628-4760

#### **D.2 Ordering Digital Semiconductor Products**

To order the Digital Semiconductor 21041 PCI Ethernet LAN Controller and evaluation board, contact your local distributor.

The following table lists some of the semiconductor products you can order from Digital:

| Product                                                                | Order Number                                             |
|------------------------------------------------------------------------|----------------------------------------------------------|
| Digital Semiconductor 21041 PCI Ethernet LAN Controller                | 21041–AB                                                 |
| Digital Semiconductor 21041 Evaluation Board Kit                       | 21A41-01                                                 |
| Digital Semiconductor 21140A PCI Fast Ethernet LAN Controller          | 21140-AC                                                 |
| Digital Semiconductor 21140A 10/100BASE-TX Evaluation Board<br>Kit     | 21A40-TX                                                 |
| Digital Semiconductor 21142 PCI 10/100-Mb/s Ethernet LAN<br>Controller | 21142–PA (PQFP<br>package)<br>21142–TA (TQFP<br>package) |

## **D.3 Ordering Digital Semiconductor Literature**

The following table lists some of the available Digital Semiconductor literature. For a complete list, contact the Digital Semiconductor Information Line.

| Title                                                                                | Order Number |
|--------------------------------------------------------------------------------------|--------------|
| Digital Semiconductor 21041 PCI Ethernet LAN<br>Controller Product Brief             | EC-QAWVB-TE  |
| Digital Semiconductor 21041 PCI Ethernet LAN<br>Controller Data Sheet                | EC-QAWWB-TE  |
| Digital Semiconductor 21041 PCI Ethernet LAN<br>Controller Hardware Reference Manual | EC-QAWXB-TE  |

## **D.4 Ordering Third-Party Literature**

You can order the following third-party literature directly from the vendor:

| Title                                                             | Vendor                                                                                                        |
|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| PCI Local Bus Specification, Revision 2.0                         | PCI Special Interest Group<br>1–800–433–5177 (U.S.)<br>1–503–797–4207 (International)<br>1–503–234–6762 (FAX) |
| Institute of Electrical and Electronics<br>Engineers (IEEE) 802.3 | IEEE Service Center<br>1–800–701–4333 (U.S.)<br>1–908–981–0060 (International)<br>1–908–981–9667 (FAX)        |