## 3.1 Control Registers

The Control registers provide the main interface between the host controller and the on-chip Ethernet controller logic. Writing to these registers controls the operation of the interface, while reading the registers allows the host controller to monitor operations.

The Control register memory is partitioned into four banks, selectable by the bank select bits, BSEL1:BSEL0, in the ECON1 register. Each bank is 32 bytes long and addressed by a 5-bit address value.

The last five locations (1Bh to 1Fh) of all banks point to a common set of registers: EIE, EIR, ESTAT, ECON2 and ECON1. These are key registers used in controlling and monitoring the operation of the device. Their common mapping allows easy access without switching the bank. The ECON1 and ECON2 registers are discussed later in this section.

Some of the available addresses are unimplemented. Any attempts to write to these locations are ignored while reads return '0's. The register at address 1Ah in each bank is reserved; read and write operations should not be performed on this register. All other reserved registers may be read, but their contents must not be changed. When reading and writing to registers which contain reserved bits, any rules stated in the register definition should be observed.

Control registers for the ENC28J60 are generically grouped as ETH, MAC and MII registers. Register names starting with "E" belong to the ETH group. Similarly, registers names starting with "MA" belong to the MAC group and registers prefixed with "MI" belong to the MII group.

TABLE 3-1: ENC28J60 CONTROL REGISTER MAP

| Bank 0  |          | Bank 1  |          | Bank 2  |          | Bank 3  |          |
|---------|----------|---------|----------|---------|----------|---------|----------|
| Address | Name     | Address | Name     | Address | Name     | Address | Name     |
| 00h     | ERDPTL   | 00h     | EHT0     | 00h     | MACON1   | 00h     | MAADR5   |
| 01h     | ERDPTH   | 01h     | EHT1     | 01h     | Reserved | 01h     | MAADR6   |
| 02h     | EWRPTL   | 02h     | EHT2     | 02h     | MACON3   | 02h     | MAADR3   |
| 03h     | EWRPTH   | 03h     | EHT3     | 03h     | MACON4   | 03h     | MAADR4   |
| 04h     | ETXSTL   | 04h     | EHT4     | 04h     | MABBIPG  | 04h     | MAADR1   |
| 05h     | ETXSTH   | 05h     | EHT5     | 05h     | _        | 05h     | MAADR2   |
| 06h     | ETXNDL   | 06h     | EHT6     | 06h     | MAIPGL   | 06h     | EBSTSD   |
| 07h     | ETXNDH   | 07h     | EHT7     | 07h     | MAIPGH   | 07h     | EBSTCON  |
| 08h     | ERXSTL   | 08h     | EPMM0    | 08h     | MACLCON1 | 08h     | EBSTCSL  |
| 09h     | ERXSTH   | 09h     | EPMM1    | 09h     | MACLCON2 | 09h     | EBSTCSH  |
| 0Ah     | ERXNDL   | 0Ah     | EPMM2    | 0Ah     | MAMXFLL  | 0Ah     | MISTAT   |
| 0Bh     | ERXNDH   | 0Bh     | EPMM3    | 0Bh     | MAMXFLH  | 0Bh     | _        |
| 0Ch     | ERXRDPTL | 0Ch     | EPMM4    | 0Ch     | Reserved | 0Ch     | _        |
| 0Dh     | ERXRDPTH | 0Dh     | EPMM5    | 0Dh     | Reserved | 0Dh     | _        |
| 0Eh     | ERXWRPTL | 0Eh     | EPMM6    | 0Eh     | Reserved | 0Eh     | _        |
| 0Fh     | ERXWRPTH | 0Fh     | EPMM7    | 0Fh     | _        | 0Fh     | _        |
| 10h     | EDMASTL  | 10h     | EPMCSL   | 10h     | Reserved | 10h     | _        |
| 11h     | EDMASTH  | 11h     | EPMCSH   | 11h     | Reserved | 11h     | _        |
| 12h     | EDMANDL  | 12h     | _        | 12h     | MICMD    | 12h     | EREVID   |
| 13h     | EDMANDH  | 13h     | _        | 13h     | _        | 13h     | _        |
| 14h     | EDMADSTL | 14h     | EPMOL    | 14h     | MIREGADR | 14h     | _        |
| 15h     | EDMADSTH | 15h     | EPMOH    | 15h     | Reserved | 15h     | ECOCON   |
| 16h     | EDMACSL  | 16h     | Reserved | 16h     | MIWRL    | 16h     | Reserved |
| 17h     | EDMACSH  | 17h     | Reserved | 17h     | MIWRH    | 17h     | EFLOCON  |
| 18h     | _        | 18h     | ERXFCON  | 18h     | MIRDL    | 18h     | EPAUSL   |
| 19h     | _        | 19h     | EPKTCNT  | 19h     | MIRDH    | 19h     | EPAUSH   |
| 1Ah     | Reserved | 1Ah     | Reserved | 1Ah     | Reserved | 1Ah     | Reserved |
| 1Bh     | EIE      | 1Bh     | EIE      | 1Bh     | EIE      | 1Bh     | EIE      |
| 1Ch     | EIR      | 1Ch     | EIR      | 1Ch     | EIR      | 1Ch     | EIR      |
| 1Dh     | ESTAT    | 1Dh     | ESTAT    | 1Dh     | ESTAT    | 1Dh     | ESTAT    |
| 1Eh     | ECON2    | 1Eh     | ECON2    | 1Eh     | ECON2    | 1Eh     | ECON2    |
| 1Fh     | ECON1    | 1Fh     | ECON1    | 1Fh     | ECON1    | 1Fh     | ECON1    |

TABLE 3-2: ENC28J60 CONTROL REGISTER SUMMARY

|               | D:: =                                       |                |            |             |                |             | B:: 4   |                       | Value       | Details    |
|---------------|---------------------------------------------|----------------|------------|-------------|----------------|-------------|---------|-----------------------|-------------|------------|
| Register Name | Bit 7                                       | Bit 6          | Bit 5      | Bit 4       | Bit 3          | Bit 2       | Bit 1   | Bit 0                 | on<br>Reset | on<br>Page |
| EIE           | INTIE                                       | PKTIE          | DMAIE      | LINKIE      | TXIE           | r           | TXERIE  | RXERIE                | 0000 0000   | 65         |
| EIR           | _                                           | PKTIF          | DMAIF      | LINKIF      | TXIF           | r           | TXERIF  | RXERIF                | -000 0000   | 66         |
| ESTAT         | INT                                         | BUFER          | r          | LATECOL     | _              | RXBUSY      | TXABRT  | CLKRDY <sup>(1)</sup> | 0000 -000   | 64         |
| ECON2         | AUTOINC                                     | PKTDEC         | PWRSV      | r           | VRPS           | _           | _       | _                     | 1000 0      | 16         |
| ECON1         | TXRST                                       | RXRST          | DMAST      | CSUMEN      | TXRTS          | RXEN        | BSEL1   | BSEL0                 | 0000 0000   | 15         |
| ERDPTL        | Read Pointer                                | Low Byte ER    | DPT<7:0>)  |             |                |             |         |                       | 1111 1010   | 17         |
| ERDPTH        | — — Read Pointer High Byte (ERDPT<12:8>)    |                |            |             |                |             |         |                       |             | 17         |
| EWRPTL        | Write Pointer                               | Low Byte (EV   | VRPT<7:0>) |             |                |             |         |                       | 0000 0000   | 17         |
| EWRPTH        |                                             |                |            |             |                |             |         |                       | 0 0000      | 17         |
| ETXSTL        |                                             |                |            |             |                |             |         |                       | 0000 0000   | 17         |
| ETXSTH        |                                             |                |            |             |                |             |         |                       | 0 0000      | 17         |
| ETXNDL        | TX End Low                                  | Byte (ETXND    | <7:0>)     |             |                |             |         |                       | 0000 0000   | 17         |
| ETXNDH        |                                             |                |            |             |                |             |         |                       | 0 0000      | 17         |
| ERXSTL        |                                             |                |            |             |                |             |         |                       | 1111 1010   | 17         |
| ERXSTH        | — — RX Start High Byte (ERXST<12:8>)        |                |            |             |                |             |         |                       | 0 0101      | 17         |
| ERXNDL        | RX End Low Byte (ERXND<7:0>)                |                |            |             |                |             |         |                       | 1111 1111   | 17         |
| ERXNDH        | — — RX End High Byte (ERXND<12:8>)          |                |            |             |                |             |         |                       | 1 1111      | 17         |
| ERXRDPTL      | RX RD Pointe                                | er Low Byte (E | RXRDPT<7:  | 0>)         |                |             |         |                       | 1111 1010   | 17         |
| ERXRDPTH      | — — RX RD Pointer High Byte (ERXRDPT<12:8>) |                |            |             |                |             |         |                       | 0 0101      | 17         |
| ERXWRPTL      | RX WR Pointer Low Byte (ERXWRPT<7:0>)       |                |            |             |                |             |         |                       | 0000 0000   | 17         |
| ERXWRPTH      | _                                           | _              | _          | RX WR Point | ter High Byte  | (ERXWRPT<1  | 2:8>)   |                       | 0 0000      | 17         |
| EDMASTL       | DMA Start Lo                                | w Byte (EDM    | AST<7:0>)  |             |                |             |         |                       | 0000 0000   | 71         |
| EDMASTH       | — — DMA Start High Byte (EDMAST<12:8>)      |                |            |             |                |             |         |                       | 0 0000      | 71         |
| EDMANDL       | DMA End Low Byte (EDMAND<7:0>)              |                |            |             |                |             |         |                       | 0000 0000   | 71         |
| EDMANDH       | — — DMA End High Byte (EDMAND<12:8>)        |                |            |             |                |             |         |                       | 0 0000      | 71         |
| EDMADSTL      | DMA Destination Low Byte (EDMADST<7:0>)     |                |            |             |                |             |         |                       | 0000 0000   | 71         |
| EDMADSTH      | _                                           | _              | _          | DMA Destina | tion High Byte | e (EDMADST< | :12:8>) |                       | 0 0000      | 71         |
| EDMACSL       | DMA Checksum Low Byte (EDMACS<7:0>)         |                |            |             |                |             |         |                       | 0000 0000   | 72         |
| EDMACSH       | DMA Checksum High Byte (EDMACS<15:8>)       |                |            |             |                |             |         |                       | 0000 0000   | 72         |
| EHT0          | Hash Table Byte 0 (EHT<7:0>)                |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT1          | Hash Table Byte 1 (EHT<15:8>)               |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT2          | Hash Table Byte 2 (EHT<23:16>)              |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT3          | Hash Table Byte 3 (EHT<31:24>)              |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT4          | Hash Table Byte 4 (EHT<39:32>)              |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT5          | Hash Table Byte 5 (EHT<47:40>)              |                |            |             |                |             |         |                       | 0000 0000   | 52         |
| EHT6          | Hash Table Byte 6 (EHT<55:48>)              |                |            |             |                |             |         | 0000 0000             | 52          |            |
| EHT7          | Hash Table Byte 7 (EHT<63:56>)              |                |            |             |                |             |         | 0000 0000             | 52          |            |
| EPMM0         | Pattern Match Mask Byte 0 (EPMM<7:0>)       |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM1         | Pattern Match Mask Byte 1 (EPMM<15:8>)      |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM2         | Pattern Match Mask Byte 2 (EPMM<23:16>)     |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM3         | Pattern Match Mask Byte 3 (EPMM<31:24>)     |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM4         | Pattern Match Mask Byte 4 (EPMM<39:32>)     |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM5         | Pattern Match Mask Byte 5 (EPMM<47:40>)     |                |            |             |                |             |         | 0000 0000             | 51          |            |
| EPMM6         | Pattern Match Mask Byte 6 (EPMM<55:48>)     |                |            |             |                |             |         |                       | 0000 0000   | 51         |
| EPMM7         | Pattern Matcl                               | h Mask Byte 7  | (EPMM<63:  | 56>)        |                |             |         |                       | 0000 0000   | 51         |

 $\textbf{Legend:} \qquad \textbf{x} = \textbf{unknown}, \ \textbf{u} = \textbf{unchanged}, \ - = \textbf{unimplemented}, \ \textbf{q} = \textbf{value} \ \textbf{depends} \ \textbf{on condition}, \ \ \textbf{r} = \textbf{reserved}, \ \textbf{do not modify}.$ 

Note 1: CLKRDY resets to '0' on Power-on Reset but is unaffected on all other Resets.

2: EREVID is a read-only register.

3: ECOCON resets to '---- -100' on Power-on Reset and '---- -uuu' on all other Resets.

## **ENC28J60**

TABLE 3-2: ENC28J60 CONTROL REGISTER SUMMARY (CONTINUED)

| Register Name         | Bit 7                                                     | Bit 6                                       | Bit 5      | Bit 4        | Bit 3         | Bit 2     | Bit 1   | Bit 0  | Value<br>on<br>Reset | Details<br>on<br>Page |
|-----------------------|-----------------------------------------------------------|---------------------------------------------|------------|--------------|---------------|-----------|---------|--------|----------------------|-----------------------|
| EPMCSL                | Pattern Match Checksum Low Byte (EPMCS<7:0>)              |                                             |            |              |               |           |         |        |                      | 51                    |
| EPMCSH                | Pattern Match Checksum High Byte (EPMCS<15:0>)            |                                             |            |              |               |           |         |        | 0000 0000            | 51                    |
| EPMOL                 | Pattern Match Offset Low Byte (EPMO<7:0>)                 |                                             |            |              |               |           |         |        | 0000 0000            | 51                    |
| EPMOH                 | _                                                         | Pattern Match Offset High Byte (EPMO<12:8>) |            |              |               |           |         |        |                      | 51                    |
| ERXFCON               | UCEN                                                      | ANDOR                                       | CRCEN      | PMEN         | MPEN          | HTEN      | MCEN    | BCEN   | 1010 0001            | 48                    |
| EPKTCNT               | Ethernet Packet Count                                     |                                             |            |              |               |           |         |        |                      | 43                    |
| MACON1                |                                                           | _                                           | _          | ŗ            | TXPAUS        | RXPAUS    | PASSALL | MARXEN | 0 0000               | 34                    |
| MACON3                | PADCFG2                                                   | PADCFG1                                     | PADCFG0    | TXCRCEN      | PHDREN        | HFRMEN    | FRMLNEN | FULDPX | 0000 0000            | 35                    |
| MACON4                | I                                                         | DEFER                                       | BPEN       | NOBKOFF      | ı             | _         | r       | r      | -00000               | 36                    |
| MABBIPG               | ı                                                         | Back-to-Back Inter-Packet Gap (BBIPG<6:0>)  |            |              |               |           |         |        |                      | 36                    |
| MAIPGL                | Non-Back-to-Back Inter-Packet Gap Low Byte (MAIPGL<6:0>)  |                                             |            |              |               |           |         |        | -000 0000            | 34                    |
| MAIPGH                | Non-Back-to-Back Inter-Packet Gap High Byte (MAIPGH<6:0>) |                                             |            |              |               |           |         |        | -000 0000            | 34                    |
| MACLCON1              | _                                                         | — — Retransmission Maximum (RETMAX<3:0>)    |            |              |               |           |         |        |                      | 34                    |
| MACLCON2              | — — Collision Window (COLWIN<5:0>)                        |                                             |            |              |               |           |         |        | 11 0111              | 34                    |
| MAMXFLL               | Maximum Frame Length Low Byte (MAMXFL<7:0>)               |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAMXFLH               | Maximum Frame Length High Byte (MAMXFL<15:8>)             |                                             |            |              |               |           |         |        | 0000 0110            | 34                    |
| MICMD                 | _                                                         | _                                           | _          | _            | _             | _         | MIISCAN | MIIRD  | 00                   | 21                    |
| MIREGADR              | — — MII Register Address (MIREGADR<4:0>)                  |                                             |            |              |               |           |         |        | 0 0000               | 19                    |
| MIWRL                 | MII Write Data Low Byte (MIWR<7:0>)                       |                                             |            |              |               |           |         |        |                      | 19                    |
| MIWRH                 | MII Write Data High Byte (MIWR<15:8>)                     |                                             |            |              |               |           |         |        |                      | 19                    |
| MIRDL                 | MII Read Data Low Byte (MIRD<7:0>)                        |                                             |            |              |               |           |         |        |                      | 19                    |
| MIRDH                 | MII Read Data High Byte(MIRD<15:8>)                       |                                             |            |              |               |           |         |        | 0000 0000            | 19                    |
| MAADR5                | MAC Address Byte 5 (MAADR<15:8>)                          |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAADR6                | MAC Address Byte 6 (MAADR<7:0>)                           |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAADR3                | MAC Address Byte 3 (MAADR<31:24>), OUI Byte 3             |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAADR4                | MAC Address Byte 4 (MAADR<23:16>)                         |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAADR1                | MAC Address Byte 1 (MAADR<47:40>), OUI Byte 1             |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| MAADR2                | MAC Address Byte 2 (MAADR<39:32>), OUI Byte 2             |                                             |            |              |               |           |         |        | 0000 0000            | 34                    |
| EBSTSD                | Built-in Self-T                                           | est Fill Seed (                             | EBSTSD<7:0 | >)           |               |           |         |        | 0000 0000            | 76                    |
| EBSTCON               | PSV2                                                      | PSV1                                        | PSV0       | PSEL         | TMSEL1        | TMSEL0    | TME     | BISTST | 0000 0000            | 75                    |
| EBSTCSL               | Built-in Self-Test Checksum Low Byte (EBSTCS<7:0>)        |                                             |            |              |               |           |         |        | 0000 0000            | 76                    |
| EBSTCSH               | Built-in Self-Test Checksum High Byte (EBSTCS<15:8>)      |                                             |            |              |               |           |         |        | 0000 0000            | 76                    |
| MISTAT                | _                                                         | _                                           | _          | _            | r             | NVALID    | SCAN    | BUSY   | 0000                 | 21                    |
| EREVID <sup>(2)</sup> | _                                                         | _                                           | _          | Ethernet Rev | ision ID (ERE | VID<4:0>) |         |        | q qqqq               | 22                    |
| ECOCON <sup>(3)</sup> | I                                                         | _                                           | _          | _            | _             | COCON2    | COCON1  | COCON0 | 100                  | 6                     |
| EFLOCON               | _                                                         | _                                           | _          | _            |               | FULDPXS   | FCEN1   | FCEN0  | 000                  | 56                    |
| EPAUSL                | Pause Timer Value Low Byte (EPAUS<7:0>)                   |                                             |            |              |               |           |         |        | 0000 0000            | 57                    |
| EPAUSH                | Pause Timer Value High Byte (EPAUS<15:8>)                 |                                             |            |              |               |           |         |        | 0001 0000            | 57                    |

Note 1: CLKRDY resets to '0' on Power-on Reset but is unaffected on all other Resets.

2: EREVID is a read-only register.

3: ECOCON resets to '---- -100' on Power-on Reset and '---- -uuu' on all other Resets.