# Am79C970A # PCnet<sup>™</sup>-PCI II Single-Chip Full-Duplex Ethernet Controller for PCI Local Bus Product #### DISTINCTIVE CHARACTERISTICS - Single-chip Ethernet controller for the Peripheral Component Interconnect (PCI) local bus - Supports ISO 8802-3 (IEEE/ANSI 802.3) and Ethernet standards - Direct interface to the PCI local bus (Revision 2.0 compliant) - High-performance 32-bit Bus Master architecture with integrated DMA buffer management unit for low CPU and bus utilization - Software-compatible with AMD PCnet family, LANCE/C-LANCE, and Am79C900 ILACC register and descriptor architecture - Compatible with PCnet family driver software - Full-duplex operation for increased network bandwidth - Big endian and little endian byte alignments supported - 3.3 V/5 V signaling for PCI bus interface - Low-power CMOS design with two sleep modes allows reduced power consumption for critical battery-powered applications and Green PCs - Integrated Magic Packet<sup>™</sup> support for remote wake up of Green PCs - Individual 272-byte transmit and 256-byte receive FIFOs provide frame buffering for increased system latency and support the following features: - Automatic retransmission with no FIFO reload - Automatic receive stripping and transmit padding (individually programmable) - Automatic runt frame rejection - Automatic selection of received collision frames - Microwire EEPROM interface supports jumperless design and provides through-chip programming - Supports optional Boot PROM for diskless node applications - Look-Ahead Packet Processing (LAPP) data handling technique reduces system overhead by allowing protocol analysis to begin before end of receive frame - Integrated Manchester encoder/decoder - Provides integrated attachment unit interface (AUI) and 10BASE-T transceiver with automatic port selection - Automatic twisted-pair receive polarity detection and automatic correction of the receive polarity - Optional byte padding to long-word boundary on receive - Dynamic transmit FCS generation programmable on a frame-by-frame basis - Internal/external loopback capabilities - Supports the following types of network interfaces: - AUI to external 10BASE-2, 10BASE-5, 10BASE-T, or 10BASE-F MAU - Internal 10BASE-T transceiver with Smart Squelch to twisted-pair medium - JTAG Boundary Scan (IEEE 1149.1) test access port interface and NAND Tree test mode for board-level production connectivity test - Supports external address detection interface (EADI) - 4 programmable LEDs for status indication - 132-pin PQFP and 144-pin TQFP packages - Support for operation in industrial temperature range (-40°C to +85°C) available in both packages #### **GENERAL DESCRIPTION** The 32-bit PCnet-PCI II single-chip full-duplex Ethernet controller is a highly integrated Ethernet system solution designed to address high-performance system application requirements. It is a flexible bus-mastering device that can be used in any application, including network-ready PCs, printers, fax modems, and bridge/router designs. The bus-master architecture provides high data throughput in the system and low Publication# 19436 Rev: E Amendment/0 Issue Date: June 2000 CPU and system bus utilization. The PCnet-PCI II controller is fabricated with AMD's advanced low-power CMOS process to provide low operating and standby current for power-sensitive applications. The PCnet-PCI II controller is a complete Ethernet node integrated into a single VLSI device. It contains a bus interface unit, a DMA buffer management unit, an IEEE 802.3-compliant media access control (MAC) function, individual 272-byte transmit and 256-byte receive FIFOs, an IEEE 802.3-compliant attachment unit interface (AUI) and twisted-pair transceiver medium attachment unit (10BASE-T MAU) that can both operate in either half-duplex or full-duplex mode. The PCnet-PCI II controller is register-compatible with the LANCE (Am7990) Ethernet controller, the C-LANCE (Am79C90) Ethernet controller, the ILACC (Am79C900) Ethernet controller, and all Ethernet controllers in the PCnet family, including the PCnet-ISA controller (Am79C960), PCnet-ISA+ controller (Am79C961), PCnet-ISA II controller (Am79C961A), PCnet-32 controller (Am79C965), PCnet-PCI controller (Am79C970), and the PCnet-SCSI controller (Am79C974). The buffer management unit supports the C-LANCE, ILACC, and PCnet descriptor software models. The PCnet-PCI II controller is software compatible with the Novell® NE2100 and NE1500 Ethernet adapter card architectures. The 32-bit multiplexed bus interface unit provides a direct interface to PCI local bus applications, simplifying the design of an Ethernet node in a PC system. The PCnet-PCI II controller provides the complete interface to an expansion ROM, allowing add-on card designs with only a single load per PCI bus interface pin. With its built-in support for both little and big endian byte alignment, this controller also addresses proprietary non-PC applications. The PCnet-PCI II controller's advanced CMOS design allows the bus interface to be connected to either a 5 V or a 3.3 V signaling environment. Both NAND Tree and JTAG test interfaces are provided. The PCnet-PCI II controller supports automatic configuration in the PCI configuration space. Additional PCnet-PCI II configuration parameters, including the unique IEEE physical address, can be read from an external non-volatile memory (microwire EEPROM) immediately following system reset. The controller has the capability to automatically select either the AUI port or the twisted-pair transceiver. Only one interface is active at any one time. Both network interfaces can be programmed to operate in either halfduplex or full-duplex mode. The individual transmit and receive FIFOs optimize system overhead, providing sufficient latency during frame transmission and reception, and minimizing intervention during normal network error recovery. The integrated Manchester encoder/decoder (MENDEC) eliminates the need for an external serial interface adapter (SIA) in the system. In addition, the device provides programmable on-chip LED drivers for transmit, receive, collision, receive polarity, link integrity, activity, or jabber status. The PCnet-PCI II controller also provides an external address detection interface (EADI) to allow fast external hardware address filtering in internetworking applications. For power-sensitive applications where low standby current is desired, the device incorporates two sleep functions to reduce overall system power consumption, excellent for notebooks and Green PCs. In conjunction with these low power modes, the PCnet-PCI II controller also has integrated functions to support Magic Packet, an inexpensive technology that allows remote wakeup of Green PCs. With the rise of embedded networking applications operating in harsh environments where temperatures may exceed the normal commercial temperature window (0°C to +70°C), an industrial temperature (–40°C to +85°C) version is available in both the 132-pin PQFP and the 144-pin TQFP package. The industrial temperature version of the PCnet-PCI II Ethernet controller is characterized across the industrial temperature range (–40°C to +85°C) within the published power supply specification (4.75 V to 5.25 V; i.e., $\pm 5\%$ V<sub>CC</sub>). #### **BLOCK DIAGRAM** # **MD** ### **TABLE OF CONTENTS** | DISTINCTIVE CHARACTERISTICS | 1 | |-----------------------------------------|----| | GENERAL DESCRIPTION | 1 | | BLOCK DIAGRAM | 3 | | CONNECTION DIAGRAM | 10 | | ORDERING INFORMATION | 12 | | PIN DESIGNATIONS – 132 PIN PQFP | 13 | | LISTED BY PIN NUMBER | | | LISTED BY GROUP | | | LISTED BY GROUP | | | LISTED BY PIN NUMBER | | | LISTED BY GROUP | | | LISTED BY DRIVER TYPE | | | | | | PIN DESCRIPTION | | | PCI INTERFACE | | | BOARD INTERFACE | | | MICROWIRE EEPROM INTERFACE | | | ATTACHMENT UNIT INTERFACE | | | TWISTED PAIR INTERFACE | | | EXTERNAL ADDRESS DETECTION INTERFACE | | | IEEE 1149.1 TEST ACCESS PORT INTERFACE | 25 | | TEST INTERFACE | 25 | | POWER SUPPLY PINS | 25 | | BASIC FUNCTIONS | 26 | | SYSTEM BUS INTERFACE FUNCTION | 26 | | SOFTWARE INTERFACE | | | NETWORK INTERFACES | 26 | | DETAILED FUNCTIONS | 27 | | SLAVE BUS INTERFACE UNIT | | | SLAVE CONFIGURATION TRANSFERS | | | SLAVE I/O TRANSFERS | | | EXPANSION ROM TRANSFERS | | | EXCLUSIVE ACCESS | | | SLAVE CYCLE TERMINATION | | | PARITY ERROR RESPONSE | 37 | | MASTER BUS INTERFACE UNIT | 39 | | BUS ACQUISITION | 39 | | BUS MASTER DMA TRANSFERS | | | BASIC NON-BURST READ TRANSFER | | | BASIC BURST READ TRANSFER | | | BASIC NON-BURST WRITE TRANSFER | | | BASIC BURST WRITE TRANSFER | | | TARGET INITIATED TERMINATION | | | DISCONNECT WITH DATA TRANSFER | | | TARGET ABORT | | | MASTER INITIATED TERMINATION | | | PREEMPTION DURING NON-BURST TRANSACTION | 48 | | PREEMPTION DURING BURST TRANSACTION | 49 | | | MASTER ABORT | | |---------|------------------------------------------------|------------| | F | PARITY ERROR RESPONSE | | | | ADVANCED PARITY ERROR HANDLING | | | | NITIALIZATION BLOCK DMA TRANSFERS | | | | DESCRIPTOR DMA TRANSFERS | | | F | FIFO DMA TRANSFERS | 59 | | | NON-BURST FIFO DMA TRANSFERS | . 59 | | | BURST FIFO DMA TRANSFERS | 60 | | | | | | | IANAGEMENT UNIT | | | | NITIALIZATION | | | | re-initialization | | | | SUSPEND | | | | BUFFER MANAGEMENT | | | | DESCRIPTOR RINGS | | | | POLLING | | | | RANSMIT DESCRIPTOR TABLE ENTRY | | | F | RECEIVE DESCRIPTOR TABLE ENTRY | 68 | | | MEDIA ACCESS CONTROL | | | Т | RANSMIT AND RECEIVE MESSAGE DATA ENCAPSULATION | 69 | | | FRAMING | 69 | | | DESTINATION ADDRESS HANDLING | 69 | | | ERROR DETECTION | 70 | | N | MEDIA ACCESS MANAGEMENT | 70 | | | MEDIUM ALLOCATION | 70 | | | COLLISION HANDLING | 71 | | Т | RANSMIT OPERATION | | | | RANSMIT FUNCTION PROGRAMMING | | | | AUTOMATIC PAD GENERATION | | | | RANSMIT FCS GENERATION | | | | RANSMIT EXCEPTION CONDITIONS | | | • | LOSS OF CARRIER | | | | LATE COLLISION | | | | SQE TEST ERROR | | | _ | RECEIVE OPERATION | | | ' | RECEIVE FUNCTION PROGRAMMING | | | | ADDRESS MATCHING | | | | | | | | AUTOMATIC PAD STRIPPING | . 75<br>76 | | | RECEIVE FCS CHECKING | | | | | | | L | OOPBACK OPERATION | | | | AUI LOOPBACK MODES | | | | T-MAU LOOPBACK MODES | . / / | | | MISCELLANEOUS LOOPBACK FEATURES | | | N | MAGIC PACKET MODE | . 78 | | MANCHES | TER ENCODER/DECODER | 79 | | | EXTERNAL CRYSTAL CHARACTERISTICS | | | | EXTERNAL CLOCK DRIVE CHARACTERISTICS | | | | MENDEC TRANSMIT PATH | | | | TRANSMITTER TIMING AND OPERATION | | | F | RECEIVER PATH | | | | NPUT SIGNAL CONDITIONING | | | | CLOCK ACQUISITION | | | | PLL TRACKING | | | | CARRIER TRACKING AND END OF MESSAGE | | | | DATA DECODING | | | | ITTER TOLERANCE DEFINITION | | | | TELLI IVLEDANGE DEFINITION | OI | # | ATTACHMENT UNIT INTERFACE | |-----------------------------------------| | DIFFERENTIAL INPUT TERMINATION81 | | COLLISION DETECTION | | TWISTED-PAIR TRANSCEIVER82 | | TWISTED-PAIR TRANSMIT FUNCTION | | TWISTED-PAIR RECEIVE FUNCTION | | LINK TEST FUNCTION | | POLARITY DETECTION AND REVERSAL | | | | TWISTED-PAIR INTERFACE STATUS | | COLLISION DETECTION FUNCTION84 | | SIGNAL QUALITY ERROR TEST FUNCTION84 | | JABBER FUNCTION | | POWER DOWN84 | | 10BASE-T INTERFACE CONNECTION | | FULL-DUPLEX OPERATION | | FULL-DUPLEX LINK STATUS LED SUPPORT | | | | EXTERNAL ADDRESS DETECTION INTERFACE | | EXPANSION ROM INTERFACE86 | | EEPROM MICROWIRE INTERFACE 89 | | AUTOMATIC EEPROM READ OPERATION89 | | LED SUPPORT91 | | POWER SAVINGS MODES | | IEEE 1149.1 TEST ACCESS PORT INTERFACE | | BOUNDARY SCAN CIRCUIT | | TAP FINITE STATE MACHINE | | | | SUPPORTED INSTRUCTIONS93 | | INSTRUCTION REGISTER AND DECODING LOGIC | | BOUNDARY SCAN REGISTER93 | | OTHER DATA REGISTERS | | NAND TREE TESTING | | RESET96 | | H RESET96 | | S RESET | | <del>-</del> | | STOP | | SOFTWARE ACCESS | | PCI CONFIGURATION REGISTERS | | I/O RESOURCES98 | | USER ACCESSIBLE REGISTERS | | PCI CONFIGURATION REGISTERS | | CONTROL AND STATUS REGISTERS | | BUS CONFIGURATION REGISTERS | | INITIALIZATION BLOCK | | | | RLEN AND TLEN | | RDRA AND TDRA | | LADRF | | PADR | | MODE | | RECEIVE DESCRIPTORS | | RMD0 | | RMD1 | | | | RMD2 | | RMD3 | | TRANSMIT DESCRIPTORS | | TMD0162 | | TMD1162 | | TMD2 | | | | PCI CONFIGURATION REGISTERS | | |-------------------------------------------------------------------------------------------------|-------| | CONTROL AND STATUS REGISTERS | | | BUS CONFIGURATION REGISTERS | . 170 | | ABSOLUTE MAXIMUM RATINGS | 171 | | OPERATING RANGES | 171 | | DC CHARACTERISTICS | 171 | | SWITCHING CHARACTERISTICS | | | BUS INTERFACE | | | 10BASE-T INTERFACE | | | EADI | | | KEY TO SWITCHING WAVEFORMS | | | SWITCHING TEST CIRCUITS | 179 | | | | | SYSTEM BUS INTERFACE | _ | | 10BASE-T INTERFACE | | | AUI | | | EADI | . 190 | | PHYSICAL DIMENSIONS | 191 | | PQB132 | _ | | PQB132 | | | PQT144 | | | APPENDIX A: PCNET-PCI II COMPATIVLE MEDIA INTERFACE MODULES | | | PCNET-PCI II COMPATIBLE 10BASE-T FILTERS AND TRANSFORMERS | . 195 | | PCNET-PCI II COMPATIBLE ADI ISOLATION TRANSFORMERS 190 PCNET-PCI II COMPATIBLE DC/DC CONVERTERS | 196 | | MANUFACTURER CONTACT INFORMATION | | | APPENDIX B: RECOMMENDATION FOR POWER AND GROUND DECOUPLING | | | APPENDIX C: ALTERNATIVE METHOD FOR INITIALIZATION | . 201 | | APPENDIX D: LOOK-AHEAD PACKET PROCESSING CONCEPT | | | INTRODUCTION OF THE LAPP CONCEPT | | | OUTLINE OF THE LAPP FLOW | | | LAPP SOFTWARE REQUIREMENTS | | | LAPP RULES FOR PARSING OF DESCRIPTORS | | | SOME EXAMPLES OF LAPP DESCRIPTION OF INTERACTION | | | BUFFER SIZE TUNING | | | APPENDIX E: PCNET-PCI II AND PCNET-PCI DIFFERENCES | 212 | | OVERVIEW | | | NEW FEATURES | | | LIST OF REGISTER BIT CHANGES | | | PCI CONFIGURATION SPACE | | | CONTROL AND STATUS REGISTERS | | | BUS CONFIGURATION REGISTERS | | | TRANSMIT DESCRIPTOR | | | LIST OF PIN CHANGES | | | APPENDIX F: AM79C970A PCNET-PCI II REV B2 SILICON ERRATA | | #### **CONNECTION DIAGRAM** 19436C-2 #### **CONNECTION DIAGRAM** ### **ORDERING INFORMATION** #### **Standard Products** AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: | Valid Combinations | | | | | | | |--------------------|-----------------------|--|--|--|--|--| | AM79C970A | KC, KC\W, VC,<br>VC\W | | | | | | | AM79C970A | KI, KI\W, VC,<br>VI\W | | | | | | #### **Valid Combinations** Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations. # PIN DESIGNATIONS – 132 PIN PQFP # **Listed By Pin Number** | Pin No. | Name | Pin No. | Name | Pin No. | Name | Pin No. | Name | |---------|------------------|---------|------------|---------|-----------------|---------|----------------| | 1 | $V_{\text{DDB}}$ | 34 | PAR | 67 | V <sub>SS</sub> | 100 | AVSS1 | | 2 | AD27 | 35 | C/BE1 | 68 | ERA5 | 101 | DO- | | 3 | AD26 | 36 | AD15 | 69 | ERA4 | 102 | DO+ | | 4 | $V_{SSB}$ | 37 | $V_{SSB}$ | 70 | ERA3 | 103 | AVDD1 | | 5 | AD25 | 38 | AD14 | 71 | ERA2 | 104 | DI- | | 6 | AD24 | 39 | AD13 | 72 | V <sub>SS</sub> | 105 | DI+ | | 7 | C/BE3 | 40 | AD12 | 73 | ERA1 | 106 | CI- | | 8 | $V_{DD}$ | 41 | AD11 | 74 | ERA0 | 107 | CI+ | | 9 | TDI | 42 | AD10 | 75 | ERD7 | 108 | AVDD2 | | 10 | IDSEL | 43 | $V_{SSB}$ | 76 | $V_{DD}$ | 109 | $V_{DD}$ | | 11 | $V_{SS}$ | 44 | AD9 | 77 | ERD6 | 110 | EEDO/LED3/SRD | | 12 | AD23 | 45 | AD8 | 78 | ERD5 | 111 | EEDI/LNKST | | 13 | AD22 | 46 | $V_{DDB}$ | 79 | V <sub>SS</sub> | 112 | EESK/LED1/SFBD | | 14 | $V_{SSB}$ | 47 | C/BE0 | 80 | ERD4 | 113 | $V_{SS}$ | | 15 | AD21 | 48 | AD7 | 81 | ERD3 | 114 | EECS | | 16 | AD20 | 49 | AD6 | 82 | $V_{SS}$ | 115 | SLEEP | | 17 | $V_{DDB}$ | 50 | $V_{SSB}$ | 83 | ERD2 | 116 | RESERVED | | 18 | AD19 | 51 | AD5 | 84 | $V_{DD}$ | 117 | ĪNTA | | 19 | AD18 | 52 | AD4 | 85 | ERD1 | 118 | TCK | | 20 | $V_{SSB}$ | 53 | AD3 | 86 | ERD0 | 119 | $V_{SS}$ | | 21 | AD17 | 54 | AD2 | 87 | LED2/SRDCLK | 120 | RST | | 22 | AD16 | 55 | $V_{SSB}$ | 88 | $V_{SS}$ | 121 | CLK | | 23 | C/BE2 | 56 | AD1 | 89 | RXD- | 122 | $V_{DD}$ | | 24 | FRAME | 57 | AD0 | 90 | RXD+ | 123 | GNT | | 25 | ĪRDY | 58 | EAR | 91 | AVDD4 | 124 | TMS | | 26 | TRDY | 59 | $V_{DD}$ | 92 | TXP- | 125 | $V_{SS}$ | | 27 | DEVSEL | 60 | EROE | 93 | TXD- | 126 | REQ | | 28 | STOP | 61 | $V_{SS}$ | 94 | TXP+ | 127 | TDO | | 29 | LOCK | 62 | DXCVR/NOUT | 95 | TXD+ | 128 | AD31 | | 30 | $V_{SS}$ | 63 | $V_{SS}$ | 96 | AVDD3 | 129 | AD30 | | 31 | PERR | 64 | ERACLK | 97 | XTAL1 | 130 | $V_{SSB}$ | | 32 | SERR | 65 | ERA7 | 98 | AVSS2 | 131 | AD29 | | 33 | $V_{\text{DDB}}$ | 66 | ERA6 | 99 | XTAL2 | 132 | AD28 | # PIN DESIGNATIONS – 132 PIN PQFP Listed By Group | Pin Name | Pin Function | Туре | Driver | No. of Pins | | |----------------------------|-------------------------------------|------|--------|-------------|--| | PCI Bus Interface | | | | | | | AD[31:0] | Address/Data Bus | Ю | TS3 | 32 | | | C/BE[3:0] | Bus Command/Byte Enable | Ю | TS3 | 4 | | | CLK | Bus Clock | I | N/A | 1 | | | DEVSEL | Device Select | Ю | STS6 | 1 | | | FRAME | Cycle Frame | Ю | STS6 | 1 | | | GNT | Bus Grant | I | N/A | 1 | | | IDSEL | Initialization Device Select | I | N/A | 1 | | | ĪNTA | Interrupt | Ю | TS6 | 1 | | | ĪRDY | Initiator Ready | Ю | STS6 | 1 | | | LOCK | Bus Lock | I | N/A | 1 | | | PAR | Parity | Ю | TS3 | 1 | | | PERR | Parity Error | Ю | STS6 | 1 | | | REQ | Bus Request | Ю | TS3 | 1 | | | RST | Reset | 1 | N/A | 1 | | | SERR | System Error | Ю | TS6 | 1 | | | STOP | Stop | Ю | STS6 | 1 | | | TRDY | Target Ready | Ю | STS6 | 1 | | | Board Interface | | | | _ | | | LED1 | LED1 | 0 | LED | 1 | | | LED2 | LED2 | 0 | LED | 1 | | | LED3 | LED3 | 0 | LED | 1 | | | SLEEP | Sleep Mode | I | N/A | 1 | | | XTAL1 | Crystal Input | I | N/A | 1 | | | XTAL2 | Crystal Output | 0 | XTAL | 1 | | | Microwave EEPROM Interface | | | | | | | EECS | Microwire Serial EEPROM Chip Select | 0 | O6 | 1 | | | EEDI | Microwire Serial EEPROM Data In | 0 | LED | 1 | | | EEDO | Microwire Address EEPROM Data Out | I | N/A | 1 | | | EESK | Microwire Serial PROM Clock | Ю | LED | 1 | | | Expansion ROM Interface | | | | | | | ERA[7:0] | Expansion ROM Address Bus | 0 | O6 | 8 | | | ERACLK | Expansion ROM Address Clock | 0 | O6 | 1 | | | ERD[7:0] | Expansion ROM Data Bus | I | N/A | 8 | | | EROE | Expansion ROM Output Enable | 0 | O6 | 1 | | # PIN DESIGNATIONS – 132 PIN PQFP Listed By Group | Pin Name | Pin Function | Type <sup>1</sup> | Driver | No. of Pins | |-------------------------|-------------------------------------------|-------------------|--------|-------------| | PCI Bus Interface | · | • | • | • | | Attachment Unit Interfa | ace AUI | | | | | CI+/CI- | AUI Collision Differential Pair | I | N/A | 2 | | DI+/DI- | AUI Data In Differential Pair | 1 | N/A | 2 | | DO+/DO- | AUI Data Out Differential Pair | 0 | DO | 2 | | DXCVR | Disable Transceiver | 0 | O6 | 1 | | 10Base-T Interface | | | | | | <u>INKST</u> | Link Status | 0 | LED | 1 | | RXD+/RXD- | Receive Differential Pair | ı | N/A | 2 | | TXD+/TXD- | Transmit Differential Pair | 0 | TDO | 2 | | TXP+/TXP- | Transmit Pre-distortion Differential Pair | 0 | TPO | 2 | | External Address Dete | ction Interface (EADI) | • | • | • | | EAR | External Address Reject Low | I | N/A | 1 | | SFBD | Start Frame Byte Delimiter | 0 | LED | 1 | | SRD | Serial Receive Data | 0 | LED | 1 | | SRDCLK | Serial Receive Data Clock | 0 | LED | 1 | | IEEE 1149.1 Test Acce | ss Port Interface (JTAG) | | | | | TCK | Test Clock | I | N/A | 1 | | TDI | Test Data In | 1 | N/A | 1 | | TDO | Test Data Out | 0 | TS6 | 1 | | TMS | Test Mode Select | ı | N/A | 1 | | Test Interface | | | | | | NOUT | NAND Tree Test Output | 0 | O6 | 1 | | Power Supplies | | | | | | $AV_{DD}$ | Analog Power | Р | N/A | 4 | | AV <sub>SS</sub> | Analog Ground | Р | N/A | 2 | | $V_{DD}$ | Digital Power | Р | N/A | 6 | | $V_{SS}$ | Digital Ground | Р | N/A | 12 | | $V_{DDB}$ | I/O Buffer Power | Р | N/A | 4 | | $V_{SSB}$ | I/O Buffer Ground | Р | N/A | 8 | # **MD** ## PIN DESIGNATIONS – 144-PIN TQFP Listed By Pin Number | Pin No. | Name | Pin No. | Name | Pin No. | Name | Pin No. | Name | |---------|-------------|---------|------------|---------|-------------|---------|------------------| | 1 | NC | 37 | NC | 73 | NC | 109 | NC | | 2 | $V_{DDB}$ | 38 | PAR | 74 | $V_{SS}$ | 110 | AVSS1 | | 3 | AD27 | 39 | C/BE1 | 75 | ERA5 | 111 | DO- | | 4 | AD26 | 40 | AD15 | 76 | ERA4 | 112 | DO+ | | 5 | $V_{SSB}$ | 41 | $V_{SSB}$ | 77 | ERA3 | 113 | AVDD1 | | 6 | AD25 | 42 | AD14 | 78 | ERA2 | 114 | DI- | | 7 | AD24 | 43 | AD13 | 79 | $V_{SS}$ | 115 | DI+ | | 8 | C/BE3 | 44 | AD12 | 80 | ERA1 | 116 | CI- | | 9 | $V_{DD}$ | 45 | AD11 | 81 | ERA0 | 117 | CI+ | | 10 | TDI | 46 | AD10 | 82 | ERD7 | 118 | AVDD2 | | 11 | IDSEL | 47 | $V_{SSB}$ | 83 | $V_{DD}$ | 119 | $V_{DD}$ | | 12 | $V_{SS}$ | 48 | AD9 | 84 | ERD6 | 120 | EEDO/LED3/SRD | | 13 | AD23 | 49 | AD8 | 85 | ERD5 | 121 | EEDI/LNKST | | 14 | AD22 | 50 | $V_{DDB}$ | 86 | $V_{SS}$ | 122 | EESK/LED1/SFBD | | 15 | $V_{SSB}$ | 51 | C/BE0 | 87 | ERD4 | 123 | $V_{SS}$ | | 16 | AD21 | 52 | AD7 | 88 | ERD3 | 124 | EECS | | 17 | AD20 | 53 | AD6 | 89 | $V_{SS}$ | 125 | SLEEP | | 18 | $V_{DDB}$ | 54 | $V_{SSB}$ | 90 | ERD2 | 126 | RESERVED | | 19 | AD19 | 55 | AD5 | 91 | $V_{DD}$ | 127 | ĪNTA | | 20 | AD18 | 56 | AD4 | 92 | ERD1 | 128 | TCK | | 21 | $V_{SSB}$ | 57 | AD3 | 93 | ERD0 | 129 | $V_{SS}$ | | 22 | AD17 | 58 | AD2 | 94 | LED2/SRDCLK | 130 | RST | | 23 | AD16 | 59 | $V_{SSB}$ | 95 | $V_{SS}$ | 131 | CLK | | 24 | C/BE2 | 60 | AD1 | 96 | RXD- | 132 | $V_{DD}$ | | 25 | FRAME | 61 | AD0 | 97 | RXD+ | 133 | GNT | | 26 | <u>IRDY</u> | 62 | EAR | 98 | AVDD4 | 134 | TMS | | 27 | TRDY | 63 | $V_{DD}$ | 99 | TXP- | 135 | $V_{SS}$ | | 28 | DEVSEL | 64 | EROE | 100 | TXD- | 136 | REQ | | 29 | STOP | 65 | $V_{SS}$ | 101 | TXP+ | 137 | TDO | | 30 | LOCK | 66 | DXCVR/NOUT | 102 | TXD+ | 138 | AD31 | | 31 | $V_{SS}$ | 67 | $V_{SS}$ | 103 | AVDD3 | 139 | AD30 | | 32 | PERR | 68 | ERACLK | 104 | XTAL1 | 140 | V <sub>SSB</sub> | | 33 | SERR | 69 | ERA7 | 105 | AVSS2 | 141 | AD29 | | 34 | $V_{DDB}$ | 70 | ERA6 | 106 | XTAL2 | 142 | AD28 | | 35 | NC | 71 | NC | 107 | NC | 143 | NC | | 36 | NC | 72 | NC | 108 | NC | 144 | NC | NC - Indicates no connect # PIN DESIGNATIONS – 144 PIN TQFP Listed By Group | Pin Name | Pin Function | Туре | Driver | No. of Pins | | | |----------------------------|-------------------------------------|------|--------|-------------|--|--| | PCI Bus Interface | | | | | | | | AD[31:0] | Address/Data Bus | Ю | TS3 | 32 | | | | C/BE[3:0] | Bus Command/Byte Enable | Ю | TS3 | 4 | | | | CLK | Bus Clock | I | N/A | 1 | | | | DEVSEL | Device Select | Ю | STS6 | 1 | | | | FRAME | Cycle Frame | Ю | STS6 | 1 | | | | GNT | Bus Grant | I | N/A | 1 | | | | IDSEL | Initialization Device Select | I | N/A | 1 | | | | ĪNTA | Interrupt | Ю | TS6 | 1 | | | | ĪRDY | Initiator Ready | Ю | STS6 | 1 | | | | LOCK | Bus Lock | I | N/A | 1 | | | | PAR | Parity | Ю | TS3 | 1 | | | | PERR | Parity Error | Ю | STS6 | 1 | | | | REQ | Bus Request | Ю | TS3 | 1 | | | | RST | Reset | 1 | N/A | 1 | | | | SERR | System Error | Ю | TS6 | 1 | | | | STOP | Stop | Ю | STS6 | 1 | | | | TRDY | Target Ready | Ю | STS6 | 1 | | | | Board Interface | | | | | | | | LED1 | LED1 | 0 | LED | 1 | | | | LED2 | LED2 | 0 | LED | 1 | | | | LED3 | LED3 | 0 | LED | 1 | | | | SLEEP | Sleep Mode | I | N/A | 1 | | | | XTAL1 | Crystal Input | 1 | N/A | 1 | | | | XTAL2 | Crystal Output | 0 | XTAL | 1 | | | | Microwave EEPROM Interface | | | | | | | | EECS | Microwire Serial EEPROM Chip Select | 0 | O6 | 1 | | | | EEDI | Microwire Serial EEPROM Data In | 0 | LED | 1 | | | | EEDO | Microwire Address EEPROM Data Out | I | N/A | 1 | | | | EESK | Microwire Serial PROM Clock | Ю | LED | 1 | | | | Expansion ROM Interface | | | | | | | | ERA[7:0] | Expansion ROM Address Bus | 0 | O6 | 8 | | | | ERACLK | Expansion ROM Address Clock | 0 | O6 | 1 | | | | ERD[7:0] | Expansion ROM Data Bus | 1 | N/A | 8 | | | | EROE | Expansion ROM Output Enable | 0 | O6 | 1 | | | # PIN DESIGNATIONS — 144-PIN TQFP Listed By Group | Pin Name | Pin Function | Type <sup>1</sup> | Driver | No. of Pins | |------------------------|-------------------------------------------|-------------------|--------|-------------| | PCI Bus Interface | • | • | • | • | | Attachment Unit Interf | ace AUI | | | | | CI+/CI- | AUI Collision Differential Pair | I | N/A | 2 | | DI+/DI- | AUI Data In Differential Pair | 1 | N/A | 2 | | DO+/DO- | AUI Data Out Differential Pair | 0 | DO | 2 | | DXCVR | Disable Transceiver | 0 | O6 | 1 | | 10Base-T Interface | | | | | | LNKST | Link Status | 0 | LED | 1 | | RXD+/RXD- | Receive Differential Pair | I | N/A | 2 | | TXD+/TXD- | Transmit Differential Pair | 0 | TDO | 2 | | TXP+/TXP- | Transmit Pre-distortion Differential Pair | 0 | TPO | 2 | | External Address Dete | ction Interface (EADI) | • | • | | | EAR | External Address Reject Low | I | N/A | 1 | | SFBD | Start Frame Byte Delimiter | 0 | LED | 1 | | SRD | Serial Receive Data | 0 | LED | 1 | | SRDCLK | Serial Receive Data Clock | 0 | LED | 1 | | IEEE 1149.1 Test Acce | ss Port Interface (JTAG) | | | | | TCK | Test Clock | I | N/A | 1 | | TDI | Test Data In | 1 | N/A | 1 | | TDO | Test Data Out | 0 | TS6 | 1 | | TMS | Test Mode Select | 1 | N/A | 1 | | Test Interface | | • | • | | | NOUT | NAND Tree Test Output | 0 | O6 | 1 | | Power Supplies | | • | • | | | $AV_{DD}$ | Analog Power | Р | N/A | 4 | | AV <sub>SS</sub> | Analog Ground | Р | N/A | 2 | | $V_{DD}$ | Digital Power | Р | N/A | 6 | | $V_{SS}$ | Digital Ground | Р | N/A | 12 | | $V_{\text{DDB}}$ | I/O Buffer Power | Р | N/A | 4 | | $V_{SSB}$ | I/O Buffer Ground | Р | N/A | 8 | #### **PIN DESIGNATIONS** ### **Listed By Driver Type** The next table describes the various types of drivers that are used in the PCnet-PCI II controller: | Name | Туре | I <sub>OL</sub> (mA) | I <sub>OH</sub> (mA) | Load (pF) | |------|----------------------|----------------------|----------------------|-----------| | LED | LED | 12 | -0.4 | 50 | | O6 | Totem Pole | 6 | -0.4 | 50 | | OD6 | Open Drain | 6 | N/A | 50 | | STS6 | Sustained Tri-State™ | 6 | -2 | 50 | | TS3 | Tri-State | 3 | -2 | 50 | | TS6 | Tri-State | 6 | -2 | 50 | All $I_{OL}$ and $I_{OH}$ values shown in the table above apply to 5 V signaling. See the section "DC Characteristics" for the values applying to 3.3 V signaling. A sustained tri-state signal is a low active signal that is driven high for one clock period before it is left floating. DO, TDO and TPO are differential output drivers. The characteristic of these and the XTAL output are described in the section "DC Characteristics". #### PIN DESCRIPTION #### **PCI** Interface AD[31:0] ### Address and Data Input/Output Address and data are multiplexed on the same bus interface pins. During the first clock of a transaction AD[31:0] contain a physical address (32 bits). During the subsequent clocks AD[31:0] contain data. Byte ordering is little endian by default. AD[7:0] are defined as least significant byte and AD[31:24] are defined as the most significant byte. For FIFO data transfers, the PC-net-PCI II controller can be programmed for big endian byte ordering. See CSR3, bit 2 (BSWP) for more details. During the address phase of the transaction, when the PCnet-PCI II controller is a bus master, AD[31:2] will address the active Double Word (DWord). The PCnet-PCI II controller always drives AD[1:0] to '00' during the address phase indicating linear burst order. When the PCnet-PCI II controller is not a bus master, the AD[31:0] lines are continuously monitored to determine if an address match exists for slave transfers. During the data phase of the transaction, AD[31:0] are driven by the PCnet-PCI II controller when performing bus master write and slave read operations. Data on AD[31:0] is latched by the PCnet-PCI II controller when performing bus master read and slave write operations. When $\overline{\text{RST}}$ is active, AD[31:0] are inputs for NAND tree testing. ### C/BE[3:0] #### Bus Command and Byte Enables Input/Output Bus command and byte enables are multiplexed on the same bus interface pins. During the address phase of the transaction, C/BE[3:0] define the bus command. During the data phase C/BE[3:0] are used as byte enables. The byte enables define which physical byte lanes carry meaningful data. C/BE0 applies to byte 0 (AD[7:0]) and C/BE3 applies to byte 3 (AD[31:24]). The function of the byte enables is independent of the byte ordering mode (BSWP, CSR3, bit 2). When $\overline{RST}$ is active, C/ $\overline{BE}[3:0]$ are inputs for NAND tree testing. #### CLK #### Clock Input This clock is used to drive the system bus interface and the internal buffer management unit. All bus signals are sampled on the rising edge of CLK and all parameters are defined with respect to this edge. The PCnet-PCI II controller operates over a range of 0 MHz to 33 MHz. This clock is not used to drive the network functions. When $\overline{\text{RST}}$ is active, CLK is an input for NAND tree testing. #### **DEVSEL** #### **Device Select** Input/Output The PCnet-PCI II controller drives DEVSEL when it detects a transaction that selects the device as a target. The device samples DEVSEL to detect if a target claims a transaction that the PCnet-PCI II controller has initiated. When $\overline{RST}$ is active, $\overline{DEVSEL}$ is an input for NAND tree testing. #### **FRAME** ### **Cycle Frame** Input/Output FRAME is driven by the PCnet-PCI II controller when it is the bus master to indicate the beginning and duration of a transaction. FRAME is asserted to indicate a bus transaction is beginning. FRAME is asserted while data transfers continue. FRAME is deasserted before the final data phase of a transaction. When the PCnet-PCI II controller is in slave mode, it samples FRAME to determine the address phase of transaction. When $\overline{\text{RST}}$ is active, $\overline{\text{FRAME}}$ is an input for NAND tree testing. #### **GNT** #### **Bus Grant** This signal indicates that the access to the bus has been granted to the PCnet-PCI II controller. The PCnet-PCI II controller supports bus parking. When the PCI bus is idle and the system arbiter asserts $\overline{\text{GNT}}$ without an active $\overline{\text{REQ}}$ from the PCnet-PCI II controller, the device will drive the AD[31:0], C/ $\overline{\text{BE}}$ [3:0] and PAR lines. When $\overline{\text{RST}}$ is active, $\overline{\text{GNT}}$ is an input for NAND tree testing. #### **IDSEL** #### **Initialization Device Select** Input Input This signal is used as a chip select for the PCnet-PCI II controller during configuration read and write transactions. When $\overline{\text{RST}}$ is active, IDSEL is an input for NAND tree testing. #### **INTA** #### **Interrupt Request** Input/Output An attention signal which indicates that one or more of the following status flags is set: BABL, EXDINT, IDON, JAB, MERR, MISS, MFCO, MPINT, RCVCCO, RINT, SINT, SLPINT, TINT, TXSTRT and UINT. Each status flag has either a mask or an enable bit which allows for suppression of INTA assertion. The flags have the following meaning: **Table 1. Interrupt Flags** | BABL | Babble | | |--------|----------------------------------|--| | EXDINT | Excessive Deferral | | | IDON | Initialization Done | | | JAB | Jabber | | | MERR | Memory Error | | | MISS | Missed Frame | | | MFCO | Missed Frame Count Overflow | | | MPINT | Magic Packet Interrupt | | | RCVCCO | Receive Collision Count Overflow | | | RINT | Receive Interrupt | | | SLPINT | Sleep Interrupt | | | SINT | System Error | | | TINT | Transmit Interrupt | | | TXSTRT | Transmit Start | | | UINT | User Interrupt | | By default INTA is an open-drain output. For applications that need a high-active edge sensitive interrupt signal, the INTA pin can be configured for this mode by setting INTLEVEL (BCR2, bit 7) to ONE. When $\overline{\text{RST}}$ is active, $\overline{\text{INTA}}$ is an input for NAND tree testing. #### **IRDY** ### Initiator Ready Input/Output IRDY indicates the ability of the initiator of the transaction to complete the current data phase. IRDY is used in conjunction with TRDY. Wait states are inserted until both IRDY and TRDY are asserted simultaneously. A data phase is completed on any clock when both IRDY and TRDY are asserted. When the PCnet-PCI II controller is a bus master, it asserts $\overline{\text{IRDY}}$ during all write data phases to indicate that valid data is present on AD[31:0]. During all read data phases the device asserts $\overline{\text{IRDY}}$ to indicate that it is ready to accept the data. When the PCnet-PCI II controller is the target of a transaction, it checks IRDY during all write data phases to determine if valid data is present on AD[31:0]. During all read data phases the device checks IRDY to determine if the initiator is ready to accept the data. When $\overline{RST}$ is active, $\overline{IRDY}$ is an input for NAND tree testing. #### **LOCK** ### Lock Input In slave mode, $\overline{\mathsf{LOCK}}$ is an input to the PCnet-PCI II controller. A bus master can lock the device to guarantee an atomic operation that requires multiple transactions. The PCnet-PCI II controller will never assert $\overline{\text{LOCK}}$ as a master. When $\overline{\text{RST}}$ is active, $\overline{\text{LOCK}}$ is an input for NAND tree testing. ### **PAR** ### Parity Input/Output Parity is even parity across AD[31:0] and C/BE[3:0]. When the PCnet-PCI II controller is a bus master, it generates parity during the address and write data phases. It checks parity during read data phases. When the PCnet-PCI II controller operates in slave mode, it checks parity during every address phase. When it is the target of a cycle, it checks parity during write data phases and it generates parity during read data phases. When $\overline{RST}$ is active, PAR is an input for NAND tree testing. #### **PERR** #### Parity Error #### Input/Output During any slave write transaction and any master read transaction, the PCnet-PCI II controller asserts $\overline{\text{PERR}}$ when it detects a data parity error and reporting of the error is enabled by setting PERREN (PCI Command register, bit 6) to ONE. During any master write transaction the PCnet-PCI II controller monitors $\overline{\text{PERR}}$ to see if the target reports a data parity error. When $\overline{\text{RST}}$ is active, $\overline{\text{PERR}}$ is an input for NAND tree testing. ### **REQ** #### **Bus Request** #### Input/Output The PCnet-PCI II controller asserts $\overline{REQ}$ pin as a signal that it wishes to become a bus master. $\overline{REQ}$ is driven high when the PCnet-PCI II controller does not request the bus. When $\overline{\text{RST}}$ is active, $\overline{\text{REQ}}$ is an input for NAND tree testing. #### **RST** #### Reset Input When RST is asserted low, then the PCnet-PCI II controller performs an internal system reset of the type H\_RESET (HARDWARE\_RESET). RST must be held for a minimum of 30 clock periods. While in the H\_RESET state, the PCnet-PCI II controller will disable or deassert all outputs. RST may be asynchronous to CLK when asserted or deasserted. It is recommended that the deassertion be synchronous to guarantee clean and bounce free edge. When RST is active, NAND tree testing is enabled. All PCI interface pins are in input mode. The result of the NAND tree testing can be observed on the NOUT output (pin 62). #### **SERR** #### **System Error** #### Input/Output During any slave transaction, the PCnet-PCI II controller asserts SERR when it detects an address parity error and reporting of the error is enabled by setting PERREN (PCI Command register, bit 6) and SERREN (PCI Command register, bit 8) to ONE. By default SERR is an open-drain output. For component test it can be programmed to be an active-high to-tem-pole output. When $\overline{RST}$ is active, $\overline{SERR}$ is an input for NAND tree testing. ### **STOP** #### Stop Input/Output In slave mode, the PCnet-PCI II controller drives the STOP signal to inform the bus master to stop the current transaction. In bus master mode, the PCnet-PCI II controller checks STOP to determine if the target wants to disconnect the current transaction. When $\overline{\text{RST}}$ is active, $\overline{\text{STOP}}$ is an input for NAND tree testing. #### **TRDY** #### **Target Ready** Input/Output TRDY indicates the ability of the target of the transaction to complete the current data phase. TRDY is used in conjunction with IRDY. Wait states are inserted until both IRDY and TRDY are asserted simultaneously. A data phase is completed on any clock when both IRDY and TRDY are asserted. When the PCnet-PCI II controller is a bus master, it checks $\overline{TRDY}$ during all read data phases to determine if valid data is present on AD[31:0]. During all write data phases the device checks $\overline{TRDY}$ to determine if the target is ready to accept the data. When the PCnet-PCI II controller is the target of a transaction, it asserts TRDY during all read data phases to indicate that valid data is present on AD[31:0]. During all write data phases the device asserts TRDY to indicate that it is ready to accept the data When $\overline{RST}$ is active, $\overline{TRDY}$ is an input for NAND tree testing. #### **Board Interface** ### LED1 LED1 Output This output is designed to directly drive an LED. By default, LED1 indicates receive activity on the network. This pin can also be programmed to indicate other network status (see BCR5). The LED1 pin polarity is programmable, but by default, it is active LOW. Note that the $\overline{\text{LED1}}$ pin is multiplexed with the EESK and SFBD pins. ### LED2 LED2 Output This output is designed to directly drive an LED. By default, LED2 indicates correct receive polarity on the 10BASE-T interface. This pin can also be programmed to indicate other network status (see BCR6). The LED2 pin polarity is programmable, but by default, it is active LOW Note that the $\overline{\text{LED2}}$ pin is multiplexed with the SRDCLK pin. ### LED3 LED3 Output This output is designed to directly drive an LED. By default, $\overline{\text{LED3}}$ indicates transmit activity on the network. This pin can also be programmed to indicate other network status (see BCR7). The $\overline{\text{LED3}}$ pin polarity is programmable, but by default, it is active LOW. Note that the $\overline{\text{LED3}}$ pin is multiplexed with the EEDO and SRD pins. Special attention must be given to the external circuitry attached to this pin. When this pin is used to drive an LED while an EEPROM is used in the system, then buffering is required between the $\overline{\text{LED3}}$ pin and the LED circuit. If an LED circuit were directly attached to this pin, it would create an IOL requirement that could not be met by the serial EEPROM attached to this pin. If no EEPROM is included in the system design, then the $\overline{\text{LED3}}$ signal may be directly connected to an LED without buffering. For more details regarding LED connection, see the section "LED Support". #### SLEEP Sleep Input When SLEEP is asserted, the PCnet-PCI II controller performs an internal system reset of the S\_RESET type and then proceeds into a power savings mode. All PCnet-PCI II controller outputs will be placed in their normal reset condition. All PCnet-PCI II controller inputs will be ignored except for the SLEEP pin itself. Deassertion of SLEEP results in wake-up. The system must refrain from starting the network operations of the PCnet-PCI II controller device for 0.5 s following the deassertion of the SLEEP signal in order to allow internal analog circuits to stabilize. Both CLK and XTAL1 inputs must have valid clock signals present in order for the SLEEP command to take effect. The SLEEP pin should not be asserted during power supply ramp-up. If it is desired that SLEEP be asserted at power up time, then the system must delay the assertion of SLEEP until three clock cycles after the completion of a hardware reset operation. The SLEEP pin must not be left unconnected. It should be tied to VDD, if the power savings mode is not used. #### XTAL1 ### Crystal Oscillator In Input The internal clock generator uses a 20 MHz crystal that is attached to the pins XTAL1 and XTAL2. The network data rate is one-half of the crystal frequency. XTAL1 may alternatively be driven using an external 20 MHz CMOS level clock signal. Refer to the section "External Crystal Characteristics" for more details. Note that when the PCnet-PCI II controller is in coma mode, there is an internal 22 k $\Omega$ resistor from XTAL1 to ground. If an external source drives XTAL1, some power will be consumed driving this resistor. If XTAL1 is driven LOW at this time power consumption will be minimized. In this case, XTAL1 must remain active for at least 30 cycles after the assertion of $\overline{\text{SLEP}}$ and deassertion of $\overline{\text{REQ}}$ . #### XTAL2 #### **Crystal Oscillator Out** Output The internal clock generator uses a 20 MHz crystal that is attached to the pins XTAL1 and XTAL2. The network data rate is one-half of the crystal frequency. If an external clock source is used on XTAL1, then XTAL 2 should be left unconnected. #### **Microwire EEPROM Interface** #### **EECS** #### **EEPROM Chip Select** Output This pin is designed to directly interface to a serial EE-PROM that uses the Microwire interface protocol. EECS is connected to the Microwire EEPROM chip select pin. It is controlled by either the PCnet-PCI II controller during command portions of a read of the entire EEPROM, or indirectly by the host system by writing to BCR19, bit 2. #### **EEDI** #### EEPROM Data In Output This pin is designed to directly interface to a serial EE-PROM that uses the Microwire interface protocol. EEDI is connected to the Microwire EEPROM data input pin. It is controlled by either the PCnet-PCI II controller dur- ing command portions of a read of the entire EEPROM, or indirectly by the host system by writing to BCR19, bit 0. Note that the EEDI pin is multiplexed with the $\overline{\text{LNKST}}$ pin. #### **EEDO** #### **EEPROM Data Out** Input This pin is designed to directly interface to a serial EE-PROM that uses the Microwire interface protocol. EEDO is connected to the Microwire EEPROM data output pin. It is controlled by either the PCnet-PCI II controller during command portions of a read of the entire EEPROM, or indirectly by the host system by reading from BCR19, bit 0. Note that the EEDO pin is multiplexed with the $\overline{\text{LED3}}$ and SRD pins. #### **EESK** #### **EEPROM Serial clock** Input/Output This pin is designed to directly interface to a serial EE-PROM that uses the Microwire interface protocol. EESK is connected to the Microwire EEPROM clock pin. It is controlled by either the PCnet-PCI II controller directly during a read of the entire EEPROM, or indirectly by the host system by writing to BCR19, bit 1. Note that the EESK pin is multiplexed with the $\overline{\text{LED1}}$ and SFBD pins. The EESK pin is also used during EEPROM Auto-detection to determine whether or not an EEPROM is present at the PCnet-PCI II controller Microwire interface. At the rising edge of CLK during the last clock during which RST is asserted, EESK is sampled to determine the value of the EEDET bit in BCR19. A sampled HIGH value means that an EEPROM is present, and EEDET will be set to ONE. A sampled LOW value means that an EEPROM is not present, and EEDET will be cleared to ZERO. See the section "EEPROM Auto-Detection" for more details. If no LED circuit is to be attached to this pin, then a pull up or pull down resistor must be attached instead, in order to resolve the EEDET setting. #### **Expansion ROM Interface** ### ERA[7:0] #### **Expansion ROM Address** Output These pins provide the address to the Expansion ROM. When EROE is asserted and ERACLK is driven HIGH, ERA[7:0] contain the upper 8 bits of the Expansion ROM address. They must be latched externally. When EROE is asserted and ERACLK is low, ERA[7:0] contain the lower 8 bits of the Expansion ROM address. All ERA outputs are forced to a constant level to conserve power while no access to the Expansion ROM is performed. #### **ERACLK** ### Expansion ROM Address Clock Output When EROE is asserted and ERACLK is driven HIGH, ERA[7:0] contain the upper 8 bits of the Expansion ROM address. ERACLK is used to latch the address bits externally. Both '373 (transparent latch) and '374 (D flip-flop) types of address latch are supported. ### ERD[7:0] #### **Expansion ROM Data** Input Data from the Expansion ROM is transferred on ERD[7:0]. When EROE is high, the ERD[7:0] inputs are internally disabled and can be left floating. #### **EROE** ### **Expansion ROM Output Enable** Output Input This signal is asserted when the Expansion ROM is read. #### **Attachment Unit Interface** #### Cl± Collision In Input Cl± is a differential input pair signaling the PCnet-PCI II controller that a collision has been detected on the network media, indicated by the Cl± inputs being driven with a 10 MHz pattern of sufficient amplitude and pulse width to meet ISO 8802-3 (IEEE/ANSI 802.3) standards. Operates at pseudo ECL levels. #### DI± #### Data In DI± is a differential input pair to the PCnet-PCI II controller carrying Manchester encoded data from the network. Operates at pseudo ECL levels. #### **DO**± #### Data Out Output DO± is a differential output pair from the PCnet-PCI II controller for transmitting Manchester encoded data to the network. Operates at pseudo ECL levels. #### **DXCVR** #### Disable Transceiver Output The DXCVR signal is provided to power down an external transceiver or DC-to-DC converter in designs that provide more than one network connection. The polarity of the asserted state of the DXCVR output is controlled by DXCVRPOL (BCR2, bit 4). By default, the DXCVR output is high when asserted. When the 10BASE-T interface is the active network port, the DXCVR output is always deasserted. When the AUI interface is the active network port, the assertion of the DXCVR output is controlled by the setting of DX-CVRCTL (BCR2, bit 5). Note that the DXCVR pin is multiplexed with the NOUT pin. #### **Twisted Pair Interface** ### **LNKST** Link Status Output This output is designed to directly drive an LED. By default, $\overline{\text{LNKST}}$ indicates an active link connection on the 10BASE-T interface. This pin can also be programmed to indicate other network status (see BCR4). The $\overline{\text{LNKST}}$ pin polarity is programmable, but by default, it is active LOW. Note that the $\overline{\mathsf{LNKST}}$ pin is multiplexed with the EEDI pin. ### **RXD**± 10BASE-T Receive Data Input 10BASE-T port differential receivers. #### **TXD**± **10BASE-T Transmit Data** Output 10BASE-T port differential drivers. #### **TXP±** #### 10BASE-T Pre-Distortion Control Output These outputs provide transmit pre-distortion control in conjunction with the 10BASE-T port differential drivers. #### External Address Detection Interface #### **EAR** #### External Address Reject Low Input The incoming frame will be checked against the internally active address detection mechanisms and the result of this check will be ORd with the value on the EAR pin. The EAR pin is defined as REJECT. The pin value is "OR"ed with the internal address detection result to determine if the current frame should be accepted or rejected. The EAR pin is internally pulled-up and can be left unconnected, if the EADI interface is not used. #### **SFBD** #### Start Frame—Byte Delimiter Output An initial rising edge on the SFBD signal indicates that a start of frame delimiter has been detected. The serial bit stream will follow on the SRD signal, commencing with the destination address field. SFBD will go high for 4 bit times (400 ns) after detecting the second ONE in the SFD (Start of Frame Delimiter) of a received frame. SFBD will subsequently toggle every 400 ns (1.25 MHz frequency) with each rising edge indicating the first bit of each subsequent byte of the received serial bit stream. SFBD will be inactive during frame transmission. Note that the SFBD pin is multiplexed with the EESK and LED1 pins. #### **SRD** ### Serial Receive Data Output SRD is the decoded NRZ data from the network. This signal can be used for external address detection. When the 10BASE-T port is selected, transitions on SRD will only occur during receive activity. When the AUI port is selected, transitions on SRD will occur during both transmit and receive activity. Note that the SRD pin is multiplexed with the EEDO and LED3 pins. #### **SRDCLK** #### Serial Receive Data Clock Output Serial Receive Data is synchronous with reference to SRDCLK. When the 10BASE-T port is selected, transitions on SRDCLK will only occur during receive activity. When the AUI port is selected, transitions on SRDCLK will occur during both transmit and receive activity. Note that the SRDCLK pin is multiplexed with the $\overline{\text{LED2}}$ pin. #### **IEEE 1149.1 Test Access Port Interface** #### **TCK** #### Test Clock Input TCK is the clock input for the boundary scan test mode operation. It can operate at a frequency of up to 10 MHz. TCK has an internal pull-up resistor. The TCK input operates in the same signaling environment as the PCI bus interface. #### **TDI** #### Test Data In Input TDI is the test data input path to the PCnet-PCI II controller. The pin has an internal pull-up resistor. The TDI input operates in the same signaling environment as the PCI bus interface. #### TDO #### Test Data Out Output TDO is the test data output path from the PCnet-PCI II controller. The pin is tri-stated when the JTAG port is inactive. The TDO output operates in the same signaling environment as the PCI bus interface. #### **TMS** #### Test Mode Select Input A serial input bit stream on the TMS pin is used to define the specific boundary scan test to be executed. The pin has an internal pull-up resistor. The TMS input operates in the same signaling environment as the PCI bus interface. #### **Test Interface** #### **NOUT** #### NAND Tree Out Output When $\overline{RST}$ is asserted, the results of the NAND tree testing can be observed on the NOUT pin. Note that the NOUT pin is multiplexed with the DXCVR pin. ### **Power Supply Pins** ### $AV_{DD}$ ### **Analog Power (4 Pins)** **Power** There are four analog +5 V supply pins. Special attention should be paid to the printed circuit board layout to avoid excessive noise on these lines. Refer to Appendix B and the PCnet Family Board Design and Layout Recommendations application note (PID #19595A) for details. ### AV<sub>SS</sub> #### **Analog Ground (2 Pins)** **Power** There are two analog ground pins. Special attention should be paid to the printed circuit board layout to avoid excessive noise on these lines. Refer to Appendix B and the PCnet Family Board Design and Layout Recommendations application note (PID #19595A) for details. ### $V_{DD}$ ### **Digital Power (6 Pins)** Power There are six power supply pins that are used by the internal digital circuitry. All $V_{DD}$ pins must be connected to a +5 V supply. ### $V_{DDB}$ #### I/O Buffer Power (4 Pins) **Power** There are four power supply pins that are used by the PCI bus input/output buffer drivers. In a system with 5 V signaling environment, all VDDB pins must be connected to a +5 V supply. In a system with 3.3 V signaling environment, all $V_{DDB}$ pins must be connected to a +3.3 V supply. #### VSS #### **Digital Ground (12 Pins)** Ground There are 12 ground pins that are used by the internal digital circuitry. ### $V_{SSB}$ #### I/O Buffer Ground (8 Pins) Ground There are 8 ground pins that are used by the PCI bus input/output buffer drivers. #### **BASIC FUNCTIONS** ### **System Bus Interface Function** The PCnet-PCI II controller is designed to operate as a bus master during normal operations. Some slave I/O accesses to the PCnet-PCI II controller are required in normal operations as well. Initialization of the PCnet-PCI II controller is achieved through a combination of PCI Configuration Space accesses, bus slave accesses, bus master accesses and an optional read of a serial EEPROM that is performed by the PCnet-PCI II controller. The EEPROM read operation is performed through the Microwire interface. The ISO 8802-3 (IEEE/ANSI 802.3) Ethernet Address may reside within the serial EEPROM. Some PCnet-PCI II controller configuration registers may also be programmed by the EEPROM read operation. The Address PROM, on-chip bus-configuration registers, and the Ethernet controller registers occupy 32 bytes of address space. Both, I/O and memory mapped I/O access are supported. Base Address registers in the PCI configuration space allow locating the address space on a wide variety of starting addresses. For diskless stations, the PCnet-PCI II controller supports an Expansion ROM of up to 64 Kbytes in size. The host can map the Expansion ROM to any memory address that aligns to a 64K boundary by modifying the Expansion ROM Base Address register in the PCI configuration space. #### **Software Interface** The software interface to the PCnet-PCI II controller is divided into three parts. One part is the PCI configuration registers. They are used to identify the PCnet-PCI II controller, and are also used to setup the configuration of the device. The setup information includes the I/O or memory mapped I/O base address, mapping of the Expansion ROM and the routing of the PCnet-PCI II controller interrupt channel. This allows for a jumperless implementation. The second portion of the software interface is the direct access to the I/O resources of the PCnet-PCI II controller. The PCnet-PCI II controller occupies 32 bytes of address space that must begin on a 32-byte block boundary. The address space can be mapped into both I/O or memory space (memory mapped I/O). The I/O Base Address Register in the PCI Configuration Space defines the start address of the address space if it is mapped to I/O space. The Memory Mapped I/O Base Address Register defines the start address of the address space if it is mapped to memory space. The 32-byte address space is used by the software to program the PCnet-PCI II controller operating mode, enable and disable various features, monitor operating status, and request particular functions to be executed by the PCnet-PCI II controller. The third portion of the software interface is the descriptor and buffer areas that are shared between the software and the PCnet-PCI II controller during normal network operations. The descriptor area boundaries are set by the software and do not change during normal network operations. There is one descriptor area for receive activity and there is a separate area for transmit activity. The descriptor space contains relocatable pointers to the network frame data and it is used to transfer frame status from the PCnet-PCI II controller to the software. The buffer areas are locations that hold frame data for transmission or that accept frame data that has been received. #### **Network Interfaces** The PCnet-PCI II controller can be connected to an 802.3 network via one of three network interfaces. The Attachment Unit Interface (AUI) provides an ISO 8802-3 (IEEE/ANSI 802.3) compliant differential interface to a remote MAU or an on-board transceiver. The 10BASE-T interface provides a twisted-pair Ethernet port. While in auto-selection mode, the interface in use is determined by an auto-sensing mechanism which checks the link status on the 10BASE-T port. If there is no active link status, then the device assumes an AUI connection. The PCnet-PCI II controller implements half or full-duplex Ethernet over all three network interfaces. # DETAILED FUNCTIONS Slave Bus Interface Unit The slave bus interface unit (BIU) controls all accesses to the PCI configuration space, the Control and Status Registers (CSR), the Bus Configuration Registers (BCR), the Address PROM (APROM) locations and the Expansion ROM. The table below shows the response of the PCnet-PCI II controller to each of the PCI commands in slave mode. **Table 2. Slave Commands** | C[3:0] | Command | Use | | | |--------|-------------------------|---------------------------------------------------------------------------------|--|--| | 0000 | Interrupt Acknowledge | Not used | | | | 0001 | Special Cycle | Not used | | | | 0010 | I/O Read | Read of CSR, BCR, APROM | | | | 0011 | I/O Write | Write to CSR, BCR, and APROM | | | | 0100 | Reserved | | | | | 0101 | Reserved | | | | | 0110 | Memory Read | Memory mapped I/O read of CSR, BCR, APROM<br>Read of the Expansion ROM | | | | 0111 | Memory Write | Memory mapped I/O write of CSR, BCR, and APROM Dummy Write to the Expansion ROM | | | | 1000 | Reserved | | | | | 1001 | Reserved | | | | | 1010 | Configuration Read | Read of the Configuration Space | | | | 1011 | Configuration Write | Write to the Configuration Space | | | | 1100 | Memory Read Multiple | Aliased to Memory Read | | | | 1101 | Dual Address Cycle | Not used | | | | 1110 | Memory Read Line | Aliased to Memory Read | | | | 1111 | Memory Write Invalidate | Aliased to Memory Write | | | #### **Slave Configuration Transfers** The host can access the PCnet-PCI II controller PCI configuration space with a configuration read or write command. The PCnet-PCI II controller will assert DEVSEL during the address phase when IDSEL is asserted, AD[1:0] are both ZERO, and the access is a configuration cycle. AD[7:2] select the DWord location in the configuration space. The PCnet-PCI II controller ignores AD[10:8], because it is a single function device. AD[31:11] are don't care. The active bytes within a DWord are determined by the byte enable signals. 8-bit, 16-bit and 32-bit transfers are supported. DEVSEL is asserted two clock cycles after the host has asserted FRAME. All configuration cycles are of fixed length. The PCnet-PCI II controller will assert TRDY on the 4th clock of the data phase. The PCnet-PCI II controller does not support burst transfers for access to configuration space. When the host keeps FRAME asserted for a second data phase, the PCnet-PCI II controller will disconnect the transfer. When the host tries to access the PCI configuration space while the automatic read of the EEPROM after H\_RESET is on-going, the PCnet-PCI II controller will terminate the access on the PCI bus with a disconnect/retry response. The PCnet-PCI II controller supports fast back-to-back transactions to different targets. This is indicated by the Fast Back-To-Back Capable bit (PCI Status register, bit 7), which is hardwired to ONE. The PCnet-PCI II controller is capable of detecting a configuration cycle even when its address phase immediately follows the data phase of a transaction to a different target without any idle state in-between. There will be no contention on the DEVSEL, TRDY and STOP signals, since the PCnet-PCI II controller asserts DEVSEL on the second clock after FRAME is asserted (medium timing). | AD31 — AD11 | AD10 — AD8 | AD7 — AD2 | AD1 | AD0 | |-------------|------------|-------------|-----|-----| | Don't care | Don't care | DWord index | 0 | 0 | 19436C-4 Figure 1. Slave Configuration Read 19436C-5 27 Figure 2. Slave Configuration Write #### Slave I/O Transfers After the PCnet-PCI II controller is configured as an I/O device by setting IOEN (for regular I/O mode) or MEMEN (for memory mapped I/O mode) in the PCI Command register, it starts monitoring the PCI bus for access to its CSR, BCR or EEPROM locations. If configured for regular I/O mode, the PCnet-PCI II controller will look for an address that falls within its 32 bytes of I/O address space (starting from the I/O base address). The PCnet-PCI II controller asserts DEVSEL if it detects an address match and the access is an I/O cycle. If configured for memory mapped I/O mode, the PCnet-PCI II controller will look for an address that falls within its 32 bytes of memory address space (starting from the memory mapped I/O base address). The PCnet-PCI II controller asserts DEVSEL if it detects an address match and the access is a memory cycle. DEVSEL is asserted two clock cycles after the host has asserted FRAME. The PCnet-PCI II controller will not assert DEVSEL if it detects an address match, but the PCI command is not of the correct type. In memory mapped I/O mode, the PCnet-PCI II controller aliases all accesses to the I/O resources of the command types "Memory Read Multiple" and "Memory Read Line" to the basic Memory Read command. All accesses of the type "Memory Write and Invalidate" are aliased to the basic Memory Write command. 8-bit, 16-bit and 32-bit non-burst transactions are supported. The PCnet-PCI II controller decodes only the upper 30 address lines to determine which I/O resource is accessed. The typical number of wait states added to a slave I/O or memory mapped I/O read or write access on the part of the PCnet-PCI II controller is 6 to 7 clock cycles, depending upon the relative phases of the internal Buffer Management Unit clock and the CLK signal, since the internal Buffer Management Unit clock is a divide-by-two version of the CLK signal. The PCnet-PCI II controller does not support burst transfers for access to its I/O resources. When the host keeps FRAME asserted for a second data phase, the PCnet-PCI II controller will disconnect the transfer. The PCnet-PCI II controller supports fast back-to-back transactions to different targets. This is indicated by the Fast Back-To-Back Capable bit (PCI Status register, bit 7), which is hardwired to ONE. The PCnet-PCI II controller is capable of detecting an I/O or a memory mapped I/O cycle even when its address phase immediately follows the data phase of a transaction to a different target, without any idle state in-between. There will be no contention on the DEVSEL, TRDY and STOP signals, since the PCnet-PCI II controller asserts DEVSEL on the second clock after FRAME is asserted (medium timing). Figure 3. Slave Read Using I/O Command Figure 4. Slave Write Using Memory Command #### **Expansion ROM Transfers** The host must initialize the Expansion ROM Base Address register at offset 30h in the PCI configuration space with a valid address before enabling the access to the device. The base address must be aligned to a 64K boundary as indicated by ROMSIZE (PCI Expansion ROM Base Address register, bits 15-11). The PCnet-PCI II controller will not react to any access to the Expansion ROM until both MEMEN (PCI Command register, bit 1) and ROMEN (PCI Expansion ROM Base Address register, bit 0) are set to ONE. After the Expansion ROM is enabled, the PCnet-PCl II controller will assert DEVSEL on all memory read accesses with an address between ROMBASE and ROMBASE + 64K -4. The PCnet-PCI II controller aliases all accesses to the Expansion ROM of the command types "Memory Read Multiple" and "Memory Read Line" to the basic Memory Read command. Eight-bit, 16-bit and 32-bit read transfers are supported. Since setting MEMEN also enables memory mapped access to the I/O resources, attention must be given the PCI Memory Mapped I/O Base Address register, before enabling access to the Expansion ROM. The host must set the PCI Memory Mapped I/O Base Ad- dress register to a value that prevents the PCnet-PCI II controller from claiming any memory cycles not intended for it. The PCnet-PCI II controller will always read four bytes for every host Expansion ROM read access. TRDY will not be asserted until all four bytes are loaded into an internal scratch register. The cycle TRDY is asserted depends on the programming of the Expansion ROM interface timing. The following figure assumes that ROMTMG (BCR18, bits 15–12) is at its default value. Since the target latency for the Expansion ROM access is considerably long, the PCnet-PCI II controller disconnects at the second data phase, when the host tries do to perform a burst read operation of the Expansion ROM. This behavior complies with the requirements for latency issues in the PCI environment and allows other devices to get fair access to the bus. When the host tries to write to the Expansion ROM, the PCnet-PCI II controller will claim the cycle by asserting DEVSEL. TRDY will be asserted one clock cycle later. The write operation will have no effect. The PCnet-PCI II controller supports fast back-to-back transactions to different targets. This is indicated by the Fast Back-To-Back Capable bit (PCI Status register, bit 7), which is hardwired to ONE. The PCnet-PCI II controller is capable of detecting a memory cycle even when its address phase immediately follows the data phase of a transaction to a different target without any idle state in-between. There will be no contention on the DEVSEL, TRDY and STOP signals, since the PC-net-PCI II controller asserts DEVSEL on the second clock after FRAME is asserted (medium timing). Figure 5. Expansion ROM Read #### **Exclusive Access** The host can lock a set of transactions to the PCnet-PCI II controller. The lock allows exclusive access to the device and can be used to guarantee atomic operations. The PCnet-PCI II controller transitions from the unlocked to the locked state when LOCK is deasserted during the address phase of a transaction that selects the device as the target. The controller stays in the locked state until both FRAME and LOCK are deasserted, or until the device signals a target abort. Note that this protocol means the device locks itself on any normal transaction. The controller will unlock automatically at the end of a normal transaction, because FRAME and LOCK will be deasserted. The lock spans over the whole slave address space. The lock only applies to slave accesses. The PCnet-PCI II controller might perform bus master cycles while being locked in slave mode. When another master tries to access the PCnet-PCI II controller while it is in the locked state, the device terminates the access with a disconnect/retry sequence. #### **Slave Cycle Termination** There are three scenarios besides normal completion of a transaction where the PCnet-PCI II controller is the target of a slave cycle and it will terminate the access. #### Disconnect When Busy The PCnet-PCI II controller cannot service any slave access while it is reading the contents of the Microwire EEPROM. Simultaneous access is not possible to avoid conflicts, since the Microwire EEPROM is used to initialize some of the PCI configuration space locations and most of the BCRs. The Microwire EEPROM read operation will always happen automatically after the deassertion of the $\overline{RST}$ pin. In addition, the host can start the read operation by setting the PREAD bit (BCR19, bit 14). While the EEPROM read is on-going, the PCnet-PCI II controller will disconnect any slave access where it is the target by asserting $\overline{STOP}$ together with $\overline{DEVSEL}$ , while driving $\overline{TRDY}$ high. $\overline{STOP}$ will stay asserted until the host removes $\overline{FRAME}$ . Note that I/O and memory slave accesses will only be disconnected if they are enabled by setting the IOEN or MEMEN bit in the PCI Command register. Without the enable bit set, the cycles will not be claimed at all. Since H\_RESET clears the IOEN and MEMEN bits, for the automatic EEPROM read after H\_RESET the disconnect only applies to configuration cycles. A second situation where the PCnet-PCI II controller will generate a PCI disconnect/retry cycle is when the host tries to access any of the I/O resources right after having read the Reset register. Since the access generates an internal reset pulse of about 1 $\mu s$ in length, all further slave accesses will be deferred until the internal reset operation is completed. Figure 6. Disconnect Of Slave Cycle When Busy Am79C970A 31 #### Disconnect Of Burst Transfer The PCnet-PCI II controller does not support burst access to the configuration space, the I/O resources, or to the Expansion ROM. The host indicates a burst transaction by keeping FRAME asserted during the data phase. When the PCnet-PCI II controller sees FRAME and IRDY asserted in the clock cycle before it wants to asserts TRDY, it also asserts STOP at the same time. The transfer of the first data phase is still successful, since IRDY and TRDY are both asserted. Figure 7. Disconnect Of Slave Burst Transfer—No Host Wait States When the host is not yet ready when the PCnet-PCI II controller asserts TRDY, the device will wait for the host to assert IRDY. When the host asserts IRDY and FRAME is still asserted, the PCnet-PCI II controller will finish the first data phase by deasserting $\overline{TRDY}$ one clock later. At the same time, it will assert $\overline{STOP}$ to signal a disconnect to the host. $\overline{STOP}$ will stay asserted until the host removes $\overline{FRAME}$ . Figure 8. Disconnect Of Slave Burst Transfer—Host Inserts Wait States #### Disconnect When Locked When the PCnet-PCI II controller is locked by one master and another master tries to access the controller, the device will disconnect the access. When the PCnet-PCI II controller is in the locked state and it sees LOCK asserted together with FRAME, it knows that an- other master tried to access it. The PCnet-PCI II controller will respond to the access by asserting STOP together with DEVSEL while driving TRDY high, thereby disconnecting the cycle. STOP will stay asserted until the other master removes FRAME. Figure 9. Disconnect Of Slave Cycle When Locked ### **Parity Error Response** When the PCnet-PCI II controller is not the current bus master, it samples the AD[31:0], C/BE[3:0] and the PAR lines during the address phase of any PCI command for a parity error. When it detects an address parity error, the controller sets PERR (PCI Status register, bit 15) to ONE. When reporting of that error is enabled by setting SERREN (PCI Command register, bit 8) and PERREN (PCI Command register, bit 6) to ONE, the Pcnet-PCI II controller also drives the SERR signal low for one clock cycle and sets SERR (PCI Status register, bit 14) to ONE. The assertion of SERR follows the address phase by two clock cycles. The PCnet-PCI II controller will not assert DEVSEL for a PCI transaction that has an address parity error, when PERREN and SERREN are set to ONE. Figure 10. Address Parity Error Response During the data phase of an I/O write, memory mapped I/O write or configuration write command that selects the PCnet-PCI II controller as target, the device samples the AD[31:0] and C/BE[3:0] lines for parity on the clock edge data is transferred. PAR is sampled in the following clock cycle. If a parity error is detected and reporting of that error is enabled by setting PERREN (PCI Command register, bit 6) to ONE, PERR is asserted one clock later. The parity error will always set PERR (PCI Status register, bit 15) to ONE even when PERREN is cleared to ZERO. The PCnet-PCI II controller will finish a transaction that has a data parity error in the normal way by asserting TRDY. The corrupted data will be written to the addressed location. Figure 11 shows a transaction that suffered a parity error at the time data was transferred (clock 7, IRDY and TRDY are both asserted). PERR is driven high at the beginning of the data phase and then drops low due to the parity error on clock 9, two clock cycles after the data was transferred. After PERR is driven low, the PC-net-PCI II controller drives PERR high for one clock cycle, since PERR is a sustained tri-state signal. Figure 11. Slave Cycle Data Parity Error Response ### **Master Bus Interface Unit** The master bus interface unit (BIU) controls the acquisition of the PCI bus and all accesses to the initialization block, descriptor rings and the receive and transmit buffer memory. The table below shows the usage of PCI commands by the PCnet-PCI II controller in master mode. **Table 3. Master Commands** | C[3:0] | Command | Use | |--------|-------------------------|--------------------------------------------------------------------------------------------------------| | 0000 | Interrupt Acknowledge | Not used | | 0001 | Special Cycle | Not used | | 0010 | I/O Read | Not used | | 0011 | I/O Write | Not used | | 0100 | Reserved | | | 0101 | Reserved | | | 0110 | Memory Read | Read of the Initialization Block and Descriptor Rings<br>Read of the Transmit Buffer in Non-burst Mode | | 0111 | Memory Write | Write to the Descriptor Rings and to the Receive Buffer | | 1000 | Reserved | | | 1001 | Reserved | | | 1010 | Configuration Read | Not used | | 1011 | Configuration Write | Not used | | 1100 | Memory Read Multiple | Read of the Transmit Buffer in Burst Mode | | 1101 | Dual Address Cycle | Not used | | 1110 | Memory Read Line | Read of the Transmit Buffer in Burst Mode | | 1111 | Memory Write Invalidate | Not used | # **Bus Acquisition** The PCnet-PCI II controller microcode will determine when a DMA transfer should be initiated. The first step in any PCnet-PCI II controller bus master transfer is to acquire ownership of the bus. This task is handled by synchronous logic within the BIU. Bus ownership is requested with the $\overline{\text{REQ}}$ signal and ownership is granted by the arbiter through the $\overline{\text{GNT}}$ signal. Figure 12 shows the PCnet-PCI II controller bus acquisition. REQ is asserted and the arbiter returns GNT while another bus master is transferring data. The PCnet-PCI II controller waits until the bus is idle (FRAME and IRDY deasserted) before it starts driving AD[31:0] and C/BE[3:0] on clock 5. FRAME is asserted at clock 5 indicating a valid address and command on AD[31:0] and C/BE[3:0]. The PCnet-PCI II controller does not use address stepping which is reflected by ADSTEP (bit 7) in the PCI Command register being hardwired to ZERO. In burst mode, the deassertion of $\overline{REQ}$ depends on the setting of EXTREQ (BCR18, bit 8). If EXTREQ is cleared to ZERO, $\overline{REQ}$ is deasserted at the same time as $\overline{FRAME}$ is asserted. (The PCnet-PCI II controller never performs more than one burst transaction within a single bus mastership period). If EXTREQ is set to $\overline{ONE}$ , the PCnet-PCI II controller does not deassert $\overline{REQ}$ until it starts the last data phase of the transaction. Once asserted, $\overline{\text{REQ}}$ remains active until $\overline{\text{GNT}}$ has become active, independent of subsequent setting of the STOP (CSR0, bit 2) or SPND (CSR5, bit 0). The assertion of H\_RESET or S\_RESET, however, will cause $\overline{\text{REQ}}$ to go inactive immediately. 19436C-15 Figure 12. Bus Acquisition ## **Bus Master DMA Transfers** There are four primary types of DMA transfers. The PCnet-PCI II controller uses non-burst as well as burst cycles for read and write access to the main memory. #### **Basic Non-Burst Read Transfer** By default, the PCnet-PCI II controller uses non-burst cycles in all bus master read operations. All PCnet-PCI II controller non-burst read accesses are of the PCI command type Memory Read (type 6). Note that during a non-burst read operation, all byte lanes will always be active. The PCnet-PCI II controller will internally discard unneeded bytes. The PCnet-PCI II controller typically performs more than one non-burst read transactions within a single bus mastership period. FRAME is dropped between consecutive non-burst read cycles. REQ however stays asserted until FRAME is asserted for the last transaction. The PCnet-PCI II controller supports zero wait state read cycles. It asserts IRDY immediately after the address phase and at the same time starts sampling DEVSEL. The following figure shows two non-burst read transactions. The first transaction has zero wait states. In the second transaction, the target extends the cycle by asserting TRDY one clock later. Figure 13. Non-Burst Read Transfer ### **Basic Burst Read Transfer** The PCnet-PCI II controller supports burst mode for all bus master read operations. The burst mode must be enabled by setting BREADE (BCR18, bit 6). To allow burst transfers in descriptor read operations, the PCnet-PCI II controller must also be programmed to use SWSTYLE THREE (BCR20, bits 7–0). All burst read accesses to the initialization block and descriptor ring are of the PCI command type Memory Read (type 6). Burst read accesses to the transmit buffer typically are longer than two data phases. When MEMCMD (BCR18, bit 9) is cleared to ZERO, all burst read accesses to the transmit buffer are of the PCI command type Memory Read Line (type 14). When MEMCMD (BCR18, bit 9) is set to ONE, all burst read accesses to the transmit buffer are of the PCI command type Memory Read Multiple (type 12). AD[1:0] will both be ZERO during the address phase indicating a linear burst order. Note that during a burst read operation, all byte lanes will always be active. The PCnet-PCI II controller will internally discard unneeded bytes. The PCnet-PCI II controller will always perform only a single burst read transaction per bus mastership period, where transaction is defined as one address phase and one or multiple data phases. The PCnet-PCI II controller supports zero wait state read cycles. It asserts IRDY immediately after the address phase and at the same time starts sampling DEVSEL. FRAME is deasserted when the next to last data phase is completed. The following figure shows a typical burst read access. The PCnet-PCI II controller arbitrates for the bus, is granted access, and reads three 32-bit words (DWord) from the system memory and then releases the bus. In the example, the memory system extends the data phase of the each access by one wait state. The example assumes that EXTREQ (BCR18, bit 8) is cleared to ZERO, therefore, REQ is deasserted in the same cycle as FRAME is asserted. 19436C-17 Figure 14. Burst Read Transfer (EXTREQ = 0, MEMCMD = 0) #### **Basic Non-Burst Write Transfer** By default, the PCnet-PCI II controller uses non-burst cycles in all bus master write operations. All PCnet-PCI II controller non-burst write accesses are of the PCI command type Memory Write (type 7). The byte enable signals indicate the byte lanes that have valid data. The PCnet-PCI II controller typically performs more than one non-burst write transactions within a single bus mastership period. FRAME is dropped between consecutive non-burst write cycles. REQ however stays asserted until FRAME is asserted for the last transaction. The PCnet-PCI II controller supports zero wait state write cycles except with the case of descriptor write transfers. (See the section "Descriptor DMA Transfers" for the only exception.) It asserts IRDY immediately after the address phase and at the same time starts sampling DEVSEL. The following figure shows two non-burst write transactions. The first transaction has two wait states. The target inserts one wait state by asserting $\overline{\mathsf{DEVSEL}}$ one clock late and another wait state by also asserting TRDY one clock late. The second transaction shows a zero wait state write cycle. The target asserts DEVSEL and TRDY in the same cycle as the PCnet-PCI II controller asserts IRDY. 19436C-18 Figure 15. Non-Burst Write Transfer ### **Basic Burst Write Transfer** The PCnet-PCI II controller supports burst mode for all bus master write operations. The burst mode must be enabled by setting BWRITE (BCR18, bit 5). To allow burst transfers in descriptor write operations, the PCnet-PCI II controller must also be programmed to use SWSTYLE THREE (BCR20, bits 7–0). All PCnet-PCI II controller burst write transfers are of the PCI command type Memory Write (type 7). AD[1:0] will both be ZERO during the address phase indicating a linear burst order. The byte enable signals indicate the byte lanes that have valid data. The PCnet-PCI II controller will always perform a single burst write transaction per bus mastership period, where transaction is defined as one address phase and one or multiple data phases. The PCnet-PCI II controller supports zero wait state write cycles except with the case of descriptor write transfers. (See the section "Descriptor DMA Transfers" for the only exception.) It asserts IRDY immediately after the address phase and at the same time starts sampling DEVSEL. FRAME is deasserted when the next to the last data phase is completed. The following figure shows a typical burst write access. The PCnet-PCI II controller arbitrates for the bus, is granted access, and writes four 32-bit words (DWords) to the system memory and then releases the bus. In this example, the memory system extends the data phase of the first access by one wait state. The follow- ing three data phases take one clock cycle each, which is determined by the timing of $\overline{TRDY}$ . The example assumes that EXTREQ (BCR18, bit 8) is set to ONE, therefore, $\overline{REQ}$ is not deasserted until the next to last data phase is finished. 19436C-19 Figure 16. Burst Write Transfer (EXTREQ = 1) # **Target Initiated Termination** When the PCnet-PCI II controller is a bus master, the cycles it produces on the PCI bus may be terminated by the target in one of three different ways. #### **Disconnect With Data Transfer** The figure below shows a disconnection in which one last data transfer occurs after the target asserted STOP. STOP is asserted on clock 4 to start the termi- nation sequence. Data is still transferred during this cycle, since both $\overline{\text{IRDY}}$ and $\overline{\text{TRDY}}$ are asserted. The PCnet-PCI II controller terminates the current transfer with the deassertion of $\overline{\text{FRAME}}$ on clock 5 and of $\overline{\text{IRDY}}$ one clock later. It finally releases the bus on clock 6. The PCnet-PCI II controller will re-request the bus after 2 clock cycles, if it wants to transfer more data. The starting address of the new transfer will be the address of the next untransferred data. 19436C-20 Figure 17. Disconnect With Data Transfer #### **Disconnect Without Data Transfer** The figure below shows a target disconnect sequence during which no data is transferred. $\overline{STOP}$ is asserted on clock 4 without $\overline{TRDY}$ being asserted at the same time. The PCnet-PCI II controller terminates the access with the deassertion of $\overline{FRAME}$ on clock 5 and of $\overline{IRDY}$ one clock cycle later. It finally releases the bus on clock 6. The PCnet-PCI II controller will re-request the bus after 2 clock cycles to retry the last transfer. The starting address of the new transfer will be the address of the last untransferred data. Figure 18. Disconnect Without Data Transfer ### **Target Abort** The figure below shows a target abort sequence. The target asserts $\overline{\text{DEVSEL}}$ for one clock. It then deasserts $\overline{\text{DEVSEL}}$ and asserts $\overline{\text{STOP}}$ on clock 4. A target can use the target abort sequence to indicate that it cannot service the data transfer and that it does not want the transaction to be retried. Additionally, the PCnet-PCI II controller cannot make any assumption about the success of the previous data transfers in the current transaction. The PCnet-PCI II controller terminates the current transfer with the deassertion of $\overline{\text{FRAME}}$ on clock 5 and of $\overline{\text{IRDY}}$ one clock cycle later. It finally releases the bus on clock 6. Since data integrity is not guaranteed, the PCnet-PCI II controller cannot recover from a target abort event. The PCnet-PCI II controller will reset all CSR locations to their STOP\_RESET values. The BCR and PCI config- uration registers will not be cleared. Any on-going network transmission is terminated in an orderly sequence. If less than 512 bits have been transmitted onto the network, the transmission will be terminated immediately, generating a runt packet. If 512 bits or more have been transmitted, the message will have the current FCS inverted and appended at the next byte boundary to guarantee an FCS error is detected at the receiving station. RTABORT (PCI Status register, bit 12) will be set to indicate that the PCnet-PCI II controller has received a target abort. In addition, SINT (CSR5, bit 11) will be set to ONE. When SINT is set, INTA is asserted if the enable bit SINTE (CSR5, bit 10) is set to ONE. This mechanism can be used to inform the driver of the system error. The host can read the PCI Status register to determine the exact cause of the interrupt. Figure 19. Target Abort 19436C-22 ### **Master Initiated Termination** There are three scenarios besides normal completion of a transaction where the PCnet-PCI II controller will terminate the cycles it produces on the PCI bus. ## **Preemption During Non-Burst Transaction** When the PCnet-PCI II controller performs multiple non-burst transactions, it keeps REQ asserted until the assertion of FRAME for the last transaction. When GNT is removed, the PCnet-PCI II controller will finish the current transaction and then release the bus. If it is not the last transaction, REQ will remain asserted to regain bus ownership as soon as possible. 19436C-23 Figure 20. Preemption During Non-Burst Transaction 19436C-24 ### **Preemption During Burst Transaction** When the PCnet-PCI II controller operates in burst mode, it only performs a single transaction per bus mastership period, where transaction is defined as one address phase and one or multiple data phases. The central arbiter can remove GNT at any time during the transaction. The PCnet-PCI II controller will ignore the deassertion of GNT and continue with data transfers, as long as the PCI Latency Timer is not expired. When the Latency Timer is ZERO and GNT is deasserted, the PCnet-PCI II controller will finish the current data phase, deassert FRAME, finish the last data phase and release the bus. If EXTREQ (BCR18, bit 8) is cleared to ZERO, it will immediately assert REQ to regain bus ownership as soon as possible. If EXTREQ is set to ONE, REQ will stay asserted. When the preemption occurs after the counter has counted down to ZERO, the PCnet-PCI II controller will finish the current data phase, deassert FRAME, finish the last data phase and release the bus. Note that it is important for the host to program the PCI Latency Timer according to the bus bandwidth requirement of the PCnet-PCI II controller. The host can determine this bus bandwidth requirement by reading the PCI MAX\_LAT and MIN\_GNT registers. The figure below assumes that the PCI Latency Timer has counted down to ZERO on clock 7. Figure 21. Preemption During Burst Transaction #### **Master Abort** The PCnet-PCI II controller will terminate its cycle with a Master Abort sequence if DEVSEL is not asserted within 4 clocks after FRAME is asserted. Master Abort is treated as a fatal error by the PCnet-PCI II controller. The PCnet-PCI II controller will reset all CSR locations to their STOP\_RESET values. The BCR and PCI configuration registers will not be cleared. Any on-going network transmission is terminated in an orderly sequence. If less than 512 bits have been transmitted onto the network, the transmission will be terminated immediately, generating a runt packet. If 512 bits or more have been transmitted, the message will have the current FCS inverted and appended at the next byte boundary to guarantee an FCS error is detected at the receiving station. RMABORT (in the PCI Status register, bit 13) will be set to indicate that the PCnet-PCI II controller has terminated its transaction with a master abort. In addition, SINT (CSR5, bit 11) will be set to ONE. When SINT is set, INTA is asserted if the enable bit SINTE (CSR5, bit 10) is set to ONE. This mechanism can be used to inform the driver of the system error. The host can read the PCI Status register to determine the exact cause of the interrupt. 19436C-25 Figure 22. Master Abort # **Parity Error Response** During every data phase of a DMA read operation, when the target indicates that the data is valid by asserting TRDY, the PCnet-PCI II controller samples the AD[31:0], C/BE[3:0] and the PAR lines for a data parity error. When it detects a data parity error, the controller sets PERR (PCI Status register, bit 15) to ONE. When reporting of that error is enabled by setting PERREN (PCI Command register, bit 6) to ONE, the PCnet-PCI II controller also drives the PERR signal low and sets DATAPERR (PCI Status register, bit 8) to ONE. The as- sertion of PERR follows the corrupted data/byte enables by two clock cycles and PAR by one clock cycle. The figure below shows a transaction that has a parity error in the data phase. The PCnet-PCI II controller asserts PERR on clock 8, two clock cycles after data is valid. The data on clock 5 is not checked for parity, since on a read access PAR is only required to be valid one clock after the target has asserted TRDY. The PCnet-PCI II controller then drives PERR high for one clock cycle, since PERR is a sustained tri-state signal. 19436C-26 Figure 23. Master Cycle Data Parity Error Response During every data phase of a DMA write operation, the PCnet-PCI II controller checks the PERR input to see if the target reports a parity error. When it sees the PERR input asserted, the controller sets PERR (PCI Status register, bit 15) to ONE. When PERREN (PCI Command register, bit 6) is set to ONE, the PCnet-PCI II controller also sets DATAPERR (PCI Status register, bit 8) to ONE. Whenever the PCnet-PCI II controller is the current bus master and a data parity error occurs, SINT (CSR5, bit 11) will be set to ONE. When SINT is set, INTA is asserted if the enable bit SINTE (CSR5, bit 10) is set to ONE. This mechanism can be used to inform the driver of the system error. The host can read the PCI Status register to determine the exact cause of the interrupt. The setting of SINT due to a data parity error is not dependent on the setting of PERREN (PCI Command register, bit 6). By default, a data parity error does not affect the state of the MAC engine. The PCnet-PCI II controller treats the data in all bus master transfers that have a parity error as if nothing has happened. All network activity continues. ### **Advanced Parity Error Handling** For all DMA cycles, the PCnet-PCI II controller provides a second, more advanced level of parity error handling. This mode is enabled by setting APERREN (BCR20, bit 10) to ONE. When APERREN is set to ONE, the BPE bits (RMD1 and TMD1, bit 23) are used to indicate parity error in data transfers to the receive and transmit buffers. Note that since the advanced parity error handling uses an additional bit in the descriptor, SWSTYLE (BCR20, bits 7–0) must be set to ONE, TWO or THREE to program the PCnet-PCI II controller to use 32-bit software structures. The PCnet-PCI II controller will react in the following way when a data parity error occurs: - Initialization block read: STOP (CSR0, bit 2) is set to ONE and causes a STOP RESET of the device. - Descriptor ring read: Any on-going network activity is terminated in an orderly sequence and then STOP (CSR0, bit 2) is set to ONE to cause a STOP RESET of the device. - Descriptor ring write: Any on-going network activity is terminated in an orderly sequence and then STOP (CSR0, bit 2) is set to ONE to cause a STOP RESET of the device. - Transmit buffer read: BPE (TMD1, bit 23) is set in the current transmit descriptor. Any on-going network transmission is terminated in an orderly sequence. - Receive buffer write: BPE (RMD1, bit 23) is set in the last receive descriptor associated with the frame Terminating on-going network transmission in an orderly sequence means that if less than 512 bits have been transmitted onto the network, the transmission will be terminated immediately, generating a runt packet. If 512 bits or more have been transmitted, the message will have the current FCS inverted and appended at the next byte boundary to guarantee an FCS error is detected at the receiving station. APERREN does not affect the reporting of address parity errors or data parity errors that occur when the PCnet-PCI II controller is the target of the transfer. ### **Initialization Block DMA Transfers** During execution of the PCnet-PCI II controller bus master initialization procedure, the PCnet-PCI II controller microcode will repeatedly request DMA transfers from the BIU. During each of these initialization block DMA transfers, the BIU will perform two data transfer cycles reading one DWord per transfer and then it will relinquish the bus. When SSIZE32 (BCR20, bit 8) is set to ONE (i.e. the initialization block is organized as 32-bit software structures), there are 7 DWords to transfer during the bus master initialization procedure, so four bus mastership periods are needed in order to complete the initialization sequence. Note that the last DWord transfer of the last bus mastership period of the initialization sequence accesses an unneeded location. Data from this transfer is discarded internally. When SSIZE32 is cleared to ZERO (i.e. the initialization block is organized as 16-bit software structures), then three bus mastership periods are needed to complete the initialization sequence. The PCnet-PCI II controller supports two transfer modes for reading the initialization block: non-burst and burst mode; with burst mode being the preferred mode when the PCnet-PCI II controller is used in a PCI bus application. When BREADE is cleared to ZERO (BCR18, bit 6), all initialization block read transfers will be executed in non-burst mode. There is a new address phase for every data phase. FRAME will be dropped between the two transfers. The two phases within a bus mastership period will have addresses of ascending contiguous order. 19436C-27 Figure 24. Initialization Block Read In Non-Burst Mode mode. AD[1:0] will be ZERO during the address phase indicating a linear burst order. 19436C-28 Figure 25. Initialization Block Read In Burst Mode # **Descriptor DMA Transfers** PCnet-PCI II controller microcode will determine when a descriptor access is required. A descriptor DMA read will consist of two data transfers. A descriptor DMA write will consist of one or two data transfers. The descriptor DMA transfers within a single bus mastership period will always be of the same type (either all read or all write). During descriptor read accesses, the byte enable signals will indicate that all byte lanes are active. Should some of the bytes not be needed, then the PCnet-PCI II controller will internally discard the extraneous information that was gathered during such a read. The settings of SWSTYLE (BCR20, bits 7–0) and BREADE (BCR18, bit 6) affect the way the PCnet-PCI II controller performs descriptor read operations. When SWSTYLE is set to ZERO, ONE or TWO, all descriptor read operations are performed in non-burst mode. The setting of BREADE has no effect in this configuration. When SWSTYLE is set to THREE, the descriptor entries are ordered to allow burst transfers. The PC-net-PCI II controller will perform all descriptor read operations in burst mode, if BREADE is set to ONE. **Table 4. Descriptor Read Sequence** | SWSTYLE<br>BCR18[6] | BREADE<br>BCR20[7:0] | AD Bus Sequence | |---------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | 0 | X | Address = XXXX XX00h Turn around cycle Data = MD1[31:24], MD0[23:0] Idle Address = XXXX XX04h Turn around cycle Data = MD2[15:0], MD1[15:0] | | 1,2 | X | Address = XXXX XX04h Turn around cycle Data = MD1[31:0] Idle Address = XXXX XX00h Turn around cycle Data = MD0[31:0] | | 3 | 0 | Address = XXXX XX04h Turn around cycle Data = MD1[31:0] Idle Address = XXXX XX08h Turn around cycle Data = MD0[31:0] | | 3 | 1 | Address = XXXX XX04h<br>Turn around cycle<br>Data = MD1[31:0]<br>Data = MD0[31:0] | 19436C-29 Figure 26. Descriptor Ring Read In Non-Burst Mode During descriptor write accesses, only the byte lanes which need to be written are enabled. If buffer chaining is used, accesses to the descriptors of all intermediate buffers consist of only one data transfer to return ownership of the buffer to the system. When SWSTYLE (BCR20, bits 7–0) is cleared to ZERO (i.e. the descriptor entries are organized as 16-bit software structures), the descriptor access will write a single byte. When SWSTYLE (BCR20, bits 7–0) is set to ONE, TWO or THREE (i.e. the descriptor entries are organized as 32-bit software structures), the descriptor access will write a single word. On all single buffer transmit or receive descriptors, as well as on the last buffer in chain, writes to the descriptor consist of two data transfers. The first one writing a DWord containing status information. The second data transfer writing a byte (SWSTYLE cleared to ZERO) or otherwise a word containing additional status and the ownership bit (i.e. MD1[31]). 19436C-30 Figure 27. Descriptor Ring Read In Burst Mode The settings of SWSTYLE (BCR20, bits 7–0) and BWRITE (BCR18, bit 5) affect the way the PCnet-PCI II controller performs descriptor write operations. When SWSTYLE is set to ZERO, ONE or TWO, all descriptor write operations are performed in non-burst mode. The setting of BWRITE has no effect in this configuration. When SWSTYLE is set to THREE, the descriptor entries are ordered to allow burst transfers. The PC-net-PCI II controller will perform all descriptor write operations in burst mode, if BWRITE is set to ONE. A write transaction to the descriptor ring entries is the only case where the PCnet-PCI II controller inserts a wait state when being the bus master. Every data phase in non-burst and burst mode is extended by one clock cycle, during which $\overline{\text{IRDY}}$ is deasserted. Table 5. Descriptor Write Sequence | SWSTYLE<br>BCR20[7:0] | BWRITE<br>BCR18[5] | AD Bus Sequence | |-----------------------|--------------------|----------------------------------------------------------------------------------------------------------| | 0 | Х | Address = XXXX XX04h<br>Data = MD2[15:0], MD1[15:0]<br>Idle<br>Address = XXXX XX00h<br>Data = MD1[31:24] | | 1,2 | Х | Address = XXXX XX08h Data = MD2[31:0] Idle Address = XXXX XX04h Data = MD1[31:16] | | 3 | 0 | Address = XXXX XX00h<br>Data = MD2[31:0]<br>Idle<br>Address = XXXX XX04h<br>Data = MD1[31:16] | | 3 | 1 | Address = XXXX XX00h<br>Data = MD2[31:0]<br>Data = MD1[31:16] | Note that the figure below assumes that the PCnet-PCI II controller is programmed to use 32-bit software structures (SWSTYLE = 1, 2, or 3). The byte enable signals for the second data transfer would be 0111b, if the device was programmed to use 16-bit software structures (SWSTYLE = 0). Figure 28. Descriptor Ring Write In Non-Burst Mode 19436C-32 Figure 29. Descriptor Ring Write In Burst Mode ### **FIFO DMA Transfers** PCnet-PCI II controller microcode will determine when a FIFO DMA transfer is required. This transfer mode will be used for transfers of data to and from the PCnet-PCI II controller FIFOs. Once the PCnet-PCI II controller BIU has been granted bus mastership, it will perform a series of consecutive transfer cycles before relinquishing the bus. All transfers within the master cycle will be either read or write cycles, and all transfers will be to contiguous, ascending addresses. Both non-burst and burst cycles are used, with burst mode being the preferred mode when the device is used in a PCI bus application. ### Non-Burst FIFO DMA Transfers In the default mode the PCnet-PCI II controller uses non-burst transfers to read and write data when accessing the FIFOs. Each non-burst transfer will be performed sequentially, with the issue of an address, and the transfer of the corresponding data with appropriate output signals to indicate selection of the active data bytes during the transfer. FRAME will be deasserted after every address phase. The number of data transfer cycles contained within a single bus mastership period is in general dependent on the programming of the DMAPLUS option (CSR4, bit 14). Several other factors will also affect the length of the bus mastership period. The possibilities are as follows: If DMAPLUS is cleared to ZERO, a maximum of 16 transfers will be performed by default. This default value may be changed by writing to the DMA Transfer Counter (CSR80). Note that DMAPLUS = 0 merely sets a maximum value. The minimum number of transfers in the bus mastership period will be determined by all of the following variables: the settings of the FIFO watermarks (CSR80), the conditions of the FIFOs, the value of the DMA Transfer Counter (CSR80), the value of the DMA Bus Timer (CSR82), and any occurrence of preemption that takes place during the bus mastership period. If DMAPLUS is set to ONE, bus cycles will continue until the transmit FIFO is filled to its high threshold (read transfers) or the receive FIFO is emptied to its low threshold (write transfers), or until the DMA Bus Activity Timer (CSR82) has expired. The exact number of total transfer cycles in the bus mastership period is dependent on all of the following variables: the settings of the FIFO watermarks, the conditions of the FIFOs, the latency of the system bus to the PCnet-PCI II controller's bus request, the speed of bus operation and bus preemption events. The DMA Transfer Counter is disabled when DMAPLUS is set to ONE. The TRDY response time of the memory device will also affect the number of transfers, since the speed of the accesses will affect the state of the FIFO. During accesses, the FIFO may be filling or emptying on the network end. For example, on a receive operation, a slower TRDY response will allow additional data to accumulate inside of the FIFO. If the accesses are slow enough, a complete DWord may become available before the end of the bus mastership period and thereby increase the number of transfers in that period. The general rule is that the longer the Bus Grant latency, the slower the bus transfer operations, the slower the clock speed, the higher the transmit watermark or the lower the receive watermark, the longer the bus mastership period will be Note that the PCI Latency Timer is not significant during non-burst transfers. #### **Burst FIFO DMA Transfers** Bursting is only performed by the PCnet-PCI II controller if the BREADE and/or BWRITE bits of BCR18 are set. These bits individually enable/disable the ability of the PCnet-PCI II controller to perform burst accesses during master read operations and master write operations, respectively. A burst transaction will start with an address phase, followed by one or more data phases. AD[1:0] will always be ZERO during the address phase indicating a linear burst order. During FIFO DMA read operations, all byte lanes will always be active. The PCnet-PCI II controller will internally discard unused bytes. During the first and the last data phases of a FIFO DMA burst write operation, one or more of the byte enable signals may be inactive. All other data phases will always write a complete DWord. 19436C-33 The following figure shows the beginning of a FIFO DMA write with the beginning of the buffer not aligned to a DWord boundary. The PCnet-PCI II controller starts off by writing only three bytes during the first data phase. This operation aligns the address for all other data transfers to a 32-bit boundary so that the PC-net-PCI II controller can continue bursting full DWords. Figure 30. FIFO Burst Write At Start Of Unaligned Buffer If a receive buffer does not end on a DWord boundary, the PCnet-PCI II controller will perform a non-DWord write on the last transfer to the buffer. The following figure shows the final three FIFO DMA transfers to a receive buffer. Since there were only nine bytes of space left in the receive buffer, the PCnet-PCI II controller burst three data phases. The first two data phases write a full DWord, the last one only writes a single byte. Note that the PCnet-PCI II controller will always perform a DWord transfer as long as it owns the buffer space, even when there are less then four bytes to write. For example, if there is only one byte left for the current receive frame, the PCnet-PCI II controller will write a full DWord, containing the last byte of the receive frame in the least significant byte position (BSWP is cleared to ZERO, CSR3, bit 2). The content of the other three bytes is undefined. The message byte count in the receive descriptor always reflects the exact length of the received frame. 19436C-34 Figure 31. FIFO Burst Write At End Of Unaligned Buffer In a PCI bus application the PCnet-PCI II controller should be set up to have the length of a bus mastership period be controlled only by the PCI Latency Timer. The Timer bit (CSR4, bit 13) should remain at its default value of ZERO so that the DMA Bus Activity Timer (CSR82) is not enabled. The DMA Transfer Counter (CSR80) should be disabled by setting DMAPLUS (CSR4, bit 14) to ONE. In this mode, the PCnet-PCI II controller will continue transferring FIFO data until the transmit FIFO is filled to its high threshold (read transfers) or the receive FIFO is emptied to its low threshold (write transfers), or the PCnet-PCI II controller is preempted, and the PCI Latency Timer is expired. The host should use the values in the PCI MIN\_GNT and MAX\_LAT registers to determine the value for the PCI Latency Timer. In applications that don't use the PCI Latency Timer or that don't support preemption the following rules apply to limit the time the PCnet-PCI II controller takes up on the bus. If DMAPLUS is cleared to ZERO, a maximum of 16 transfers will be performed by default. This default value may be changed by writing to the DMA Transfer Counter (CSR80). Note that DMAPLUS = 0 merely sets a maximum value. The minimum number of transfers in the bus mastership period will be determined by all of the following variables: the settings of the FIFO watermarks (CSR80), the conditions of the FIFOs, the value of the DMA Transfer Counter (CSR80) and the value of the DMA Bus Activity Timer (CSR82). If DMAPLUS is set to ONE, bursting will continue until the transmit FIFO is filled to its high threshold (read transfers) or the receive FIFO is emptied to its low threshold (write transfers), or until the DMA Bus Activity Timer (CSR82) has expired. The exact number of total transfer cycles in the bus mastership period is dependent on all of the following variables: the settings of the FIFO watermarks, the conditions of the FIFOs, the latency of the system bus to the PCnet-PCI II controller's bus request, and the speed of bus operation. The DMA Transfer Counter is disabled when DMAPLUS is set to ONE. The TRDY response time of the memory device will also affect the number of transfers, since the speed of the accesses will affect the state of the FIFO. During accesses, the FIFO may be filling or emptying on the network end. For example, on a receive operation, a slower TRDY response will allow additional data to accumulate inside of the FIFO. If the accesses are slow enough, a complete DWord may become available before the end of the bus mastership period and thereby increase the number of transfers in that period. The general rule is that the longer the Bus Grant latency, the slower the bus transfer operations, the slower the clock speed, the higher the transmit watermark or the lower the receive watermark, the longer the total burst length will be. When a FIFO DMA burst operation is preempted, the PCnet-PCI II controller will not relinquish bus ownership until the PCI Latency Timer expires. The DMA Transfer Counter will freeze at the current value while the PCnet-PCI II controller is waiting to regain bus ownership. It will continue counting when the FIFO DMA burst operation restarts. The Bus Activity Timer will be reset to its starting value when the PCnet-PCI II controller regains bus ownership. The PCI Latency Timer cannot be disabled. Systems that support preemption and that want to control the duration of the PCnet-PCI II controller bus mastership period with the DMA Transfer Counter or the Bus Activity Timer must program the PCI Latency Timer with a high value so that it does not expire before the other two registers do. #### **BUFFER MANAGEMENT UNIT** The Buffer Management Unit (BMU) is a microcoded state machine which implements the initialization procedure and manages the descriptors and buffers. The buffer management unit operates at half the speed of the CLK input. #### Initialization PCnet-PCI II controller initialization includes the reading of the initialization block in memory to obtain the operating parameters. The initialization block can be organized in two ways. When SSIZE32 (BCR20, bit 8) is at its default value of ZERO, all initialization block entries are logically 16-bits wide to be backwards compatible with the Am79C90 C-LANCE and Am79C96x PCnet-ISA family. When SSIZE32 (BCR20, bit 8) is set to ONE, all initialization block entries are logically 32-bits wide. Note that the PCnet-PCI II controller alwavs performs 32-bit bus transfers to read the initialization block entries. The initialization block is read when the INIT bit in CSR0 is set. The INIT bit should be set before or concurrent with the STRT bit to insure correct operation. Once the initialization block has been completely read in and internal registers have been updated, IDON will be set in CSR0, generating an interrupt (if IENA is set). The PCnet-PCI II controller obtains the start address of the initialization block from the contents of CSR1 (least significant 16 bits of address) and CSR2 (most significant 16 bits of address). The host must write CSR1 and CSR2 before setting the INIT bit. The initialization block contains the user defined conditions for PCnet-PCI II controller operation, together with the base addresses and length information of the transmit and receive descriptor rings. There is an alternate method to initialize the PCnet-PCI II controller. Instead of initialization via the initialization block in memory, data can be written directly into the appropriate registers. Either method or a combination of the two may be used at the discretion of the programmer. Please refer to Appendix C for details on this alternate method. #### Re-Initialization The transmitter and receiver sections of the PCnet-PCI II controller can be turned on via the initialization block (DTX, DRX, CSR15, bits 1–0). The states of the transmitter and receiver are monitored by the host through CSR0 (RXON, TXON bits). The PCnet-PCI II controller should be re-initialized if the transmitter and/or the receiver were not turned on during the original initialization, and it was subsequently required to activate them or if either section was shut off due to the detection of an error condition (MERR, UFLO, TX BUFF error). Re-initialization may be done via the initialization block or by setting the STOP bit in CSR0, followed by writing to CSR15, and then setting the START bit in CSR0. Note that this form of restart will not perform the same in the PCnet-PCI II controller as in the CLANCE. In particular, upon restart, the PCnet-PCI II controller reloads the transmit and receive descriptor pointers with their respective base addresses. This means that the software must clear the descriptor OWN bits and reset its descriptor ring pointers before restarting the PCnet-PCI II controller. The reload of descriptor base addresses is performed in the CLANCE only after initialization, so a restart of the CLANCE without initialization leaves the CLANCE pointing at the same descriptor locations as before the restart. ### Suspend The PCnet-PCI II controller offers a suspend mode that allows easy updating of the CSR registers without going through a full re-initialization of the device. The suspend mode also allows stopping the device with orderly termination of all network activity. The host requests the PCnet-PCI II controller to enter the suspend mode by setting SPND (CSR5, bit 0) to ONE. When the host sets SPND to ONE, the PCnet-PCI II controller first finishes all on-going transmit activity and updates the corresponding transmit descriptor entries. It then finishes all on-going receive activity and updates the corresponding receive descriptor entries. It then sets the read-version of SPND to ONE and enters the suspend mode. The host must poll SPND until it reads back ONE to determine that the PCnet-PCI II controller has entered the suspend mode. In suspend mode, all of the CSR and BCR registers are accessible. As long as the PCnet-PCI II controller is not reset while in suspend mode (by H\_RESET, S\_RESET or by setting the STOP bit), no re-initialization of the device is required after the device comes out of suspend mode. When the host clears SPND, the PCnet-PCI II controller will leave the suspend mode and will continue at the transmit and receive descriptor ring locations, where it had left off. ### **Buffer Management** Buffer management is accomplished through message descriptor entries organized as ring structures in memory. There are two descriptor rings, one for transmit and one for receive. Each descriptor describes a single buffer. A frame may occupy one or more buffers. If multiple buffers are used, this is referred to as buffer chaining. #### **Descriptor Rings** Each descriptor ring must occupy a contiguous area of memory. During initialization the user-defined base address for the transmit and receive descriptor rings, as well as the number of entries contained in the descriptor rings are set up. The programming of the software style (SWSTYLE, BCR20, bits 7–0) affects the way the descriptor rings and their entries are arranged. When SWSTYLE is at its default value of ZERO, the descriptor rings are backwards compatible with the Am79C90 C-LANCE and Am79C96x PCnet-ISA family. The descriptor ring base addresses must be aligned to an 8-byte boundary and a maximum of 128 ring entries is allowed when the ring length is set through the TLEN and RLEN fields of the initialization block. Each ring entry contains a subset of the three 32-bit transmit or receive message descriptors (TMD, RMD) that are organized as four 16-bit structures (SSIZE (BCR20, bit 8) is set to ZERO). Note that even though the PCnet-PCI II controller treats the descriptor entries as 16-bit structures, it will always perform 32-bit bus transfers to access the descriptor entries. The value of CSR2, bits 15-8 is used as the upper 8-bits for all memory addresses during bus master transfers. When SWSTYLE is set to ONE, TWO or THREE, the descriptor ring base addresses must be aligned to a 16-byte boundary and a maximum of 512 ring entries is allowed when the ring length is set through the TLEN and RLEN fields of the initialization block. Each ring entry is organized as three 32-bit message descriptors (SSIZE32 (BCR20, bit 8) is set to ONE). The fourth DWord is reserved. When SWSTYLE is set to THREE, the order of the message descriptors is optimized to allow read and write access in burst mode. For any software style, the ring lengths can be set beyond this range (up to 65535) by writing the transmit and receive ring length registers (CSR76, CSR78) directly Each ring entry contains the following information: - The address of the actual message data buffer in user or host memory - The length of the message buffer - Status information indicating the condition of the buffer To permit the queuing and de-queuing of message buffers, ownership of each buffer is allocated to either the PCnet-PCI II controller or the host. The OWN bit within the descriptor status information, either TMD or RMD, is used for this purpose. When OWN is set to ONE, it signifies that the PCnet-PCI II controller currently has ownership of this ring descriptor and its associated buffer. Only the owner is permitted to relinquish ownership or to write to any field in the descriptor entry. A device that is not the current owner of a descriptor entry cannot assume ownership or change any field in the entry. A device may, however, read from a descriptor that it does not currently own. Software should always read descriptor entries in sequential order. When software finds that the current descriptor is owned by the PCnet-PCI II controller, then the software must not read ahead to the next descriptor. The software should wait at a descriptor it does not own until the PCnet-PCI II controller sets OWN to ZERO to release ownership to the software. (When LAPPEN (CSR3, bit 5) is set to ONE, this rule is modified. See the LAPPEN description.) At initialization, the PCnet-PCI II controller reads the base address of both the transmit and receive descriptor rings into CSRs for use by the PCnet-PCI II controller during subsequent operations. The following figure illustrates the relationship between the initialization base address, the initialization block, the receive and transmit descriptor ring base addresses, the receive and transmit descriptors and the receive and transmit data buffers, when SSIZE32 is cleared to ZERO. Note that the value of CSR2, bits 15–8 is used as the upper 8-bits for all memory addresses during bus master transfers. 19436C-35 Figure 32. 16-Bit Software Model The following figure illustrates the relationship between the initialization base address, the initialization block, the receive and transmit descriptor ring base addresses, the receive and transmit descriptors and the receive and transmit data buffers, when SSIZE32 is set to ONE. Figure 33. 32-bit Software Model # **Polling** 64 If there is no network channel activity and there is no pre- or post-receive or pre- or post-transmit activity being performed by the PCnet-PCI II controller, then the PCnet-PCI II controller will periodically poll the current receive and transmit descriptor entries in order to ascertain their ownership. If the DPOLL bit in CSR4 is set, then the transmit polling function is disabled. A typical polling operation consists of the following: The PCnet-PCI II controller will use the current receive descriptor address stored internally to vector to the appro- priate Receive Descriptor Table Entry (RDTE). It will then use the current transmit descriptor address (stored internally) to vector to the appropriate Transmit Descriptor Table Entry (TDTE). The accesses will be made in the following order: RMD1, then RMD0 of the current RDTE during one bus arbitration, and after that, TMD1, then TMD0 of the current TDTE during a second bus arbitration. All information collected during polling activity will be stored internally in the appropriate CSRs, if the OWN bit is set. (i.e. CSR18, CSR19, CSR20, CSR21, CSR40, CSR42, CSR50, CSR52). A typical receive poll is the product of the following conditions: - PCnet-PCI II controller does not own the current DTE and the poll time has elapsed and RXON = 1 (CSR0, bit 5), or - 2. PCnet-PCI II controller does not own the next RDTE and there is more than one receive descriptor in the ring and the poll time has elapsed and RXON = 1. If RXON is cleared to ZERO, the PCnet-PCI II controller will never poll RDTE locations. In order to avoid missing frames the system should have at least on RDTE available. To minimize poll activity two RDTEs should be available. In this case, the poll operation will only consist of the check of the status of the current TDTE. A typical transmit poll is the product of the following conditions: - 1. PCnet-PCI II controller does not own the current TDTE and DPOLL = 0 (CSR4, bit 12) and TXON = 1 (CSR0, bit 4) and the poll time has elapsed, or - PCnet-PCI II controller does not own the current TDTE and DPOLL = 0 and TXON = 1 and a frame has just been received, or - PCnet-PCI II controller does not own the current TDTE and DPOLL = 0 and TXON = 1 and a frame has just been transmitted. Setting the TDMD bit of CSR0 will cause the microcode controller to exit the poll counting code and immediately perform a polling operation. If RDTE ownership has not been previously established, then an RDTE poll will be performed ahead of the TDTE poll. If the microcode is not executing the poll counting code when the TDMD bit is set, then the demanded poll of the TDTE will be delayed until the microcode returns to the poll counting code. The user may change the poll time value from the default of 65,536 clock periods by modifying the value in the Polling Interval register (CSR47). ### **Transmit Descriptor Table Entry** If, after a Transmit Descriptor Table Entry (TDTE) access, the PCnet-PCI II controller finds that the OWN bit of that TDTE is not set, the PCnet-PCI II controller resumes the poll time count and re-examines the same TDTE at the next expiration of the poll time count. If the OWN bit of the TDTE is set, but the Start of Packet (STP) bit is not set, the PCnet-PCI II controller will immediately request the bus in order to clear the OWN bit of this descriptor. (This condition would normally be found following a late collision (LCOL) or retry (RTRY) error that occurred in the middle of a transmit frame chain of buffers.) After resetting the OWN bit of this descriptor, the PCnet-PCI II controller will again immediately request the bus in order to access the next TDTE location in the ring. If the OWN bit is set and the buffer length is 0, the OWN bit will be cleared. In the C-LANCE the buffer length of 0 is interpreted as a 4096-byte buffer. A zero length buffers is acceptable as long as it is not the last buffer in a chain (STP = 0 and ENP = 1). If the OWN bit and STP are set, then microcode control proceeds to a routine that will enable transmit data transfers to the FIFO. The PCnet-PCI II controller will look ahead to the next transmit descriptor after it has performed at least one transmit data transfer from the first buffer. If the PCnet-PCI II controller does not own the next TDTE (i.e. the second TDTE for this frame), it will complete transmission of the current buffer and update the status of the current (first) TDTE with the BUFF and UFLO bits being set. If DXSUFLO (CSR3, bit 6) is cleared to ZERO, the underflow error will cause the transmitter to be disabled (CSR0, TXON = 0). The PCnet-PCI II controller will have to be re-initialized to restore the transmit function. Setting DXSUFLO to ONE enables the PCnet-PCI II controller to gracefully recover from an underflow error. The device will scan the transmit descriptor ring until it finds either the start of a new frame or a TDTE it does not own. To avoid an underflow situation in a chained buffer transmission, the system should always set the transmit chain descriptor own bits in reverse order. If the PCnet-PCI II controller does own the second TDTE in a chain, it will gradually empty the contents of the first buffer (as the bytes are needed by the transmit operation), perform a single-cycle DMA transfer to update the status of the first descriptor (clear the OWN bit in TMD1), and then it may perform one data DMA access on the second buffer in the chain before executing another lookahead operation. (i.e. a lookahead to the third descriptor.) It is imperative that the host system never reads the TDTE OWN bits out of order. The PCnet-PCI II controller normally clears OWN bits in strict FIFO order. However, the PCnet-PCI II controller can queue up to two frames in the transmit FIFO. When the second frame uses buffer chaining, the PCnet-PCI II controller might return ownership out of normal FIFO order. The OWN bit for last (and maybe only) buffer of the first frame is not cleared until transmission is completed. During the transmission the PCnet-PCI II controller will read in buffers for the next frame and clear their OWN bits for all but the last one. The first and all intermediate buffers of the second frame can have their OWN bits cleared before the PCnet-PCI II controller returns ownership for the last buffer of the first frame. If an error occurs in the transmission before all of the bytes of the current buffer have been transferred, transmit status of the current buffer will be immediately updated. If the buffer does not contain the end of packet, the PCnet-PCI II controller will skip over the rest of the frame which experienced the error. This is done by returning to the polling microcode where the PCnet-PCI II controller will clear the OWN bit for all descriptors with OWN = 1 and STP = 0 and continue in like manner until a descriptor with OWN = 0 (no more transmit frames in the ring) or OWN = 1 and STP = 1 (the first buffer of a new frame) is reached. At the end of any transmit operation, whether successful or with errors, immediately following the completion of the descriptor updates, the PCnet-PCI II controller will always perform another polling operation. As described earlier, this polling operation will begin with a check of the current RDTE, unless the PCnet-PCI II controller already owns that descriptor. Then the PCnet-PCI II controller will poll the next TDTE. If the transmit descriptor OWN bit has a ZERO value, the PCnet-PCI II controller will resume incrementing the poll time counter. If the transmit descriptor OWN bit has a value of ONE, the PCnet-PCI II controller will begin filling the FIFO with transmit data and initiate a transmission. This end-of-operation poll coupled with the TDTE lookahead operation allows the PCnet-PCI II controller to avoid inserting poll time counts between successive transmit frames. By default, whenever the PCnet-PCI II controller completes a transmit frame (either with or without error) and writes the status information to the current descriptor, then the TINT bit of CSR0 is set to indicate the completion of a transmission. This causes an interrupt signal if the IENA bit of CSR0 has been set and the TINTM bit of CSR3 is cleared. The PCnet-PCI II controller provides two modes to reduce the number of transmit interrupts. The interrupt of a successfully transmitted frame can be suppressed by setting TINTOKD (CSR5, bit 15) to ONE. Another mode, which is enabled by setting LTINTEN (CSR5, bit 14) to ONE, allows suppression of interrupts for successful transmissions for all but the last frame in a sequence. #### **Receive Descriptor Table Entry** If the PCnet-PCI II controller does not own both the current and the next Receive Descriptor Table Entry (RDTE) then the PCnet-PCI II controller will continue to poll according to the polling sequence described above. If the receive descriptor ring length is one, then there is no next descriptor to be polled. If a poll operation has revealed that the current and the next RDTE belong to the PCnet-PCI II controller then additional poll accesses are not necessary. Future poll operations will not include RDTE accesses as long as the PCnet-PCI II controller retains ownership of the current and the next RDTE. When receive activity is present on the channel, the PCnet-PCI II controller waits for the complete address of the message to arrive. It then decides whether to accept or reject the frame based on all active addressing schemes. If the frame is accepted the PCnet-PCI II controller checks the current receive buffer status register CRST (CSR41) to determine the ownership of the current buffer. If ownership is lacking, the PCnet-PCI II controller will immediately perform a final poll of the current RDTE. If ownership is still denied, the PCnet-PCI II controller has no buffer in which to store the incoming message. The MISS bit will be set in CSR0 and the Missed Frame Counter (CSR112) will be incremented. An interrupt will be generated if IENA (CSR0, bit 6) is set to ONE and MISSM (CSR3, bit 12) is cleared to ZERO. Another poll of the current RDTE will not occur until the frame has finished. If the PCnet-PCI II controller sees that the last poll (either a normal poll, or the final effort described in the above paragraph) of the current RDTE shows valid ownership, it proceeds to a poll of the next RDTE. Following this poll, and regardless of the outcome of this poll, transfers of receive data from the FIFO may begin. Regardless of ownership of the second receive descriptor, the PCnet-PCI II controller will continue to perform receive data DMA transfers to the first buffer. If the frame length exceeds the length of the first buffer, and the PCnet-PCI II controller does not own the second buffer, ownership of the current descriptor will be passed back to the system by writing a ZERO to the OWN bit of RMD1 and status will be written indicating buffer (BUFF = 1) and possibly overflow (OFLO = 1) errors If the frame length exceeds the length of the first (current) buffer, and the PCnet-PCI II controller does own the second (next) buffer, ownership will be passed back to the system by writing a ZERO to the OWN bit of RMD1 when the first buffer is full. The OWN bit is the only bit modified in the descriptor. Receive data transfers to the second buffer may occur before the PCnet-PCI II controller proceeds to look ahead to the ownership of the third buffer. Such action will depend upon the state of the FIFO when the OWN bit has been updated in the first descriptor. In any case, lookahead will be performed to the third buffer and the information gathered will be stored in the chip, regardless of the state of the ownership bit. This activity continues until the PCnet-PCI II controller recognizes the completion of the frame (the last byte of this receive message has been removed from the FIFO). The PCnet-PCI II controller will subsequently update the current RDTE status with the end of frame (ENP) indication set, write the message byte count (MCNT) for the entire frame into RMD2 and overwrite the "current" entries in the CSRs with the "next" entries ### **Media Access Control** The Media Access Control (MAC) engine incorporates the essential protocol requirements for operation of a compliant Ethernet/802.3 node, and provides the interface between the FIFO sub-system and the Manchester Encoder/Decoder (MENDEC). This section describes operation of the MAC engine when operating in half-duplex mode. When operating in half-duplex mode, the MAC engine is fully compliant to Section 4 of ISO/IEC 8802-3 (ANSI/IEEE Standard 1990 Second Edition) and ANSI/IEEE 802.3 (1985). When operating in full-duplex mode, the MAC engine behavior changes as described in the section "Full-Duplex Operation". The MAC engine provides programmable enhanced features designed to minimize host supervision, bus utilization, and pre- or post- message processing. These include the ability to disable retries after a collision, dynamic FCS generation on a frame-by-frame basis, automatic pad field insertion and deletion to enforce minimum frame size attributes, automatic re-transmission without reloading the FIFO, and automatic deletion of collision fragments. The two primary attributes of the MAC engine are: - Transmit and receive message data encapsulation - Framing (frame boundary delimitation, frame synchronization) - Addressing (source and destination address handling) - Error detection (physical medium transmission errors) - Media Access Management - Medium allocation (collision avoidance) - Contention resolution (collision handling) # Transmit and Receive Message Data Encapsulation The MAC engine provides minimum frame size enforcement for transmit and receive frames. When APAD\_XMT (CSR, bit 11) is set to ONE, transmit messages will be padded with sufficient bytes (containing 00h) to ensure that the receiving station will observe an information field (destination address, source address, length/type, data and FCS) of 64 bytes. When ASTRP\_RCV (CSR4, bit 10) is set to ONE, the receiver will automatically strip pad bytes from the received message by observing the value in the length field, and stripping excess bytes if this value is below the minimum data size (46 bytes). Both features can be independently over-ridden to allow illegally short (less than 64 bytes of frame data) messages to be transmitted and/or received. The use of this feature reduces bus utilization because the pad bytes are not transferred into or out of main memory. #### **Framing** The MAC engine will autonomously handle the construction of the transmit frame. Once the transmit FIFO has been filled to the predetermined threshold (set by XMTSP in CSR80), and access to the channel is currently permitted, the MAC engine will commence the 7 byte preamble sequence (10101010b, where first bit transmitted is a 1). The MAC engine will subsequently append the Start Frame Delimiter (SFD) byte (10101011b) followed by the serialized data from the transmit FIFO. Once the data has been completed, the MAC engine will append the FCS (most significant bit first) which was computed on the entire data portion of the frame. The data portion of the frame consists of destination address, source address, length/type, and frame data. The user is responsible for the correct ordering and content in each of these fields in the frame. The receive section of the MAC engine will detect an incoming preamble sequence and lock to the encoded clock. The internal MENDEC will decode the serial bit stream and present this to the MAC engine. The MAC will discard the first 8 bits of information before searching for the SFD sequence. Once the SFD is detected, all subsequent bits are treated as part of the frame. The MAC engine will inspect the length field to ensure minimum frame size, strip unnecessary pad characters (if enabled), and pass the remaining bytes through the receive FIFO to the host. If pad stripping is performed, the MAC engine will also strip the received FCS bytes, although normal FCS computation and checking will occur. Note that apart from pad stripping, the frame will be passed unmodified to the host. If the length field has a value of 46 or greater, all frame bytes including FCS will be passed unmodified to the receive buffer, regardless of the actual frame length. If the frame terminates or suffers a collision before 64 bytes of information (after SFD) have been received, the MAC engine will automatically delete the frame from the receive FIFO, without host intervention. The PCnet-PCI II controller has the ability to accept runt packets for diagnostics purposes and proprietary networks. ### **Destination Address Handling** The first 6 bytes of information after SFD will be interpreted as the destination address field. The MAC engine provides facilities for physical (unicast), logical (multicast) and broadcast address reception. #### **Error Detection** The MAC engine provides several facilities which report and recover from errors on the medium. In addition, it protects the network from gross errors due to inability of the host to keep pace with the MAC engine activity. On completion of transmission, the following transmit status is available in the appropriate Transmit Message Descriptor (TMD) and Control and Status Register (CSR) areas: - The number of transmission retry attempts (ONE, MORE, RTRY, and TRC). - Whether the MAC engine had to Defer (DEF) due to channel activity. - Excessive deferral (EXDEF), indicating that the transmitter has experienced Excessive Deferral on this transmit frame, where Excessive Deferral is defined in ISO 8802-3 (IEEE/ANSI 802.3). - Loss of Carrier (LCAR), indicating that there was an interruption in the ability of the MAC engine to monitor its own transmission. Repeated LCAR errors indicate a potentially faulty transceiver or network connection. - Late Collision (LCOL) indicates that the transmission suffered a collision after the slot time. This is indicative of a badly configured network. Late collisions should not occur in a normal operating network. - Collision Error (CERR) indicates that the transceiver did not respond with an SQE Test message within the first 4 µs after a transmission was completed. This may be due to a failed transceiver, disconnected or faulty transceiver drop cable, or the fact the transceiver does not support this feature (or it is disabled). In addition to the reporting of network errors, the MAC engine will also attempt to prevent the creation of any network error due to the inability of the host to service the MAC engine. During transmission, if the host fails to keep the transmit FIFO filled sufficiently, causing an underflow, the MAC engine will guarantee the message is either sent as a runt packet (which will be deleted by the receiving station) or has an invalid FCS (which will also cause the receiver to reject the message). The status of each receive message is available in the appropriate Receive Message Descriptor (RMD) and CSR areas. All received frames are passed to the host regardless of any error. The FRAM error will only be reported if an FCS error is detected and there are a non integral number of bytes in the message. During the reception, the FCS is generated on every serial bit (including the dribbling bits) coming from the cable, although the internally saved FCS value is only updated on the eighth bit (on each byte boundary). The MAC engine will ignore up to 7 additional bits at the end of a message (dribbling bits), which can occur under normal network operating conditions. The framing error is reported to the user as follows: - If the number of dribbling bits are 1 to 7 and there is no FCS error, then there is no Framing error (FRAM = 0). - If the number of dribbling bits are 1 to 7 and there is a FCS error, then there is also a Framing error (FRAM = 1). - If the number of dribbling bits is ZERO, then there is no Framing error. There may or may not be a FCS error. - If the number of dribbling bits is EIGHT, then there is no Framing error. FCS error will be reported and the receive message count will indicated one extra byte. Counters are provided to report the Receive Collision Count and Runt Packet Count, for network statistics and utilization calculations. Note that if the MAC engine detects a received frame which has a 00b pattern in the preamble (after the first 8-bits which are ignored), the entire frame will be ignored. The MAC engine will wait for the network to go inactive before attempting to receive additional frames. # **Media Access Management** The basic requirement for all stations on the network is to provide fairness of channel allocation. The 802.3/Ethernet protocols define a media access mechanism which permits all stations to access the channel with equality. Any node can attempt to contend for the channel by waiting for a predetermined time (Inter Packet Gap) after the last activity, before transmitting on the media. The channel is a multidrop communications media (with various topological configurations permitted) which allows a single station to transmit and all other stations to receive. If two nodes simultaneously contend for the channel, their signals will interact causing loss of data, defined as a collision. It is the responsibility of the MAC to attempt to avoid and recover from a collision, to guarantee data integrity for the end-to-end transmission to the receiving station. #### **Medium Allocation** The IEEE/ANSI 802.3 Standard (ISO/IEC 8802-3 1990) requires that the CSMA/CD MAC monitor the medium for traffic by watching for carrier activity. When carrier is detected, the media is considered busy, and the MAC should defer to the existing message. The ISO 8802-3 (IEEE/ANSI 802.3) Standard also allows optional two part deferral after a receive message. See ANSI/IEEE Std 802.3-1990 Edition, 4.2.3.2.1: **Note:** It is possible for the PLS carrier sense indication to fail to be asserted during a collision on the media. If the deference process simply times the interFrame gap based on this indication it is possible for a short interFrame gap to be generated, leading to a potential reception failure of a subsequent frame. To enhance system robustness the following optional measures, as specified in 4.2.8, are recommended when InterFrame Spacing Part 1 is other than ZERO: - Upon completing a transmission, start timing the interpacket gap, as soon as transmitting and carrier Sense are both false. - 2. When timing an interFrame gap following reception, reset the interFrame gap timing if carrier Sense becomes true during the first 2/3 of the interFrame gap timing interval. During the final 1/3 of the interval the timer shall not be reset to ensure fair access to the medium. An initial period shorter than 2/3 of the interval is permissible including ZERO." The MAC engine implements the optional receive two part deferral algorithm, with a first part inter-frame-spacing time of 6.0 $\mu$ s. The second part of the inter-frame-spacing interval is therefore 3.6 $\mu$ s. The PCnet-PCI II controller will perform the two part defferral algorithm as specified in Section 4.2.8 (Process Deference). The Inter Packet Gap (IPG) timer will start timing the 9.6 µs InterFrameSpacing after the receive carrier is deasserted. During the first part deferral (Inter-Frame Spacing Part1 - IFS1) the PCnet-PCI II controller will defer any pending transmit frame and respond to the receive message. The IPG counter will be cleared to ZERO continuously until the carrier deasserts, at which point the IPG counter will resume the 9.6 µs count once again. Once the IFS1 period of 6.0 μs has elapsed, the PCnet-PCI II controller will begin timing the second part deferral (Inter-Frame Spacing Part2 – IFS2) of 3.6 µs. Once IFS1 has completed, and IFS2 has commenced, the PCnet-PCI II controller will not defer to a receive frame if a transmit frame is pending. This means that the PCnet-PCI II controller will not attempt to receive the receive frame, since it will start to transmit, and generate a collision at 9.6 µs. The PCnet-PCI II controller will complete the preamble (64-bit) and jam (32-bit) sequence before ceasing transmission and invoking the random backoff algorithm. This transmit two part deferral algorithm is implemented as an option which can be disabled using the DXMT2PD bit in CSR3. Two part deferral after transmission is useful for ensuring that severe IPG shrinkage cannot occur in specific circumstances, causing a transmit message to follow a receive message so closely as to make them indistinguishable. During the time period immediately after a transmission has been completed, the external transceiver (in the case of a standard AUI connected device), should generate the SQE Test message (a nominal 10 MHz burst of 5–15 Bit Times duration) on the Cl $\pm$ pair (within 0.6–1.6 $\mu$ s after the transmission ceases). During the time period in which the SQE Test message is expected the PCnet-PCI II controller will not respond to receive carrier sense. See ANSI/IEEE Std 802.3-1990 Edition, 7.2.4.6 (1): Note: "At the conclusion of the output function, the DTE opens a time window during which it expects to see the signal\_quality\_error signal asserted on the Control In circuit. The time window begins when the CARRIER\_STATUS becomes CARRIER\_OFF. If execution of the output function does not cause CARRIER\_ON to occur, no SQE test occurs in the DTE. The duration of the window shall be at least 4.0 µs but no more than 8.0 µs. During the time window the Carrier Sense Function is inhibited." The PCnet-PCI II controller implements a carrier sense "blinding" period of 4.0 $\mu$ s length starting from the deassertion of carrier sense after transmission. This effectively means that when transmit two part deferral is enabled (DXMT2PD is cleared) the IFS1 time is from 4 $\mu$ s to 6 $\mu$ s after a transmission. However, since IPG shrinkage below 4 $\mu$ s will rarely be encountered on a correctly configured network, and since the fragment size will be larger than the 4 $\mu$ s blinding window, the IPG counter will be reset by a worst case IPG shrinkage/fragment scenario and the PCnet-PCI II controller will defer its transmission. If carrier is detected within the 4.0 to 6.0 $\mu$ s IFS1 period, the PCnet-PCI II controller will not restart the "blinding" period, but only restart IFS1. #### **Collision Handling** Collision detection is performed and reported to the MAC engine by the integrated Manchester Encoder/Decoder (MENDEC). If a collision is detected before the complete preamble/ SFD sequence has been transmitted, the MAC Engine will complete the preamble/SFD before appending the jam sequence. If a collision is detected after the preamble/SFD has been completed, but prior to 512 bits being transmitted, the MAC Engine will abort the transmission, and append the jam sequence immediately. The jam sequence is a 32-bit all ZEROs pattern. The MAC Engine will attempt to transmit a frame a total of 16 times (initial attempt plus 15 retries) due to normal collisions (those within the slot time). Detection of collision will cause the transmission to be re-scheduled to a time determined by the random backoff algorithm. If a single retry was required, the ONE bit will be set in the transmit frame status. If more than one retry was required, the MORE bit will be set. If all 16 attempts experienced collisions, the RTRY bit will be set (ONE and MORE will be clear), and the transmit message will be flushed from the FIFO. If retries have been disabled by setting the DRTY bit in CSR15, the MAC Engine will abandon transmission of the frame on detection of the first collision. In this case, only the RTRY bit will be set and the transmit message will be flushed from the FIFO. If a collision is detected after 512 bit times have been transmitted, the collision is termed a late collision. The MAC Engine will abort the transmission, append the jam sequence and set the LCOL bit. No retry attempt will be scheduled on detection of a late collision, and the transmit message will be flushed from the FIFO. The ISO 8802-3 (IEEE/ANSI 802.3) Standard requires use of a "truncated binary exponential backoff" algorithm which provides a controlled pseudo random mechanism to enforce the collision backoff interval, before re-transmission is attempted. See ANSI/IEEE Std 802.3-1990 Edition, 4.2.3.2.5: **Note:** "At the end of enforcing a collision (jamming), the CSMA/CD sublayer delays before attempting to retransmit the frame. The delay is an integer multiple of slot Time. The number of slot times to delay before the nth re-transmission attempt is chosen as a uniformly distributed random integer r in the range: $0 \le r < 2k$ where k = min (n, 10)." The PCnet-PCI II controller provides an alternative algorithm, which suspends the counting of the slot time/IPG during the time that receive carrier sense is detected. This aids in networks where large numbers of nodes are present, and numerous nodes can be in collision. It effectively accelerates the increase in the backoff time in busy networks, and allows nodes not involved in the collision to access the channel whilst the colliding nodes await a reduction in channel activity. Once channel activity is reduced, the nodes resolving the collision time out their slot time counters as normal. This modified backoff algorithm is enabled when EMBA (CSR3, bit 3) is set to ONE. ### TRANSMIT OPERATION The transmit operation and features of the PCnet-PCI II controller are controlled by programmable options. The PCnet-PCI II controller offers a 272-byte transmit FIFO to provide frame buffering for increased system latency, automatic re-transmission with no FIFO reload, and automatic transmit padding. ## **Transmit Function Programming** Automatic transmit features such as retry on collision, FCS generation/transmission, and pad field insertion can all be programmed to provide flexibility in the (re-)transmission of messages. Disable retry on collision (DRTY) is controlled by the DRTY bit of the Mode register (CSR15) in the initialization block Automatic pad field insertion is controlled by the APAD XMT bit in CSR4. The disable FCS generation/transmission feature can be programmed as a static feature or dynamically on a frame by frame basis. Transmit FIFO Watermark (XMTFW) in CSR80 sets the point at which the BMU requests more data from the transmit buffers for the FIFO. A minimum of XMTFW empty spaces must be available in the transmit FIFO before the BMU will request the system bus in order to transfer transmit frame data into the transmit FIFO. Transmit Start Point (XMTSP) in CSR80 sets the point when the transmitter actually attempts to transmit a frame onto the media. A minimum of XMTSP bytes must be written to the transmit FIFO for the current frame be-fore transmission of the current frame will begin. (When automatically padded packets are being sent, it is conceivable that the XMTSP is not reached when all of the data has been transferred to the FIFO. In this case, the transmission will begin when all of the frame data has been placed into the transmit FIFO.) The default value of XMTSP is 01b, meaning there has to be 64 bytes in the transmit FIFO to start a transmission. ### **Automatic Pad Generation** Transmit frames can be automatically padded to extend them to 64 data bytes (excluding preamble). This allows the minimum frame size of 64 bytes (512 bits) for 802.3/Ethernet to be guaranteed with no software intervention from the host/controlling process. Setting the APAD\_XMT bit in CSR4 enables the automatic padding feature. The pad is placed between the LLC data field and FCS field in the 802.3 frame. FCS is always added if the frame is padded, regardless of the state of DXMTFCS (CSR15, bit 3) or ADD\_FCS/NO\_FCS (TMD1, bit 29). The transmit frame will be padded by bytes with the value of 00h. The default value of APAD\_XMT is 0, which will disable automatic pad generation after H\_RESET. It is the responsibility of upper layer software to correctly define the actual length field contained in the message to correspond to the total number of LLC Data bytes encapsulated in the frame (length field as defined in the ISO 8802-3 (IEEE/ANSI 802.3) standard). The length value contained in the message is not used by the PCnet-PCI II controller to compute the actual number of pad bytes to be inserted. The PCnet-PCI II controller will append pad bytes dependent on the actual number of bits transmitted onto the network. Once the last data byte of the frame has com- pleted, prior to appending the FCS, the PCnet-PCI II controller will check to ensure that 544 bits have been transmitted. If not, pad bytes are added to extend the frame size to this value, and the FCS is then added. Figure 34. ISO 8802-3 (IEEE/ANSI 802.3) Data Frame The 544 bit count is derived from the following: Minimum frame size (excluding 64 bytes 512 bits preamble/SFD, including FCS) Preamble/SFD size 8 bytes 64 bits FCS size 4 bytes 32 bits At the point that FCS is to be appended, the transmitted frame should contain: Preamble/SFD + (Min Frame Size – FCS) $$64 + (512 - 32) = 544$$ bits A minimum length transmit frame from the PCnet-PCI II controller will therefore be 576 bits, after the FCS is appended. ### **Transmit FCS Generation** Automatic generation and transmission of FCS for a transmit frame depends on the value of DXMTFCS (CSR15, bit 3). If DXMTFCS is cleared to ZERO, the transmitter will generate and append the FCS to the transmitted frame. If the automatic padding feature is invoked (APAD\_XMT is set in CSR4), the FCS will be appended by the PCnet-PCI II controller regardless of the state of DXMTFCS or ADD\_FCS/NO\_FCS (TMD1, bit 29). Note that the calculated FCS is transmitted most significant bit first. The default value of DXMT-FCS is 0 after H RESET. ADD\_FCS (TMD1, bit 29) allows the automatic generation and transmission of FCS on a frame by frame basis. DXMTFCS should be cleared to ZERO in this mode. To generate FCS for a frame, ADD\_FCS must be set in the first descriptor of a frame (STP is set to ONE). Note that bit 29 of TMD1 has the function of ADD\_FCS if SWSTYLE (BCR20, bits 7–0) is programmed to ZERO, TWO or THREE. When SWSTYLE is set to ONE for ILACC backwards compatibility, bit 29 of TMD1 changes its function to NO FCS. When DXMTFCS is cleared to ZERO and NO\_FCS is set to ONE in the last descriptor of a frame (ENP is set to ONE), the PCnet-PCI II controller will not generate and append an FCS to a transmit frame. # **Transmit Exception Conditions** Exception conditions for frame transmission fall into two distinct categories. Those which are the result of normal network operation, and those which occur due to abnormal network and/or host related events. Normal events which may occur and which are handled autonomously by the PCnet-PCI II controller include collisions within the slot time with automatic retry. The PCnet-PCI II controller will ensure that collisions which occur within 512 bit times from the start of transmission (including preamble) will be automatically retried with no host intervention. The transmit FIFO ensures this by guaranteeing that data contained within the FIFO will not be overwritten until at least 64 bytes (512 bits) of preamble plus address, length and data fields have been transmitted onto the network without encountering a collision. Note that if DRTY (CSR15, bit 5) is set to ONE or if the network interface is operating in full-duplex mode, no collision handling is required, and any byte of frame data in the FIFO can be overwritten as soon as it is transmitted. If 16 total attempts (initial attempt plus 15 retries) fail, the PCnet-PCI II controller sets the RTRY bit in the current transmit TDTE in host memory (TMD2), gives up ownership (resets the OWN bit to ZERO) for this frame, and processes the next frame in the transmit ring for transmission. Abnormal network conditions include: - Loss of carrier. - Late collision. - SQE Test Error. (Does not apply to 10BASE-T port.) These conditions should not occur on a correctly configured 802.3 network operating in half-duplex mode, and will be reported if they do. None of these conditions will occur on a network operating in full-duplex mode. (See the section "Full-Duplex Operation" for more detail.) When an error occurs in the middle of a multi-buffer frame transmission, the error status will be written in the current descriptor. The OWN bit(s) in the subsequent descriptor(s) will be cleared until the STP (the next frame) is found. #### **Loss of Carrier** When operating in half-duplex mode, a loss of carrier condition will be reported if the PCnet-PCI II controller cannot observe receive activity whilst it is transmitting on the AUI port. In AUI mode, after the PCnet-PCI II controller initiates a transmission it will expect to see data "looped-back" on the DI± pair. This will internally generate a "carrier sense", indicating that the integrity of the data path to and from the MAU is intact, and that the MAU is operating correctly. This "carrier sense" signal must be asserted before the last bit is transmitted on DO±. If "carrier sense" does not become active in response to the data transmission, or becomes inactive before the end of transmission, the loss of carrier (LCAR) error bit will be set in TMD2 after the frame has been transmitted. The frame will not be retried on the basis of an LCAR error. When the 10BASE-T port is selected, LCAR will be reported for every frame transmitted while the network interface is in the Link Fail state. #### **Late Collision** A late collision will be reported if a collision condition occurs after one slot time (512 bit times) after the transmit process was initiated (first bit of preamble commenced). The PCnet-PCI II controller will abandon the transmit process for that frame, set Late Collision (LCOL) in the associated TMD2, and process the next transmit frame in the ring. Frames experiencing a late collision will not be retried. Recovery from this condition must be performed by upper layer software. #### **SQE Test Error** During the inter packet gap time following the completion of a transmitted message, the AUI CI± pair is asserted by some transceivers as a self-test. The integral Manchester Encoder/Decoder will expect the SQE Test Message (nominal 10MHz sequence) to be returned via the CI± pair within a 40 network bit-time period after DI± goes inactive (this does not apply if the 10BASE-T port is selected). If the CI± input is not asserted within the 40 network bit-time period following the completion of transmission, then the PCnet-PCI II controller will set the CERR bit in CSR0. CERR will be asserted in 10BASE-T mode after transmit if T-MAU is in Link Fail state. CERR will never cause INTA to be activated. It will, however, set the ERR bit CSR0. # **Receive Operation** The receive operation and features of the PCnet-PCI II controller are controlled by programmable options. The PCnet-PCI II controller offers a 256-byte receive FIFO to provide frame buffering for increased system latency, automatic flushing of collision fragments (runt packets), automatic receive pad stripping and a variety of address match options. ### **Receive Function Programming** Automatic pad field stripping is enabled by setting the ASTRP\_RCV bit in CSR4. This can provide flexibility in the reception of messages using the 802.3 frame format. All receive frames can be accepted by setting the PROM bit in CSR15. Acceptance of unicast and broadcast frames can be individually turned off by setting the DRCVPA or DRCVBC bits in CSR15. The Physical Address register (CSR12 to CSR14) stores the address the PCnet-PCI II controller compares to the destination address of the incoming frame for a unicast address match. The Logical Address Filter register (CSR8 to CSR11) serves as a hash filter for multicast address match. The point at which the BMU will start to transfer data from the receive FIFO to buffer memory is controlled by the RCVFW bits in CSR80. The default established during H\_RESET is 01b which sets the watermark flag at 64 bytes filled. For test purposes, the PCnet-PCI II controller can be programmed to accept runt packets by setting RPA in CSR124. ### **Address Matching** The PCnet-PCI II controller supports three types of address matching: unicast, multicast, and broadcast. The normal address matching procedure can be modified by programming three bits in CSR15, the mode register (PROM, DRCVPA, and DRCVBC). If the first bit received after the start of frame delimiter (the least significant bit of the first byte of the destination address field) is 0, the frame is unicast, which indicates that the frame is meant to be received by a single node. If the first bit received is 1, the frame is multicast, which indicates that the frame is meant to be received by a group of nodes. If the destination address field contains all ONEs, the frame is broadcast, which is a special type of multicast. Frames with the broadcast address in the destination address field are meant to be received by all nodes on the local area network. When a unicast frame arrives at the PCnet-PCI II controller, the controller will accept the frame if the destination address field of the incoming frame exactly matches the 6-byte station address stored in the Physical Address registers (PADR, CSR12 to CSR14). The byte ordering is such that the first byte received from the network (after the SFD) must match the least significant byte of CSR12 (PADR[7:0]), and the sixth byte received must match the most significant byte of CSR14 (PADR[47:40]). When DRCVPA (CSR15, bit 13) is set to ONE, the PCnet-PCI II controller will not accept unicast frames. If the incoming frame is multicast, the PCnet-PCI II controller performs a calculation on the contents of the destination address field to determine whether or not to accept the frame. This calculation is explained in the section that describes the Logical Address Filter (LADRF). When all bits of the LADRF registers are 0, no multicast frames are accepted, except for broadcast frames. Although broadcast frames are classified as special multicast frames, they are treated differently by the PC-net-PCI II controller hardware. Broadcast frames are always accepted, except when DRCVBC (CSR15, bit 14) is set. None of the address filtering described above applies when the PCnet-PCI II controller is operating in the promiscuous mode. In the promiscuous mode, all properly formed packets are received, regardless of the contents of their destination address fields. The promiscuous mode overrides the Disable Receive Broadcast bit (DRCVBC bit I4 in the MODE register) and the Disable Receive Physical Address bit (DRCVPA, CSR15, bit 13). The PCnet-PCI II controller operates in promiscuous mode when PROM (CSR15, bit 15) is set. In addition, the PCnet-PCI II controller provides the External Address Detection Interface (EADI) to allow external address filtering. See the section "External Address Detection Interface" for further detail. The receive descriptor entry RMD1 contains three bits that indicate which method of address matching caused the PCnet-PCI II controller to accept the frame. Note that these indicator bits are only available when the PCnet-PCI II controller is programmed to use 32-bit structures for the descriptor entries (BCR20, bit 7–0, SWSTYLE is set to ONE, TWO or THREE). PAM (RMD1, bit 22) is set by the PCnet-PCI II controller when it accepted the received frame due to a match of the frame's destination address with the content of the physical address register. LAFM (RMD1, bit 21) is set by the PCnet-PCI II controller when it accepted the received frame based on the value in the logical address filter register. BAM (RMD1, bit 20) is set by the PCnet-PCI II controller when it accepted the received frame because the frame's destination address is of the type "Broadcast". If DRCVBC (CSR15, bit 14) is cleared to ZERO, only BAM, but not LAFM will be set when a Broadcast frame is received, even if the Logical Address Filter is programmed in such a way that a Broadcast frame would pass the hash filter. If DRCVBC is set to ONE and the Logical Address Filter is programmed in such a way that a Broadcast frame would pass the hash filter, LAFM will be set on the reception of a Broadcast frame. When the PCnet-PCI II controller operates in promiscuous mode and none of the three match bits is set, it is an indication that the PCnet-PCI II controller only accepted the frame because it was in promiscuous mode. When the PCnet-PCI II controller is not programmed to be in promiscuous mode, but the EADI interface is enabled, then when none of the three match bits is set, it is an indication that the PCnet-PCI II controller only accepted the frame because it was not rejected by driving the EAR pin LOW within 64 bytes after SFD. Table 6. Receive Address Match | PAM | LAFM | BAM | DRCVBC | Comment | |-----|------|-----|--------|--------------------------------------------------------------| | 0 | 0 | 0 | Х | Frame accepted due to PROM = 1 or no EADI reject | | 1 | 0 | 0 | Х | Physical Address Match | | 0 | 1 | 0 | 0 | Logical Address Filter Match; Frame is not of Type Broadcast | | 0 | 1 | 0 | 1 | Logical Address Filter Match; Frame can be of Type Broadcast | | 0 | 0 | 1 | 0 | Broadcast Frame | #### **Automatic Pad Stripping** During reception of an 802.3 frame the pad field can be stripped automatically. Setting ASTRP\_RCV (CSR4, bit 0) to ONE enables the automatic pad stripping feature. The pad field will be stripped before the frame is passed to the FIFO, thus preserving FIFO space for additional frames. The FCS field will also be stripped, since it is computed at the transmitting station based on the data and pad field characters, and will be invalid for a receive frame that has had the pad characters stripped. The number of bytes to be stripped is calculated from the embedded length field (as defined in the ISO 8802-3 (IEEE/ANSI 802.3) definition) contained in the frame. The length indicates the actual number of LLC data bytes contained in the message. Any received frame which contains a length field less than 46 bytes will have the pad field stripped (if ASTRP\_RCV is set). Receive frames which have a length field of 46 bytes or greater will be passed to the host unmodified. The figure below shows the byte/bit ordering of the received length field for an 802.3 compatible frame format Figure 35. 802.3 Frame And Length Field Transmission Order Since any valid Ethernet Type field value will always be greater than a normal 802.3 Length field (≥ 46), the PC-net-PCI II controller will not attempt to strip valid Ethernet frames. Note that for some network protocols, the value passed in the Ethernet Type and/or 802.3 Length field is not compliant with either standard and may cause problems if pad stripping is enabled. #### **Receive FCS Checking** Reception and checking of the received FCS is performed automatically by the PCnet-PCI II controller. Note that if the Automatic Pad Stripping feature is enabled, the FCS for padded frames will be verified against the value computed for the incoming bit stream including pad characters, but the FCS value for a padded frame will not be passed to the host. If an FCS error is detected in any frame, the error will be reported in the CRC bit in RMD1. #### **Receive Exception Conditions** Exception conditions for frame reception fall into two distinct categories: those which are the result of normal network operation, and those which occur due to abnormal network and/or host related events. Normal events which may occur and which are handled autonomously by the PCnet-PCI II controller are basically collisions within the slot time and automatic runt packet rejection. The PCnet-PCI II controller will ensure that collisions which occur within 512 bit times from the start of reception (excluding preamble) will be automatically deleted from the receive FIFO with no host intervention. The receive FIFO will delete any frame which is composed of fewer than 64 bytes provided that the Runt Packet Accept (RPA bit in CSR124) feature has not been enabled and the network interface is operating in half-duplex mode. This criterion will be met regardless of whether the receive frame was the first (or only) frame in the FIFO or if the receive frame was queued behind a previously received message. Abnormal network conditions include: - FCS errors - Late Collision Host related receive exception conditions include MISS, BUFF, and OFLO. These are described in the section "Buffer Management Unit". ## **Loopback Operation** Loopback is a mode of operation intended for system diagnostics. In this mode, the transmitter and receiver are both operating at the same time so that the controller receives its own transmissions. The controller provides two basic types of loopback. In internal loopback mode, the transmitted data is looped back to the receiver inside the controller without actually transmitting any data to the external network. The receiver will move the received data to the next receive buffer, where it can be examined by software. Alternatively, in external loopback mode, data can be transmitted to and received from the external network. Loopback operation is enabled by setting LOOP (CSR15, bit 2) to ONE. The mode of loopback operation is dependent on the active network port and on the settings of the control bits INTL (CSR15, bit 6), MENDECL (CSR15, bit 10) and TMAULOOP (BCR2, bit 14). The setting of the full-duplex control bits in BCR9 has no effect on the loopback operation. ## **AUI Loopback Modes** When AUI is the active network port there are three modes of loopback operation: internal with and without MENDEC and external loopback. The setting of TMAULOOP has no effect for this port. When INTL and MENDECL are set to ONE, internal loopback without MENDEC is selected. Data coming out of the transmit FIFO is fed directly to the receive FIFO. The AUI transmitter is disabled and signals on the receive and collision inputs are ignored. When INTL is set to ONE and MENDECL is cleared to ZERO, internal loopback including the MENDEC is selected. Data is routed from the transmit FIFO through the MENDEC back to the receive FIFO. No data is transmitted to the network. All signals on the receive and collision inputs are ignored. External loopback operation is selected by setting INTL to ZERO. The programming of MENDECL has no effect in this mode. The AUI transmitter is enabled and data is transmitted to the network. The PCnet-PCI II controller expects data to be looped back to the receive inputs outside the chip. Collision detection is active in this mode. #### **T-MAU Loopback Modes** When T-MAU is the active network port there are four modes of loopback operation: internal loopback with and without MENDEC and two external loopback modes. When INTL and MENDECL are set to ONE, internal loopback without MENDEC is selected. Data coming out of the transmit FIFO is fed directly to the receive FIFO. The T-MAU does not transmit any data to the network, but it continues to send link pulses. All signals on the receive inputs are ignored. LCAR (TMD2, bit 27) will always read ZERO, regardless of the link state. The programming of TMAULOOP has no effect. When INTL is set to ONE and MENDECL is cleared to ZERO, internal loopback including the MENDEC is selected. Data is routed from the transmit FIFO through the MENDEC back to the receive FIFO. The T-MAU does not transmit any data to the network, but it continues to send link pulses. All signals on the receive inputs are ignored. LCAR (TMD2, bit 27) will always read ZERO, regardless of the link state. The programming of TMAULOOP has no effect. External loopback operation works slightly different when the T-MAU is the active network port. In a 10BASE-T network, the hub does not generate a receive carrier back to the PCnet-PCI II controller while the chip is transmitting. The T-MAU provides this function internally. A true external loopback covering all the components on the printed circuit board can only be performed by using a special connector that connects the transmit pins of the RJ-45 jack to its receive pins, namely, pin 1 connected to pin 3 and pin 2 connected to pin 6. When INTL is cleared to ZERO and TMAU-LOOP is set to ONE, data is transmitted to the network and is expected to be routed back to the chip. Collision detection is disabled in this mode. The link state machine is forced into the link pass state. LCAR will always read ZERO. The programming of MENDECL has no effect in this mode. The PCnet-PCI II controller provides a special external loopback mode that allows the device to be connected to a live 10BASE-T network. The virtual external loopback mode is invoked by setting INTL and TMAULOOP to ZERO. In this mode, data coming out of the transmit FIFO is fed directly into the receive FIFO. Additionally, all transmit data is output to the network. The link state machine is active as is the collision detection logic. The programming of MENDECL has no effect in this mode. #### Miscellaneous Loopback Features All transmit and receive function programming, such as automatic transmit padding and receive pad stripping, operates identically in loopback as in normal operation. Loopback mode can be performed with any frame size. Runt Packet Accept is internally enabled (RPA bit in CSR124 is not affected) when any loopback mode is invoked. This is to be backwards compatible to the C-LANCE (Am79C90) software. Since the PCnet-PCI II controller has two FCS generators there are no more restrictions on FCS generation or checking or on testing multicast address detection as they exist in the half-duplex PCnet family devices and in the C-LANCE and ILACC. On receive the PCnet-PCI II controller now provides true FCS status. The descriptor for a frame with an FCS error will have the FCS bit (RMD1, bit 27) set to ONE. The FCS generator on the transmit side can still be disabled by setting DXMTFCS (CSR15, bit 3) to ONE. In internal loopback operation the PCnet-PCI II controller provides a special mode to test the collision logic. When FCOLL (CSR15, bit 4) is set to ONE, a collision is forced during every transmission attempt. This will result in a Retry error. # **Magic Packet Mode** Magic Packet mode is enabled by performing three steps. First, the PCnet-PCI II controller must be put into suspend mode (see description of CSR5, bit 0), allowing any current network activity to finish. Next, MP-MODE (CSR5, bit 1) must be set to ONE if it has not been set already. Finally, either SLEEP must be asserted (hardware control) or MPEN (CSR5, bit 2) must be set to ONE (software control). In Magic Packet mode, the PCnet-PCI II controller remains fully powered-up (all $V_{DD}$ and $V_{DDB}$ pins must remain at their supply levels). The device will not generate any bus master transfers. No transmit operations will be initiated on the network. The device will continue to receive frames from the network, but all frames will be automatically flushed from the receive FIFO. Slave accesses to the PCnet-PCI II controller are still possible. Magic Packet mode can be disabled at any time by deasserting $\overline{SLEEP}$ or clearing MPEN. A Magic Packet frame is a frame that is addressed to the PCnet-PCI II controller and contains a data sequence in its data field made up of sixteen consecutive physical addresses (PADR[47:0]). The PCnet-PCI II controller will search incoming frames until it finds a Magic Packet frame. The device starts scanning for the sequence after processing the Length field of the frame. The data sequence can begin anywhere in the data field of the frame, but must be detected before the PCnet-PCI II controller reaches the frame's FCS field. The PCnet- PCI II controller is designed such that it does not need the synchronization sequence (6 bytes of all ONEs ("FFFFFFFFFFFFFF") at the beginning of the data field), to correctly recognize the proper data sequence. However, any deviation of the incoming frame's Magic Packet data sequence from the required physical address sequence, even by a single bit, will prevent the detection of that frame as a Magic Packet frame. The PCnet-PCI II controller supports two different modes of address detection for a Magic Packet frame. If MPPLBA (CSR5, bit 5) is at its default value of ZERO, the PCnet-PCI II controller will only detect a Magic Packet frame if the destination address of the frame matches the content of the physical address register (PADR). If MPPLBA is set to ONE, the destination address of the Magic Packet frame can be unicast, multicast, or broadcast. Note that the setting of MPPLBA only effects the address detection of the Magic Packet frame. The Magic Packet data sequence must be made up of sixteen consecutive physical addresses (PADR[47:0]), even if the packet contains a valid destination address that is not the physical address. When the PCnet-PCI II controller detects a Magic Packet frame, it sets MPINT (CSR5, bit 4) to ONE. If INEA (CSR0, bit 6) and MPINTE (CSR5, bit 3) are set to ONE, INTA will be asserted. The interrupt signal can be used wake up the system. As an alternative, one of the four LED pins can be programmed to indicate that a Magic Packet frame has been received. MPSE (BCR4–7, bit 9) must be set to ONE to enable that function. Note that the polarity of the LED pin can be programmed to be active High by setting LEDPOL (BCR4–7, bit 14) to ONE. Once a Magic Packet frame is detected, the PCnet-PCI II controller will discard the frame internally, but will not resume normal transmit and receive operations until SLEEP is deasserted or MPEN is cleared, disabling Magic Packet mode. Once either of these events has occurred indicating that the system has detected the assertion of INTA or an LED pin and is now "awake", the controller will continue polling the receive and transmit descriptor rings where it left off. Reinitialization should not be performed. If Magic Packet mode is disabled by the deassertion of SLEEP, then in order to immediately reenable Magic Packet mode, the SLEEP pin must remain deasserted for at least 200 ns before it is reasserted. If Magic Packet mode is disabled by clearing MPEN, then it may be immediately reenabled by setting MPEN back to ONE. The bus interface clock (CLK) must continue running if INTA is used to indicate the detection of a magic packet. A system that wants to stop the clock during Magic Packet mode should use one of the LED pins as an indicator of Magic Packet frame detection. It should also stop the clock after enabling Magic Packet mode, other- wise PCI bus activity, including accessing CSR5 to set MPMODE and possibly MPEN to a ONE, could be affected. The clock should be restarted before Magic Packet mode is disabled if MPEN is being cleared or the clock must be restarted right after magic packet mode is disabled if SLEEP is being deasserted. Otherwise, the receive FIFO may overflow if new frames arrive. The network clock (XTAL1) must continue running at all times while in Magic Packet mode. ## MANCHESTER ENCODER/DECODER The integrated Manchester Encoder/Decoder (MEN-DEC) provides the PLS (Physical Layer Signaling) functions required for a fully compliant ISO 8802-3 (IEEE/ANSI 802.3) station. The MENDEC provides the encoding function for data to be transmitted on the network using the high accuracy on-board oscillator, driven by either the crystal oscillator or an external CMOS level compatible clock. The MENDEC also provides the decoding function from data received from the network. The MENDEC contains a Power On Reset (POR) circuit, which ensures that all analog portions of the PCnet-PCI II controller are forced into their correct state during power up, and prevents erroneous data transmission and/or reception during this time. # **External Crystal Characteristics** When using a crystal to drive the oscillator, the following crystal specification may be used to ensure less than $\pm 0.5$ ns jitter at DO $\pm$ : **Table 7. Crystal Characteristics** | Parameter | Min | Nom | Max | Units | |-------------------------------------------------------------------------|-----|-------|-----|-------| | Parallel Resonant Frequency | | 20 | | MHz | | 2. Resonant Frequency Error | -50 | | +50 | PPM | | 3. Change in Resonant Frequency With Respect To Temperature (0 – 70 C)* | -40 | | +40 | PPM | | 4. Crystal Load Capacitance | 20 | | 50 | pF | | 5. Motional Crystal Capacitance (C1) | | 0.022 | | pF | | 6. Series Resistance | | | 35 | ohm | | 7. Shunt Capacitance | | | 7 | pF | | 8. Drive Level | | | TBD | mW | <sup>\*</sup> Requires trimming specification, not trim is 50 PPM total. ## **External Clock Drive Characteristics** When driving the oscillator from a CMOS level external clock source, XTAL2 must be left floating (uncon- nected). An external clock having the following characteristics must be used to ensure less than $\pm 0.5$ ns jitter at DO±. **Table 8. External Clock Source Characteristics** | Clock Frequency: | 20 MHz ±0.01% | |--------------------------------------------|----------------------------------| | Rise/Fall Time (tR/tF): | <= 6 ns from 0.5 V to VDD -0.5 V | | XTAL1 HIGH/LOW Time (tHIGH/tLOW): | 20 ns min. | | XTAL1 Falling Edge to Falling Edge Jitter: | < ±0.2 ns at 2.5 V input (VDD/2) | #### **MENDEC Transmit Path** The transmit section encodes separate clock and NRZ data input signals into a standard Manchester encoded serial bit stream. The transmit outputs (DO±) are designed to operate into terminated transmission lines. When operating into a 78 $\Omega$ terminated transmission line, the transmit signaling meets the required output levels and skew for Cheapernet, Ethernet and IEEE-802.3. # **Transmitter Timing and Operation** A 20 MHz fundamental mode crystal oscillator provides the basic timing reference for the MENDEC portion of the PCnet-PCI II controller. The crystal frequency is divided by two to create the internal transmit clock reference. Both the 10 MHz and 20 MHz clocks are fed into the Manchester Encoder. The internal transmit clock is used by the MENDEC to synchronize the Internal Transmit Data (ITXDAT) and Internal Transmit Enable (ITXEN) from the controller. The internal transmit clock is also used as a stable bit rate clock by the receive section of the MENDEC and controller. The oscillator requires an external 0.01% timing reference. If an external crystal is used, the accuracy requirements are tighter because allowance for the on-board parasitics must be made to deliver a final accuracy of 0.01%. Transmission is enabled by the controller. As long as the ITXEN request remains active, the serial output of the controller will be Manchester encoded and appear at DO±. When the internal request is dropped by the controller, the differential transmit outputs go to one of two idle states, dependent on TSEL in the Mode Register (CSR15, bit 9): Table 9. TSEL Effect | | The idle state of DO± yields ZERO differential to operate transformer-coupled loads. | |------------|--------------------------------------------------------------------------------------| | TSEL HIGH: | In this idle state, DO+ is positive with respect to DO- (logical HIGH). | #### **Receiver Path** The principal functions of the receiver are to signal the PCnet-PCI II controller that there is information on the receive pair, and separate the incoming Manchester encoded data stream into clock and NRZ data. The receiver section (see the figure below) consists of two parallel paths. The receive data path is a ZERO threshold, wide bandwidth line receiver. The carrier path is an offset threshold bandpass detecting line receiver. Both receivers share common bias networks to allow operation over a wide input common mode range. Figure 36. Receiver Block Diagram # **Input Signal Conditioning** Transient noise pulses at the input data stream are rejected by the Noise Rejection Filter. Pulse width rejection is proportional to transmit data rate. The Carrier Detection circuitry detects the presence of an incoming data frame by discerning and rejecting noise from expected Manchester data, and controls the stop and start of the phase-lock loop during clock acquisition. Clock acquisition requires a valid Manchester bit pattern of 1010b to lock onto the incoming message. When input amplitude and pulse width conditions are met at $Dl\pm$ , the internal enable signal from the MEN-DEC to controller (IRXEN) is asserted and a clock acquisition cycle is initiated. ## **Clock Acquisition** When there is no activity at DI $\pm$ (receiver is idle), the receive oscillator is phase locked to the internal transmit clock. The first negative clock transition (bit cell center of first valid Manchester ZERO) after IRXEN is asserted interrupts the receive oscillator. The oscillator is then restarted at the second Manchester ZERO (bit time 4) and is phase locked to it. As a result, the MENDEC acquires the clock from the incoming Manchester bit pattern in 4 bit times with a 1010b Manchester bit pattern. IRXCLK and IRXDAT are enabled 1/4 bit time after clock acquisition in bit cell 5. IRXDAT is at a HIGH state when the receiver is idle (no IRXCLK). IRXDAT however, is undefined when clock is acquired and may remain HIGH or change to LOW state whenever IRXCLK is enabled. At 1/4 bit time into bit cell 5, the controller portion of the PCnet-PCI II controller sees the first IRXCLK transition. This also strobes in the incoming fifth bit to the MENDEC as Manchester ONE. IRXDAT may make a transition after the IRXCLK rising edge in bit cell 5, but its state is still undefined. The Manchester ONE at bit 5 is clocked to IRXDAT output at 1/4 bit time in bit cell 6. # **PLL Tracking** After clock acquisition, the phase-locked clock is compared to the incoming transition at the bit cell center (BCC) and the resulting phase error is applied to a correction circuit. This circuit ensures that the phase-locked clock remains locked on the received signal. Individual bit cell phase corrections of the Voltage Controlled Oscillator (VCO) are limited to 10% of the phase difference between BCC and phase-locked clock. Hence, input data jitter is reduced in IRXCLK by 10 to 1. # **Carrier Tracking and End of Message** The carrier detection circuit monitors the DI $\pm$ inputs after IRXEN is asserted for an end of message. IRXEN deasserts 1 to 2 bit times after the last positive transition on the incoming message. This initiates the end of reception cycle. The time delay from the last rising edge of the message to IRXEN deassert allows the last bit to be strobed by IRXCLK and transferred to the controller section, but prevents any extra bit(s) at the end of message. # **Data Decoding** The data receiver is a comparator with clocked output to minimize noise sensitivity to the DI $\pm$ inputs. Input error is less than $\pm$ 35 mV to minimize sensitivity to input rise and fall time. IRXCLK strobes the data receiver output at 1/4 bit time to determine the value of the Manchester bit, and clocks the data out on IRXDAT on the following IRXCLK. The data receiver also generates the signal used for phase detector comparison to the internal MENDEC voltage controlled oscillator (VCO). ## **Jitter Tolerance Definition** The MENDEC utilizes a clock capture circuit to align its internal data strobe with an incoming bit stream. The clock acquisition circuitry requires four valid bits with the values 1010b. The clock is phase-locked to the negative transition at the bit cell center of the second ZERO in the pattern. Since data is strobed at 1/4 bit time, Manchester transitions which shift from their nominal placement through 1/4 bit time will result in improperly decoded data. With this as the criterion for an error, a definition of Jitter Handling is: The peak deviation approaching or crossing 1/4 bit cell position from nominal input transition, for which the MENDEC section will properly decode data. ## **Attachment Unit Interface** The Attachment Unit Interface (AUI) is the PLS (Physical Layer Signaling) to PMA (Physical Medium Attachment) interface which effectively connects the DTE to a MAU. The differential interface provided by the PC-net-PCI II controller is fully compliant to Section 7 of ISO 8802-3 (ANSI/IEEE 802.3). After the PCnet-PCI II controller initiates a transmission it will expect to see data "looped-back" on the DI± pair (when the AUI port is selected). This will internally generate a "carrier sense", indicating that the integrity of the data path to and from the MAU is intact, and that the MAU is operating correctly. This "carrier sense" signal must be asserted before end of transmission. If "carrier sense" does not become active in response to the data transmission, or becomes inactive before the end of transmission, the loss of carrier (LCAR) error bit will be set in the transmit descriptor ring (TMD2, bit 27) after the frame has been transmitted. #### **Differential Input Termination** The differential input for the Manchester data (Dl $\pm$ ) is externally terminated by two 40.2 $\Omega$ resistors and one optional common-mode bypass capacitor, as shown in the diagram below. The differential input impedance, ZIDF, and the common-mode input impedance, ZICM, are specified so that the Ethernet specification for cable termination impedance is met using standard 1% resistor terminators. If SIP devices are used, 39 ohms is also a suitable value. The CI $\pm$ differential inputs are terminated in exactly the same way as the DI $\pm$ pair. Figure 37. AUI Differential Input Termination #### **Collision Detection** A MAU detects the collision condition on the network and generates a 10 MHz differential signal at the Cl± inputs. This collision signal passes through an input stage which detects signal levels and pulse duration. When the signal is detected by the MENDEC it sets the ICLSN line HIGH. The condition continues for approximately 1.5 bit times after the last LOW-to-HIGH transition on Cl±. # **Twisted-pair Transceiver** This section describes operation of the Twisted Pair Transceiver (T-MAU) when operating in half-duplex mode. When in half-duplex mode, the T-MAU implements the Medium Attachment Unit (MAU) functions for the Twisted Pair Medium as specified by the supplement to IEEE 802.3 standard (Type 10BASE-T). When operating in full-duplex mode, the MAC engine behavior changes as described in the section "Full-Duplex Operation". The T-MAU provides twisted pair driver and receiver circuits, including on-board transmit digital predistortion and receiver squelch and a number of additional features including Link Status indication, Automatic Twisted Pair Receive Polarity Detection/Correction and Indication, Receive Carrier Sense, Transmit Active and Collision Present indication. ## **Twisted Pair Transmit Function** The differential driver circuitry in the TXD± and TXP± pins provides the necessary electrical driving capability and the pre-distortion control for transmitting signals over maximum length Twisted Pair cable, as specified by the 10BASE-T supplement to the ISO 8802-3 (IEEE/ANSI 802.3) Standard. The transmit function for data output meets the propagation delays and jitter specified by the standard. #### **Twisted Pair Receive Function** The receiver complies with the receiver specifications of the ISO 8802-3 (IEEE/ANSI 802.3) 10BASE-T Standard, including noise immunity and received signal rejection criteria ("Smart Squelch"). Signals meeting these criteria appearing at the RXD± differential input pair are routed to the MENDEC. The receiver function meets the propagation delays and jitter requirements specified by the standard. The receiver squelch level drops to half its threshold value after unsquelch to allow reception of minimum amplitude signals and to offset carrier fade in the event of worst case signal attenuation and crosstalk noise conditions. 19436C-40 Note that the 10BASE-T Standard defines the receive input amplitude at the external Media Dependent Interface (MDI). Filter and transformer loss are not specified. The T-MAU receiver squelch levels are defined to account for a 1 dB insertion loss at 10 MHz, which is typical for the type of receive filters/transformers employed. Normal 10BASE-T compatible receive thresholds are employed when the LRT bit (CSR15, bit 9) is cleared to ZERO. When the LRT bit is set to ONE, the Low Receive Threshold option is invoked, and the sensitivity of the T-MAU receiver is increased. This allows longer line lengths to be employed, exceeding the 100 m target distance of normal 10BASE-T (assuming typical 24 AWG cable). The increased receiver sensitivity compensates for the increased signal attenuation caused by the additional cable distance. However, making the receiver more sensitive means that it is also more susceptible to extraneous noise, primarily caused by coupling from co-resident services (crosstalk). For this reason, it is recommended that when using the Low Receive Threshold option that the service should be installed on 4-pair cable only. Multipair cables within the same outer sheath have lower crosstalk attenuation, and may allow noise emitted from adjacent pairs to couple into the receive pair, and be of sufficient amplitude to falsely unsquelch the T-MAU. #### **Link Test Function** The Link Test Function is implemented as specified by the 10BASE-T standard. During periods of transmit pair inactivity, "Link beat pulses" will be periodically sent over the twisted pair medium to constantly monitor medium integrity. When the link test function is enabled (DLNKTST bit in CSR15 is cleared), the absence of link beat pulses and receive data on the RXD± pair will cause the T-MAU to go into a Link Fail state. In the Link Fail state, data trans- mission, data reception, data loopback and the collision detection functions are disabled, and remain disabled until valid data or more than five consecutive link pulses appear on the RXD± pair. During Link Fail, the Link Status signal is inactive. When the link is identified as functional, the Link Status signal is asserted. The LNKST pin displays the Link Status signal by default. The T-MAU will power up in the Link Fail state and the normal algorithm will apply to allow it to enter the Link Pass state. If T-MAU is selected using the PORTSEL bits in CSR15, the T-MAU will be forced into the Link Fail state when moving from AUI to T-MAU selection. Transmission attempts during Link Fail state will produce no network activity and will produce LCAR and CERR error indications. In order to interoperate with systems which do not implement Link Test, this function can be disabled by setting the DLNKTST bit in CSR15. With link test disabled, the data driver, receiver and loopback functions as well as collision detection remain enabled irrespective of the presence or absence of data or link pulses on the RXD± pair. Link Test pulses continue to be sent regardless of the state of the DLNKTST bit. ## **Polarity Detection and Reversal** The T-MAU receive function includes the ability to invert the polarity of the signals appearing at the RXD± pair if the polarity of the received signal is reversed (such as in the case of a wiring error). This feature allows data frames received from a reverse wired RXD± input pair to be corrected in the T-MAU prior to transfer to the MENDEC. The polarity detection function is activated following H\_RESET or Link Fail, and will reverse the receive polarity based on both the polarity of any previous link beat pulses and the polarity of subsequent frames with a valid End Transmit Delimiter (ETD). When in the Link Fail state, the T-MAU will recognize link beat pulses of either positive or negative polarity. Exit from the Link Fail state is made due to the reception of 5–6 consecutive link beat pulses of identical polarity. On entry to the Link Pass state, the polarity of the last 5 link beat pulses is used to determine the initial receive polarity configuration and the receiver is reconfigured to subsequently recognize only link beat pulses of the previously recognized polarity. Positive link beat pulses are defined as received signal with a positive amplitude greater than 585 mV (LRT = 1) with a pulse width of 60 ns–200 ns. This positive excursion may be followed by a negative excursion. This definition is consistent with the expected received signal at a correctly wired receiver, when a link beat pulse which fits the template of Figure 14-12 of the 10BASE-T Standard is generated at a transmitter and passed through 100 m of twisted pair cable. Negative link beat pulses are defined as received signals with a negative amplitude greater than 585 mV with a pulse width of 60–200 ns. This negative excursion may be followed by a positive excursion. This definition is consistent with the expected received signal at a reverse wired receiver, when a link beat pulse which fits the template of Figure 14-12 in the 10BASE-T Standard is generated at a transmitter and passed through 100 m of twisted pair cable. The polarity detection/correction algorithm will remain "armed" until two consecutive frames with valid ETD of identical polarity are detected. When "armed", the receiver is capable of changing the initial or previous polarity configuration based on the ETD polarity. On receipt of the first frame with valid ETD following H\_RESET or Link Fail, the T-MAU will utilize the inferred polarity information to configure its RXD± input, regardless of its previous state. On receipt of a second frame with a valid ETD with correct polarity, the detection/correction algorithm will "lock-in" the received polarity. If the second (or subsequent) frame is not detected as confirming the previous polarity decision, the most recently detected ETD polarity will be used as the default. Note that frames with invalid ETD have no effect on updating the previous polarity decision. Once two consecutive frames with valid ETD have been received, the T-MAU will disable the detection/correction algorithm until either a Link Fail condition occurs or H RESET is activated. During polarity reversal, an internal POL signal will be active. During normal polarity conditions, this internal POL signal is inactive. The state of this signal can be read by software and/or displayed by LED when enabled by the LED control bits in the Bus Configuration Registers (BCR4 to BCR7). #### **Twisted Pair Interface Status** When the T-MAU is in Link Pass state, three signals (XMT, RCV and COL) indicate whether the T-MAU is transmitting, receiving, or in a collision state with both functions active simultaneously. These signals are internal signals that can be programmed to appear on any of the LED output pins. Programming is done by writing to BCR4 to BCR7. In the Link Fail state, XMT, RCV and COL are inactive. #### **Collision Detection Function** Activity on both twisted pair signals RXD± and TXD± at the same time constitutes a collision, thereby causing the internal COL signal to be activated. COL will remain active until one of the two colliding signals changes from active to idle. However, transmission attempt in Link Fail state results in LCAR and CERR indication. COL stays active for 2 bit times at the end of a collision. ## **Signal Quality Error Test Function** The Signal Quality Error (SQE) test function (also called Heartbeat) is disabled when the 10BASE-T port is selected. #### Jabber Function The Jabber function prevents the twisted pair transmit function of the T-MAUTXD± from being active for an excessive period of time (20 ms to 150 ms). This prevents any one node from disrupting the network due to a "stuck-on" or faulty transmitter. If this maximum transmit time is exceeded, the T-MAU transmitter circuitry is disabled, the JAB bit is set (CSR4, bit 1) and the COL signal is asserted. Once the transmit data stream is removed, the T-MAU waits an "unjab" time of 250 ms to 750 ms before it deasserts COL and re-enables the transmit circuitry. #### **Power Down** The T-MAU circuitry can be made to go into a power savings mode. The T-MAU will go into the power down mode when H\_RESET is active, when coma mode is active, or when the T-MAU is not selected. Refer to the section "Power Savings Modes" for descriptions of the various power down modes. Any of the three conditions listed above resets the internal logic of the T-MAU and places the device into power down mode. In this mode, the Twisted Pair driver pins (TXD±, TXP±) are driven LOW, and the internal T-MAU status signals (LNKST, RCVPOL, XMT, RCV and COL) signals are inactive. After coming out of the power down mode, the T-MAU will remain in the reset state for an additional 10 $\mu$ s. Immediately after the reset condition is removed, the T-MAU will be forced into the Link Fail state. The T-MAU will move to the Link Pass state only after 5–6 link beat pulses and/or a single received message is detected on the RD± pair. In snooze mode, the T-MAU receive circuitry will remain enabled even while the SLEEP pin is driven LOW. #### **10BASE-T Interface Connection** The figure below shows the proper 10BASE-T network interface design. Refer to Appendix A for a list of compatible 10BASE-T filter/transformer modules. Note that the recommended resistor values and filter and transformer modules are the same as those used by the IMR+ (Am79C981). 19436C-41 Figure 38. 10BASE-T Interface Connection ## **Full-Duplex Operation** The PCnet-PCI II controller supports full-duplex operation on all three network interfaces: AUI and 10BASE-T. Full-duplex operation allows simultaneous transmit and receive activity on the TXD± and RXD± pairs of the 10BASE-T port, the DO± and DI± pairs of the AUI port. Full-duplex operation is enabled by the FDEN and AUIFD bits located in BCR9. The PCnet-PCI II controller does not support IEEE standard auto-negotiation between half-duplex and full-duplex operation. When operating in full-duplex mode, the following changes to the device operation are made: Bus Interface/Buffer Management Unit changes: - The first 64 bytes of every transmit frame are not pre- served in the transmit FIFO during transmission of the first 512 bits as described in the section "Transmit Exception Conditions". Instead, when full-duplex mode is active and a frame is being transmitted, the XMTFW bits (CSR80, bits 9–8) always govern when transmit DMA is requested. - Successful reception of the first 64 bytes of every receive frame is not a requirement for receive DMA to begin as described in the section "Receive Exception Condition". Instead, receive DMA will be requested as soon as either the Receive FIFO Watermark (CSR80, bits 13–12) is reached or a complete valid receive frame is detected, regardless of length. This receive FIFO operation is identical to when the RPA bit (CSR124, bit 3) is set during half-duplex mode operation. ## MAC Engine changes: - Changes to the Transmit Deferral mechanism: - Transmission is not deferred while receive is active. - The Inter Packet Gap (IPG) counter which governs transmit deferral during the IPG between back-to-back transmits is started when transmit activity for the first packet ends instead of when transmit and carrier activity ends. - When the AUI port is active, Loss of Carrier (LCAR) reporting is disabled. (LCAR is still reported when the 10BASE-T port is active if a packet is transmitted while in Link Fail state.) - The 4.0 µs carrier sense blinding period after a transmission during which the SQE test normally occurs is disabled. - When the AUI port is active, the SQE Test error reporting (CERR) is disabled. (CERR is still reported when the 10BASE-T port is active if a packet is transmitted while in Link Fail state.) - The collision indication input to the MAC engine is ignored. T-MAU changes: - The internal transmit to receive feedback path which is used to indicate carrier sense during normal transmission in half-duplex mode is disabled. - The collision detect circuit is disabled. - The SQE test function is disabled. #### **Full-Duplex Link Status LED Support** The PCnet-PCI II controller provides a bit in each of the LED Status registers (BCR4, BCR5, BCR6, BCR7) to display the Full-Duplex Link Status. If the FDLSE bit (bit 8) is set, a value of ONE will be sent to the associated LEDOUT bit when the T-MAU is in the Full-Duplex Link Pass state. ## **External Address Detection Interface** The External Address Detection Interface (EADI) is provided to allow external address filtering. It is selected by setting the EADISEL bit in BCR2 to ONE. This feature is typically utilized for terminal servers, bridges and/or router products. The EADI interface can be used in conjunction with external logic to capture the packet destination address from the serial bit stream as it arrives at the PCnet-PCI II controller, compare the captured address with a table of stored addresses or identifiers, and then determine whether or not the PCnet-PCI II controller should accept the packet. The EADI interface outputs are delivered directly from the NRZ decoded data and clock recovered by the Manchester decoder. This allows the external address detection to be performed in parallel with frame reception and address comparison in the MAC Station Address Detection (SAD) block of the PCnet-PCI II controller. SRDCLK is provided to allow clocking of the receive bit stream into the external address detection logic. Note that when the 10BASE-T port is selected, transitions on SRDCLK will only occur during receive activity. When the AUI port is selected, transitions on SRDCLK will occur during both transmit and receive activity. Once a received frame commences and data and clock are available from the decoder, the EADI logic will monitor the alternating (1,0) preamble pattern until the two ONEs of the Start Frame Delimiter (SFD, 10101011 bit pattern) are detected, at which point the SFBD output will be driven HIGH. The SFBD signal will initially be LOW. The assertion of SFBD is a signal to the external address detection logic that the SFD has been detected and that subsequent SRDCLK cycles will deliver packet data to the external logic. Therefore, when SFBD is asserted, the external address matching logic should begin de-serialization of the SRD data and send the resulting destination address to a Content Addressable Memory (CAM) or other address detection device. In order to reduce the amount of logic external to the PCnet-PCI II controller for multiple address decoding systems, the SFBD signal will toggle at each new byte boundary within the packet, subsequent to the SFD. This eliminates the need for externally supplying byte framing logic. SRD is the decoded NRZ data from the network. This signal can be used for external address detection. Note that when the 10BASE-T port is selected, transitions on SRD will only occur during receive activity. When the AUI port is selected, transitions on SRD will occur during both transmit and receive activity. The EAR pin should be driven LOW by the external address comparison logic to reject a frame. If an address match is detected by comparison with either the Physical Address or Logical Address Filter registers contained within the PCnet-PCI II controller or the frame is of the type "Broadcast", then the frame will be accepted regardless of the condition of $\overline{\text{EAR}}$ . When the EADISEL bit of BCR2 is set to ONE and the PCnet-PCI II controller is programmed to promiscuous mode (PROM bit of the Mode Register is set to ONE), then all incoming frames will be accepted, regardless of any activity on the $\overline{\text{EAR}}$ pin. Internal address match is disabled when PROM (CSR15, bit 15) is cleared to ZERO, DRCVBC (CSR15, bit 14) and DRCVPA (CSR15, bit 13) are set to ONE and the Logical Address Filter registers (CSR8 to CSR11) are programmed to all ZEROs. When the EADISEL bit of BCR2 is set to ONE and internal address match is disabled, then all incoming frames will be accepted by the PCnet-PCI II controller, unless the EAR pin becomes active during the first 64 bytes of the frame (excluding preamble and SFD). This allows external address lookup logic approximately 58 byte times after the last destination address bit is available to generate the EAR signal, assuming that the PCnet-PCI II controller is not configured to accept runt packets. The EADI logic only samples $\overline{\text{EAR}}$ from 2 bit times after SFD until 512 bit times (64 bytes) after SFD. The frame will be accepted if $\overline{\text{EAR}}$ has not been asserted during this window. If Runt Packet Accept (CSR124, bit 3) is enabled, then the $\overline{\text{EAR}}$ signal must be generated prior to the receive message completion, if frame rejection is to be guaranteed. Runt packet sizes could be as short as 12 byte times (assuming 6 bytes for source address, 2 bytes for length, no data, 4 bytes for FCS) after the last bit of the destination address is available. $\overline{\text{EAR}}$ must have a pulse width of at least 110 ns. Note that when the PCnet-PCI II controller is operating in full-duplex mode or runt packet accept is turned on (CSR124, bit 3) the Receive FIFO Watermark (CSR80, bits 13–12) must be programmed to 64 (01b) or 128 (10b) to allow the full window of 512 bit times after SFD for the assertion of $\overline{EAR}$ . If the watermark was programmed to 16 (00b), receive FIFO DMA could start before $\overline{EAR}$ is asserted to reject the frame. The EADI outputs continue to provide data throughout the reception of a frame. This allows the external logic to capture frame header information to determine protocol type, inter-networking information, and other useful data. The EADI interface will operate as long as the STRT bit in CSR0 is set, even if the receiver and/or transmitter are disabled by software (DTX and DRX bits in CSR15 are set). This configuration is useful as a semi-power-down mode in that the PCnet-PCI II controller will not perform any power-consuming DMA operations. However, external circuitry can still respond to control frames on the network to facilitate remote node control. The table below summarizes the operation of the EADI interface: | PROM | EAR | Required Timing | Received Messages | |------|-----|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | 1 | Х | No timing requirements | All received frames | | 0 | 1 | No timing requirements | All received frames | | 0 | 0 | Low for 110 ns during the window from 2 bits after SFD to 512 bits after SFD | PCnet-PCI II controller internal physical address and logical address filter matches and broadcast frames | Table 10. EADI Operations # **Expansion ROM Interface** The Expansion ROM is an 8-bit ROM connected to the PCnet-PCI II controller Expansion ROM Data bus (ERD). It can be of up to 64 Kbytes in size. The Expansion ROM Address bus (ERA) is 8 bits wide. An external latch is required to store the upper 8 bits of the 16-bit address to the ROM. All ERA outputs are forced to a constant level to conserve power while no access to the Expansion ROM is performed. EROE is asserted during the Expansion ROM read operation. This signal can be used to control the $\overline{OE}$ input of the ROM. EROE can be left unconnected and the $\overline{OE}$ input of the ROM can be tied to ground to always enable the ROM data outputs. The $\overline{CE}$ input of the ROM can either be tied to ground or it can also be connected to EROE. 19436C-42 Figure 39. Expansion ROM Interface The signal ERACLK is provided to strobe the upper 8 bits of the address into an external latch. The timing relation of ERACLK to ERA is such that both '373 (transparent latch) and '374 (D flip-flop) types of address latch can be used. The PCnet-PCI II controller will always read four bytes for every host Expansion ROM read access. The interface to the Expansion ROM runs synchronous to the PCI bus interface clock. The PCnet-PCI II controller will start the read operation to the Expansion ROM by driving the upper 8-bits of the Expansion ROM address on ERA[7:0]. This happens in the same clock cycle that the device claims the transfer by asserting DEVSEL. One clock later, EROE is asserted and ERACLK goes high to allow latching of the upper address bits externally. The upper portion of the Expansion ROM address will be the same for all four byte read cycles. ERACLK is asserted for one clock. ERA[7:0] are driven with the upper 8-bits of the Expansion ROM address for one more clock cycle after ERACLK goes low. Next, the PCnet-PCI II controller starts driving the lower 8 bits of the Expansion ROM address on ERA[7:0]. The time the PCnet-PCI II controller waits for data to be valid is programmable. ROMTMG (BCR18, bits 15–12) defines the time from when the PCnet-PCI II controller drives ERA[7:0] with the lower 8-bits of the Expansion ROM address to when the PCnet-PCI II controller latches in the data on the ERD[7:0] inputs. The register value specifies the time in number of clock cycles. When ROMTMG is set to Nine (the default value), ERD[7:0] is sampled with the next rising edge of CLK nine clock cycles after ERA[7:0] was driven with a new address value. The clock edge that is used to sample the data is also the clock edge that generates the next Expansion ROM address. Only the first three bytes of Expansion ROM data are stored in holding registers. The fourth byte is passed directly from the ERD[7:0] inputs to the AD[31:24] outputs. One clock cycle after the last data byte is available, PCnet-PCI II controller asserts TRDY. Two clock cycles after the data is transferred on the PCI bus, $\overline{EROE}$ is deasserted. The access time for the Expansion ROM device ( $t_{ACC}$ ) can be calculated by subtracting the clock to output delay for the ERA[7:0] outputs ( $t_{VAL}(ERA)$ ) and the input to clock setup time for the ERD[7:0] inputs ( $t_{SU}(ERD)$ ) from the time defined by ROMTMG: $$t_{ACC} \le ROMTMG^* clock period - t_{VAL}(ERA) - t_{SU}(ERD)$$ For an adapter card application, the value used for clock period should be 30 ns to guarantee correct interface timing at the maximum clock frequency of 33 MHz. The timing diagram below assumes the default programming of ROMTMG (1001b = 9 CLK). After reading the first byte, the PCnet-PCI II controller reads in three more bytes by incrementing the lower portion of the ROM address. After the last byte is strobed in, $\overline{TRDY}$ will be asserted on clock 44. When the host tries to perform a burst read of the Expansion ROM, the PC-net-PCI II will disconnect the access at the second data phase. Figure 40. Expansion ROM Bus Read Sequence The host must program the Expansion ROM Base Address register in the PCI configuration space before the first access to the Expansion ROM. The PCnet-PCI II controller will not react to any access to the Expansion ROM until both MEMEN (PCI Command register, bit 1) and ROMEN (PCI Expansion ROMBase Address register, bit 0) are set to ONE. After the Expansion ROM is enabled, the PCnet-PCI II controller will claim all memory read accesses with an address between ROMBASE and ROMBASE + 64K – 4 (ROMBASE, PCI Expansion ROM Base Address register, bits 31–11). The address output to the Expansion ROM is the offset from the address on the PCI bus to ROMBASE. The PCnet-PCI II controller aliases all accesses to the Expansion ROM of the command types "Memory Read Multiple" and "Memory Read Line" to the basic Memory Read command. Since setting MEMEN also enables memory mapped access to the I/O resources, attention must be given to the PCI Memory Mapped I/O Base Address register, before enabling access to the Expansion ROM. The host must set the PCI Memory Mapped I/O Base Address register to a value that prevents the PCnet-PCI II controller from claiming any memory cycles not intended for it. During the boot procedure the system will try to find an Expansion ROM. A PCI system assumes that an Expansion ROM is present when it reads the ROM signature 55h (byte 0) and AAh (byte 1). A design without Expansion ROM can guarantee that the Expansion ROM detection fails by connecting two adjacent ERD pins together and tying them high or low. #### **EEPROM Microwire Interface** The PCnet-PCI II controller contains a built-in capability for reading and writing to an external serial EEPROM. This built-in capability consists of an interface for direct connection to a Microwire compatible EEPROM, an automatic EEPROM read feature, and a user-programmable register that allows direct access to the Microwire interface pins. ## **Automatic EEPROM Read Operation** Shortly after the deassertion of the RST pin, the PCnet-PCI II controller will read the contents of the EEPROM that is attached to the Microwire interface. Because of this automatic read capability of the PCnet-PCI II controller, an EEPROM can be used to program many of the features of the PCnet-PCI II controller at power-up, allowing system-dependent configuration information to be stored in the hardware, instead of inside the device driver. If an EEPROM exists on the Microwire interface, the PCnet-PCI II controller will read the EEPROM contents at the end of the H\_RESET operation. The EEPROM contents will be serially shifted into a temporary register and then sent to various register locations on board the PCnet-PCI II controller. Access to the PCnet-PCI II controller configuration space, the Expansion ROM or any I/O resource is not possible during the EEPROM read operation. The PCnet-PCI II controller will terminate any access attempt with the assertion of DEVSEL and STOP while TRDY is not asserted, signaling to the initiator to disconnect and retry the access at a later time. A checksum verification is performed on the data that is read from the EEPROM. If the checksum verification passes, PVALID (BCR19, bit 15) will be set to ONE. If the checksum verification of the EEPROM data fails, PVALID will be cleared to ZERO and the PCnet-PCI II controller will force all EEPROM-programmable BCR registers back to their H\_RESET default values. The content of the Address PROM locations (offsets 0h–Fh from the I/O or memory mapped I/O base address), however, will not be cleared. The 8 bit checksum for the entire 36 bytes of the EEPROM should be FFh. If no EEPROM is present at the time of the automatic read operation, the PCnet-PCI II controller will recognize this condition and will abort the automatic read operation and clear both the PREAD and PVALID bits in BCR19. All EEPROM-programmable BCR registers will be assigned their default values after H\_RESET. The content of the Address PROM locations (offsets 0h—Fh from the I/O or memory mapped I/O base address) will be undefined. If the user wishes to modify any of the configuration bits that are contained in the EEPROM, then the seven command, data and status bits of BCR19 can be used to write to the EEPROM. After writing to the EEPROM, the host should set the PREAD bit of BCR19. This action forces a PCnet-PCI II controller re-read of the EE-PROM so that the new EEPROM contents will be loaded into the EEPROM-programmable registers on board the PCnet-PCI II controller. (The EEPROM-programmable registers may also be reprogrammed directly, but only information that is stored in the EEPROM will be preserved at system power-down.) When the PREAD bit of BCR19 is set, it will cause the PCnet-PCI II controller to ignore further accesses to the PCnet-PCI II controller configuration space, the Expansion ROM, or any I/O resource until the completion of the EEPROM read operation. The PCnet-PCI II controller will terminate these access attempts with the assertion of DEVSEL and STOP while TRDY is not asserted, signaling to the initiator to disconnect and retry the access at a later time. #### **EEPROM Auto-Detection** The PCnet-PCI II controller uses the EESK/LED1/SFBD pin to determine if an EEPROM is present in the system. At the rising edge of CLK during the last clock during which RST is asserted, the PCnet-PCI II controller will sample the value of the EESK/LED1/SFBD pin. If the sampled value is a ONE, then the PCnet-PCI II controller assumes that an EE-PROM is present, and the EEPROM read operation begins shortly after the RST pin is deasserted. If the sampled value of EESK/LED1/SFBD is a ZERO, the PCnet-PCI II controller assumes that an external pulldown device is holding the EESK/LED1/SFBD pin low indicating that there is no EEPROM in the system. Note that if the designer creates a system that contains an LED circuit on the EESK/LED1/SFBD pin but has no EEPROM present, then the EEPROM auto-detection function will incorrectly conclude that an EEPROM is present in the system. However, this will not pose a problem for the PCnet-PCI II controller, since the checksum verification will fail. #### Direct Access to the Microwire Interface The user may directly access the Microwire port through the EEPROM register, BCR19. This register contains bits that can be used to control the Microwire interface pins. By performing an appropriate sequence of accesses to BCR19, the user can effectively write to and read from the EEPROM. This feature may be used by a system configuration utility to program hardware configuration information into the EEPROM. #### **EEPROM-programmable Registers** The following registers contain configuration information that will be programmed automatically during the EEPROM read operation: | ■ I/O offsets 0h–Fh | Address PROM locations | |---------------------|--------------------------------------| | ■ BCR2 | Miscellaneous Configuration register | | ■ BCR4 | Link Status LED register | | ■ BCR5 | LED1 Status register | | ■ BCR6 | LED2 Status register | | ■ BCR7 | LED3 Status register | | ■ BCR9 | Full-Duplex Control register | | ■ BCR18 | Burst and Bus Control register | ■ BCR22 PCI Latency register If PREAD (BCR19, bit 14) and PVALID (BCR19, bit 15) are cleared to ZERO, then the EEPROM read has experienced a failure and the contents of the EEPROM programmable BCR register will be set to default H\_RESET values. The content of the Address PROM locations, however, will not be cleared. Note that accesses to the Address PROM I/O locations do not directly access the Address EEPROM itself. Instead, these accesses are routed to a set of shadow registers on board the PCnet-PCI II controller that are loaded with a copy of the EEPROM contents during the automatic read operation that immediately follows the H\_RESET operation. #### **EEPROM MAP** The automatic EEPROM read operation will access 18 words (i.e. 36 bytes) of the EEPROM. The format of the EEPROM contents is shown below, beginning with the byte that resides at the lowest EEPROM address: Table 11. EEPROM Content | Word<br>Address | Byte<br>Addr. | Most Significant Byte | Byte<br>Addr. | Least Significant Byte | |--------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00h<br>(Lowest<br>EEPROM<br>address) | 01h | Second byte of the ISO 8802-3<br>(IEEE/ANSI 802.3) station physical address<br>for this node | 00h | First byte of the ISO 8802-3<br>(IEEE/ANSI 802.3) station physical address<br>for this node, where first byte refers to the<br>first byte to appear on the 802.3 medium | | 01h | 03h | Fourth byte of the node address | 02h | Third byte of the node address | | 02h | 05h | Sixth byte of the node address | 04h | Fifth byte of the node address | | 03h | 07h | Reserved Location: must be 00h | 06h | Reserved location must be 00h | | 04h | 09h | Hardware ID: must be 11h if compatibility to AMD drivers is desired | 08h | Reserved location must be 00h | | 05h | 0Bh | User programmable space | 0Ah | User programmable space | | 06h | 0Dh | MSByte of two-byte checksum, which is the sum of bytes 00h–0Bh and bytes 0Eh and 0Fh | 0Ch | LSByte of two-byte checksum, which is the sum of bytes 00h–0Bh and bytes 0Eh and 0Fh | | 07h | 0Fh | Must be ASCII W (57h) if compatibility to AMD driver software is desired | 0Eh | Must be ASCII W (57h) if compatibility to AMD driver software is desired | | 08h | 11h | BCR4[15:8] (Link Status LED) | 10h | BCR4[7:0] (Link Status LED) | | 09h | 13h | BCR5[15:8] (LED1 Status) | 12h | CR5[7:0] (LED1 Status) | | 0Ah | 15h | BCR18[15:8] (Burst and Bus Control) | 14h | BCR18[7:0] (Burst and Bus Control) | | 0Bh | 17h | BCR2[15:8] (Miscellaneous Configuration) | 16h | BCR2[7:0] (Miscellaneous Configuration) | | 0Ch | 19h | BCR6[15:8] (LED2 Status) | 18h | BCR6[7:0] (LED2 Status) | | 0Dh | 1Bh | BCR7[15:8] (LED3 Status) | 1Ah | BCR7[7:0] (LED3 Status) | | 0Eh | 1Dh | BCR9[15:8] (Full-Duplex Control) | 1Ch | BCR9[7:0] (Full-Duplex Control) | | 0Fh | 1Fh | Checksum adjust byte for the first 36 bytes of the EEPROM contents, checksum of the first 36 bytes of the EEPROM should total to FFh | 1Eh | Reserved location must be 00h | | 10h | 21h | BCR22[15:8] (PCI Latency) | 20h | BCR22[7:0] (PCI Latency) | | 11h | 23h | Reserved location must be 00h | 22h | Reserved location must be 00h | Note that the first bit out of any word location in the EEPROM is treated as the MSB of the register that is being programmed. For example, the first bit out of EEPROM word location 08h will be written into BCR4, bit 15, the second bit out of EEPROM word location 08h will be written into BCR4, bit 14, etc. There are two checksum locations within the EE-PROM. The first checksum will be used by AMD driver software to verify that the ISO 8802-3 (IEEE/ANSI 802.3) station address has not been corrupted. The value of bytes 0Ch and 0Dh should match the sum of bytes 00h through 0Bh and 0Eh and 0Fh. The second checksum location — byte 1 Fh — is not a checksum total, but is, instead, a checksum adjustment. The value of this byte should be such that the total checksum for the entire 36 bytes of EEPROM data equals the value FFh. The checksum adjust byte is needed by the PCnet-PCI II controller in order to verify that the EE-PROM content has not been corrupted. # **LED Support** The PCnet-PCI II controller can support up to four LEDs. LED outputs LNKST, LED1 and LED2 allow for direct connection of an LED and its supporting pullup device. LED output LED3 may require an additional buffer between the PCnet-PCI II controller output pin and the LED and its supporting pullup device. Because the LED3 output is multiplexed with other PC-net-PCI II controller functions, it may not always be possible to connect an LED circuit directly to the LED3 pin. In applications that want to use the pin to drive an LED and also have an EEPROM, it might be necessary to buffer the LED3 circuit from the EEPROM connection. When an LED circuit is directly connected to the EEDO/LED3/SRD pin, then it is not possible for most Microwire EEPROM devices to sink enough IOL to maintain a valid low level on the EEDO input to the PC-net-PCI II controller. In applications where an EE-PROM is not needed, the LED3 pin may be directly connected to an LED circuit. The PCnet-PCI II controller LED3 pin driver will be able to sink enough current to properly drive the LED circuit. Each LED can be programmed through a BCR register to indicate one or more of the following network status or activities: Collision Status, Full-Duplex Link Status, Half-Duplex Link Status, Jabber Status, Magic Packet Status, Receive Match, Receive Polarity, Receive Status and Transmit Status. The LED pins can be configured to operate in either open-drain mode (active low) or in totem-pole mode (active high). The output can be stretched to allow the human eye to recognize even short events that last only several microseconds. After H\_RESET, the four LED outputs are configured in the following manner: **LED Output** Indication **Driver Mode Pulse Stretch LNKST** Link Status Open Drain - Active Low Enabled LED1 Receive Status Open Drain - Active Low Enabled LED2 Receive Polarity Open Drain - Active Low Enabled LED3 Transmit Status Open Drain - Active Low Enabled Table 12. LED Default Configuration For each LED register, each of the status signals is ANDed with its enable signal, and these signals are all ORed together to form a combined status signal. Each LED pins combined status signal can be programmed to run to a pulse stretcher, which consists of a 3-bit shift register clocked at 38 Hz (26 ms). The data input of each shift register is normally at logic 0. The OR gate output for each LED register asynchronously sets all three bits of its shift register when the output becomes asserted. The inverted output of each shift register is used to control an LED pin. Thus the pulse stretcher provides 2–3 clocks of stretched LED output, or 52 ms to 78 ms. 19436C-44 Figure 41. LED Control Logic # **Power Savings Modes** The PCnet-PCI II controller supports two hardware power savings modes. Both are entered by driving the SLEEP pin LOW. The power down mode that yields the most power savings is called coma mode. In coma mode, the entire device is shut down. All inputs are ignored except the SLEEP pin itself. Coma mode is enabled when AWAKE (BCR2, bit 2) is at its default value of ZERO and SLEEP is asserted. The second power saving mode is called snooze mode. In snooze mode, enabled by setting AWAKE to ONE and driving the SLEEP pin LOW, the T-MAU receive circuitry will remain active even while the SLEEP pin is driven LOW. The LNKST output is the only one of the LED pins that continues to function. All other sections of the device are shut down. The LNKSTE bit must be set in BCR4 to enable indication of a good 10BASE-T link if there are link beat pulses or valid frames present. This LNKST pin can be used to drive an LED and/or external hardware that directly controls the SLEEP pin of the PCnet-PCI II controller. This configuration effectively wakes the system when there is any activity on the 10BASE-T link. Snooze mode can be used only if the T-MAU is the selected network port. Link beat pulses are not transmitted during snooze mode. The SLEEP pin must not be asserted while the PC-net-PCI II controller is requesting the bus or while a slave or bus master cycle is in progress. A recommended method is to set the PCnet-PCI II controller into *suspend* mode by setting the SPND bit in CSR5 to ONE prior to asserting the SLEEP pin. Another recommended method is to *stop* the device by setting the STOP bit in CSR0 to ONE prior to asserting the SLEEP pin. Before the sleep mode is invoked, the PCnet-PCI II controller will perform an internal S\_RESET. This S\_RESET operation will not affect the values of the BCR registers or the PCI configuration space. S\_RESET terminates all network activity abruptly. The host can use the suspend mode (SPND, CSR5, bit 0) to terminate all network activity in an orderly sequence before issuing an S\_RESET. When coming out of the sleep mode, the PCnet-PCI II controller can be programmed to generate an interrupt and inform the driver about the wake-up. The PCnet-PCI II controller will set SLPINT (CSR5, bit 9), when coming out of the sleep mode. INTA will be asserted, when the enable bit SLPINTE (CSR5, bit 8) is set to ONE. Note that the assertion of INTA due to SLPINT is not dependent on the main interrupt enable bit INEA (CSR0, bit 6), which will be cleared by the reset going into the sleep mode. 90 Am79C970A The SLEEP pin should not be asserted during power supply ramp-up. If it is desired that SLEEP be asserted at power up time, then the system must delay the assertion of SLEEP until three clock cycles after the completion of a hardware reset operation. ## **IEEE 1149.1 Test Access Port Interface** An IEEE 1149.1 compatible boundary scan Test Access Port is provided for board level continuity test and diagnostics. All digital input, output and input/output pins are tested. Analog pins, including the AUI differential driver (DO±) and receivers (DI±, CI±), and the crystal input (XTAL1/XTAL2) pins, are not tested. The T-MAU drivers TXD±, TXP± and receiver RXD± are also not tested. The following is a brief summary of the IEEE 1149.1 compatible test functions implemented in the PC-net-PCI II controller. #### **Boundary Scan Circuit** The boundary scan test circuit requires four pins (TCK, TMS, TDI and TDO), defined as the Test Access Port (TAP). It includes a finite state machine (FSM), an instruction register, a data register array, and a power-on reset circuit. Internal pull-up resistors are provided for the TDI, TCK, and TMS pins. The boundary scan circuit remains active during Sleep mode. #### **TAP Finite State Machine** The TAP engine is a 16-state finite state machine (FSM), driven by the Test Clock (TCK) and the Test Mode Select (TMS) pins. An independent power-on reset circuit is provided to ensure the FSM is in the TEST\_LOGIC\_RESET state at power-up. The FSM is also reset when TMS and TDI are high for five TCK periods. # **Supported Instructions** In addition to the minimum IEEE 1149.1 requirements (BYPASS, EXTEST, and SAMPLE instructions), three additional instructions (IDCODE, TRIBYP and SETBYP) are provided to further ease board-level testing. All unused instruction codes are reserved. See the following table for a summary of supported instructions. Table 13. IEEE 1149.1 Supported Instruction Summary | Instruction Name | Instruction Code | Description | Mode | Selected Data Register | |------------------|------------------|-------------------------|--------|------------------------| | EXTEST | 0000 | External Test | Test | BSR | | IDCODE | 0001 | ID Code Inspection | Normal | ID REG | | SAMPLE | 0010 | Sample Boundary | Normal | BSR | | TRIBYP | 0011 | Force Float | Normal | Bypass | | SETBYP | 0100 | Control Boundary To 1/0 | Test | Bypass | | BYPASS | 1111 | Bypass Scan | Normal | Bypass | ## **Instruction Register and Decoding Logic** After the TAP FSM is reset, the IDCODE instruction is always invoked. The decoding logic gives signals to control the data flow in the Data registers according to the current instruction. #### **Boundary Scan Register** Each Boundary Scan Register (BSR) cell has two stages. A flip-flop and a latch are used for the Serial Shift Stage and the Parallel Output Stage, respectively. There are four possible operation modes in the BSR cell: Table 14. Boundry Scan Register Mode Of Operation | 1 | Capture | |---|-----------------| | 2 | Shift | | 3 | Update | | 4 | System Function | ## **Other Data Registers** - 1. Bypass Register (1 bit) - 2. Device ID register (32 bits) Table 15. Device ID Register | Bits 31–28 | Version Bits 27–12 Part Number (0010 0100 0011 XXXX) | |------------|-------------------------------------------------------------------------------------------------------------------| | Bits 11-1 | Manufacturer ID. The 11 bit manufacturer ID cod for AMD is 0000000001 in accordance with JEDEC publication 106-A. | | Bit 0 | Always a logic 1 | Note that the content of the Device ID register is the same as the content of CSR88. ## **NAND Tree Testing** The PCnet-PCI II controller provides a NAND tree test mode to allow checking connectivity to the device on a printed circuit board. The NAND tree is built on all PCI bus signals. NAND tree testing is enabled by asserting $\overline{RST}$ . All PCI bus signals will become inputs on the assertion of $\overline{RST}$ . The result of the NAND tree test can be observed on the NOUT pin. Figure 42. NAND Tree Circuitry 94 Am79C970A Pin 120 (RST) is the first input to the NAND tree. Pin 117 (INTA) is the second input to the NAND tree, followed by pin 121 (CLK). All other PCI bus signals follow, counter clockwise, with pin 57 (AD0) being the last. Pins labeled NC and all power supply pins are not part of the NAND tree. The table below shows the complete list of pins connected to the NAND tree. Table 16. NAND Tree Pin Sequence | NAND<br>Tree<br>Input No. | Pin No. | Name | NAND<br>Tree<br>Input No. | Pin No. | Name | NAND<br>Tree<br>Input No. | Pin No. | Name | |---------------------------|---------|-------|---------------------------|---------|--------|---------------------------|---------|-------| | 1 | 120 | RST | 18 | 15 | AD21 | 35 | 36 | AD15 | | 2 | 117 | ĪNTA | 19 | 16 | AD20 | 36 | 38 | AD14 | | 3 | 121 | CLK | 20 | 18 | AD19 | 37 | 39 | AD13 | | 4 | 123 | GNT | 21 | 19 | AD18 | 38 | 40 | AD12 | | 5 | 126 | REQ | 22 | 21 | AD17 | 39 | 41 | AD11 | | 6 | 128 | AD31 | 23 | 22 | AD16 | 40 | 42 | AD10 | | 7 | 129 | AD30 | 24 | 23 | C/BE2 | 41 | 44 | AD9 | | 8 | 131 | AD29 | 25 | 24 | FRAME | 42 | 45 | AD8 | | 9 | 132 | AD28 | 26 | 25 | ĪRDY | 43 | 47 | C/BE0 | | 10 | 2 | AD27 | 27 | 26 | TRDY | 44 | 48 | AD7 | | 11 | 3 | AD26 | 28 | 27 | DEVSEL | 45 | 49 | AD6 | | 12 | 5 | AD25 | 29 | 28 | STOP | 46 | 51 | AD5 | | 13 | 6 | AD24 | 30 | 29 | LOCK | 47 | 52 | AD4 | | 14 | 7 | C/BE3 | 31 | 31 | PERR | 48 | 53 | AD3 | | 15 | 10 | IDSEL | 32 | 32 | SERR | 49 | 54 | AD2 | | 16 | 12 | AD23 | 33 | 34 | PAR | 50 | 56 | AD1 | | 17 | 13 | AD22 | 34 | 35 | C/BE1 | 51 | 57 | AD0 | RST must be asserted low to start a NAND tree test sequence. Initially, all NAND tree inputs except RST should be driven high. This will result in a high output at the NOUT pin. If the NAND tree inputs are driven from high to low in the same order as they are connected to build the NAND tree, NOUT will toggle every time an additional input is driven low. NOUT will change to low, when INTA is driven low and all other NAND tree inputs stay high. NOUT will toggle back to high, when CLK is additionally driven low. The square wave will continue until all NAND tree inputs are driven low. NOUT will be high, when all NAND tree inputs are driven low. Note, that some of the pins connected to the NAND tree are outputs in normal mode of operation. They must not be driven from an external source until the PCnet-PCI II controller is configured for NAND tree testing. Figure 43. NAND Tree Waveform #### Reset There are three different types of RESET operations that may be performed on the PCnet-PCI II controller device, H\_RESET, S\_RESET and STOP. These names have been used throughout the document. The following is a description of each type of RESET operation. #### **H RESET** Hardware Reset (H\_RESET) is a PCnet-PCI II controller reset operation that has been created by the proper assertion of the $\overline{RST}$ pin of the PCnet-PCI II controller device. When the minimum pulse width timing as specified in the $\overline{RST}$ pin description has been satisfied, then an internal reset operation will be performed. H\_RESET will program most of the CSR and BCR registers to their default value. Note that there are several CSR and BCR registers that are undefined after H\_RESET. See the sections on the individual registers for details. H\_RESET will clear all registers in the PCI configuration space. H\_RESET will cause the microcode program to jump to its reset state. Following the end of the H\_RESET operation, the PCnet-PCI II controller will attempt to read the EEPROM device through the EEPROM Microwire interface. H\_RESET resets the T-MAU into the Link Fail state. #### **S RESET** Software Reset (S\_RESET) is a PCnet-PCI II controller reset operation that has been created by a read access to the Reset register which is located at offset 14h in Word I/O mode or offset 18h in DWord I/O mode from the PCnet-PCI II controller I/O or memory mapped I/O base address. S\_RESET will reset all of or some portions of CSR0, 3, 4, 15, 80, 100 and 124 to default values. For the identity of individual CSRs and bit locations that are affected by S\_RESET, see the individual CSR register descriptions. S\_RESET will not affect any PCI configuration space locations. With the exception of DWIO (BCR18, bit 7) S\_RESET will not affect any of the BCR register values. S\_RESET will cause the microcode program to jump to its reset state. Following the end of the S\_RESET operation, the PCnet-PCI II controller will not attempt to read the EEPROM device. S\_RESET does not affect the status of the T-MAU. After S\_RESET, the host must perform a full re-initialization of the PCnet-PCI II controller before starting network activity. S\_RESET will clear DWIO (BCR18, bit 7) and the PC-net-PCI II controller will be in 16-bit I/O mode after the reset operation. A DWord write operation to the RDP (I/O offset 10h) must be performed to set the device into 32-bit I/O mode. 96 Am79C970A S\_RESET will cause REQ to deassert immediately. STOP (CSR0, bit 2) or SPND (CSR5, bit 0) can be used to terminate any pending bus mastership request in an orderly sequence. S\_RESET terminates all network activity abruptly. The host can use the suspend mode (SPND, CSR5, bit 0) to terminate all network activity in an orderly sequence before issuing an S\_RESET. #### **STOP** A STOP reset is generated by the assertion of the STOP bit in CSR0. Writing a ONE to the STOP bit of CSR0, when the stop bit currently has a value of ZERO, will initiate a STOP reset. If the STOP bit is already a ONE, then writing a ONE to the STOP bit will not generate a STOP reset. STOP will reset all or some portions of CSR0, 3, and 4 to default values. For the identity of individual CSRs and bit locations that are affected by STOP, see the individual CSR register descriptions. STOP will not affect any of the BCR and PCI configuration space locations. STOP will cause the microcode program to jump to its reset state. Following the end of the STOP operation, the PCnet-PCI II controller will not attempt to read the EEPROM device. Setting the STOP bit does not affect the T-MAU. Note that STOP will not cause a deassertion of the REQ signal, if it happens to be active at the time of the write to CSR0. The PCnet-PCI II controller will wait until it gains bus ownership and it will first finish all scheduled bus master accesses before the STOP reset is executed. STOP terminates all network activity abruptly. The host can use the suspend mode (SPND, CSR5, bit 0) to terminate all network activity in an orderly sequence before setting the STOP bit. ## **Software Access** #### **PCI Configuration Registers** The PCnet-PCI II controller implements a 256-byte configuration space as defined by the PCI specification revision 2.0. The 64-byte header includes all registers required to identify the PCnet-PCI II controller and its function. Additional registers are used to setup the configuration of the PCnet-PCI II controller in a system. None of the device specific registers located at offsets 40h through FCh are implemented. The layout of the PCnet-PCI II controller PCI configuration space is shown in the table below. The PCI configuration registers are accessible only by configuration cycles. All multi-byte numeric fields follow little endian byte ordering. All write accesses to Reserved locations have no effect; reads from these locations will return a data value of ZERO. | 31 | 24 | 23 | 16 | 15 8 | 3 7 0 | Offset | | |------------|----------------------------------------------|-------------|------|------------------|-------------|--------|--| | | Device ID | | | | Vendor ID | | | | | Sta | tus | | Cor | nmand | 04h | | | Base-Class | | Sub-Class | | Programming IF | Revision ID | 08h | | | Reserved | | Header Type | | Latency Timer | Reserved | 0Ch | | | | | I/O | Base | Address | <b>-</b> | 10h | | | | | Memory Ma | pped | I/O Base Address | | 14h | | | | | | Rese | erved | | 18h | | | | | | Rese | erved | | 1Ch | | | | Reserved | | | | | | | | | | | Rese | erved | | 24h | | | | | | Rese | erved | | 28h | | | | | | Rese | erved | | 2Ch | | | | | Expansion | RON | M Base Address | | 30h | | | | | | Rese | erved | | 34h | | | | | | Rese | erved | | 38h | | | MAX_LAT | MAX_LAT MIN_GNT Interrupt Pin Interrupt Line | | | | | | | | | Reserved | | | | | | | | Reserved | | | | | | | | | | Reserved | | | | | | | Table 17. PCI Configuration Space Layout #### I/O Resources The PCnet-PCI II controller requires 32 bytes of address space for access to all the various internal registers as well as to some setup information stored in an external serial EEPROM. A software reset port is available, too. The PCnet-PCI II controller supports mapping the address space to both I/O and memory space. The value in the PCI I/O Base Address register determines the start address of the I/O address space. The register is typically programmed by the PCI configuration utility after system power-up. The PCI configuration utility must also set the IOEN bit in the PCI Command register to enable I/O accesses to the PCnet-PCI II controller. For memory mapped I/O access, the PCI Memory Mapped I/O Base Address register controls the start address of the memory space. The MEMEN bit in the PCI Command register must also be set to enable the mode. Both base address registers can be active at the same time. The PCnet-PCI II controller supports two modes for accessing the I/O resources. For backwards compatibility with AMD's 16-bit Ethernet controllers, Word I/O is the default mode after power up. The device can be configured to DWord I/O mode by software. ## I/O Registers The PCnet-PCI II controller registers are divided into two groups. The Control and Status Registers (CSR) are used to configure the Ethernet MAC engine and to obtain status information. The Bus Control Registers (BCR) are use to configure the bus interface unit and the LEDs. Both sets of registers are accessed using indirect addressing. The CSR and BCR share a common Register Address Port (RAP). There are, however, separate data ports. The Register Data Port (RDP) is used to access a CSR. The BCR Data Port (BDP) is used to access a BCR. In order to access a particular CSR location, the RAP should first be written with the appropriate CSR address. The RDP will then points to the selected CSR. A read of the RDP will yield the selected CSR data. A write to the RDP will write to the selected CSR. In order to access a particular BCR location, the RAP should first be written with the appropriate BCR address. The BDP will then points to the selected BCR. A read of the BDP will yield the selected BCR data. A write to the BDP will write to the selected BCR. Once the RAP has been written with a value, the RAP value remains unchanged until another RAP write occurs, or until an H\_RESET or S\_RESET occurs. RAP is cleared to all ZEROs when an H\_RESET or S\_RESET occurs. RAP is unaffected by setting the STOP bit. # Address PROM Space The PCnet-PCI II controller allows for connection of a serial EEPROM. The first 16 bytes of the EEPROM will be automatically loaded into the Address PROM (APROM) space after H\_RESET. The Address PROM space is a convenient place to store the value of the 48-bit IEEE station address. It can be overwritten by the host computer. Its content has no effect on the operation of the controller. The software must copy the station address from the Address PROM space to the initialization block or to CSR12-14 in order for the receiver to accept unicast frames directed to this station. The 6 bytes of IEEE station address occupy the first 6 locations of the Address PROM space. The next six bytes are reserved. Bytes 12 and 13 should match the value of the checksum of bytes 1 through 11 and 14 and 15. Bytes 14 and 15 should each be ASCII W (57h). The above requirements must be met in order to be compatible with AMD driver software. The APROMWE bit (BCR2, bit 8) must be set to ONE to enable write access to the Address PROM space. #### Reset Register A read of the Reset register creates an internal software reset (S\_RESET) pulse in the PCnet-PCI II controller. The internal S\_RESET pulse that is generated by this access is different from both the assertion of the hardware $\overline{RST}$ pin (H\_RESET) and from the assertion of the software STOP bit. Specifically, S\_RESET is the equivalent of the assertion of the $\overline{RST}$ pin (H\_RESET) except that S\_RESET has no effect on the BCR or PCI Configuration space locations or on the T-MAU. The NE2100 LANCE based family of Ethernet cards requires that a write access to the Reset register follows each read access to the Reset register. The PCnet-PCI II controller does not have a similar requirement. The write access is not required but it does not have any effects. Note that the PCnet-PCI II controller cannot service any slave accesses for a very short time after a read access of the Reset register, because the internal S\_RESET operation takes about 1 $\mu s$ to finish. The PCnet-PCI II controller will terminate all slave accesses with the assertion of $\overline{\text{DEVSEL}}$ and $\overline{\text{STOP}}$ while $\overline{\text{TRDY}}$ is not asserted, signaling to the initiator to disconnect and retry the access at a later time. #### Word I/O Mode After H\_RESET, the PCnet-PCI II controller is programmed to operate in Word I/O mode. DWIO (BCR18, bit 7) will be cleared to ZERO. The table below shows how the 32 bytes of address space are used in Word I/O mode. Table 18. I/O Map In Word I/O Mode (DWIO = 0) | Offset | No. of Bytes | Register | |----------|--------------|-----------------------------| | 00h -0Fh | 16 | APROM | | 10h | 2 | RDP | | 12h | 2 | RAP (shared by RDP and BDP) | | 14h | 2 | Reset Register | | 16h | 2 | BDP | | 18h -1Fh | 8 | Reserved | All I/O resources must be accessed in word quantities and on word addresses. The Address PROM locations can also be read in byte quantities. The only allowed DWord operation is a write access to the RDP, which switches the device to DWord I/O mode. A read access other than listed in the table below will yield undefined data, a write operation may cause unexpected reprogramming of the PCnet-PCI II controller control registers. Table 19. Legal I/O Accesses in Word I/O Mode (DWIO = 0) | AD[4:0] | BE[3:0] | Туре | Comment | |---------|---------|------|----------------------------------------------------------------------------------------| | 0XX00 | 1110 | RD | Byte Read of APROM Location 0h, 4h, 8h or Ch | | 0XX01 | 1101 | RD | Byte Read of APROM Location 1h, 5h, 9h or Dh | | 0XX10 | 1011 | RD | Byte Read of APROM Location 2h, 6h, Ah or Eh | | 0XX11 | 0111 | RD | Byte Read of APROM Location 3h, 7h, Bh or Fh | | 0XX00 | 1100 | RD | Word Read of APROM Locations 1h (MSB) and 0h (LSB), 5h and 4h, 8h and 9h or Ch and Dh | | 0XX10 | 0011 | RD | Word Read of APROM Location 3h (MSB) and 2h (LSB), 7h and 6h, Bh and Ah or Fh or Eh | | 10000 | 1100 | RD | Word Read of RDP | | 10010 | 0011 | RD | Word Read of RAP | | 10100 | 1100 | RD | Word Read of Reset Register | | 10110 | 0011 | RD | Word Read of BDP | | 0XX00 | 1100 | WR | Word Write to APROM Locations 1h (MSB) and 0h (LSB), 5h and 4h, 8h and 9h or Ch and Dh | | 0XX10 | 0011 | WR | Word Write to APROM Locations 3h (MSB) and 2h (LSB), 7h and 6h, Bh and Ah or Fh and Eh | | 10000 | 1100 | WR | Word Write to RDP | | 10010 | 0011 | WR | Word Write to RAP | | 10100 | 1100 | WR | Word Write to Reset Register | | 10110 | 0011 | WR | Word Write to BDP | | 10000 | 0000 | WR | DWord Write to RDP, switches Device to DWord I/O Mode | #### Double Word I/O Mode The PCnet-PCI II controller can be configured to operate in DWord (32bit) I/O mode. The software can invoke the DWIO mode by performing a DWord write access to the I/O location at offset 10h (RDP). The data of the write access must be such that it does not affect the intended operation of the PCnet-PCI II controller. Setting the device into 32-bit I/O mode is usually the first operation after H\_RESET. The RAP register will point to CSR0 at that time. Writing a value of ZERO to CSR0 is a save operation. DWIO (BCR18, bit 7) will be set to ONE as indicating that the PCnet-PCI II controller operates in 32-bit I/O mode. Note that even though the I/O resource mapping changes when the I/O mode setting changes, the RDP location offset is the same for both modes. Once the DWIO bit has been set to ONE, only H\_RESET or S\_RESET can clear it to ZERO. The DWIO mode setting is unaffected by setting the STOP bit. The table below shows how the 32 bytes of address space are used in DWord I/O mode. Table 20. I/O Map In DWord I/O Mode (DWIO = 1) | Offset | No. of Bytes | Register | |-----------|--------------|-----------------------------| | 00h – 0Fh | 16 | APROM | | 10h | 4 | RDP | | 14h | 4 | RAP (shared by RDP and BDP) | | Offset | No. of Bytes | Register | |--------|--------------|----------------| | 18h | 4 | Reset Register | | 1Ch | 4 | BDP | All I/O resources must be accessed in DWord quantities and on DWord addresses. A read access other than listed in the table below will yield undefined data, a write operation may cause unexpected reprogramming of the PCnet-PCI II controller control registers. Table 21. Legal I/O Accesses in Double Word I/O Mode (DWIO = 1) | AD[4:0] | BE[3:0] | Туре | Comment | |---------|---------|------|-------------------------------------------------------------------------------------| | 0XX00 | 0000 | RD | DWord Read of APROM Locations 3h (MSB) to 0h (LSB), 7h to 4h, Bh to 8h or Fh to Ch | | 10000 | 0000 | RD | DWord Read of RDP | | 10100 | 0000 | RD | DWord Read of RAP | | 11000 | 0000 | RD | DWord Read of Reset Register | | 0XX00 | 0000 | WR | DWord Write to APROM Locations 3h (MSB) to 0h (LSB), 7h to 4h, Bh to 8h or Fh to Ch | | 10000 | 0000 | WR | DWord Write to RDP | | 10100 | 0000 | WR | DWord Write to RAP | | 11000 | 0000 | WR | DWord Write to Reset Register | ## **USER ACCESSIBLE REGISTERS** The PCnet-PCI II controller has three types of user registers: the PCI configuration registers, the Control and Status registers (CSR) and the Bus Control registers (BCR). The PCnet-PCI II controller implements all PCnet-ISA (Am79C960) registers, all C-LANCE (Am79C90) registers, all ILACC (Am79C900) registers, plus a number of additional registers. The PCnet-PCI II controller CSRs are compatible with both the PCnet-ISA CSRs and all of the C-LANCE CSRs upon power up. Compatibility to the ILACC set of CSRs requires one access to the Software Style register (BCR20, bits 7–0) to be performed. By setting an appropriate value of the Software Style register (BCR20, bits 7–0) the user can select a set of CSRs that are compatible with the ILACC set of CSRs. The PCI configuration registers can be accessed in any data width. All other registers must be accessed according to the I/O mode that is currently selected. When WIO mode is selected, all other register locations are defined to be 16 bits in width. When DWIO mode is selected, all these register locations are defined to be 32 bits in width, with the upper 16 bits of most register locations marked as reserved locations with undefined values. When performing register write operations in DWIO mode, the upper 16 bits should always be written as ZEROs. When performing register read operations in DWIO mode, the upper 16 bits of I/O resources should always be regarded as having undefined values, except for CSR88. PCnet-PCI II controller registers can be divided into four groups: ## **PCI Configuration Registers** Registers that are intended to be initialized by the system initialization procedure (e.g. BIOS device initialization routine) to program the operation of the PCnet-PCI II controller PCI bus interface. # **Setup Registers** Registers that are intended to be initialized by the device driver to program the operation of various PC-net-PCI II controller features. ## **Running Registers** Registers that are intended to be used by the device driver software once the PCnet-PCI II controller is running to access status information and to pass control information. ## **Test Registers** Registers that are intended to be used only for testing and diagnostic purposes. Below is a list of the registers that fall into each of the first three categories. Those registers that are not included in either of these lists can be assumed to be intended for diagnostic purposes. ## **PCI Configuration Registers** The following is a list of those registers that would typically need to be programmed once during the initialization of the PCnet-PCI II controller within a system: - PCI I/O Base Address or Memory Mapped I/O Base Address register - PCI Expansion ROM Base Address register - PCI Interrupt Line register - PCI Latency Timer register - PCI Status register - PCI Command register ## **Setup Registers** The following is a list of those registers that would typically need to be programmed once during the setup of the PCnet-PCI II controller within a system. The control bits in each of these registers typically do not need to be modified once they have been written. However, there are no restrictions as to how many times these registers may actually be accessed. Note that if the default power up values of any of these registers is acceptable to the application, then such registers need never be accessed at all. Registers marked with "A" may be programmable through the EEPROM read operation, and therefore do not necessarily need to be written to by the system initialization procedure or by the driver software. Registers marked with "\*" will be initialized by the initialization block read operation. | CSR1 | Initialization Block Address[15:0] | |--------|--------------------------------------| | CSR2 | Initialization Block Address[31:16] | | CSR3 | Interrupt Masks and Deferral Control | | CSR4 | Test and Features Control | | CSR5 | Extended Control and Interrupt | | CSR8* | Logical Address Filter[15:0] | | CSR9* | Logical Address Filter[31:16] | | CSR10* | Logical Address Filter[47:32] | | CSR11* | Logical Address Filter[63:48] | | CSR12* | Physical Address[15:0] | | CSR13* | Physical Address[31:16] | | CSR14* | Physical Address[47:32] | | CSR15* | Mode | | CSR24* | Base Address of Receive Descriptor Ring Lower | |--------|------------------------------------------------| | CSR25* | Base Address of Receive Descriptor Ring Upper | | CSR30* | Base Address of Transmit Descriptor Ring Lower | | CSR31* | Base Address of Transmit Descriptor Ring Upper | | CSR47 | Polling Interval | | CSR76* | Receive Descriptor Ring Length | | CSR78* | Transmit Descriptor Ring Length | | CSR82 | Bus Activity Timer | | CSR100 | Memory Error Timeout | | CSR122 | Receiver Packet Alignment Control | | BCR2^ | Miscellaneous Configuration | | BCR4^ | Link Status LED | | BCR5^ | LED1 Status | | BCR6^ | LED2 Status | | BCR7^ | LED3 Status | | BCR9^ | Full-Duplex Control | | BCR18^ | Bus and Burst Control | | BCR20 | Software Style | | | | #### **Running Registers** The following is a list of those registers that would typically need to be periodically read and perhaps written during the normal running operation of the PCnet-PCI II controller within a system. Each of these registers contains control bits or status bits or both. | RAP | Register Address Port | | |---------------------|--------------------------------|--| | CSR0 | PCnet-PCI II Controller Status | | | CSR4 | Test and Features Control | | | CSR5 | Extended Control and Interrupt | | | CSR112 | Missed Frame Count | | | CSR114 | Receive Collision Count | | | PCI Status register | | | ## **PCI Configuration Registers** ## PCI Vendor ID (Offset 00h) The PCI Vendor ID register is a 16-bit register that identifies the manufacturer of the PCnet-PCI II controller. Advanced Micro Devices, Inc.'s (AMD) Vendor ID is 1022h. Note that this vendor ID is not the same as the Manufacturer ID in CSR88andCSR89. The vendor ID is assigned by the PCI Special Interest Group. The PCI Vendor ID register is located at offset 00h in the PCI Configuration Space. It is read only. #### PCI Device ID Register (Offset 02h) The PCI Device ID register is a 16-bit register that uniquely identifies the PCnet-PCI II controller within AMD's product line. The PCnet-PCI II controller Device ID is 2000h. Note that this Device ID is not the same as the Part number in CSR88 and CSR89. The Device ID is assigned by Advanced Micro Devices, Inc. The PCI Device ID register is located at offset 02h in the PCI Configuration Space. It is read only. #### PCI Command Register (Offset 04h) The PCI Command register is a 16-bit register used to control the gross functionality of the PCnet-PCI II controller. It controls the PCnet-PCI II controller's ability to generate and respond to PCI bus cycles. To logically disconnect the PCnet-PCI II controller device from all PCI bus cycles except Configuration cycles, a value of ZERO should be written to this register. The PCI Command register is located at offset 04h in the PCI Configuration Space. It is read and written by the host. Memory Write and Invalidate Cy-**MWIEN** the host. cle enable. Read as ZERO, write Bit Name **Description** operations have no effect. The PCnet-PCI II controller only generates Memory Write cycles. 15-10 RES Reserved locations. Read as ZE-ROs, write operations have no ef-Special Cycle enable. Read as 3 SCYCEN fect. ZERO, write operations have no effect. The PCnet-PCI II control-9 **FBTBEN** Fast Back-to-Back Enable. Read ler ignores all Special Cycle operas ZERO, write operations have ations. no effect. The PCnet-PCI II controller will not generate Fast 2 **BMEN** Bus Master enable. Setting Back-to-Back cycles. BMEN enables the PCnet-PCI II controller to become a bus mas-SERR enable. Controls the as-8 **SERREN** ter on the PCI bus. The host must sertion of the SERR pin. SERR is set BMEN before setting the INIT disabled when SERREN is or STRT bit in CSR0 of the PCcleared. SERR will be asserted net-PCI II controller. on detection of an address parity error and if both SERREN and BMEN is cleared by H RESET PERREN (bit 6 of this register) and is not effected by S\_RESET are set. or by setting the STOP bit. SERREN is cleared bν Memory Space access enable. 1 **MEMEN** H RESET and is not effected by The PCnet-PCI II controller will S\_RESET or by setting the STOP ignore all memory accesses bit. when MEMEN is cleared. The host must set MEMEN before the **ADSTEP** Address/data stepping. Read as first memory access to the de-ZERO, write operations have no vice. effect. The PCnet-PCI II controller does not use address step-For memory mapped I/O, the ping. host must program the PCI Memory Mapped I/O Base Address 6 **PERREN** Parity Error Response enable. register with a valid memory ad-Enables the parity error response dress before setting MEMEN. functions. When PERREN is "0" and the PCnetPCI II controller For accesses to the Expansion detects a parity error, it only sets ROM, the host must program the 5 the Detected Parity Error bit in the PCI Status register. When PERREN is "1", the PCnet-PCI II controller asserts PERR on the detection of a data parity error. It also sets the DATAPERR bit (PCI Status register, bit 8), when the data parity error occurred during a master cycle. PERREN also enables reporting address parity errors through the SERR pin and the SERR bit in the PCI Status H RESET and is not effected by S RESET or by setting the STOP RO, write operations have no ef- cleared by is register. **PERREN** fect. VGASNOOP VGA palette snoop. Read as ZE- 102 Am79C970A PCI Expansion ROM Base Address register at offset 30h with a valid memory address before setting MEMEN. The PCnet-PCI II controller will only respond to accesses to the Expansion ROM when both ROMEN (PCI Expansion ROM Base Address register, bit 0) and MEMEN are set to ONE. Since MEMEN also enables the memory mapped access to the PCnet-PCI II controller I/O resources, the PCI Memory Mapped I/O Base Address register must be programmed with an address so that the device does not claim cycles not intended for it. MEMEN is cleared by H\_RESET and is not effected by S RESET or by setting the STOP bit. 0 **IOEN** I/O Space access enable. The PCnet-PCI II controller will ignore all I/O accesses when IOEN is cleared. The host must set IOEN before the first I/O access to the > grammed with a valid I/O address before setting IOEN. > IOEN is cleared by H\_RESET and is not effected by S RESET or by setting the STOP bit. > device. The PCI I/O Base Ad- dress register must be pro- # PCI Status Register (Offset 06h) The PCI Status register is a 16-bit register that contains status information for the PCI bus related events. It is located at offset 06h in the PCI Configuration Space. | Bit | Name | Description | |-----|------|--------------------------------------------------------------------------------------------------------------------------------------------| | 15 | PERR | Parity Error. PERR is set when the PCnet-PCI II controller detects a parity error. | | | | The PCnet-PCl II controller samples the AD[31:0], C/BE[3:0] and the PAR lines for a parity error at the following times: | | | | In slave mode, during the address phase of any PCI bus command. | | | | In slave mode, for all I/O, memory<br>and configuration write com-<br>mands that select the PCnet-PCI<br>II controller when data is trans- | ferred (TRDY and IRDY are asserted). In master mode, during the data phase of all memory read commands. In master mode, during the data phase of the memory write command, the PCnet-PCI II controller sets the PERR bit if the target reports a data parity error by asserting the PERR signal. PERR is not effected by the state of the Parity Error Response enable bit (PCI Command register, bit 6). PERR is set by the PCnet-PCI II controller and cleared by writing a ONE. Writing a ZERO has no effect. PERR is cleared by H RESET and is not affected by S\_RESET or by setting the STOP bit. **SERR** Signaled SERR. SERR is set when the PCnet-PCI II controller detects an address parity error, and both SERREN and PERREN (PCI Command register, bits 8 and 6) are set. > SERR is set by the PCnet-PCI II controller and cleared by writing a ONE. Writing a ZERO has no effect. SERR is cleared by H RESET and is not affected by S\_RESET or by setting the STOP bit. **RMABORT** Received Master Abort. RM-ABORT is set when the PCnet-PCI II controller terminates a master cycle with a master abort sequence. RMABORT is set by the PCnet-PCI II controller and cleared by writing a ONE. Writing a ZERO has no effect. RMABORT is cleared by H RESET and is not affected by S\_RESET or by setting the STOP bit. **RTABORT** Received Target Abort. RT-ABORT is set when a target terminates a PCnet-PCI II controller master cycle with a target abort sequence. RTABORT is set by the PCnet-PCI II controller and cleared 14 13 12 Am79C970A 103 by writing a ONE. Writing a ZERO has no effect. RTABORT is cleared by H RESET and is not affected by S RESET or by setting the STOP bit. 11 **STABORT** Send Target Abort. Read as ZE-RO, write operations have no effect. The PCnet-PCI II controller will never terminate a slave access with a target abort sequence. STABORT is read only. 10-9 DEVSEL Device Select timing. DEVSEL is set to 01b (medium), which means that the PCnet-PCI II controller will assert DEVSEL two clock periods after FRAME is asserted. DEVSEL is read only. 8 DATAPERR Data Parity Error detected. DATAPERR is set when the PCnet-PCI II controller is the current bus master and it detects a data parity error and the Parity Error Response enable bit (PCI Command register, bit 6) is set. > During the data phase of all memory read commands, the PCnet-PCI II controller checks for parity error by sampling the AD[31:0] and C/BE[3:0] and the PAR lines. During the data phase of all memory write commands, the PCnet-PCI II controller checks the PERR input to detect whether the target has reported a parity error. > DATAPERR is set by the PCnet-PCI II controller and cleared by writing a ONE. Writing a ZERO has no effect. DATAPERR is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 7 **FBTBC** Fast Back-To-Back Capable. Read as ONE, write operations have no effect. The PCnet-PCI II controller is capable of accepting fast back-to-back transactions with the first transaction addressing a different target. 6-0 RES Reserved locations. Read as ZE-RO, write operations have no effect. #### PCI Revision ID Register (Offset 08h) The PCI Revision ID register is an 8-bit register that specifies the PCnet-PCI II controller revision number. The value of this register is 1xh, with the lower four bits being silicon-revision dependent. The PCI Revision ID register is located at offset 08h in the PCI Configuration Space. It is read only. #### PCI Programming Interface Register (Offset 09h) The PCI Programming Interface register is an 8-bit register that identifies the programming interface of PCnet-PCI II controller. PCI does not define any specific register-level programming interfaces for network devices. The value of this register is 00h. The PCI Programming Interface register is located at offset 09h in the PCI Configuration Space. It is read only. #### PCI Sub-Class Register (Offset 0Ah) The PCI Sub-Class register is an 8-bit register that identifies specifically the function of the PCnet-PCI II controller. The value of this register is 00h which identifies the PCnet-PCI II controller device as an Ethernet controller. The PCI Sub-Class register is located at offset 0Ah in the PCI Configuration Space. It is read only. #### PCI Base-Class Register (Offset 0Bh) The PCI Base-Class register is an 8-bit register that broadly classifies the function of the PCnet-PCI II controller. The value of this register is 02h which classifies the PCnet-PCI II controller device as a network control- The PCI Base-Class register is located at offset 0Bh in the PCI Configuration Space. It is read only. ## PCI Latency Timer Register (Offset 0Dh) The PCI Latency Timer register is an 8-bit register that specifies the minimum guaranteed time the PCnet-PCI Il controller will control the bus once it starts its bus mastership period. The time is measured in clock cvcles. Every time the PCnet-PCI II controller asserts FRAME at the beginning of a bus mastership period, it will copy the value of the PCI Latency Timer register into a counter and start counting down. The counter will freeze at ZERO. When the system arbiter removes GNT while the counter is non-ZERO, the PCnet-PCI II controller will continue with its data transfers. It will only release the bus when the counter has reached ZERO. The PCI Latency Timer is only significant in burst transactions, where FRAME stays asserted until the last data phase. In a non-burst transaction, FRAME is only asserted during the address phase. The internal latency counter will be cleared and suspended while FRAME is deasserted. All 8 bits of the PCI Latency Timer register are programmable. The host should read the PCnet-PCI II controller PCI MIN\_GNT and PCI MAX\_LAT registers to determine the latency requirements for the device and then initialize the Latency Timer register with an appropriate value. The PCI Latency Timer register is located at offset 0Dh in the PCI Configuration Space. It is read and written by the host. The PCI Latency Timer register is cleared by H\_RESET and is not effected by S\_RESET or by setting the STOP bit. ## PCI Header Type Register (Offset 0Eh) The PCI Header Type register is an 8-bit register that describes the format of the PCI Configuration Space locations 10h to 3Ch and that identifies a device to be single or multi function. The PCI Header Type register is located at address 0Eh in the PCI Configuration Space. It is read only. | Bit | Name | Description | |-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | FUNCT | Single function/multi function device. Read as ZERO, write operations have no effect. The PCnet-PCI II controller is a single function device. | | 6–0 | LAYOUT | PCI configuration space layout. Read as ZEROs, write operations have no effect. The layout of the PCI configuration space locations 10h to 3Ch is as shown in the table at the beginning of this section. | ## PCI I/O Base Address Register (Offset 10h) The PCI I/O Base Address register is a 32-bit register that determines the location of the PCnet-PCI II controller I/O resources in all of I/O space. It is located at offset 10h in the PCI Configuration Space. | 31 | -5 | ЮE | 3AS | Ε | |----|----|----|-----|---| | | | | | | I/O base address most significant 27 bits. These bits are written by the host to specify the location of the PCnet-PCI II controller I/O resources in all of I/O space. IO-BASE must be written with a valid address before the PCnet-PCI II controller slave I/O mode is turned on by setting the IOEN bit (PCI Command register, bit 0). When the PCnet-PCI II controller is enabled for I/O mode (IOEN is set), it monitors the PCI bus for a valid I/O command. If the value on AD[31:5] during the address phase of the cycles matches the value of IOBASE, the PCnet-PCI II controller will drive DEVSEL indicating it will respond to the access. IOBASE is read and written by the host. IOBASE is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. #### 4–2 IOSIZE 1 0 **IOSPACE** I/O size requirements. Read as ZEROs, write operations have no effect. IOSIZE indicates the size of the I/O space the PCnet-PCI II controller requires. When the host writes a value of FFFF FFFFh to the I/O Base Address register, it will read back a value of ZERO in bits 4–2. That indicates a PCnet-PCI II controller I/O space requirement of 32 bytes. RES Reserved location. Read as ZE-RO, write operations have no ef- fect. I/O space indicator. Read as ONE, write operations have no effect. Indicating that this base address register describes an I/O base address. # PCI Memory Mapped I/O Base Address Register (Offset 14h) The PCI Memory Mapped I/O Base Address register is a 32-bit register that determines the location of the PC-net-PCI II controller I/O resources in all of memory space. It is located at offset 14h in the PCI Configuration Space. | Bit | Name | Description | |------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–5 | MEMBASE | Memory mapped I/O base address most significant 27 bits. These bits are written by the host to specify the location of the PC-net-PCI II controller I/O resources in all of memory space. MEM-BASE must be written with a valid address before the PCnet-PCI II controller slave memory mapped I/O mode is turned on by setting the MEMEN bit (PCI Command register, bit 1). | 105 Am79C970A When the PCnet-PCI II controller is enabled for memory mapped I/O mode (MEMEN is set), it monitors the PCI bus for a valid memory command. If the value on AD[31:5] during the address phase of the cycles matches the value of MEMBASE, the PCnet-PCI II controller will drive DEVSEL indicating it will respond to the access. MEMBASE is read and written by the host. MEMBASE is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. MEMSIZE Memory mapped I/O size requirements. Read as ZEROs, write operations have no effect. MEMSIZE indicates the size of the memory space the PCnet-PCI II controller requires. When the host writes a value of FFFF FFFFh to the Memory Mapped I/O Base Address register, it will read back a value of ZERO in bit 4. That indicates a PCnet-PCI II controller memory space requirement of 32 bytes. PREFETCH 3 Prefetchable. Read as ZERO. write operations have no effect. Indicates that memory space controlled by this base address register is not prefetchable. Data in the memory mapped I/O space cannot be prefetched. Because one of I/O resources in this address space is a Reset register, the order of the read accesses is important. **TYPE** 2-1 Memory type indicator. Read as ZEROs, write operations have no effect. Indicates that this base address register is 32 bits wide and mapping can be done anywhere in the 32-bit memory space. 0 MEMSPACE Memory space indicator. Read as ZERO, write operations have no effect. Indicates that this base address register describes a memory base address. # **PCI Expansion ROM Base Address Register** (Offset 30h) The PCI Expansion ROM Base Address register is a 32-bit register that defines the base address, size and address alignment of an Expansion ROM. It is located at offset 30h in the PCI Configuration Space. #### Description Name 31-16ROMBASE Expansion ROM base address most significant 16 bits. These bits are written by the host to specify the location of the Expansion ROM in all of memory space. ROMBASE must be written with a valid address before the PCnet-PCI II controller Expansion ROM access is enabled by setting ROMEN (PCI Expansion ROM Base Address register, bit 0) and MEMEN (PCI Command register, bit 1). Since the 16 most significant bits of the base address are programmable, the host can map the Expansion ROM on any 64K boundary. When the PCnet-PCI II controller is enabled for Expansion ROM access (ROMEN and MEMEN are set to ONE), it monitors the PCI bus for a valid memory command. If the value on AD[31:2] during the address phase of the cycle falls between ROMBASE and ROMBASE + 64K - 4, the PCnet-PCI II controller will drive DEVSEL indicating it will respond to the access. ROMBASE is read and written by the host. ROMBASE is cleared by H RESET and is not affected by S\_RESET or by setting the STOP bit. 15-11 ROMSIZE ROM size. Read as ZEROs, write operation have no effect. ROM-SIZE indicates the maximum size of the Expansion ROM the PCnet-PCI II controller can support. The host can determine the Expansion ROM size by writing FFFF800h to the Expansion ROM Base Address register. It will read back a value of ZERO in bits 15-11, indicating an Expansion ROM size of 64K. Note that ROMSIZE only specifies the maximum size of Expansion ROM the PCnet-PCI II controller supports. A smaller ROM can be used, too. The actual size of the code in the Expansion ROM is always determined by reading the Expansion ROM header. 10-1 RES Reserved location. Read as ZE-ROs, write operations have no effect. 0 ROMEN Expansion ROM enable. Written by the host to enable access to the Expansion ROM. The PC-net-PCI II controller will only respond to accesses to the Expansion ROM when both ROMEN and MEMEN (PCI Command register, bit 1) are set to ONE. ROMEN is read and written by the host. ROMEN is cleared by H\_RESET and is not effected by S\_RESET or by setting the STOP bit. #### PCI Interrupt Line Register (Offset 3Ch) The PCI Interrupt Line register is an 8-bit register that is used to communicate the routing of the interrupt. This register is written by the POST software as it initializes the PCnet-PCI II controller in the system. The register is read by the network driver to determine the interrupt channel which the POST software has assigned to the PCnet-PCI II controller. The PCI Interrupt Line register is not modified by the PCnet-PCI II controller. It has no effect on the operation of the device. The PCI Interrupt Line register is located at offset 3Ch in the PCI Configuration Space. It is read and written by the host. It is cleared by H\_RESET and is not affected S\_RESET or by setting the STOP bit. ## PCI Interrupt Pin Register (Offset 3Dh) This PCI Interrupt Pin register is an 8-bit register that indicates the interrupt pin that the PCnet-PCI II controller is using. The value for the PCnet-PCI II controller Interrupt Pin register is 01h, which corresponds to INTA. The PCI Interrupt Pin register is located at offset 3Dh in the PCI Configuration Space. It is read only. #### PCI MIN\_GNT Register (Offset 3Eh) The PCI MIN\_GNT register is an 8-bit register that specifies the minimum length of a burst period that the PCnet-PCI II controller needs to keep up with the network activity. The length of the burst period is calculated assuming a clock rate of 33 MHz. The register value specifies the time in units of 1/4 ms. The PCI MIN\_GNT register is an alias of BCR22, bits 7–0. The default value for MIN\_GNT is 06h, which corresponds to a minimum grant of 1.5 $\mu$ s. One and a half $\mu$ s is the time it takes the PCnet-PCI II controller to read/write 64 bytes. (16 DWord transfers in burst mode with one extra wait state per data phase inserted by the target.) Note that the default is only a typical value. This calculation also does not take into account any descriptor accesses. The host should use the value in this register to determine the setting of the PCI Latency Timer register. The PCIMIN\_GNT register is located at offset 3Eh in the PCI Configuration Space. It is read only. #### PCI MAX\_LAT Register (Offset 3Fh) The PCI MAX\_LAT register is an 8-bit register that specifies the maximum arbitration latency the PC-net-PCI II controller can sustain without causing problems to the network activity. The register value specifies the time in units of 1/4 microseconds. The MAX\_LAT register is an alias of BCR22, bits 15–8. The default value for MAX\_LAT is FFh, which corresponds to a maximum latency of 63.75 µs. The actual maximum latency the PCnet-PCI II controller can handle is 153.6 µs, which is also the value for the bus time-out (see CSR100). The host should use the value in this register to determine the setting of the PCI Latency Timer register. The PCIMAX\_LAT register is located at offset 3Fh in the PCI Configuration Space. It is read only. ## **RAP Register** The RAP (Register Address Pointer) register is used to gain access to CSR and BCR registers on board the PCnet-PCI II controller. The RAP contains the address of a CSR or BCR. As an example of RAP use, consider a read access to CSR4. In order to access this register, it is necessary to first load the value 0004h into the RAP by performing a write access to the RAP offset of 12h (12h when WIO mode has been selected, 14h when DWIO mode has been selected). Then a second access is performed, this time to the RDP offset of 10h (for either WIO or DWIO mode). The RDP access is a read access, and since RAP has just been loaded with the value of 0004h, the RDP read will yield the contents of CSR4. A read of the BDP at this time (offset of 16h when WIO mode has been selected, 1Ch when DWIO mode has been selected) will yield the contents of BCR4, since the RAP is used as the pointer into both BDP and RDP space. | RAP: | Register Ad | dress Port | | | nel longer than the time required | |---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Description | | to send the maximum length frame. BABL will be set if 1519 bytes or greater are transmitted. | | | 31-16 RES | | Reserved locations. Written as ZEROs and read as undefined. | | | When BABL is set, INTA is asserted if IENA is ONE and the | | | RES | Reserved locations. Read and written as ZEROs. | | | mask bit BABLM (CSR3, bit 14) is<br>ZERO. BABL assertion will set<br>the ERR bit, regardless of the | | 7–0 | RAP | Register Address Port. The value of these 8 bits determines which CSR or BCR will be accessed when an I/O access to the RDP or BDP port, respectively, is performed. | 13 | | settings of IENA and BABLM. Read/Write accessible always. | | | | | | CERR | BABL is cleared by the host by writing a ONE. Writing a ZERO has no effect. BABL is cleared by H_RESET, S_RESET or by set- | | cause | e unexpected | ndefined CSR or BCR locations may reprogramming of the PCnet-PCI II | | | ting the STOP bit. Collision Error is set by the PC- | | defin | controller control registers. A read access will yield undefined values. | | | CENN | net-PCI II controller when the device operates in half-duplex | | Read/Write accessible always. RAP is cleared by H_RESET or S_RESET and is unaffected by setting the STOP bit. | | | | | mode and the collision inputs to<br>the AUI port failed to activate<br>within 20 network bit times after | | | | atus Registers | | | the chip terminated transmission (SQE Test). This feature is a | | to the<br>that i<br>pend<br>as a | e RDP (Regis<br>s read or writ<br>upon the cur<br>pointer into the | accessible by performing accesses ster Data Port). The particular CSR tten during an RDP access will derent setting of the RAP. RAP serves e CSR space. | | | transceiver test feature. CERR reporting is disabled when the AUI interface is active and the PCnet-PCI II controller operates in full-duplex mode. | | CSR(<br>Bit | CSR0: PCnet-PCI II Controller Status Register Bit Name Description | | | | In 10BASE-T mode, for both half-duplex and full-duplex opera- | | | | Certain bits in CSR0 indicate the cause of an interrupt. The regis- | is-<br>di-<br>ing<br>his<br>ad<br>ue | | tion, CERR will be set after a transmission if the T-MAU is in Link Fail state. | | | ter is designed so that the cator bits are cleared by ONEs to those bit location | ter is designed so that these indi-<br>cator bits are cleared by writing<br>ONEs to those bit locations. This<br>means that the software can read | | | CERR assertion will not result in an interrupt being generated. CERR assertion will set the ERR bit. | | | | CSR0 and write back the value just read to clear the interrupt condition. | | | Read/Write accessible always. CERR is cleared by the host by writing a ONE. Writing a ZERO | | 31–16 RES | | Reserved locations. Written as ZEROs and read as undefined. | | | has no effect. CERR is cleared by H_RESET, S_RESET or by setting the STOP bit. | | 15 | ERR | Error is set by the ORing of BABL, CERR, MISS, and MERR. ERR remains set as long as any of the error flags are true. | 12 | MISS | Missed Frame is set by the PC-net-PCI II controller when it looses an incoming receive frame because a receive descriptor was not available. This bit is the only immediate indication that receive data has been lost since there is no current receive descriptor. The Missed Frame Counter (CSR112) also increments each time a receive frame is missed. | | | | Read accessible always. ERR is read only. Write operations are ignored. | | | | | 14 | BABL | Babble is a transmitter time-out<br>error. BABL is set by the PC-<br>net-PCI II controller when the<br>transmitter has been on the chan- | | | | When MISS is set, INTA is asserted if IENA is ONE and the mask bit MISSM (CSR3, bit 12) is ZERO. MISS assertion will set the ERR bit, regardless of the settings of IENA and MISSM. Read/Write accessible always. MISS is cleared by the host by writing a ONE. Writing a ZERO has no effect. MISS is cleared by H\_RESET, S\_RESET or by setting the STOP bit. 11 MERR Memory Error is set by the PC-net-PCI II controller when it requests the use of the system interface bus by asserting REQ and GNT has not been asserted after a programmable length of time. The length of time in microseconds before MERR is asserted will depend upon the setting of the Bus Timeout register (CSR100). The default setting of CSR100 will set MERR after 153.6 µs of bus latency. When MERR is set, INTA is asserted if IENA is ONE and the mask bit MERRM (CSR3, bit 11) is ZERO. MERR assertion will set the ERR bit, regardless of the settings of IENA and MERRM. Read/Write accessible always. MERR is cleared by the host by writing a ONE. Writing a ZERO has no effect. MERR is cleared by H\_RESET, S\_RESET or by setting the STOP bit. 10 RINT Receive Interrupt is set by the PCnet-PCI II controller after the last descriptor of a receive frame has been updated by writing a ZERO to the OWN bit. RINT may also be set when the first descriptor of a receive frame has been updated by writing a ZERO to the OWN bit if the LAPPEN bit of CSR3 has been set to ONE. When RINT is set, INTA is asserted if IENA is ONE and the mask bit RINTM (CSR3, bit 10) is ZERO. Read/Write accessible always. RINT is cleared by the host by writing a ONE. Writing a ZERO has no effect. RINT is cleared by H\_RESET, S\_RESET or by setting the STOP bit. 9 TINT Transmit Interrupt is set by the PCnet-PCI II controller after the OWN bit in the last descriptor of a transmit frame has been cleared to indicate the frame has been sent or an error occurred in the transmission. When TINT is set, INTA is asserted if IENA is ONE and the mask bit TINTM (CSR3, bit 9) is ZERO. TINT will not be set if TINTOKD (CSR122, bit 2) is set to ONE and the transmission was successful. Read/Write accessible always. TINT is cleared by the host by writing a ONE. Writing a ZERO has no effect. TINT is cleared by H\_RESET, S\_RESET or by setting the STOP bit. 8 IDON Initialization Done is set by the PCnet-PCI II controller after the initialization sequence has completed. When IDON is set, the PCnet-PCI II controller has read the initialization block from memory. When IDON is set, INTA is asserted if IENA is ONE and the mask bit IDONM (CSR3, bit 8) is ZERO. Read/Write accessible always. IDON is cleared by the host by writing a ONE. Writing a ZERO has no effect. IDON is cleared by H\_RESET, S\_RESET or by setting the STOP bit. 7 INTR Interrupt Flag indicates that one or more following interrupt causing conditions has occurred: BABL, EXDINT, IDON, JAB, MERR, MISS, MFCO, MPINT, RVCC, RINT, SINT, SLPINT, TINT, TXSTRT or UINT and the associated mask or enable bit is programmed to allow the event to cause an interrupt. If IENA is set to ONE and INTR is set, INTA will be active. When INTR is set by SINT or SLPINT, INTA will be active independent of the state of INEA. Read accessible always. INTR is read only. INTR is cleared by Am79C970A 109 | 6 | IENA | clearing all of the active individual interrupt bits that have not been masked out. Interrupt Enable allows INTA to be active if the Interrupt Flag is set. If IENA is cleared to ZERO, INTA will be disabled regardless of the state of INTR. | | | Read/Write accessible always. TDMD is set by writing a ONE. Writing a ZERO has no effect. TDMD will be cleared by the buffer management unit when it polls a transmit descriptor. TDMD is cleared by H_RESET, S_RESET or by setting the STOP bit. | |---|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | RXON | Read/Write accessible always. IENA is set by writing a ONE and cleared by writing a ZERO. IENA is cleared by H_RESET, S_RESET or by setting the STOP bit. Receive On indicates that the re- | 2 | STOP | STOP assertion disables the chip from all DMA and network activity. The chip remains inactive until either STRT or INIT are set. If STOP, STRT and INIT are all set together, STOP will override STRT and INIT. | | 5 | HAON | ceive function is enabled. RXON is set to ONE if DRX (CSR15, bit 0) is cleared to ZERO after the START bit is set. If INIT and START are set together, RXON will not be set until after the initial- | 4 | STRT | Read/Write accessible always. STOP is set by writing a ONE, by H_RESET or S_RESET. Writing a ZERO has no effect. STOP is cleared by setting either STRT or INIT. | | 4 | TXON | ization block has been read in. Read accessible always. RXON is read only. RXON is cleared by H_RESET, S_RESET or by setting the STOP bit. Transmit On indicates that the transmit function is enabled. | 1 | SINI | STRT assertion enables the PC-<br>net-PCI II controller to send and<br>receive frames and perform buff-<br>er management operations. Set-<br>ting STRT clears the STOP bit. If<br>STRT and INIT are set together,<br>the PCnet-PCI II controller initial- | | | | TXON is set to ONE if DTX (CSR15, bit 1) is cleared to ZERO after the START bit is set. If INIT and START are set together, TXON will not be set until after the initialization block has been read in. | | | ization will be performed first. Read/Write accessible always. STRT is set by writing a ONE. Writing a ZERO has no effect. STRT is cleared by H_RESET, S_RESET or by setting the STOP bit. | | | | Read accessible always. TXON is read only. TXON is cleared by H_RESET, S_RESET or by setting the STOP bit. | 0 | INIT | INIT assertion enables the PC-<br>net-PCI II controller to begin the<br>initialization procedure which<br>reads the initialization block from<br>memory. Setting INIT clears the | | 3 | TDMD | Transmit Demand, when set, causes the buffer management unit to access the transmit descriptor ring without waiting for the poll-time counter to elapse. If TXON is not enabled, TDMD bit will be cleared and no transmit descriptor ring access will occur. If the DPOLL bit in CSR4 is set, automatic polling in disabled and | | | STOP bit. If STRT and INIT are set together, the PCnet-PCI II controller initialization will be performed first. INIT is not cleared when the initialization sequence has completed. Read/Write accessible always. INIT is set by writing a ONE. Writing a ZERO has no effect. INIT is | | | | automatic polling is disabled and TDMD can be used to start a transmission. | | | cleared by H_RESET, S_RESET or by setting the STOP bit. | show the 32 bit address that in- | Bit Name | Description | | | cludes the appended field. | |------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16 RES<br>15–0 IADR[15:0] | This register is aliased with CSR16. Reserved locations. Written as ZEROs and read as undefined. Lower 16 bits of the address of the initialization block. Bit locations 1 and 0 must both be ZERO | | | If SSIZE32 is set to ONE, then the IADR[31:24] bits will be used strictly as the upper 8 bits of the initialization block address. In this mode, software will provide 32-bit pointer values for all of the shared software structures-i.e. descriptor bases and buffer addresses. | | | to align the initialization block to a DWord boundary. Read/Write accessible only when either the STOP or the SPND bit is set. Unaffected by H_RESET | | | Read/Write accessible only when either the STOP or the SPND bit is set. Unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | or S_RESET or by setting the STOP bit. | 7–0 | IADR[23:16] | Bits 23 through 16 of the address of the initialization block. | | <b>CSR2: Initialization</b> | n Block Address 1 | | | Read/Write accessible only when | | Bit Name | Description This register is aliased with CSR17. | | | either the STOP or the SPND bit is set. Unaffected by H_RESET, S_RESET or by setting the STOP bit. | | 04 40 DE0 | | CSR | 3: Interrupt Ma | asks and Deferral Control | | 31–16 RES | Reserved locations. Written as ZEROs and read as undefined. | Bit | Name | Description | | 15–8 IADR[31:24] | If SSIZE32 (BCR20, bit 8) is cleared to ZERO, then the IADR[31:24] bits will be used to | 31–10 | 6 RES | Reserved locations. Written as ZEROs and read as undefined. | | | generate the upper 8 bits of all bus mastering addresses, as re- | 15 | RES | Reserved location. Read and written as ZERO. | | | quired for a 32-bit address bus. Note that the 16-bit software structures will yield only 24 bits of address for PCnet-PCI II control- | 14 | BABLM | Babble Mask. If BABLM is set, the BABL bit will be masked and unable to set the INTR bit. | | | ler bus master accesses. The PCnet-PCI II controller is designed for 32-bit systems which require 32 bits of address. There- | | | Read/Write accessible always.<br>BABLM is cleared by H_RESET<br>or S_RESET and is not affected<br>by STOP. | | | fore, whenever SSIZE32 is cleared to ZERO, the | 13 | RES | Reserved location. Read and written as ZERO. | | | IADR[31:24] bits will be appended to the 24-bit initialization address, to each 24-bit descriptor base address and to each begin- | 12 | MISSM | Missed Frame Mask. If MISSM is set, the MISS bit will be masked and unable to set the INTR bit. | | | ning 24-bit buffer address in order to form complete 32-bit addresses. The upper 8 bits that exist in the descriptor address | | | Read/Write accessible always. MISSM is cleared by H_RESET or S_RESET and is not affected by STOP. | | | registers and the buffer address<br>registers which are stored on<br>board the PCnet-PCI II controller<br>will be overwritten with the | 11 | MERRM | Memory Error Mask. If MERRM is set, the MERR bit will be masked and unable to set the INTR bit. | | | IADR[31:24] value, so that CSR accesses to these registers will | | | Read/Write accessible always.<br>MERRM is cleared by H_RESET | **CSR1: Initialization Block Address 0** or S RESET and is not affected by STOP. 10 **RINTM** Receive Interrupt Mask. If RINTM is set, the RINT bit will be masked and unable to set the INTR bit. Read/Write accessible always. RINTM is cleared by H RESET or S RESET and is not affected by STOP. **TINTM** 9 Transmit Interrupt Mask. TINTM is set, the TINT bit will be masked and unable to set the INTR bit. Read/Write accessible always. TINTM is cleared by H RESET or S RESET and is not affected by STOP. 8 **IDONM** Initialization Done Mask. IDONM is set, the IDON bit will be masked and unable to set the INTR bit. Read/Write accessible always. IDONM is cleared by H RESET or S RESET and is not affected by STOP. 7 **RES** Reserved location. Read and written as ZEROs. Disable Transmit Stop on Under-6 **DXSUFLO** flow error. When DXSUFLO is cleared to ZERO, the transmitter is turned off when an UFLO error occurs (CSR0, TXON = 0). When DXSUFLO is set to ONE, the PCnet-PCI II controller gracefully recovers from an UFLO error. It scans the transmit descriptor ring until it finds the start of a new frame and starts a new transmission. Read/Write accessible always. **DXSUFLO** is cleared H RESET or S RESET and is not affected by STOP. **LAPPEN** Look Ahead Packet Processing 5 Enable. When set to ONE, the LAPPEN bit will cause the PCnet-PCI II controller to generate an interrupt following the descriptor write operation to the first buffer of a receive frame. This interrupt will be generated in addition to the interrupt that is generated following the descriptor write operation to the last buffer of a receive packet. The interrupt will be signaled through the RINT bit of CSR0. Setting LAPPEN to ONE also enables the PCnet-PCI II controller to read the STP bit of receive descriptors. The PCnet-PCI II conwill troller use the STP information to determine where it should begin writing a receive packet's data. Note that while in this mode, the PCnet-PCI II controller can write intermediate packet data to buffers whose descriptors do not contain STP bits set to ONE. Following the write to the last descriptor used by a packet, the PCnet-PCI II controller will scan through the next descriptor entries to locate the next STP bit that is set to ONE.The PCnet-PCI II controller will begin writing the next packet's data to the buffer pointed to by that descriptor. Note that because several descriptors may be allocated by the host for each packet, and not all messages may need all of the descriptors that are allocated between descriptors that have STP set to ONE, then some descriptors/buffers may be skipped in the ring. While performing the search for the next STP bit that is set to ONE, the PCnet-PCI II controller will advance through the receive descriptor ring regardless of the state of ownership bits. If any of the entries that are examined during this search indicate PCnet-PCI II controller ownership of the descriptor but also have STP cleared to ZERO, the PCnet-PCI II controller will clear the OWN bit to ZERO in these entries. If a scanned entry indicates host ownership with STP cleared to ZERO, the PCnet-PCI II controller will not alter the entry, but will advance to the next entry. When the STP bit is set to ONE, but the descriptor that contains this setting is not owned by the PCnet-PCI II controller, then the PCnet-PCI II controller will stop advancing through the ring entries and begin periodic polling of this entry. When the STP bit is set to ONE, and the descriptor that contains this setting is owned by the PCnet-PCI II controller, then the PCnet-PCI II controller will stop advancing through the ring entries, store the descriptor information that it has just read, and wait for the next receive to arrive. This behavior allows the host software to pre-assign buffer space in such a manner that the header portion of a receive packet will always be written to a particular memory area, and the data portion of a receive packet will always be written to a separate memory area. The interrupt is generated when the header bytes have been written to the header memory area. Read/Write accessible always. LAPPEN bit is cleared by H\_RESET or S\_RESET and is not affected by STOP. See Appendix D for more information on the Look Ahead Packet Processing concept. 4 DXMT2PD Disable Transmit Two Part Deferral (see the section "Medium Allocation" for more details). If DXMT2PD is set, Transmit Two Part Deferral will be disabled. Read/Write accessible always. DXMT2PD is cleared by H\_RESET or S\_RESET and is not affected by STOP. 3 EMBA Enable Modified Back-off Algorithm (see the section "Collision Handling" for more details). If EMBA is set, a modified back-off algorithm is implemented. Read/Write accessible always. EMBA is cleared by H\_RESET or S\_RESET and is not affected by STOP. 2 BSWP Byte Swap. This bit is used to choose between big and little endian modes of operation. When BSWP is set to ONE, big endian mode is selected. When BSWP is cleared to ZERO, little endian mode is selected. When big endian mode is selected, the PCnet-PCI II controller will swap the order of bytes on the AD bus during a data phase on accesses to the FIFOs only: AD[31:24] is byte 0, AD[23:16] is byte 1, AD[15:8] is byte 2 and AD[7:0] is byte 3. When little endian mode is selected, the order of bytes on the AD bus during a data phase is: AD[31:24] is byte 3, AD[23:16] is byte 2, AD[15:8] is byte 1 and AD[7:0] is byte 0. Byte swap only affects data transfers that involve the FIFOs. Initialization block transfers, descriptor transfers, RDP, RAP, BDP and PCI configuration space accesses, Address PROM transfers, and Expansion ROM accesses are not affected by the setting of the BSWP bit. Note that the byte ordering of the PCI bus is defined to be little endian. BSWP should not be set to ONE when the PCnet-PCI II controller is used in a PCI bus application. Read/Write accessible always. BSWP is cleared by H\_RESET or S\_RESET and is not affected by STOP. 1 RES Reserved location. The default value of this bit is a ZERO. Writing a ONE to this bit has no effect on device function. If a ONE is written to this bit, then a ONE will be read back. Existing drivers may write a ONE to this bit for compatibility, but new drivers should write a ZERO to this bit and should treat the read value as undefined. 0 RES Reserved location. The default value of this bit is a ZERO. Writing a ONE to this bit has no effect on device function. If a ONE is written to this bit, then a ONE will be read back. Existing drivers may write a ONE to this bit for compatibility, but new drivers should write a ZERO to this bit and should treat the read value as undefined. Am79C970A 113 | CSF | R4: Test and F | eatures Control | | | net-PCI II controller is used in a | |-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Description | | | PCI bus application. | | | | Certain bits in CSR4 indicate the cause of an interrupt. The register is designed so that these indi- | | | Read/Write accessible always.<br>TIMER is cleared by H_RESET<br>or S_RESET and is unaffected by<br>setting the STOP bit. | | | | cator bits are cleared by writing ONEs to those bit locations. This means that the software can read CSR4 and write back the value just read to clear the interrupt condition. | 12 | DPOLL | Disable Transmit Polling. If DPOLL is set, the Buffer Management Unit will disable transmit polling. If DPOLL is cleared, automatic transmit polling is enabled. If DPOLL is set, the TDMD bit in CSR0 must be set in order to ini- | | 31– | 16 RES | Reserved locations. Written as ZEROs and read as undefined. | | | tiate a manual poll of a transmit descriptor. Transmit descriptor | | 15 | EN124 | Enable CSR124 access. Setting EN124 to ONE allows the user to | | | polling will not take place if TXON is cleared. | | | | write to bits in CSR124 which enable Runt Packet Accept mode (RPA, bit 3). Once these bits are accessed EN124 must be cleared back to ZERO. | | | Read/Write accessible always. DPOLL is cleared by H_RESET or S_RESET and is unaffected by setting the STOP bit. | | | | Read/Write accessible always. EN124 is cleared by H_RESET or S_RESET and is unaffected by setting the STOP bit. | 11 | APAD_XMT | Auto Pad Transmit. When set, APAD_XMT enables the automatic padding feature. Transmit frames will be padded to extend them to 64 bytes including FCS. | | | | In order to set EN124, it must be written with a ONE during the first write access to CSR4 after H_RESET or S_RESET. Once a ZERO is written to this bit position, EN124 cannot be set until after the PCnet-PCI II controller is reset by H_RESET or S_RESET. | | | The FCS is calculated for the entire frame including pad, and appended after the pad. APAD_XMT will override the programming of the DXMTFCS bit (CSR15, bit 3) and of the ADD_FCS/NO_FCS bit (TMD1, bit 29). | | 14 | DMAPLUS | When DMAPLUS is set to ONE, the DMA Burst Transfer Counter in CSR80 is disabled. If DMA-PLUS is cleared to ZERO, the counter is enabled. | | | Read/Write accessible always.<br>APAD_XMT is cleared by<br>H_RESET or S_RESET and is<br>unaffected by setting the STOP<br>bit. | | | | DMAPLUS should be set to ONE when the PCnet-PCI II controller is used in a PCI bus application. | 10 | ASTRP_RCV | Auto Strip Receive. When set, ASTRP_RCV enables the automatic pad stripping feature. The | | | | Read/Write accessible always. DMAPLUS is cleared by H_RESET or S_RESET and is | | | pad and FCS fields will be<br>stripped from receive frames and<br>not placed in the FIFO. | | 13 | TIMER | unaffected by setting the STOP bit. Enable Bus Activity Timer. If TIM-ER is set to ONE, the Bus Activity | | | Read/Write accessible always.<br>ASTRP_RCV is cleared by<br>H_RESET or S_RESET and is<br>unaffected by setting the STOP | | | | Timer (CSR82) is enabled. If TIMER is cleared, the Bus Activity Timer is disabled. | 9 | MFCO | bit. Missed Frame Counter Overflow is set by the PCnet-PCI II control- | | | | TIMER should stay at its default value of ZERO when the PC- | | | ler when the Missed Frame<br>Counter (CSR112) wraps<br>around. | 115 H RESET or S RESET or by serted if IENA is ONE and the setting the STOP bit. mask bit MFCOM is ZERO. 5 **RCVCCO** Receive Collision Counter Overflow is set by the PCnet-PCI II Read/Write accessible always. MFCO is cleared by the host by controller when the Receive Colwriting a ONE. Writing a ZERO lision Counter (CSR114) wraps has no effect. MFCO is cleared around. by H\_RESET, S\_RESET or by When RCVCCO is set. INTA is setting the STOP bit. asserted if IENA is ONE and the When the value 01h has been mask bit RCVCCOM is ZERO. programmed into the SWSTYLE Read/Write accessible always. register (BCR20, bits 7-0) for IL-RCVCCO is cleared by the host ACC (Am79C900) compatibility, by writing a ONE. Writing a then this bit has no meaning and ZERO has no effect. RCVCCO is PCnet-PCI II controller will never cleared by H\_RESET, S\_RESET set the value of this bit to ONE. or by setting the STOP bit. **MFCOM** Missed Frame Counter Overflow 8 When the value 01h has been Mask. If MFCOM is set, the programmed into the SWSTYLE MFCO bit will be masked and unregister (BCR20, bits 7-0) for ILable to set the INTR bit. ACC (Am79C900) compatibility, then this bit has no meaning and Read/Write accessible always. MFCOM is set to ONE by PCnet-PCI II controller will never H\_RESET or S\_RESET and is set the value of this bit to ONE. unaffected by setting the STOP **RCVCCOM** Receive Collision Counter Overbit. flow Mask. If RCVCCOM is set, When the value 01h has been the RCVCCO bit will be masked programmed into the SWSTYLE and unable to set the INTR bit. register (BCR20, bits 7-0) for IL-Read/Write accessible always. ACC (Am79C900) compatibility, RCVCCOM is set to ONE by then this bit has no meaning and H\_RESET or S\_RESET and is PCnet-PCI II controller will clear unaffected by setting the STOP the value of this bit to ZERO. bit. 7 UINTCMD Interrupt Command. When the value 01h has been UINTCMD can be used by the programmed into the SWSTYLE host to generate an interrupt unregister (BCR20, bits 7-0) for ILrelated to any network activity. ACC (Am79C900) compatibility, When UINTCMD is set. INTA is then this bit has no meaning and asserted if IENA is set to ONE. PCnet-PCI II controller will clear UINTCMD will be cleared interthe value of this bit to ZERO. nally after the PCnet-PCI II con-3 **TXSTRT** Transmit Start status is set by the troller has set UINT to ONE. PCnet-PCI II controller whenever Read/Write accessible always. it begins transmission of a frame. UINTCMD is cleared When TXSTRT is set, INTA is as-H\_RESET or S\_RESET or by serted if IENA is ONE and the setting the STOP bit. mask bit TXSTRTM is ZERO. 6 UINT User Interrupt. UINT is set by the Read/Write accessible always. PCnet-PCI II controller after the TXSTRT is cleared by the host by host has issued a user interrupt writing a ONE. Writing a ZERO command by setting UINTCMD has no effect. TXSTRT is cleared (CSR4, bit 7) to ONE. by H\_RESET, S\_RESET or by Read/Write accessible always. setting the STOP bit. UINT is cleared by the host by 2 **TXSTRTM** Transmit Start Mask. If TXwriting a ONE. Writing a ZERO STRTM is set, the TXSTRT bit has no effect. UINT is cleared by Am79C970A When MFCO is set. INTA is as- will be masked and unable to set just read to clear the interrupt the INTR bit. condition. Read/Write accessible always. Reserved locations. Written as 31-16RES TXSTRTM is set to ONE by ZEROs and read as undefined. H RESET or S RESET and is 15 **TOKINTD** Transmit OK Interrupt Disable. If unaffected by setting the STOP TOKINTD is set to ONE, the TINT bit in CSR0 will not be set when a JAB Jabber Error is set by the PCnettransmission was successful. PCI II controller when the T-MAU Only a transmit error will set the exceeds the allowed transmis-TINT bit. sion time limit. Jabber can only TOKINTD has no effect when be asserted in 10BASE-T mode. LTINTEN (CSR5, bit 14) is set to When JAB is set. INTA is assert-ONE. A transmit descriptor with ed if IENA is ONE and the mask LTINT set to ONE will always bit JABM is ZERO. cause TINT to be set to ONE, independent of the success of the Read/Write accessible always. transmission. JAB is cleared by the host by writing a ONE. Writing a ZERO has Read/Write accessible always. no effect. JAB is cleared by TOKINTD cleared is H RESET, S RESET or by set-H RESET or S RESET and is ting the STOP bit. unaffected by setting the STOP bit. When the value 01h has been programmed into the SWSTYLE 14 **LTINTEN** Last Transmit Interrupt Enable. register (BCR20, bits 7-0) for IL-When set to ONE, the LTINTEN ACC (Am79C900) compatibility, bit will cause the PCnet-PCI II then this bit has no meaning and controller to read bit 28 of TMD1 PCnet-PCI II controller will never as LTINT. The setting LTINT will set the value of this bit to ONE. determine if TINT will be set at the end of the transmission. 0 **JABM** Jabber Error Mask. If JABM is set, the JAB bit will be masked Read/Write accessible always. and unable to set the INTR bit. LTINTEN is cleared H RESET or S RESET and is Read/Write accessible always. unaffected by setting the STOP JABM is set to ONE by H RESET or S RESET and is unaffected by setting the STOP 13-12 RES Reserved locations. Written as ZEROs and read as undefined. bit. When the value 01h has been 11 SINT System Interrupt is set by the PCprogrammed into the SWSTYLE net-PCI II controller when it deregister (BCR20, bits 7-0) for ILtects a system error during a bus ACC (Am79C900) compatibility, master transfer on the PCI bus. then this bit has no meaning and System errors are data parity er-PCnet-PCI II controller will clear ror, master abort or a target the value of this bit to ZERO. abort. The setting of SINT due to a data parity error is not depen-**CSR5: Extended Control and Interrupt** dent on the setting of PERREN Bit Name **Description** (PCI Command register, bit 6). When SINT is set, INTA is assert-Certain bits in CSR5 indicate the ed if the enable bit SINTE is ONE. cause of an interrupt. The regis-Note that the assertion of an inter is designed so that these inditerrupt due to SINT is not depencator bits are cleared by writing dent on the state of the INEA bit, ONEs to those bit locations. This since INEA is cleared by the means that the software can read STOP reset generated by the CSR5 and write back the value system error. When EXDINT is set. INTA is as- writing a ONE. Writing a ZERO 117 SINT is cleared by the host by serted if the enable bit EXDINTE writing a ONE. Writing a ZERO is ONE. has no effect. The state of SINT is Read/Write accessible always. not affected by clearing any of the EXDINT is cleared by the host by PCI Status register bits that get writing a ONE. Writing a ZERO set when a data parity error has no effect. EXDINT is cleared (DATAPERR, bit 8), master abort by H\_RESET and is not affected (RMABORT, bit 13) or target by S\_RESET or by setting the abort (RTABORT, bit 12) occurs. STOP bit. SINT is cleared by H RESET or **EXDINTE** Excessive Deferral Interrupt En-S RESET and is not affected by able. If EXDINTE is set, the setting the STOP bit. EXDINT bit will be able to set the System Interrupt Enable. If SIN-10 SINTE INTR bit. TE is set, the SINT bit will be able Read/Write accessible always. to set the INTR bit. EXDINTE is cleared to ZERO by Read/Write accessible always. H\_RESET and is not affected by SINTE is cleared to ZERO by S RESET or by setting the STOP H RESET or S RESET and is bit. not affected by setting the STOP **MPPLBA** 5 Magic Packet Physical Logical bit. Broadcast Accept. If MPPLBA is **SLPINT** 9 Sleep Interrupt is set by the PCcleared to ZERO, the PCnet-PCI net-PCI II controller when it Il controller will only detect a comes out of sleep mode. magic packet if the destination When SLPINT is set. INTA is asaddress of the packet matches the content of the physical adserted if the enable bit SLPINTE is ONE. Note that the assertion of dress register (PADR). If MPPLan interrupt due to SLPINT is not BA is set to ONE, the destination dependent on the state of the address of the magic packet can be unicast, multicast or broad-INEA bit, since INEA is cleared by S RESET when entering the cast. Note that the setting of MP-PLBA only effects the address sleep mode. detection of the magic packet. Read/Write accessible always. The magic packet data sequence SLPINT is cleared by the host by must be in all cases the same, writing a ONE. Writing a ZERO i.e., a 16-times repetition of the has no effect. SLPINT is cleared the physical address by H RESET and is not affected (PADR[47:0]). by S\_RESET or by setting the STOP bit. Read/Write accessible always. MPPLBA is cleared to ZERO by 8 **SLPINTE** Interrupt Enable. H RESET or S RESET and is SLPINTE is set, the SLPINT bit not affected by setting the STOP will be able to set the INTR bit. Read/Write accessible always. **MPINT** Magic Packet Interrupt is set by SLPINTE is cleared to ZERO by the PCnet-PCI II controller when H RESET and is not affected by the device is in magic packet S RESET or by setting the STOP mode and it receives a magic bit. packet. **EXDINT** 7 Excessive Deferral Interrupt is When MPINT is set, INTA is asset by the PCnet-PCI II controller serted if IENA (CSR0, bit 6) and when the transmitter has experithe enable bit MPINTE are set to enced Excessive Deferral on a ONE. transmit frame, where Excessive Deferral is defined in ISO 8802-3 Read/Write accessible always. (IEEE/ANSI 802.3). MPINT is cleared by the host by Am79C970A Read/Write accessible always. has no effect. MPINT is cleared finishes all on-going transmit acby H\_RESET, S\_RESET or by tivity and updates the corresetting the STOP bit. sponding transmit descriptor entries. It then finishes all on-go-**MPINTE** Magic Packet Interrupt Enable. If 3 ing receive activity and updates MPINTE is set, the MPINT bit will the corresponding receive debe able to set the INTR bit. scriptor entries. It then sets the Read/Write accessible always. read-version of SPND to ONE MPINTE is cleared to ZERO by and enters the suspend mode. H RESET or S RESET and is In suspend mode, all of the CSR not affected by setting the STOP and BCR registers are accessible. As long as the PCnet-PCI II 2 **MPEN** Magic Packet Enable. MPEN alcontroller is not reset while in lows activation of the magic packsuspend mode (by H\_RESET, et mode by software. The S\_RESET or by setting the STOP PCnet-PCI II controller will enter bit), no re-initialization of the dethe magic packet mode when vice is required after the device both MPEN and MPMODE are comes out of suspend mode. The set to ONE. PCnet-PCI II controller will con-Read/Write accessible always. tinue at the transmit and receive MPEN is cleared to ZERO by descriptor ring locations where it H\_RESET or S\_RESET and is had left off. not affected by setting the STOP Read/Write accessible always. SPND is cleared by H RESET, **MPMODE** Magic Packet Mode. Setting MP-S\_RESET or by setting the STOP 1 MODE to ONE will redefine the bit. SLEEP pin to be a magic packet **CSR6: RX/TX Descriptor Table Length** enable pin. The PCnet-PCI II Name **Description** controller will enter the magic packet mode when MPMODE is set to one and either SLEEP is 31-16RES Reserved locations. Written as asserted or MPEN is set to ONE. ZEROs and read as undefined. Read/Write accessible always. 15-12TLEN Contains a copy of the transmit MPMODE is cleared to ZERO by encoded ring length (TLEN) field H RESET or S RESET and is read from the initialization block not affected by setting the STOP during PCnet-PCI II controller initialization. This field is written during the PCnet-PCI II controller 0 **SPND** Suspend. Setting SPND to ONE will cause the PCnet-PCI II coninitialization routine. troller to start entering the sus-Read accessible only when either pend mode. The host must poll the STOP or the SPND bit is set. SPND until it reads back ONE to Write operations have no effect determine that the PCnet-PCI II and should not be performed. controller has entered the sus-TLEN is only defined after initialpend mode. Setting SPND to ization. These bits are unaffected ZERO will get the PCnet-PCI II by H\_RESET, S\_RESET or by controller out of suspend mode. setting the STOP bit. SPND can only be set to ONE if 11-8 RLEN Contains a copy of the receive STOP (CSR0, bit 2) is cleared to encoded ring length (RLEN) read ZERO. H RESET, S RESET or from the initialization block during setting the STOP bit will get the PCnet-PCI II controller initializa-PCnet-PCI II controller out of sustion. This field is written during pend mode. the PCnet-PCI II controller initial-When the host requests the PCization routine. net-PCI II controller to enter the suspend mode, the device first | | Read accessible only when either | CSR10 | ): Logical Ad | dress Filter 2 | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | the STOP or the SPND bit is set. | Bit | Name | Description | | | Write operations have no effect<br>and should not be performed.<br>RLEN is only defined after initial-<br>ization. These bits are unaffected<br>by H_RESET, S_RESET or by | 31–161 | | Reserved locations. Written as ZEROs and read as undefined. | | | setting the STOP bit. | 15-UL <i>F</i> | ADRF[47:32] | Logical Address Filter, LADRF[47:32]. The content of | | 7–0 RES | Reserved locations. Read as ZE-ROs. Write operations are ignored. | | | this register is undefined until loaded from the initialization block after the INIT bit in CSR0 | | CSR8: Logical Add | lress Filter 0 | | | has been set or a direct register write has been performed on this | | Bit Name | Description | | | register. | | 31–16RES<br>15–0LADRF[15:0] | Reserved locations. Written as ZEROs and read as undefined. Logical Address Filter, | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by | | | LADRF[15:0]. The content of this | 00544 | | setting the STOP bit. | | | register is undefined until loaded from the initialization block after | Bit | : Logical Ad<br>Name | dress Filter 3 Description | | | the INIT bit in CSR0 has been set | ——— | INAITIE | Description | | | or a direct register write has been performed on this register. Read/Write accessible only when | 31–161 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 15–0L <i>A</i> | ADRF[63:48] | Logical Address Filter,<br>LADRF[63:48]. The content of<br>this register is undefined until<br>loaded from the initialization<br>block after the INIT bit in CSR0 | | CSR9: Logical Add | Iress Filter 1 Description | | | has been set or a direct register write has been performed on this register. | | 31–16RES<br>15–0LADRF[31:16] | LADRF[31:16]. The content of | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | this register is undefined until loaded from the initialization | CSR12 | : Physical A | ddress Register 0 | | | block after the INIT bit in CSR0 has been set or a direct register | Bit | Name | Description | | | write has been performed on this | | | | | | register. Read/Write accessible only when | 31–161 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 15–0P/ | ADR[15:0] | Physical Address Register, PADR[15:0]. The content of this register is undefined until loaded from the initialization block after the INIT bit in CSR0 has been set or a direct register write has been performed on this register. | | | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | | by H_RESET, S_RESET or by setting the STOP bit. | | | Read/Write accessible only when either the STOP or the SPND bit | |-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CSR13: Physical | Address Register 1 | | | is set. | | Bit Name | Description | 14 | DRCVBC | Disable Receive Broadcast. | | 31–16RES<br>15–0PADR[31:16] | Reserved locations. Written as ZEROs and read as undefined. Physical Address Register, | | | When set, this bit disables the PCnet-PCI II controller from receiving broadcast messages. DRCVBC has no effect when PROM is set to ONE. | | 13-01 ADIT[31.10] | PADR[31:16]. The content of this register is undefined until loaded from the initialization block after the INIT bit in CSR0 has been set or a direct register write has been performed on this register. | | | Read/Write accessible only when either the STOP or the SPND bit is set. DRCVBC is cleared by H_RESET or S_RESET and not affected by STOP. | | CSR14: Physical | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. Address Register 2 | 13 | DRCVPA | Disable Receive Physical Address. When set, the physical address detection (Station or node ID) of the PCnet-PCI II controller will be disabled. Frames addressed to the node's individual physical address will not be rec- | | Bit Name | Description | | | ognized. DRCVPA has no effect | | - Nume | | | | when PROM is set to ONE. | | 31-16RES | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only when either the STOP or the SPND bit is set. | | 15-0PADR[47:32] | Physical Address Register, PADR[47:32]. The content of this register is undefined until loaded from the initialization block after the INIT bit in CSR0 has been set or a direct register write has been performed on this register. Read/Write accessible only when | 12 | DLNKTST | Disable Link Status. When DLNKTST is set to ONE, monitoring of Link Pulses is disabled. When DLNKTST is cleared to ZERO, monitoring of Link Pulses is enabled. This bit only has meaning when the 10BASE-T network interface is selected. | | | either the STOP or the SPND bit<br>is set. These bits are unaffected<br>by H_RESET, S_RESET or by | | | Read/Write accessible only when either the STOP or the SPND bit is set. | | | setting the STOP bit. | 11 | DAPC | Disable Automatic Polarity Cor- | | CSR15: Mode<br>Bit Name | Description | | | rection. When DAPC is set to ONE, the 10BASE-T receive polarity reversal algorithm is disabled. When DAPC is cleared to | | | This register's fields are loaded during the PCnet-PCI II controller initialization routine with the cor- | | | ZERO, the polarity reversal algorithm is enabled. | | | responding initialization block values. The host can also write directly to this register. | | | This bit only has meaning when the 10BASE-T network interface is selected. | | 31-16RES | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only when either the STOP or the SPND bit is set. | | 15 PROM | Promiscuous Mode. When PROM is set to ONE, all in- | 10 | MENDECL | MENDEC Loopback Mode. See | | | coming receive frames are accepted. | | | the description of the LOOP bit in CSR15. | Low Receive Threshold. When Read/Write accessible only when LRT either the STOP or the SPND bit LRT is set to ONE, the internal twisted pair receive thresholds are reduced by 4.5 dB below the Low Receive Threshold (T-MAU 9 LRT standard 10BASE-T value (ap-Mode only) proximately 3/5) and the un-**TSEL** Transmit Mode Select (AUI Mode squelch threshold for the RXD only) circuit will be 180 mV-312 mV peak. **Table 22. Network Port Configuration** | PORTSEL[1:0] | ASEL(BCR2[1]) | Link Status (of 10BASE-T) | Network Port | |--------------|---------------|---------------------------|--------------| | 0X | 1 | Fail | AUI | | 0X | 1 | Pass | 10BASE-T | | 00 | 0 | Х | AUI | | 01 | 0 | X | 10BASE-T | | 10 | Х | Х | Reserved | | 11 | Х | Х | Reserved | When LRT is cleared to ZERO, the unsquelch threshold for the RXD circuit will be the standard 10BASE-T value of 300 mV-520 mV peak. In either case, the RXD circuit post squelch threshold will be one half of the unsquelch threshold This bit only has meaning when the 10BASE-T network interface is selected. Read/Write accessible only when either the STOP or the SPND bit is set. Cleared by H\_RESET or S\_RESET and is unaffected by setting the STOP bit. TSEL Transr Transmit Mode Select. TSEL controls the levels at which the AUI drivers rest when the AUI transmit port is idle. When TSEL is cleared to ZERO, DO+ and DO-yield zero differential to operate transformer coupled loads (Ethernet 2 and 802.3). When TSEL is set to ONE, the DO+idles at a higher value with respect to DO-, yielding a logical HIGH state (Ethernet 1). This bit only has meaning when the AUI network interface is selected. Read/Write accessible only when either the STOP or the SPND bit is set. Cleared by H\_RESET or S RESET. 8-7PORTSEL[1:0] Port Select bits allow for software controlled selection of the network medium. The only legal values for this field are 00 and 01. PORTSEL setting of AUI and 10BASE-T are ignored when the ASEL bit of BCR2 (bit 1) has been set to ONE. Read/Write accessible only when either the STOP or the SPND bit is set. Cleared by H\_RESET or S\_RESET and is unaffected by setting the STOP bit. 6 INTL 5 Am79C970A Internal Loopback. See the description of LOOP (CSR15, bit 2). Read/Write accessible only when either the STOP or the SPND bit is set. DRTY Disable Retry. When DRTY is set to ONE, PCnet-PCI II controller will attempt only one transmission. In this mode, the device will not protect the first 64 bytes of frame data in the transmit FIFO from being overwritten, because automatic retransmission will not be necessary. When DRTY is cleared to ZERO, the PCnet-PCI 121 Il controller will attempt 16 transmissions before signaling a retry error. Read/Write accessible only when either the STOP or the SPND bit is set. 4 FCOLL Force Collision. This bit allows the collision logic to be tested. The PCnet-PCI II controller must be in internal loopback for FCOLL to be valid. If FCOLL is set to ONE, a collision will be forced during loopback transmission attempts, which will result in a Retry Error. If FCOLL is cleared to ZERO, the Force Collision logic will be disabled. FCOLL is defined after the initialization block is read. **Table 23. Loopback Configuration** | LOOP | INTL | MENDECL | Loopback Mode | |------|------|---------|----------------------------------| | 0 | Х | Х | Non-loopback | | 1 | 0 | Х | External Loopback | | 1 | 1 | 0 | Internal Loopback Include MENDEC | | 1 | 1 | 1 | Internal Loopback Exclude MENDEC | Read/Write accessible only when either the STOP or the SPND bit is set. 3 DXMTFCS Disable Transmit CRC (FCS). When DXMTFCS is cleared to ZERO, the transmitter will generate and append an FCS to the transmitted frame. When DXMTFCS is set to ONE, no FCS is generated or sent with the transmitted frame. DXMTFCS is overridden when ADD\_FCS is set in TMD1. If DXMTFCS is set and ADD\_FCS is clear for a particular frame, no FCS will be generated. The value of ADD\_FCS is valid only when STP is set in TMD1. If ADD\_FCS is set for a particular frame, the state of DXMTFCS is ignored and a FCS will be appended on that frame by the transmit circuitry. See also the ADD FCS bit in TMD1. This bit is called DTCR in the C-LANCE (Am79C90). Read/Write accessible only when either the STOP or the SPND bit is set. 2 LOOP Loopback Enable allows PCnet-PCI II controller to operate in full-duplex mode for test purposes. The setting of the full-duplex control bits in BCR9 have no effect when the device operates in loopback mode. When LOOP is set to ONE, loopback is enabled. In combination with INTL and MENDECL, various loopback modes are defined in the Loopback Configuration table. Read/Write accessible only when either the STOP or the SPND bit is set. LOOP is cleared by H\_RESET or S\_RESET and is unaffected by setting the STOP bit. DTX Disable Transmit. When DTX is set to ONE, the PCnet-PCI II controller will not access the transmit descriptor ring and therefore no transmissions are attempted. When DTX is cleared to ZERO, TXON (CSR0, bit 4) is set to ONE after STRT (CSR0, bit 1) has been set to ONE. Read/Write accessible only when either the STOP or the SPND bit is set. 0 DRX Disable Receiver. When DRX is set to ONE, the PCnet-PCI II controller will not access the receive descriptor ring and therefore all receive frame data are ignored. When DRX is cleared to ZERO, RXON (CSR0, bit 5) is set to ONE after STRT (CSR0, bit 1) has been set to ONE. Read/Write accessible only when either the STOP or the SPND bit is set. 122 | aliz | zation Block Address Lower | CSR2 | 0: Current | Transmit Buffer Address Lower | |--------------|-------------------------------------------------------------------------------------------------------------------|-------|-------------|---------------------------------------------------------------------------------------------| | ne | Description | Bit | Name | Description | | | Reserved locations. Written as ZEROs and read as undefined. | 31–16 | RES | Reserved locations. Written ZEROs and read as undefined | | | This register is an alias of CSR1. | 15–0 | CXBAL | Contains the lower 16 bits of | | | Read/Write accessible only when either the STOP or the SPND bit | | | current transmit buffer addre<br>from which the PCnet-PCI II co<br>troller is transmitting. | | | is set. | | | Read/Write accessible only wh | | _ | ation Block Address Upper Description | | | either the STOP or the SPND is set. These bits are unaffec | | <del>-</del> | | | | by H_RESET, S_RESET or setting the STOP bit. | | | Reserved locations. Written as | CSR2 | 1: Current | Transmit Buffer Address Upper | | | ZEROs and read as undefined. | Bit | Name | Description | | H | This register is an alias of CSR2. | | | | | | Read/Write accessible only when<br>either the STOP or the SPND bit<br>is set. | 31–16 | RES | Reserved locations. Written ZEROs and read as undefined | | urren | t Receive Buffer Address Lower | 15–0 | CXBAU | Contains the upper 16 bits of | | ne | Description | | | current transmit buffer addr<br>from which the PCnet-PCI II c<br>troller is transmitting. | | | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only wleither the STOP or the SPND | | - | Contains the lower 16 bits of the current receive buffer address at which the PCnet-PCI II controller | | | is set. These bits are unaffed<br>by H_RESET, S_RESET or<br>setting the STOP bit. | | | will store incoming frame data. | | | ceive Buffer Address Lower | | | Read/Write accessible only when<br>either the STOP or the SPND bit | Bit | Name | Description | | | is set. These bits are unaffected<br>by H_RESET, S_RESET or by<br>setting the STOP bit. | 31–16 | SRES | Reserved locations. Written ZEROs and read as undefined | | Curren | t Receive Buffer Address Upper | 15–0 | NRBAL | Contains the lower 16 bits of next receive buffer address | | ame | Description | | | which the PCnet-PCI II control will store incoming frame data | | ES | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only wheither the STOP or the SPND | | BAU | Contains the upper 16 bits of the current receive buffer address at which the PCnet-PCI II controller | | | is set. These bits are unaffed<br>by H_RESET, S_RESET or<br>setting the STOP bit. | | | will store incoming frame data. | CSR2 | 3: Next Red | eive Buffer Address Upper | | | Read/Write accessible only when | Bit | Name | Description | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 31–16 | RES | Reserved locations. Written ZEROs and read as undefine | | | setting the STOF bit. | 15–0 | NRBAU | Contains the upper 16 bits of next receive buffer address | | | | | | | | | which the PCnet-PCI II controller | CSR27: Next Receive Descriptor Address Upper | | | | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------|---------------------------------------------------------------------------------------------|--| | | will store incoming frame data. | Bit | Name | Description | | | | Read/Write accessible only when<br>either the STOP or the SPND bit<br>is set. These bits are unaffected<br>by H_RESET, S_RESET or by | 31–16 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | CSR24: Base Addr<br>Ring Lower | setting the STOP bit. ess of Receive Descriptor | 15–0 | NRDAU | Contains the upper 16 bits of the next receive descriptor address pointer. | | | Bit Name | Description | | | Read/Write accessible only when either the STOP or the SPND bit | | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | 15-0 BADRL | Contains the lower 16 bits of the | CSR2 | 8: Current R | eceive Descriptor Address Lower | | | | base address of the receive descriptor ring. | Bit | Name | Description | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | 31–16 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | CCDOS: Doos Address | by H_RESET, S_RESET or by setting the STOP bit. | 15–0 | CRDAL | Contains the lower 16 bits of the current receive descriptor address pointer. | | | Ring Upper | ess of Receive Descriptor | | | Read/Write accessible only when | | | Bit Name 31–16 RES | Description Reserved locations. Written as | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by | | | 31-10HES | ZEROs and read as undefined. | CCD2 | O. Curront B | setting the STOP bit. | | | 15–0 BADRU | Contains the upper 16 bits of the | Bit | 9: Current H<br>Name | eceive Descriptor Address Upper Description | | | | base address of the receive descriptor ring. | | | | | | | Read/Write accessible only when either the STOP or the SPND bit | 31–16 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 15–0 | CRDAU | Contains the upper 16 bits of the current receive descriptor address pointer. | | | CSR26: Next Recei | ive Descriptor Address Lower | | | Read/Write accessible only when | | | Bit Name | Description | | | either the STOP or the SPND bit is set. These bits are unaffected | | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | CSB3 | ∩· Rase ∆do | by H_RESET, S_RESET or by setting the STOP bit. Iress of Transmit Descriptor | | | 15-0 NRDAL | Contains the lower 16 bits of the | | Lower | iress of Transmit Descriptor | | | | next receive descriptor address pointer. | Bit | Name | Description | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | 31–16 | RES | Reserved locations. Written as ZEROs and read as undefined. | | | | by H_RESET, S_RESET or by setting the STOP bit. | 15–0 | BADXL | Contains the lower 16 bits of the base address of the transmit descriptor ring. | | | | | | | Read/Write accessible only when either the STOP or the SPND bit | | | | is set. These bits are unaffected<br>by H_RESET, S_RESET or by<br>setting the STOP bit. | 15–0 | CXDAL | Contains the lower 16 bits of the current transmit descriptor address pointer. Read/Write accessible only when | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------| | Ring Upper<br>Bit Nan | e Description | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | CSR3<br>Uppe | | Transmit Descriptor Address | | 15-0 BADX | J Contains the upper 16 bits of the base address of the transmit descriptor ring. | Bit | Name | Description | | | Read/Write accessible only when either the STOP or the SPND bit | | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 15–0 | CXDAU | Contains the upper 16 bits of the current transmit descriptor address pointer. | | CSR32: Nex | Transmit Descriptor Address Lower | | | Read/Write accessible only when | | Bit Nar | e Description | | | either the STOP or the SPND bit<br>is set. These bits are unaffected<br>by H_RESET, S_RESET or by | | 31-16RES | Reserved locations. Written as ZEROs and read as undefined. | CSR | setting the STOP bit. | | | 15–0 NXDA | Contains the lower 16 bits of the next transmit descriptor address pointer. | Lowe<br>Bit | | Description | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | RES<br>NNRDAL | Reserved locations. Written as ZEROs and read as undefined. Contains the lower 16 bits of the next next receive descriptor ad- | | CSR33: Nex | Transmit Descriptor Address Upper | | | dress pointer. | | Bit Nar | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | 31-16RES | Reserved locations. Written as ZEROs and read as undefined. | | | by H_RESET, S_RESET or by setting the STOP bit. | | 15–0 NXDA | next transmit descriptor address | CSR3<br>Uppe | | t Receive Descriptor Address | | | pointer. | Bit | Name | Description | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by | 31–16 | 6 RES | Reserved locations. Written as ZEROs and read as undefined. | | CSR34: Cur<br>Lower | setting the STOP bit. ent Transmit Descriptor Address | 15–0 | NNRDAU | Contains the upper 16 bits of the next next receive descriptor address pointer. | | Bit Nar | e Description | | | Read/Write accessible only when either the STOP or the SPND bit | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | CSR38: Next Next Transmit Descriptor Address<br>Lower | | 15-0 CRST | Current Receive Status. This field is a copy of bits 31-16 of | |-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | Bit Name | Description | | RMD1 of the current receive descriptor. | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | 15–0 NNXDAL | Contains the lower 16 bits of the next next transmit descriptor address pointer. | 00040 | by H_RESET, S_RESET or by setting the STOP bit. | | | Read/Write accessible only when | | Transmit Byte Count | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | Bit Name 31–16 RES | Reserved locations. Written as ZEROs and read as undefined. | | CSR39: Next Next Next Next Next Next Next Next | xt Transmit Descriptor Address | 15-12RES | Reserved locations. Read and written as ZEROs. | | Bit Name | Description | 11-0 CXBC | Current Transmit Byte Count. This field is a copy of the BCNT | | 31–16 RES | Reserved locations. Written as ZEROs and read as undefined. | | field of TMD1 of the current trans-<br>mit descriptor. | | 15–0 NNXDAU | Contains the upper 16 bits of the | CSR43: Current | Transmit Status | | | next next transmit descriptor address pointer. | Bit Name | Description | | | Read/Write accessible only when either the STOP or the SPND bit | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | CSR40: Current | is set. These bits are unaffected<br>by H_RESET, S_RESET or by<br>setting the STOP bit.<br>Receive Byte Count | 15-0 CXST | Current Transmit Status. This field is a copy of bits 31–16 of TMD1 of the current transmit descriptor. | | Bit Name | Description | | Read/Write accessible only when | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | 15-12RES | Reserved locations. Read and written as ZEROs. | CSR44: Next Re | ceive Byte Count | | 11-0 CRBC | Current Receive Byte Count.This | Bit Name | Description | | | field is a copy of the BCNT field of RMD1 of the current receive descriptor. | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only when either the STOP or the SPND bit | 15-12RES | Reserved locations. Read and written as ZEROs. | | CSR41: Current | is set. These bits are unaffected<br>by H_RESET, S_RESET or by<br>setting the STOP bit. | 11-0 NRBC | Next Receive Byte Count. This field is a copy of the BCNT field of RMD1 of the next receive descriptor. | | | | | scriptor. | | 31–16 RES | Reserved locations. Written as ZEROs and read as undefined. | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | CSR45: Next Red<br>Bit Name | ceive Status Description | | | periods (1.966 ms when CLK = 33 MHz). The POLLINT value of 0000h is created during the mi- | |-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | crocode initialization routine, and therefore might not be seen when reading CSR47 after H_RESET | | 15-0 NRST | Next Receive Status. This field is a copy of bits 31–16 of RMD1 of the next receive descriptor. | | | or S_RESET. If the user desires to program a value for POLLINT other than the | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | default, the correct procedure is to first set only INIT in CSR0. When the initialization sequence is complete, the user must set STOP (CSR0, bit 2) or SPND | | CSR46: Poll Tim | e Counter | | | (CSR5, bit 0). Then the user may write to CSR47 and then set | | Bit Name | Description | | | STRT in CSR0. In this way, the default value of 0000h in CSR47 | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | will be overwritten with the desired user value. | | 15-0 POLL | Poll Time Counter. This counter is incremented by the PCnetPCI II controller microcode and is used to trigger the descriptor ring polling operation of the PC net-PCI II controller. | | | If the user does not use the stan-<br>dard initialization procedure<br>(standard implies use of an initial-<br>ization block in memory and set-<br>ting the INIT bit of CSR0), but<br>instead chooses to write directly<br>to each of the registers that are | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by | | | involved in the INIT operation, it is imperative that the user also write to CSR47 as part of the alternative initialization sequence. | | CCD47: Dolling I | setting the STOP bit. | | | Read/Write accessible only when | | CSR47: Polling I Bit Name | Description | | | either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | 31-16RES | Reserved locations. Written as | CSB | 58: Software | · · | | | ZEROs and read as undefined. | Bit | Name | Description | | 15–0 POLLINT | Polling Interval. This register contains the time that the PCnet-PCI II controller will wait between successive polling operations. The POLLINT value is expressed as the two's complement of the de- | | | This register is an alias of the location BCR20. Accesses to/from this register are equivalent to accesses to BCR20. | | | sired interval, where each bit of POLLINT represents one clock | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | | period. POLLINT[3:0] are ig-<br>nored. The sign of the two's com-<br>plement POLLINT value is | 15–1 | 1RES | Reserved locations. Written as ZEROs and read as undefined. | | | implied to be a one, so POL-LINT[15] does not represent the sign bit, but is the MSB of the number. | 10 | APERREN | Advanced Parity Error Handling Enable. When APERREN is set to ONE, the BPE bits (RMD1 and TMD1, bit 23) are used to indicat- | | | The default value of this register | | | ed parity error in data transfers to | The default value of this register is 0000h. This corresponds to a polling interval of 65,536 clock 127 Am79C970A ed parity error in data transfers to the receive and transmit buffers. Note that since the advanced parity error handling uses an additional bit in the descriptor, SW-STYLE (bits 7–0 of this register) must be set to ONE, TWO or THREE to program the PC-net-PCI II controller to use 32-bit software structures. APERREN does not affect the reporting of address parity errors or data parity errors that occur when the PCnet-PCI II controller is the target of the transfer. Read accessible always, write accessible only when either the STOP or the SPND bit is set. APERREN is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 9 CSRPCNET CSR PCnet-ISA configuration. When set, this bit indicates that the PCnet-PCI II controller register bits of CSR4 and CSR3 will map directly to the CSR4 and CSR3 bits of the PCnet-ISA (Am79C960) device. When cleared, this bit indicates that PCnet-PCI II controller register bits of CSR4 and CSR3 will map directly to the CSR4 and CSR3 bits of the ILACC (Am79C900) device. The value of CSRPCNET is determined by the PCnet-PCI II controller according to the setting of the Software Style (SWSTYLE, bits 7–0 of this register). Read accessible always. CSR-PCNET is read only. Write operations will be ignored. H\_RESET (since SWSTYLE defaults to ZE-RO) and is not affected by S\_RESET or by setting the STOP bit. 8 SSIZE32 32-Bit Software Size. When set, this bit indicates that the PCnetP-CI II controller utilizes 32-bit software structures for the initialization block and the transmit and receive descriptor entries. When cleared, this bit indicates that the PCnet-PCI II controller utilizes 16-bit software structures for the initialization block and the transmit and re- ceive descriptor entries. In this mode the PCnet-PCI II controller is backwards compatible with the Am79C90 C-LANCE and Am79C960 PCnet-ISA. The value of SSIZE32 is determined by the PCnet-PCI II controller according to the setting of the Software Style (SWSTYLE, bits 7–0 of this register). Read accessible always. SSIZE32 is read only. Write operations will be ignored. SSIZE32 will be cleared after H\_RESET (since SWSTYLE defaults to ZERO) and is not affected by S\_RESET or by setting the STOP bit. If SSIZE32 is cleared to ZERO, then bits IADR[31:24] of CSR2 will be used to generate values for the upper 8 bits of the 32 bit address bus during master accesses initiated by the PCnetPCI II controller. This action is required, since the 16-bit software structures will yield only 24 bits of address for PCnet-PCI II controller bus master accesses. If SSIZE32 is set to ONE, then the software structures that are common to the PCnet-PCI II controller and the host system will supply a full 32 bits for each address pointer that is needed by the PCnet-PCI II controller for performing master accesses. The value of the SSIZE32 bit has no effect on the drive of the upper 8 address bits. The upper 8 address pins are always driven, regardless of the state of the SSIZE32 bit. Note that the setting of the SSIZE32 bit has no effect on the width for I/O accesses. I/O access width is determined by the state of the DWIO bit (BCR18, bit 7). 7-0 SWSTYLE Software Style register. The value in this register determines the style of register and memory resources that shall be used by the PCnet-PCI II controller. The Software Style selection will affect the interpretation of a few bits within the CSR space, the order of the descriptor entries and the width of the descriptors and initialization block entries. All PCnet-PCI II controller CSR bits and BCR bits and all descriptor, buffer and initialization block entries not cited in the table be- low are unaffected by the software style selection. Read/Write accessible only when either the STOP or the SPND bit is set. The SWSTYLE register will contain the value 00h following H\_RESET and will be unaffected by S\_RESET or by setting the STOP bit. dress pointer. The PCnet-PCI II controller can stack multiple Read/Write accessible only when either the STOP or the SPND bit **Table 24. Software Styles** | SWSTYLE<br>[7:0] | Style Name | CSRPCNET | SSIZE32 | Initialization Block<br>Entries | Descriptor Ring<br>Entries | Altered Bit<br>Interpretations | |------------------|--------------------------------|-----------|-----------|-------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------| | 00h | C-LANCE<br>/<br>PCnet-ISA | 1 | 0 | 16-bit software<br>structures, non-burst<br>or burst access | 16-bit software<br>structures, non-<br>burst access only | All bits in CSR4<br>are used, TMD1[29]<br>is ADD_FCS | | 01h | ILACC | 0 | 1 | 32-bit software<br>structures, non-burst<br>or burst access | 32-bit software<br>access structures,<br>non-burst access<br>only | CSR4[9:8], CSR4[5:4]<br>and CSR4[1:0] have<br>no function, TMD1[29]<br>is NO_FCS. | | 02h | PCnet-<br>PCI II | 1 | 1 | 32-bt software<br>structures, non-burst<br>or burst access | 32-bit software<br>structures, non-<br>burst access only | All bits in CSR4 are<br>used, TMD1[29] is<br>ADD_FCS | | 03h | PCnet-<br>PCI II<br>controller | 1 | 1 | 32-bit software<br>structures, non-burst<br>or burst access | 32-bit software<br>structures, non-<br>burst or burst<br>access | All bits in CSR4 are<br>used, TMD1[29] is<br>ADD_FCS | | All Other | Reserved | Undefined | Undefined | Undefined | Undefined | Undefined | | 1 / 0 | 711101 | 11000110 | ondomied | Ondomiod | Ondomioa | | Ondom | |---------------|------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|--------------------|-------| | | CSR60: Previous Transmit Descriptor Address<br>Lower | | | | | | | | Bit | Nar | ne | Description | | | | | | 31–16RES | | | Reserved loca<br>ZEROs and rea | | | | | | 15–0 PXDAL | | AL. | Contains the lower 16 bits of the previous transmit descriptor address pointer. The PCnet-PCI II controller can stack multiple transmit frames. | | | SR62: Pre<br>t Nai | | | | | | Read/Write acc | or the SPND | ) bit | -16RES | | | | | | is set. These bits are unaffected | | | 15-12RES | | | | | by H_RESET, S_RESET or by setting the STOP bit. | | | -0 PXBC | ; | | | CSR6<br>Upper | | evious Tr | ansmit Descrip | otor Address | | | | | Bit | Na | me | Description | | | | | Reserved locations. Written as ZEROs and read as undefined. Contains the upper 16 bits of the previous transmit descriptor ad- 31-16RES 15-0 PXDAU | is set. These bits are unaffecte by H_RESET, S_RESET or b setting the STOP bit. | | | |---------------------------------------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------| | CSR62: P | revious T | ransmit Byte Count | | Bit N | ame | Description | | 31–16RES | | Reserved locations. Written as ZEROs and read as undefined. | | 15-12RES | 3 | Reserved locations. | | 11-0 PXBC | | Previous Transmit Byte Count.<br>This field is a copy of the BCNT<br>field of TMD1 of the previous<br>transmit descriptor. | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | transmit frames. | CSR63: Previous Transmit Status | | | 11–0 | NXBC | Next Transmit Byte Count. This | |---------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------| | Bit N | Name | Description | | | field is a copy of the BCNT field of TMD1 of the next transmit descriptor. | | 31–16RE<br>15–0 PX | | Reserved locations. Written as ZEROs and read as undefined. Previous Transmit Status. This | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | 10 0 1 % | .01 | field is a copy of bits 31–16 of TMD1 of the previous transmit descriptor. Read/Write accessi- | | | by H_RESET, S_RESET or by setting the STOP bit. | | | | ble only when either the STOP or | | | nsmit Status | | | | the SPND bit is set. These bits are unaffected by H_RESET, | Bit | Name | Description | | | | S_RESET or by setting the STOP bit. | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | CSR64: N | Next Trar | nsmit Buffer Address Lower | 15–0 | NXST | Next Transmit Status. This field is | | Bit N | Name | Description | | | a copy of bits 31–16 of TMD1 of the next transmit descriptor. | | 31–16RE | | Reserved locations. Written as ZEROs and read as undefined. | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | 15–0 NX | BAL | Contains the lower 16 bits of the<br>next transmit buffer address from<br>which the PCnet-PCI II controller | | | by H_RESET, S_RESET or by setting the STOP bit. | | | | will transmit an outgoing frame. | 7–0 | RES | Reserved locations. Read and written as ZEROs. Accessible | | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | | only when either the STOP or the SPND bit is set. | | | | by H_RESET, S_RESET or by setting the STOP bit. | CSR:<br>Bit | 72: Receive<br>Name | Descriptor Ring Counter Description | | CSR65: N | Next Trar | nsmit Buffer Address Upper | | | | | Bit N | Name | Description | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | 31–16RE | :S | Reserved locations. Written as ZEROs and read as undefined. | 15–0 | RCVRC | Receive Descriptor Ring Counter location. Contains a two's complement binary number used to | | 15–0 NX | (BAU | Contains the upper 16 bits of the next transmit buffer address from which the PCnet-PCI II controller will transmit an outgoing frame. | | | number the current receive descriptor. This counter interprets the value in CSR76 as pointing to the first descriptor. A counter val- | | | | Read/Write accessible only when either the STOP or the SPND bit | | | ue of ZERO corresponds to the last descriptor in the ring. | | 00000 | <b></b> | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected | | | Next Trar<br>Name | nsmit Byte Count Description | | | by H_RESET, S_RESET or by setting the STOP bit. | | | | | CSR | 74: Transmi | t Descriptor Ring Counter | | 31–16RE | :S | Reserved locations. Written as ZEROs and read as undefined. | Bit | Name | Description | | 15–12RE | :S | Reserved locations. Read and written as ZEROs. | 31–1 | 6 RES | Reserved locations. Written as ZEROs and read as undefined. | 15-0 XMTRC Transmit Descriptor Rina Counter location. Contains a two's complement binary number used to number the current transmit descriptor. This counter interprets the value in CSR78 as pointing to the first descriptor. A counter value of ZERO corresponds to the last descriptor in the rina. Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H\_RESET, S\_RESET or by setting the STOP bit. **CSR76: Receive Descriptor Ring Length** Bit **Description** Name 31-16RES Reserved locations. Written as ZEROs and read as undefined. 15-0 RCVRL Receive Descriptor Ring Length. Contains the two's complement of the receive descriptor ring length. This register is initialized during the PCnet-PCI II controller initialization routine based on the value in the RLEN field of the initialization block. However, the ring length can be programmed to any value from 1 to 65535 by writing directly to this register. Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H\_RESET, S\_RESET or by setting the STOP bit. **CSR78: Transmit Descriptor Ring Length** Bit Name Description 31-16 RES Reserved locations. Written as ZEROs and read as undefined. Transmit Descriptor Ring Length. Contains the two's complement of the transmit descriptor ring length. This register is initialized during the PCnetPCI II controller initialization routine based on the value in the TLEN field of the initialization block. However, the ring length can be programmed to any value from 1 to 65535 by writing directly to this register. 15-0 XMTRL Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H\_RESET, S\_RESET or by setting the STOP bit. # CSR80: DMA Transfer Counter and FIFO Watermark Control | Bit Name | Description | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | 15-14RES | Reserved locations. Read as ONEs and written as ZEROs. Accessible only when either the STOP or the SPND bit is set. | | 13-12RCVFW[1 | Receive FIFO Watermark. RCVFW specifies the number of bytes which must be present in the receive FIFO (once the frame has been verified as a non-runt) before receive DMA is requested. If the network interface is operating in half-duplex mode, at least 64 bytes or a complete frame must be received in order for a receive DMA to start. This effectively avoids having to react to receive frames which are runts or suffer a collision during the slot time (512 bit times). If the Runt Packet Accept feature is enabled or if the network interface is operating in full-duplex mode, receive DMA will be requested as soon as either the Receive FIFO Watermark is reached, or a complete valid receive frame is detected (regardless of length). If the EADI interface is active and the Runt Packet Accept feature is enabled or the network interface is operating in full-duplex mode, RCVFW must not be programmed to 00b | **Table 25. Receive Watermark Programming** frame. to allow enough time to reject the | RCVFW[1:0] | Bytes Received | |------------|----------------| | 00 | 16 | | 01 | 64 | | 10 | 128 | | 11 | Reserved | Read/Write accessible only when either the STOP or the SPND bit is set. RCVFW is set to a value of 01b (64 bytes) after H\_RESET or S\_RESET and is unaffected by setting the STOP bit. 11-10XMTSP[1:0] Transmit Start Point. As soon as the number of bytes in the transmit FIFO reaches the XMTSP value, the PCnet-PCI II controller starts trying to transmit. When the entire frame is in the FIFO, transmission attempts will start regardless of the value in XMTSP. If the network interface is operating in half-duplex mode, regardless of XMTSP, the FIFO will not internally overwrite its data until at least 64 bytes (or the entire frame if shorter than 64 bytes) have been transmitted onto the network. This ensures that for collisions within the slot time window. transmit data need not be reloaded into the transmit FIFO, and retries will be handled autonomously by the MAC. If the Disable Retry feature is enabled, or if the network is operating in full-duplex mode, the PCnet-PCI Il controller can overwrite the beginning of the frame as soon as the data is transmitted, because no collision handling is required in these modes. **Table 26. Transmit Start Point Programming** | XMTSP[1:0] | Bytes Written | |------------|---------------| | 00 | 8 | | 01 | 64 | | 10 | 128 | | 11 | 248 | Read/Write accessible only when either the STOP or the SPND bit is set. XMTSP is set to a value of 01b (64 bytes) after H\_RESET or S\_RESET and is unaffected by setting the STOP bit. 9–8 XMTFW[1:0] Transmit FIFO Watermark. XMT-FW controls the point at which transmit DMA is requested. Transmit DMA is requested when the number of bytes specified by XMTFW can be written to the transmit FIFO. **Table 27. Transmit Watermark Programming** | XMTFW[1:0] | Byte Spaces Available | |------------|-----------------------| | 00 | 16 | | 01 | 64 | | 10 | 128 | | 11 | Reserved | Read/Write accessible only when either the STOP or the SPND bit is set. XMTFW is set to a value of 00b (16 bytes) after H\_RESET or S\_RESET and is unaffected by setting the STOP bit. 7-0 DMATC[7:0] DMA Transfer Counter. If DMA-PLUS (CSR4, bit 14) is cleared to ZERO, this counter contains the maximum number of FIFO read or write data phases the PCnet-PCI II controller will perform during a single bus mastership period, if not preempted. The DMA Transfer Counter is not used to limit the number of data phases during initialization block or descriptor transfers. A value of ZERO will be interpreted as one data phase. If DMAPLUS is set to ONE, the DMA Transfer Counter is disabled, and the PCnet-PCI II controller will try to transfer data as long as the transmit FIFO is not full or as long as the receive FIFO is not empty. When the PCnet-PCI II controller is preempted and the last data phase has finished, DMATC will freeze. It will continue counting down when the PCnet-PCI II controller is granted bus ownership again and continues with the data transfers. DMATC should not be enabled when the PCnet-PCI II controller is used in a PCI bus application. The PCI Latency Timer should be the only entity governing the time the PCnet-PCI II controller has control over the bus. Read/Write accessible only when either the STOP or the SPND bit is set. Note that the read operation will yield the value of the run-time copy of the DMA Transfer Counter and not the register that holds the programmed value. Most read operations will yield a value of ZERO, because the run-time counter is only reloaded with the programmed value at the beginning of a new bus mastership period. The DMA Transfer Counter is set to a value of 16 (10h) after H\_RESET or S\_RESET and is unaffected by setting the STOP bit. **CSR82: Bus Activity Timer** Bit Name Description 31-16 RES Reserved locations. Written as ZEROs and read as undefined. 15-0 DMABAT Bus Activity Timer. If TIMER (CSR4, bit 13) is set to ONE, this register controls the maximum allowable time that PCnet-PCI II controller will take up on the system bus during FIFO data transfers. The Bus Activity Timer does not limit the time on the system bus during initialization block or descriptor transfers. The DMABAT value is interpreted as an unsigned number with a resolution of 0.1 $\mu$ s. For instance, a value of 51 $\mu$ s would be programmed with a value of 510 (1FEh). A value of ZERO (the default value) will result in a single data transfer. DMABAT starts counting down when the PCnet-PCI II controller is granted bus ownership and the bus is idle. When DMABAT has counted down to ZERO, the PCnet-PCI II controller will finish the current data phase before releasing the bus. Note that because DMABAT does not run on the PCI bus interface clock, the actual time the PCnet-PCI II controller takes up the bus might differ by 2 to 3 clock periods from the value programmed to DMABAT. DMABAT should not be enabled when the PCnet-PCI II controller is used in a PCI bus application. The PCI Latency Timer should be the only entity governing the time the PCnet-PCI II controller has control over the bus. Read/Write accessible only when either the STOP or the SPND bit is set. Note that the read operation will yield the value of the run-time copy of the Bus Activity Timer and not the register that holds the programmed value. Most read operations will yield a value of ZERO, because the run-time counter is only reloaded with the programmed value at the beginning of a new bus mastership period. The Bus Activity Timer register is cleared to a value of 0000h after H RESET S RESET and is unaffected by setting the STOP bit. ## **CSR84: DMA Address Register Lower** | Bit | Name | Description | |-------|------|-------------------------------------------------------------| | 31–16 | SRES | Reserved locations. Written as ZEROs and read as undefined. | This register contains the lower 16 bits of the address of system memory for the current DMA cycle. The Bus Interface Unit controls the Address Register by issuing commands to increment the memory address for sequential operations. The DMABAL register is undefined until the first PCnet-PCI II controller DMA operation. Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H\_RESET, S\_RESET or by setting the STOP bit. # CSR85: DMA Address Register Upper | Bit | Name | Description | |-------|------|-------------------------------------------------------------| | 31–16 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | 15-0 DMABAU 15-0 DMABAL This register contains the upper 16 bits of the address of system memory for the current DMA cycle. The Bus Interface Unit controls the Address Register by issuing commands to increment the memory address for sequential operations. The DMABAU | | | register is undefined until the first PCnet-PCI II controller DMA operation. Read/Write accessible only when either the STOP or the SPND bit is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 11 – | 1MANFID | Manufacturer ID. The 11-bit manufacturer code for AMD is 000000000001b. This code is per the JEDEC Publication 106-A. Note that this code is not the same as the Vendor ID in the PCI configuration space. Read accessible always. MAN- | |---------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CSR86 | 6: Buffer By | rte Counter | | | FID is read only. Write operations | | Bit | Name | Description | 0 | ONE | are ignored.<br>Always a logic ONE. | | 31–161 | | Reserved locations. Written as ZEROs and read as undefined. | | | Read accessible always. ONE is read only. Write operations are ignored. | | 15–121 | RES | Reserved locations. Read and written with ONEs. | CSR | 89: Chip ID F | Register Upper | | 11–0 I | DMABC | DMA Byte Count Register. Con- | Bit | Name | Description | | | | tains the two's complement of the remaining size of the current transmit or receive buffer in | | 16RES | Reserved locations. Read as undefined. | | | | bytes. This register is increment-<br>ed by the Bus Interface Unit. The<br>DMABC register is undefined un- | 15 – | 12VER | Version. This 4-bit pattern is silicon-revision dependent. | | | | til written. Read/Write accessible only when either the STOP or the SPND bit | | | Read accessible always. VER is read only. Write operations are ignored. | | | | is set. These bits are unaffected by H_RESET, S_RESET or by setting the STOP bit. | 11 – | 0PARTIDU | Upper 12 bits of the PCnet-PCI II controller part number. I.e. 0010 0110 0010b. | | CSR88 | 3: Chip ID R<br>Name | Register Lower Description | | | Read accessible always. PARTIDU is read only. Write operations are ignored. | | 31 – 28 | 8VER | Version. This 4-bit pattern is sili- | CSR94: Transmit Time Domain Reflectometry Count | | | | | | con revision dependent. Read accessible always. VER is | Bit | Name | Description | | 27 – 12 | 2PARTID | read only. Write operations are ignored. Part number. The 16-bit code for | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | | | the PCnet-PCI II controller is 0010 0110 0010 0001b (2621h). | 15–1 | 0RES | Reserved locations. Read and written as ZEROs. | | | | This register is exactly the same as the Device ID register in the JTAG description. It is, however, different from the ID stored in the Device ID register in the PCI configuration space. Read accessible only when either the STOP or the SPND bit is set. PARTID is read only. Write operations are ignored. | 9–0 | XMTTDR | Time Domain Reflectometry reflects the state of an internal counter that counts from the start of transmission to the occurrence of loss of carrier. TDR is incremented at a rate of 10 MHz. Read accessible only when either the STOP or the SPND bit is set. Write operations are ignored. XMTTDR is cleared by H_RESET or S_RESET. | | CSR100: Bus Timeout Bit Name Description | | | | nored. MFC is cleared by H_RESET or S_RESET or by | |-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | - Name | - Description | | | setting the STOP bit. | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | CSR1<br>Bit | 14: Receive<br>Name | Collision Count Description | | 15-0 MERRT | RRTO This register contains the value of the longest allowable bus latency (interval between assertion | | SRES | Reserved locations. Written as ZEROs and read as undefined. | | | of REQ and assertion of GNT) that a system may insert into a PCnet-PCI II controller master transfer. If this value of bus latency is exceeded, then MERR (CSR0, bit 11) will be set to ONE, and an interrupt may be generated, depending upon the setting of the MERRM bit (CSR3, bit 11) and the IENA bit (CSR0, bit 6). The value in this register is interpreted as the unsigned number of XTAL1 clock periods divided by two, i.e. the value in this register is given in 0.1 µs increments. For example, the value 0600h (1536 decimal) will assume MERR to be | 15–0 | RCC | Receive Collision Count. Indicates the total number of collisions on the network encountered by the receiver since the last reset of the counter. RCC will roll over to a count of ZERO from the value 65535. The RCVCCO bit of CSR4 (bit 5) will be set each time that this occurs. The PCnet-PCI II controller will continue counting collisions on the network while the device is in suspend mode (SPND = 1, CSR5, bit 0) Read accessible always. RCC is read only, write operations are ig- | | | decimal) will cause a MERR to be indicated after 153.6 µs of bus latency. A value of ZERO will allow an infinitely long bus latency, i.e. | 000 | IOO Advance | nored. RCC is cleared by H_RESET or S_RESET or by setting the STOP bit. | | | bus timeout error will never oc-<br>cur. | Bit | Name | ed Feature Control Description | | | Read/Write accessible only when either the STOP or the SPND bit is set. This register is set to | · | BRES | Reserved locations. Written as ZEROs and read as undefined. | | | 0600h by H_RESET or<br>S_RESET and is unaffected by<br>setting the STOP bit. | 15–2 | RES | Reserved locations. Written as ZEROs and read as undefined. | | CSR112: Miss | sed Frame Count | 0 | RCVALGN | Receive Frame Align. When set, this bit forces the data field of ISO 8802-3 (IEEE/ANSI 802.3) frames to align to DWord address | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | | boundaries. It is important to note that this feature will only function | | 15-0 MFC | Missed Frame Count. Indicates the number of missed frames. MFC will roll over to a count of ZERO from the value 65535. The MFCO bit (CSR4, bit 8) will be set each time that this occurs. The PCnet-PCI II controller will not count missed frames while the device is in suspend mode (SPND = 1, CSR5, bit 0). | | | correctly if all receive buffer boundaries are DWord aligned and all receive buffers have 0 MOD 4 lengths. In order to accomplish the data alignment, the PCnet-PCI II controller simply inserts two bytes of random data at the beginning of the receive frame (i.e. before the ISO 8802-3 (IEEE/ANSI 802.3) destination address field). The MCNT field | will not include the extra two bytes. Read/Write accessible always. RCVALGN is cleared by H\_RESET or S\_RESET and is not affected by STOP. #### CSR124: Test Register 1 | Bit | Name | Description | |------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | This register is used to place the PCnet-PCI II controller into various test modes. Only Runt Packet Accept is user accessible test modes. All other test modes are for AMD internal use only. | | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | 15–5 | RES | Reserved locations. Written as ZEROs and read as undefined. | | 4 | RES | Reserved locations. Written as ZEROs and read as undefined. | | 3 | RPA | Runt Packet Accept. This bit forces the PCnet-PCI II controller to accept runt packets (packets shorter than 64 bytes). | | | | Read accessible always. Write accessible when EN124 (CSR4, bit 15) is set to ONE. RPA is cleared by H_RESET or S_RESET and is not affected by setting the STOP bit. | | 2–0 | RES | Reserved locations. Written as ZEROs and read as undefined. | ### **Bus Configuration Registers** The Bus Configuration Registers (BCRs) are used to program the configuration of the bus interface and other special features of the PCnet-PCI II controller that are not related to the IEEE 8802-3 MAC functions. The BCRs are accessed by first setting the appropriate RAP value, and then by performing a slave access to the BDP. All BCR registers are 16 bits wide in Word I/O mode (DWIO = 0, BCR18, bit 7) and 32 bits wide in DWord I/O mode (DWIO = 1). The upper 16 bits of all BCR registers are undefined when in DWord I/O mode. These bits should be written as ZEROs and should be treated as undefined when read. The default value given for any BCR is the value in the register after H\_RESET. Some of these values may be changed shortly after H\_RESET when the contents of the external EEPROM is automatically read in. With the exception of DWIO (BCR18, bit 7) BCR register values are not affected by S\_RESET. None of the BCR register values are affected by the assertion of the STOP bit. Note that several registers have no default value. BCR0, BCR1, BCR3, BCR8, BCR10–17 and BCR21 are reserved and have undefined values. The content of BCR2 is undefined until is has been first programmed through the EEPROM read operation or a user register write operation. BCR0, BCR1, BCR16, BCR17 and BCR21 are registers that are used by other devices in the PCnet family. Writing to these registers has no effect on the operation of the PCnet-PCI II controller. Writes to those registers marked as Reserved will have no effect. Reads from these locations will produce undefined values. Table 28. BCR Registers | | | | | Progra | mmability | |-------|----------|---------|-----------------------------|--------|-----------| | RAP | MNEMONIC | Default | Name | User | EEPROM | | 0 | MSRDA | 0005h | Reserved | No | No | | 1 | MSWRA | 0005h | Reserved | No | No | | 2 | MC | 0002h | Miscellaneous Configuration | Yes | Yes | | 3 | Reserved | N/A | Reserved | No | No | | 4 | LNKST | 00C0h | Link Status LED | Yes | Yes | | 5 | LED1 | 0084h | LED1 Status | Yes | Yes | | 6 | LED2 | 0088h | LED2 Status | Yes | Yes | | 7 | LED3 | 0090h | LED3 Status | Yes | Yes | | 8 | Reserved | N/A | Reserved | No | No | | 9 | FDC | 0000h | Full-Duplex Control | Yes | Yes | | 10–15 | Reserved | N/A | Reserved | No | No | | 16 | IOBASEL | N/A | Reserved | No | No | | 17 | IOBASEU | N/A | Reserved | No | No | | 18 | BSBC | 9001h | Burst and Bus Control | Yes | Yes | | 19 | EECAS | 0002h | EEPROM Control and Status | Yes | No | | 20 | SWS | 0000h | Software Style | Yes | No | | 21 | INTCON | N/A | Reserved | No | No | | 22 | PCILAT | FF06h | PCI Latency | Yes | Yes | | 22 | PCILAI | FF06h PCI Latency | | | | Yes | Yes | |-------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------|--------------------------------------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------| | BCR0<br>Bit | : Master Mo | ode Read Active Description | | | patibility w devices. | ith other | PCnet family | | 31–16 | | Reserved locations. Written as ZEROs and read as undefined. | | | only Write fect. | operation | VRA is read<br>s have no ef- | | 15–0 | MSRDA | Reserved locations. After H_RESET, the value in this regis- | BCF<br>Bit | R2: Miscellaned Name | ous Configu<br>Descripti | | | | | | ter will be 0005h. The setting of this register has no effect on any PCnet-PCI II controller function. It is only included for software compatibility with other PCnet family devices. | | | are progra | ammable<br>EPROM. F<br>only bits st | n this register<br>through the<br>Reserved bits<br>nould be pro- | | | | Read always. MSRDA is read only Write operations have no ef- | 31–1 | 16RES | | | . Written as undefined. | | BCR1 | : Master Mo | fect.<br>ode Write Active | 15 | RES | Reserved<br>ZERO and | | Written as undefined. | | Bit | Name | Description | 14 | TMAULOOP | | | lows external | | 31–16 | 31–16RES Reserved locations. VZEROs and read as ur | | | | loopback packets to pass on<br>the network through the T-MA<br>interface, if the T-MAU interface | the T-MAU<br>AU interface | | | 15-0 MSWRA | MSWRA | Reserved locations. After H_RESET, the value in this regis- | | | | as not be | If the T-MAU<br>een selected,<br>effect. | | | | ter will be 0005h. The setting of<br>this register has no effect on any<br>PCnet-PCI II controller function. It<br>is only included for software com- | | | TMAULOC | P is clea | ible always.<br>red to ZERO<br>s unaffected | by S\_RESET or by setting the STOP bit. 13-9 RES Reserved locations. Written as ZEROs and read as undefined. 8 APROMWE Address PROM Write Enable. The PCnet-PCI II controller contains a shadow RAM on board for storage of the first 16 bytes loaded from the serial EEPROM. Accesses to Address PROM I/O Resources will be directed toward this RAM. When APROM-WE is set to ONE, then write access to the shadow RAM will be enabled. Read/Write accessible always. APROMWE is cleared to ZERO by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 7 INTLEVEL Interrupt Level. This bit allows the interrupt output signals to be programmed for level or edge-sensitive applications. When INTLEVEL is cleared to ZERO, the INTA pin is configured for level-sensitive applications. In this mode, an interrupt request is signaled by a low level driven on the INTA pin by the PCnet-PCI II controller. When the interrupt is cleared, the INTA pin is tristated by the PCnet-PCI II controller and allowed to be pulled to a high level by an external pullup device. This mode is intended for systems which allow the interrupt signal to be shared by multiple devices. When INTLEVEL is set to ONE, the INTA pin is configured for edge-sensitive applications. In this mode, an interrupt request is signaled by a high level driven on the INTA pin by the PCnet-PCI II controller. When the interrupt is cleared, the INTA pin is driven to a low level by the PCnet-PCI II controller. This mode is intended for systems that do not allow interrupt channels to be shared by multiple devices. INTLEVEL should not be set to ONE when the PCnet-PCI II controller is used in a PCI bus application. Read/Write accessible always. INTLEVEL is cleared to ZERO by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 6 RES Reserved location. Written as ZERO and read as undefined. 5 DXCVRCTL DXCVR Control. When the AUI is the active network port, DX-CVRCTL controls the assertion of the DXCVR output. The polarity of the asserted state is controlled by the DXCVRPOL bit (BCR2, bit 4). The DXCVR pin can be used to control a DC-to-DC converter in applications that want to connect a 10BASE2 MAU as well as a standard DB15 AUI connector to the PCnet-PCI II controller AUI. When DXCVRCTL is set to ONE, the DXCVR output will be asserted. This could be used to enable a DC-to-DC converter for 10BASE2 MAUs (assuming the enable input of the DC-to-DC converter is active high and DX-CVRPOL is cleared to ZERO). When DXCVRCTL is cleared to ZERO, the DXCVR output will be deasserted. This would power down the DC-to-DC converter. When the 10BASE-T interface is the active network port, the DX-CVR output is always deasserted. Read/Write accessible always. DXCVRCTL is cleared by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 4 DXCVRPOL DXCVR Polarity. This bit controls the polarity of the asserted state of the DXCVR output. When DXCVRPOL is cleared to ZERO, the DXCVR output will be HIGH when asserted. When DXCVRPOL is set to ONE, the DXCVR output will be LOW when asserted. 138 Table 29. DXCVR Output Control | DXCVRCTL | DXCVRPOL | Active<br>Network<br>Port | DXCVR<br>Output | |----------|----------|---------------------------|-----------------| | Х | 0 | 10BASE-T | Low | | Х | 1 | 10BASE-T | High | | 0 | 0 | AUI | Low | | 1 | 0 | AUI | High | | 0 | 1 | AUI | High | | 1 | 1 | AUI | Low | Read/Write accessible always. DXCVRPOL is cleared by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 3 EADISEL EADI Select. When set to ONE, this bit enables the three EADI interface pins that are multiplexed with other functions. EESK/LED1 becomes SFBD, EEDO/LED3 becomes SRD, and LED2 becomes SRDCLK. Read/Write accessible always. EADISEL is cleared by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit 2 AWAKE This bit selects one of two different sleep modes. If AWAKE is set to ONE and the SLEEP pin is asserted, the PC-net-PCI II controller goes into snooze mode. If AWAKE is cleared to ZERO and the SLEEP pin is asserted, the PCnet-PCI II controller goes into coma mode. See the section "Power Saving Modes" for more details. This bit only has meaning when the 10BASE-T network interface is selected. Read/Write accessible always. AWAKE is cleared to ZERO by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 1 ASEL Auto Select. When set, the PC-net-PCI II controller will automatically select the operating media interface port. If ASEL has been set to ONE, and the 10BASE-T transceiver is in the Link Pass state, the 10BASE-T port will be used. If ASEL has been set to ONE, and the 10BASE-T port is in the Link Fail state, the AUI port will be used. If one of the above conditions changes during transmission, switching between the ports will not occur until the transmission is ended. When ASEL is set to ONE, Link Beat Pulses will be transmitted on the 10BASE-T port, regardless of the state of Link Status. When ASEL is cleared to ZERO, Link Beat Pulses will only be transmitted on the 10BASE-T port when the PORTSEL bits of the Mode Register (CSR15) have selected 10BASE-T as the active port. When ASEL is cleared to ZERO, then the selected network port will be determined by the settings of the PORTSEL bits of CSR15. Read/Write accessible always. ASEL is set to ONE by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. The network port configurations are as follows: **Table 30. Network Port Configuration** | PORTSEL[1:0] | ASEL<br>(BCR2[1]) | Link Status<br>(of 10BASE-T) | Network<br>Port | |--------------|-------------------|------------------------------|-----------------| | 0X | 1 | Fail | AUI | | 0X | 1 | Pass | 10BASE-T | | 00 | 0 | Х | AUI | | 01 | 0 | Х | 10BASE-T | | 10 | Х | Х | Reserved | | 11 | Х | Х | Reserved | 0 XMAUSEL Reserved location. Read/Write accessible always. This reserved location is cleared by H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. Writing a ONE to this bit has no effect on the operation of the PCnet-PCI II controller. | BCR4: Link Status LED (LNKST) | | | | | The setting of this bit will not ef- | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit Na | ame | Description | | | fect the polarity of the LEDOUT bit for this register. | | | | BCR4 determines which function(s) activate the LNKST pin. The pin will indicate the logical OR of the enabled functions. | | | Read/Write accessible always.<br>LEDPOL is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | | BCR4 defaults to Link Status (LNKST) with pulse stretcher enabled (PSE = 1). | 13 | LEDDIS | LED Disable. This bit is used to disable the LED output. When LEDDIS is set to ONE and LED-POL is cleared to ZERO, the LED | | | | Note that bits 15–0 in this register are programmable through the external EEPROM. Reserved bits and read-only bits should be programmed to ZERO. | | | output pin will be floating. When LEDDIS is set to ONE and LED-POL is set to ONE, the LED output pin will be driven LOW. When LEDDIS has the value ZERO, the | | 31–16RES | | Reserved locations. Written as ZEROs and read as undefined. | | | LED output value will be governed by the LEDOUT and LED-POL values. | | 15 LED | OUT | This bit indicates the current (non-stretched) value of the LED output pin. A value of ONE in this bit indicates that the OR of the enabled signals is true. | | | Read/Write accessible always. LEDDIS is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | The logical value of the LEDOUT status signal is determined by the | 12– | 10RES | Reserved locations. Written as ZEROs and read as undefined. | | | | settings of the individual Status Enable bits of this register (bits 8 and 6–0). | 9 | MPSE | Magic Packet Status Enable.<br>When this bit is set to ONE, a value of ONE is passed to the LED- | | | Read accessible always. This bit is read only. Writes have no effect. LEDOUT is unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | | OUT bit in this register when magic packet mode is enabled and a magic packet is detected on the network. | | 14 LEC | OPOL | LED Polarity. When this bit has the value ZERO, the LED pin will be asserted LOW whenever the | | | Read/Write accessible always. MPSE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | OR of the enabled signals is true, and the LED pin will be disabled and allowed to float whenever the OR of the enabled signals is false. (The LED output will be an open drain output, and the output value will be the inverse of the LEDOUT status bit.) | 8 | FDLSE | Full-duplex Link Status Enable. Indicates the full-duplex Link Test Status. When this bit is set to ONE, a value of ONE is passed to the LEDOUT signal when the PCnet-PCI II controller is functioning in a Link Pass state and full-duplex operation is enabled. | | | | When this bit has the value ONE, the LED pin will be asserted HIGH whenever the OR of the enabled signals is true, and the LED pin will be driven to a LOW level whenever the OR of the enabled signals is false. (The LED output will be a totem pole output, and the output value will be the same polarity as the LEDOUT status bit.) | | | When the PCnet-PCI II controller is not functioning in a Link Pass state with full-duplex operation being enabled, a value of ZERO is passed to the LEDOUT signal. When the 10BASE-T port is active, a value of ONE is passed to the LEDOUT signal whenever the Link Test Function detects a Link Pass state and the FDEN (BCR9, bit 0) bit is set. When the AUI port | | | | is active, a value of ONE is passed to the LEDOUT signal whenever full-duplex operation on the AUI port is enabled (both FDEN and AUIFD bits in BCR9 are set to ONE). Read/Write accessible always. FDI SE is cleared by H BESET. | 4 | XMTE | and is not affected by S_RESET or by setting the STOP bit. Transmit Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is transmit activity on the network. | |---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | PSE | FDLSE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. Pulse Stretcher Enable. When this bit is set to ONE, the LED illumination time is extended so that brief occurrences of the enabled function will be seen on this LED output. A value of ZERO disables the pulse stretcher. | 3 | RXPOLE | Read/Write accessible always. XMTE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. Receive Polarity Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when the polarity of the RXD± pair is not reversed. | | | | Read/Write accessible always. PSE is set to ONE by H_RESET and is not affected by S_RESET | | | Receive polarity indication is valid only if the T-MAU is in link pass state. | | 6 | LNKSTE | or by setting the STOP bit. Link Status Enable. When this bit is set to ONE, a value of ONE will be passed to the LEDOUT bit in this register when the T MALL on | | | Read/Write accessible always.<br>RXPOLE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | this register when the T-MAU operating in half-duplex mode is in Link Pass state. When the T-MAU operating in half-duplex mode is in Link Fail state, a value of ZERO is passed to the LED- | 2 | RCVE | Receive Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is receive activity on the network. | | | | | OUT bit. The function of this bit is masked if the 10BASE-T port is operating in full-duplex mode. This allows a | | | Read/Write accessible always. RCVE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | system to have separate LEDs for half-duplex Link Status and for full-duplex Link Status. Read/Write accessible always. | 1 | JABE | Jabber status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when the PCnet-PCI | | | | LNKSTE is set to ONE by H_RESET and is not affected by S_RESET or by setting the STOP | | | Il controller is jabbering on the network. Read/Write accessible always. | | 5 | RCVME | bit. Receive Match Status Enable. When this bit is set to ONE, a val- | | | JABE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | ue of ONE is passed to the LED-OUT bit in this register when the there is receive activity on the network that has passed the address match function for this node. All address matching modes are included: physical, logical filtering, broadcast and promiscuous. Read/Write accessible always. RCVME is cleared by H_RESET | 0 | COLE | Collision status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is collision activity on the network. The activity on the collision inputs to the AUI port within the first 4 µs after every transmission for the purpose of SQE testing will not cause the LEDOUT bit to be set. | Read/Write accessible always. | | | COLE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | output will be a totem pole output, and the output value will be the same polarity as the LEDOUT | |-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BCR5: LED1 Status | | | | | status bit.) | | Bit | Name | Description | | | The setting of this bit will not effect the polarity of the LEDOUT bit for this register. | | | | BCR5 determines which function(s) activate the LED1 pin. The pin will indicate the logical OR of the enabled functions. BCR5 defaults to Receive Status (RCV) | | | Read/Write accessible always.<br>LEDPOL is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | | with pulse stretcher enabled (PSE = 1). | 13 | LEDDIS | LED Disable. This bit is used to disable the LED output. When LEDDIS is set to ONE and LED- | | | | Note that bits 15–0 in this register are programmable through the external EEPROM. Reserved bits and read-only bits should be programmed to ZERO. | | | POL is cleared to ZERO, the LED output pin will be floating. When LEDDIS is set to ONE and LED-POL is set to ONE, the LED output pin will be driven LOW. When | | 31–10 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | | LEDDIS has the value ZERO, the LED output value will be gov- | | 15 | LEDOUT | This bit indicates the current (non-stretched) value of the LED | | | erned by the LEDOUT and LED-POL values. | | | | output pin. A value of ONE in this bit indicates that the OR of the enabled signals is true. | | | Read/Write accessible always.<br>LEDDIS is cleared by H_RESET<br>and is not affected by S_RESET | | | | The logical value of the LEDOUT status signal is determined by the | 12 | 10RES | or by setting the STOP bit. Reserved locations. Written as | | | | settings of the individual Status | 12 | TOTILO | ZEROs and read as undefined. | | | | Enable bits of this register (bits 8 and 6–0). | 9 | MPSE | Magic Packet Status Enable.<br>When this bit is set to ONE, a val- | | | | Read accessible always. This bit is read only. Writes have no effect. LEDOUT is unaffected by H_RESET, S_RESET or by setting the STOP bit. | | | ue of ONE is passed to the LED-<br>OUT bit in this register when<br>magic packet mode is enabled<br>and a magic packet is detected<br>on the network. | | 14 | LEDPOL | LED Polarity. When this bit has the value ZERO, the LED pin will be asserted LOW whenever the OR of the enabled signals is true, | | | Read/Write accessible always.<br>MPSE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | | and the LED pin will be disabled and allowed to float whenever the OR of the enabled signals is false. (The LED output will be an open drain output, and the output value will be the inverse of the LEDOUT status bit.) | 8 | FDLSE | Full-duplex Link Status Enable. Indicates the full-duplex Link Test Status. When this bit is set to ONE, a value of ONE is passed to the LEDOUT signal when the PCnet-PCI II controller is functioning in a Link Pass state and | | | | When this bit has the value ONE, the LED pin will be asserted HIGH whenever the OR of the enabled signals is true, and the LED pin will be driven to a LOW level whenever the OR of the en- | | | full-duplex operation is enabled. When the PCnet-PCI II controller is not functioning in a Link Pass state with full-duplex operation being enabled, a value of ZERO is passed to the LEDOUT signal. | abled signals is false. (The LED | | | When the 10BASE-T port is active, a value of ONE is passed to the LEDOUT signal whenever the Link Test Function detects a Link Pass state and the FDEN (BCR9, bit 0) bit is set. When the AUI port is active, a value of ONE is passed to the LEDOUT signal | | | modes are included: physical, logical filtering, broadcast and promiscuous. Read/Write accessible always. RCVME is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | |---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | whenever full-duplex operation on the AUI port is enabled (both FDEN and AUIFD bits in BCR9 are set to ONE). | 4 | XMTE | Transmit Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is transmit activity on the network. | | _ | | Read/Write accessible always. FDLSE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | Read/Write accessible always. XMTE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | 7 | PSE | Pulse Stretcher Enable. When this bit is set to ONE, the LED illumination time is extended so that brief occurrences of the enabled function will be seen on this LED output. A value of ZERO disables the pulse stretcher. | 3 | RXPOLE | Receive Polarity Status Enable. When this bit is set to ONE, a value of ONE is passed to the LED-OUT bit in this register when the polarity of the RXD± pair is not reversed. | | | | Read/Write accessible always. PSE is set to ONE by H_RESET and is not affected by S_RESET | | | Receive polarity indication is valid only if the T-MAU is in link pass state. | | 6 | LNKSTE | or by setting the STOP bit. Link Status Enable. When this bit is set to ONE, a value of ONE will be passed to the LEDOUT bit in | | | Read/Write accessible always.<br>RXPOLE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | be passed to the LEDOUT bit in this register when the T-MAU operating in half-duplex mode is in Link Pass state. When the T-MAU operating in half-duplex mode is in Link Fail state, a value | 2 | RCVE | Receive Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is receive activity on the network. | | | | | of ZERO is passed to the LED-<br>OUT bit. The function of this bit is masked<br>if the 10BASE-T port is operating | | | Read/Write accessible always. RCVE is set to ONE by H_RESET and is not affected by S_RESET or by setting the STOP | | | | in full-duplex mode. This allows a system to have separate LEDs for half-duplex Link Status and for full-duplex Link Status. | 1 | JABE | bit. Jabber status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in | | | | Read/Write accessible always.<br>LNKSTE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | this register when the PCnet-PCI II controller is jabbering on the network. | | 5 | RCVME | Receive Match Status Enable.<br>When this bit is set to ONE, a value of ONE is passed to the LED- | | | Read/Write accessible always. JABE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | OUT bit in this register when the there is receive activity on the network that has passed the address match function for this node. All address matching | 0 | COLE | Collision status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is collision activity on the network. | 144 The activity on the collision inputs to the AUI port within the first 4 µs after every transmission for the purpose of SQE testing will not enabled signals is true, and the cause the LEDOUT bit to be set. LED pin will be driven to a LOW level whenever the OR of the en-Read/Write accessible always. abled signals is false. (The LED COLE is cleared by H RESET output will be a totem pole output, and is not affected by S\_RESET and the output value will be the or by setting the STOP bit. same polarity as the LEDOUT **BCR6: LED2 Status** status bit.) Bit Name Description The setting of this bit will not effect the polarity of the LEDOUT bit for this register. BCR6 determines which function(s) activate the $\overline{LED2}$ pin. The Read/Write accessible always. pin will indicate the logical OR of LEDPOL is cleared by H RESET the enabled functions. BCR6 deand is not affected by S\_RESET faults to Receive Polarity Status or by setting the STOP bit. (RXPOL) with pulse stretcher en-13 **LEDDIS** LED Disable. This bit is used to abled (PSE = 1). disable the LED output. When Note that bits 15-0 in this register LEDDIS is set to ONE and LEDare programmable through the POL is cleared to ZERO, the LED external EEPROM. Reserved bits output pin will be floating. When and read-only bits should be pro-LEDDIS is set to ONE and LEDgrammed to ZERO. POL is set to ONE, the LED output pin will be driven LOW. When 31-16RES Reserved locations. Written as LEDDIS has the value ZERO, the ZEROs and read as undefined. LED output value will be gov-15 **LEDOUT** This bit indicates the current erned by the LEDOUT and LED-(non-stretched) value of the LED POL values. output pin. A value of ONE in this Read/Write accessible always. bit indicates that the OR of the LEDDIS is cleared by H\_RESET enabled signals is true. and is not affected by S\_RESET The logical value of the LEDOUT or by setting the STOP bit. status signal is determined by the Reserved locations. Written as 12-10 RES settings of the individual Status ZEROs and read as undefined. Enable bits of this register (bits 8 and 6-0). **MPSE** Magic Packet Status Enable. When this bit is set to ONE, a val-Read accessible always. This bit ue of ONE is passed to the LEDis read only. Writes have no ef-OUT bit in this register when fect. LEDOUT is unaffected by magic packet mode is enabled H\_RESET, S\_RESET or by setand a magic packet is detected ting the STOP bit. on the network. 14 LEDPOL LED Polarity. When this bit has Read/Write accessible always. the value ZERO, the LED pin will MPSE is cleared by H RESET be asserted LOW whenever the and is not affected by S RESET OR of the enabled signals is true, or by setting the STOP bit. and the LED pin will be disabled and allowed to float whenever the 8 **FDLSE** Full-duplex Link Status Enable. OR of the enabled signals is Indicates the full-duplex Link Test false. (The LED output will be an Status. When this bit is set to open drain output, and the output ONE, a value of ONE is passed value will be the inverse of the to the LEDOUT signal when the LEDOUT status bit.) PCnet-PCI II controller is functioning in a Link Pass state and full-duplex operation is enabled. Am79C970A When this bit has the value ONE. the LED pin will be asserted HIGH whenever the OR of the 145 | | | When the PCnet-PCI II controller is not functioning in a Link Pass state with full-duplex operation being enabled, a value of ZERO is passed to the LEDOUT signal. When the 10BASE-T port is active, a value of ONE is passed to the LEDOUT signal whenever the Link Test Function detects a Link Pass state and the FDEN (BCR9, bit 0) bit is set. When the AUI port is active, a value of ONE is passed to the LEDOUT signal whenever full-duplex operation on the AUI port is enabled (both FDEN and AUIFD bits in BCR9 are set to ONE). Read/Write accessible always. FDLSE is cleared by H_RESET and is not affected by S_RESET | 4 | XMTE | OUT bit in this register when the there is receive activity on the network that has passed the address match function for this node. All address matching modes are included: physical, logical filtering, broadcast and promiscuous. Read/Write accessible always. RCVME is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. Transmit Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is transmit activity on the network. Read/Write accessible always. XMTE is cleared by H_RESET and is not affected by S_RESET | |---|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | PSE | or by setting the STOP bit. Pulse Stretcher Enable. When this bit is set to ONE, the LED illumination time is extended so that brief occurrences of the enabled function will be seen on this LED output. A value of ZERO disables the pulse stretcher. | 3 | RXPOLE | or by setting the STOP bit. Receive Polarity Status Enable. When this bit is set to ONE, a value of ONE is passed to the LED-OUT bit in this register when the polarity of the RXD± pair is not reversed. | | | | Read/Write accessible always. PSE is set to ONE by H_RESET and is not affected by S_RESET | | | Receive polarity indication is valid only if the T-MAU is in link pass state. | | 6 | LNKSTE | or by setting the STOP bit. Link Status Enable. When this bit is set to ONE, a value of ONE will be passed to the LEDOUT bit in | | | Read/Write accessible always. RXPOLE is set to ONE by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | this register when the T-MAU operating in half-duplex mode is in Link Pass state. When the T-MAU operating in half-duplex mode is in Link Fail state, a value of ZERO is passed to the LED- | 2 | RCVE | Receive Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is receive activity on the network. | | | | OUT bit. The function of this bit is masked if the 10BASE-T port is operating in full-duplex mode. This allows a | | | Read/Write accessible always.<br>RCVE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | | system to have separate LEDs for half-duplex Link Status and for full-duplex Link Status. | 1 | JABE | Jabber status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when the PCnet-PCI | | | | Read/Write accessible always. LNKSTE is cleared by H_RESET and is not affected by S_RESET | | | II controller is jabbering on the network. | | 5 | RCVME | or by setting the STOP bit. Receive Match Status Enable. When this bit is set to ONE, a value of ONE is passed to the LED- | | | Read/Write accessible always. JABE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | 0 | COLE | Collision status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is collision activity on the network. The activity on the collision inputs to the AUI port within the first 4 µs after every transmission for the purpose of SQE testing will not cause the LEDOUT bit to be set. Read/Write accessible always. COLE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | open drain output, and the output value will be the inverse of the LEDOUT status bit.) When this bit has the value ONE, the LED pin will be asserted HIGH whenever the OR of the enabled signals is true, and the LED pin will be driven to a LOW level whenever the OR of the enabled signals is false. (The LED output will be a totem pole output, and the output value will be the same polarity as the LEDOUT status bit.) | |------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BCR<br>Bit | 7: LED3 Statu<br>Name | Description | | | The setting of this bit will not effect the polarity of the LEDOUT bit for this register. | | | | BCR7 determines which function(s) activate the LED3 pin. The pin will indicate the logical OR of the enabled functions. BCR7 defaults to Transmit Status (XMT) with pulse stretcher enabled (PSE = 1). Note that bits 15–0 in this register are programmable through the external EEPROM. Reserved bits and read-only bits should be programmed to ZERO. | 13 | LEDDIS | Read/Write accessible always. LEDPOL is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. LED Disable. This bit is used to disable the LED output. When LEDDIS is set to ONE and LED- POL is cleared to ZERO, the LED output pin will be floating. When LEDDIS is set to ONE and LED- POL is set to ONE, the LED out- put pin will be driven LOW. When | | 31–1 | 6RES | Reserved locations. Written as ZEROs and read as undefined. | | | LEDDIS has the value ZERO, the LED output value will be governed by the LEDOUT and LED- | | 15 | LEDOUT | This bit indicates the current (non-stretched) value of the LED output pin. A value of ONE in this bit indicates that the OR of the enabled signals is true. | | | POL values. Read/Write accessible always. LEDDIS is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | | The logical value of the LEDOUT status signal is determined by the | 12– | 10RES | Reserved locations. Written as ZEROs and read as undefined. | | | | settings of the individual Status Enable bits of this register (bits 8 and 6–0). Read accessible always. This bit is read only. Writes have no effect. LEDOUT is unaffected by H_RESET, S_RESET or by set- | 9 | MPSE | Magic Packet Status Enable. When this bit is set to ONE, a value of ONE is passed to the LED-OUT bit in this register when magic packet mode is enabled and a magic packet is detected on the network. | | 14 | LEDPOL | ting the STOP bit. LED Polarity. When this bit has the value ZERO, the LED pin will be asserted LOW whenever the OR of the enabled signals is true, and the LED pin will be disabled and allowed to float whenever the OR of the enabled signals is false. (The LED output will be an | 8 | FDLSE | Read/Write accessible always. MPSE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. Full-duplex Link Status Enable. Indicates the full-duplex Link Test Status. When this bit is set to ONE, a value of ONE is passed | | | to the LEDOUT signal when the PCnet-PCI II controller is functioning in a Link Pass state and full-duplex operation is enabled. When the PCnet-PCI II controller is not functioning in a Link Pass state with full-duplex operation being enabled, a value of ZERO is passed to the LEDOUT signal. | 5 | RCVME | and is not affected by S_RESET or by setting the STOP bit. Receive Match Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when the there is receive activity on the network that has passed the address match function for this | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | When the 10BASE-T port is active, a value of ONE is passed to the LEDOUT signal whenever the Link Test Function detects a Link | | | node. All address matching modes are included: physical, logical filtering, broadcast and promiscuous. | | | Pass state and the FDEN (BCR9, bit 0) bit is set. When the AUI port is active, a value of ONE is passed to the LEDOUT signal whenever full-duplex operation | | | Read/Write accessible always. RCVME is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | on the AUI port is enabled (both FDEN and AUIFD bits in BCR9 are set to ONE). | 4 | XMTE | Transmit Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is | | | Read/Write accessible always. FDLSE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | transmit activity on the network. Read/Write accessible always. XMTE is set to ONE by H_RESET and is not affected by | | 7 PSE | Pulse Stretcher Enable. When this bit is set to ONE, the LED illumination time is extended so | | | S_RESET or by setting the STOP bit. | | | that brief occurrences of the en-<br>abled function will be seen on this<br>LED output. A value of ZERO dis-<br>ables the pulse stretcher. | 3 | RXPOLE | Receive Polarity Status Enable. When this bit is set to ONE, a value of ONE is passed to the LED-OUT bit in this register when the polarity of the RXD± pair is not re- | | | Read/Write accessible always. PSE is set to ONE by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | versed. Receive polarity indication is valid only if the T-MAU is in link pass state. | | 6 LNKSTE | Link Status Enable. When this bit is set to ONE, a value of ONE will be passed to the LEDOUT bit in this register when the T-MAU operating in half-duplex mode is in | | | Read/Write accessible always. RXPOLE is cleared by H_RESET and is not affected by S_RESET or by setting the STOP bit. | | | Link Pass state. When the T-MAU operating in half-duplex mode is in Link Fail state, a value of ZERO is passed to the LED-OUT bit. | 2 | RCVE | Receive Status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when there is receive activity on the network. | | | The function of this bit is masked if the 10BASE-T port is operating in full-duplex mode. This allows a system to have separate LEDs | | | Read/Write accessible always.<br>RCVE is cleared by H_RESET<br>and is not affected by S_RESET<br>or by setting the STOP bit. | | | for half-duplex Link Status and for full-duplex Link Status. Read/Write accessible always. LNKSTE is cleared by H_RESET | 1 | JABE | Jabber status Enable. When this bit is set to ONE, a value of ONE is passed to the LEDOUT bit in this register when the PCnet-PCI | Il controller is jabbering on the Read/Write accessible always. network. FDRPAD is cleared by H RESET and is not affected by S\_RESET Read/Write accessible always. or by setting the STOP bit. JABE is cleared by H\_RESET and is not affected by S RESET 1 **AUIFD** AUI full-duplex. AUIFD enables or by setting the STOP bit. full-duplex operation on the AUI port. AUIFD is only meaningful if COLE 0 Collision status Enable. When FDEN (BCR9, bit 0) is set to this bit is set to ONE, a value of ONE. If the FDEN bit is ZERO, ONE is passed to the LEDOUT the AUI port will always operate bit in this register when there is in half-duplex mode. If FDEN is collision activity on the network. set to ONE and AUIFD is set to The activity on the collision inputs ONE, full-duplex operation on the to the AUI port within the first 4 µs AUI port is enabled. However, if after every transmission for the FDEN is set to ONE but the purpose of SQE testing will not AUIFD bit is cleared to ZERO. the cause the LEDOUT bit to be set. AUI port will always operate in Read/Write accessible always. half-duplex mode. COLE is cleared by H RESET Read/Write accessible always. and is not affected by S\_RESET AUIFD is cleared by H RESET or by setting the STOP bit. and is not affected by S\_RESET **BCR9: Full-Duplex Control** or by setting the STOP bit. Bit Name Description Full-duplex Enable. FDEN en-0 **FDEN** full-duplex ables operation. When FDEN is set to ONE, the Note that bits 15-0 in this register PCnet-PCI II controller will operare programmable through the ate in full-duplex mode when eiexternal EEPROM. Reserved bits ther the 10BASE-T port is and read-only bits should be proenabled. To enable full-duplex grammed to ZERO. operation on the AUI port, the 31-16RES Reserved locations. Written as AUIFD bit (BCR9, bit1) must be ZEROs and read as undefined. set to ONE in addition to setting 15-3 RES Reserved locations. Written as FDEN to ONE. When the ZEROs and read as undefined. DLNKTST bit (CSR15, bit 12) is set to ONE, the 10BASE-T port 2 **FDRPAD** Full-Duplex Runt Packet Accept will operate in half-duplex mode Disable. When FDRPAD is set to regardless of the setting of ONE and full-duplex mode is en-FDEN. abled, the PCnet-PCI II controller will only receive frames that meet Effect on the **FDEN** Effect on the the minimum Ethernet frame AUIFD (bit 1) 10BASE-T (bit 0) **AUI Port** length of 64 bytes. Receive DMA **Port** will not start until at least 64 bytes Х 0 Half-Duplex Half-Duplex or a complete frame have been received. By default, FDRPAD is 0 1 Half-Duplex Full-Duplex cleared to ZERO. The PCnet-PCI 1 Full-Duplex Full-Duplex Il controller will accept any length frame and receive DMA will start Read/Write accessible always. according to the programming of FDEN is cleared by H RESET the receive FIFO watermark. and is not affected by S\_RESET Note that there should not be any or by setting the STOP bit. runt packets in a full-duplex net-BCR16: I/O Base Address Lower work, since the main cause for Bit Name Description runt packets is a network collision and there are no collisions in a full-duplex network. | 31-16RES | Reserved locations. Written as | | data on the ERD[7:0] inputs. The | |-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–5 IOBASEL | ZEROs and read as undefined. Reserved locations. After H_RESET, the value of these bits will be undefined. The settings of these bits will have no effect on | | register value specifies the time in number of clock cycles. A ROMTMG value of ZERO results in the same timing as a ROMT-MG value of ONE. | | | any PCnet-PCI II controller function. It is only included for software compatibility with other PCnet family devices. | | The access time for the Expansion ROM device (tACC) can be calculated by subtracting the clock to output delay for the | | | Read/Write accessible always. IOBASEL is not affected by S_RESET or by setting the STOP bit. | | ERA[7:0] outputs (tVAL(ERA)) and the input to clock setup time for the ERD[7:0] inputs (tSU(ERD)) from the time defined by ROMTMG: | | 4–0 RES | Reserved locations. Written as ZEROs, read as undefined. | | t <sub>ACC</sub> £ ROMTMG * clock period –<br>t <sub>VAL</sub> (ERA) – t <sub>SU</sub> (ERD) | | BCR17: I/O Base | Address Upper | | For an adapter card application, | | Bit Name | Description | | the value used for clock period should be 30 ns to guarantee cor- | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | rect interface timing at the maximum clock frequency of 33 MHz. | | 15-0 IOBASEU | Reserved locations. After H_RESET, the value in this register will be undefined. The setting of this register has no effect on any PCnet-PCI II controller function. It is only included for software compatibility with other PCnet family devices. | | Read accessible always. Write accessible only when either the STOP or the SPND bit is set. ROMTMG is set to the value of 1001b by H_RESET and is not affected by S_RESET or by setting the STOP bit. The default value allows using an Expansion ROM with an access time of 250 | | | Read/Write accessible always. IOBASEU is not affected by S_RESET or by setting the STOP | 11–10RES | ns in a system with a maximum clock frequency of 33 MHz. Reserved locations. Written as | | BCR18: Burst an | bit.<br>ad Bus Control Register | | ZEROs and read as undefined. | | Bit Name | Description | 9 MEMCMD | Memory Command. This bit determines the command code | | | Note that bits 15–0 in this register are programmable through the external EEPROM. Reserved bits and read-only bits should be programmed to ZERO. | | used for burst read accesses to<br>transmit buffers. When MEMC-<br>MD is cleared to ZERO, all burst<br>read accesses to transmit buffers<br>are of the PCI command type<br>Memory Read Line (type 14). | | 31–16RES | Reserved locations. Written as ZEROs and read as undefined. | | When MEMCMD is set to ONE, all burst read accesses to transmit buffers are of the PCI com- | | 15-12 ROMTMG | Expansion ROM Timing. The value of ROMTMG is used to tune the timing of the Expansion ROM interface. ROMTMG defines the time from when the PCnet-PCI II controller drives ERA[7:0] with the lower 8-bits of the Expansion ROM address to when the PCnet-PCI II controller latches in the | | mand type Memory Read Multiple (type 12). Read accessible always. Write accessible only when either the STOP or the SPND bit is set. MEMCMD is cleared by H_RESET and is not affected by S_RESET or by setting the STOP | 8 EXTREQ Extended Request. This bit controls the deassertion of REQ for a burst transaction. If EXTREQ is cleared to ZERO. REQ is deasserted at the beginning of a burst transaction. (The PCnetPCI II controller never performs more than one burst transaction within a single bus mastership period.) In this mode, the PCnetPCI II controller relies on the PCI Latency Timer to get enough bus bandwidth, in case the system arbiter also removes GNT at the beginning of the burst transaction. If EXTREQ is set to ONE, REQ stays asserted until the next to last data phase of the burst transaction is done. This mode is useful for systems that implement an arbitration scheme without preemption and require that REQ stays asserted throughout the transaction. EXTREQ should not be set to ONE when the PCnet-PCI II controller is used in a PCI bus application. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. EXTREQ is cleared by H\_RESET and or S\_RESET and is not affected by setting the STOP bit. 7 DWIO Double Word I/O. When set, this bit indicates that the PCnet-PCI II controller is programmed for DWord I/O (DWIO) mode. When cleared, this bit indicates that the PCnet-PCI II controller is programmed for Word I/O (WIO) mode. This bit affects the I/O Resource Offset map and it affects the defined width of the PCnet-PCI II controller's I/O resources. See the sections "Word I/O Mode" and "Double Word I/O Mode" for more details. Read accessible always. DWIO is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 6 BREADE Burst Read Enable. When set, this bit enables burst mode during memory read accesses. The PCnet-PCI II controller can perform burst transfers when reading the initialization block, the descriptor ring entries (when SW-STYLE is set to Three), and the buffer memory. When cleared, this bit prevents the device from bursting during read accesses. BREADE should be set to ONE when the PCnet-PCI II controller is used in a PC bus application to guarantee maximum performance. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. BREADE is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 5 BWRITE Burst Write Enable. When set, this bit enables burst mode during memory write accesses. The PCnet-PCI II controller can perform burst transfers when writing the descriptor ring entries (when SWSTYLE is set to Three) and the buffer memory. When cleared, this bit prevents the device from bursting during write accesses. BWRITE should be set to ONE when the PCnet-PCI II controller is used in a PCI bus application to guarantee maximum performance. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. BWRITE is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 4-3 TSTSHDW Reserved locations. Written and read as ZEROs. 2-0 RES Reserved locations. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. After H\_RESET, the value in these bits will be 001b. The setting of these bits has no effect on any PCnet-PCI II controller function. LINBC is not affected by S\_RESET or by setting the STOP bit. 150 ### **BCR19: EEPROM Control and Status** ### Bit Name Description 31-16 RES Reserved locations. Written as ZEROs and read as undefined. 15 PVALID EEPROM Valid status bit. A value of ONE in this bit indicates that a PREAD operation has occurred, and that (1) there is an EEPROM connected to the PC-net-PCI II controller Microwire interface pins and (2) the contents read from the EEPROM have passed the checksum verification operation. A value of ZERO in this bit indicates that the checksum for the entire 36 bytes of EE-PROM is incorrect or that no EEPROM is connected to the Microwire interface pins. If PVALID becomes ZERO following an EEPROM read operation (either automatically generated after H\_RESET, or requested through PREAD), then all EEPROM-programmable BCR locations will be reset to their H\_RESET values. The contents of the Address PROM locations, however, will not be cleared. If the EEPROM detection fails, then all attempted PREAD commands will terminate early and PVALID will not be set. This applies to the automatic read of the EEPROM after H\_RESET as well as to host-initiated PREAD commands. Read accessible only. PVALID is read only. Write operations have no effect. PVALID is cleared to ZERO during H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 14 PREAD EEPROM Read command bit. When this bit is set to ONE by the host, the PVALID bit (BCR19, bit 15) will immediately be cleared to ZERO and then the PCnet-PCI II controller will perform a read operation of 36 bytes from the EE-PROM through the Microwire interface. The EEPROM data that is fetched during the read will be stored in the appropriate internal registers on board the PCnet-PCI II controller. EEPROM contents will be indirectly accessible to the host through read accesses to the Address PROM (offsets 0h through Fh) and through read accesses to the EEPROM-programmable BCRs. Note that read accesses from these locations will not actually access the EE-PROM itself, but instead will access the PCnet-PCI II controller's internal copy of the EEPROM contents. Write accesses to these locations may change the PCnet-PCI II controller register contents, but the EEPROM locations will not be affected. EE-PROM locations may also be accessed directly by programming bits 4-0 of this register. At the end of the read operation, the PREAD bit will automatically be cleared to ZERO by the PC-net-PCI II controller and PVALID will be set, provided that an EE-PROM existed on the Microwire interface pins and that the check-sum for the entire 36 bytes of EE-PROM was correct. Note that when PREAD is set to ONE, the PCnet-PCI II controller will no longer respond to any accesses directed toward it, until the PREAD operation has completed successfully. The PCnet-PCI II controller will terminate these accesses with the assertion of DEVSEL and STOP while TRDY is not asserted, signaling to the initiator to disconnect and retry the access at a later time. If a PREAD command is given to the PCnet-PCI II controller but no EEPROM is detected at the Microwire interface pins, the PREAD command will terminate early, the PREAD bit will be cleared to ZERO, the PVALID bit will remain ZERO, and all EE-PROM-programmable BCR locations will be reset to their H\_RESET values. The contents of the Address PROM locations, however, will not be cleared. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. PREAD is cleared to ZERO during H\_RESET and is unaffected by S\_RESET or by setting the STOP bit. 13 EEDET EEPROM Detect. This bit indicates the sampled value of the EESK/LED1/SFBD pin at the rising edge of CLK during the last clock during which RST is asserted. This value indicates whether or not an EEPROM has been detected at the EEPROM interface. If this bit is a ONE, it indicates that an EEPROM has been detected. If this bit is a ZERO, it indicates that an EEPROM has not been detected. Read accessible always. EEDET is read only. Write operations have no effect. It is unaffected by S\_RESET or by setting the STOP bit. The following table indicates the possible combinations of EEDET and the existence of an EEPROM and the resulting operations that are possible on the EEPROM Microwire interface: Table 31. EEDET Setting | | | | | | _ | | | | |-------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | EEDE<br>Value<br>(BCR19 | е | EEPROM<br>Connected? | Result if PREAD is | Set to O | NE | Result of Automatic EEPROM Read<br>Operation Following H_RESET | | | | 0 | | No | EEPROM read operation i<br>Entire read sequence will<br>failure will result, PVALID<br>ZERO. | occur, ch | ecksum | First TWO EESK clock cycles are generated, then EEPROM read operation is aborted and PVALID is cleared to ZERO. | | | | 0 | | Yes | EEPROM read operation i<br>Entire read sequence will<br>operation will pass, PVALI | occur, ch | ecksum | First TWO EESK clock cycles are generated, then EEPROM read operation is aborted and PVALID is cleared to ZERO. | | | | 1 | | No | EEPROM read operation i<br>Entire read sequence will<br>failure will result, PVALID<br>ZERO. | occur, ch | ecksum | EEPROM read operation is attempted. Entire read sequence will occur, checksum failure will result, PVALID is cleared to ZERO. | | | | 1 | | Yes | EEPROM read operation i<br>Entire read sequence will<br>operation will pass, PVALI | occur, ch | ecksum | EEPROM read operation is attempted.<br>Entire read sequence will occur, checksum<br>operation will pass, PVALID is set to ONE. | | | | 12–5 RE | ΞS | | locations. Written as ad as undefined. | | | S_RESET or by setting the STOP bit. | | | | 4 EE | ΞN | bit is set to values of I be driven of and EEDI EEN is cleated active to LEDI are trolled by spectively. Read accessible STOP or EEN is of I served. | port enable. When this to ONE, it causes the ECS, ESK, and EDI to onto the EECS, EESK, pins, respectively. If eared to ZERO and no read function is curve, then EECS will be W and the EESK and change their function and LNKST and are con-BCR5 and BCR4, resessible always. Write only when either the the SPND bit is set. Cleared to ZERO by and is unaffected by | 2 | ECS | Reserved location. Written as ZERO and read as undefined. EEPROM Chip Select. This bit is used to control the value of the EECS pin of the Microwire interface when the EEN bit is set to ONE and the PREAD bit is cleared to ZERO. If EEN is set to ONE and PREAD is cleared to ZERO and ECS is set to ONE, then the EECS pin will be forced to a HIGH level at the rising edge of the next clock following bit programming. If EEN is set to ONE and PREAD is cleared to ZERO and ECS is cleared to ZERO and ECS is cleared to ZERO, then the EECS pin will be forced to a LOW level at the rising edge | | | of the next clock following bit programming. ECS has no effect on the output value of the EECS pin unless the PREAD bit is cleared to ZERO and the EEN bit is set to ONE. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. ECS is cleared to ZERO by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 1 ESK EEPROM Serial Clock. This bit and the EDI/EDO bit are used to control host access to the EE-PROM. Values programmed to this bit are placed on to the EESK pin at the rising edge of the next clock following bit programming, except when the PREAD bit is set to ONE or the EEN bit is cleared to ZERO. If both the ESK bit and the EDI/EDO bit values are changed during one BCR19 write operation while EEN is set to ONE, then setup and hold times of the EEDI pin value with respect to the EESK signal edge are not quaranteed. ESK has no effect on the EESK pin unless the PREAD bit is cleared to ZERO and the EEN bit is set to ONE. Table 32. Microwire Interface Pin Assignment | RST Pin | PREAD or Auto<br>Read in Progress | EEN | EEN EECS | | EEDI | |---------|-----------------------------------|-----|----------|-----------|--------------| | High | Х | Х | Low | Tri-State | Tri-State | | Low | 1 | Х | Active | Active | Active | | Low | 0 | 1 | BCR19[2] | BCR19[1] | BCR19[0] | | Low | 0 | 0 | Low | LED1 | <u>LNKST</u> | 10 Read accessible always. Write accessible only when either the STOP or the SPND bit is set. ESK is set to ONE by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. 0 EDI/EDO EEPROM Data In/EEPROM Data Out. Data that is written to this bit will appear on the EEDI output of the Microwire interface, except when the PREAD bit is set to ONE or the EEN bit is cleared to ZERO. Data that is read from this bit reflects the value of the EEDO input of the Microwire interface. EDI/EDO has no effect on the EEDI pin unless the PREAD bit is cleared to ZERO and the EEN bit is set to ONE. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. EDI/EDO is cleared to ZERO by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. **BCR20: Software Style** **APERREN** Bit Name Description This register is an alias of the location CSR58. Accesses to/from this register are equivalent to accesses to CSR58. 31–16RES Reserved locations. Written as ZEROs and read as undefined. 15–11RES Reserved locations. Written as ZEROs and read as undefined. Advanced Parity Error Handling Enable. When APERREN is set to ONE, the BPE bits (RMD1 and TMD1, bit 23) are used to indicated parity error in data transfers to the receive and transmit buffers. Note that since the advanced parity error handling uses an additional bit in the descriptor, SW-STYLE (bits 7–0 of this register) must be set to ONE, TWO or THREE to program the PC-net-PCI II controller to use 32-bit software structures. APERREN does not affect the reporting of address parity errors or data parity errors that occur when the PCnet-PCI II controller is the target of the transfer. Read accessible always, write accessible only when either the STOP or the SPND bit is set. APERREN is cleared by H\_RESET and is not affected by S\_RESET or by setting the STOP bit. ### 9 CSRPCNET CSR PCnet-ISA configuration. When set, this bit indicates that the PCnet-PCI II controller register bits of CSR4 and CSR3 will map directly to the CSR4 and CSR3 bits of the PCnet-ISA (Am79C960) device. When cleared, this bit indicates that PCnet-PCI II controller register bits of CSR4 and CSR3 will map directly to the CSR4 and CSR3 bits of the ILACC (Am79C900) device. The value of CSRPCNET is determined by the PCnet-PCI II controller according to the setting of the Software Style (SWSTYLE, bits 7–0 of this register). Read accessible always. CSR-PCNET is read only. Write operations will be ignored. CSRPCNET will be set after H\_RESET (since SWSTYLE defaults to ZERO) and is not affected by S\_RESET or by setting the STOP bit. ### 8 SSIZE32 32-Bit Software Size. When set, this bit indicates that the PC-net-PCI II controller utilizes 32-bit software structures for the initialization block and the transmit and receive descriptor entries. When cleared, this bit indicates that the PCnet-PCI II controller utilizes 16-bit software structures for the initialization block and the transmit and receive descriptor entries. In this mode the PCnet-PCI II controller is backwards compatible with the Am79C90 C-LANCE and Am79C960 PCnet-ISA. The value of SSIZE32 is determined by the PCnet-PCI II controller according to the setting of the Software Style (SWSTYLE, bits 7–0 of this register). Read accessible always. SSIZE32 is read only. Write operations will be ignored. SSIZE32 will be cleared after H\_RESET (since SWSTYLE defaults to ZERO) and is not affected by S\_RESET or by setting the STOP bit. If SSIZE32 is cleared to ZERO, then bits IADR[31:24] of CSR2 will be used to generate values for the upper 8 bits of the 32 bit address bus during master accesses initiated by the PCnet-PCI II controller. This action is required, since the 16-bit software structures will yield only 24 bits of address for PCnet-PCI II controller bus master accesses. If SSIZE32 is set to ONE, then the software structures that are common to the PCnet-PCI II controller and the host system will supply a full 32 bits for each address pointer that is needed by the PCnet-PCI II controller for performing master accesses. The value of the SSIZE32 bit has no effect on the drive of the upper 8 address bits. The upper 8 address pins are always driven, regardless of the state of the SSIZE32 bit. Note that the setting of the SSIZE32 bit has no effect on the width for I/O accesses. I/O access width is determined by the state of the DWIO bit (BCR18, bit 7). ### 7–0 SWSTYLE Software Style register. The value in this register determines the style of register and memory resources that shall be used by the PCnet-PCI II controller. The Software Style selection will affect the interpretation of a few bits within the CSR space, the order of the descriptor entries and the width of the descriptors and initialization block entries. All PCnet-PCI II controller CSR bits and BCR bits and all descriptor, buffer and initialization block entries not cited in the table be- low are unaffected by the software style selection. **Table 33. Software Styles** | SWSTYLE<br>[7:0] | Style Name | CSRPCNET | SSIZE32 | Initialization Block<br>Entries | Descriptor Ring<br>Entries | Altered Bit<br>Interpretations | |------------------|----------------------------|-----------|-----------|-------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------| | 00h | C-LANCE<br>/<br>PCnet-ISA | 1 | 0 | 16-bit software<br>structures, non-burst<br>or burst access | 16-bit software<br>structures, non-burst<br>access only | All bits in CSR4 are<br>used, TMD1[29] is<br>ADD_FCS | | 01h | ILACC | 0 | 1 | 32-bit software<br>structures, non-burst<br>or burst access | 32-bit software<br>structures, non-burst<br>access only | CSR4[9:8], CSR4[5:4]<br>and CSR4[1:0] have<br>no function, TMD1[29]<br>is NO_FCS. | | 02h | PCnet-PCI | 1 | 1 | 32-bit software<br>structures, non-burst<br>or burst access | 32-bit software<br>structures, non-burst<br>access only | All bits in CSR4 are<br>used, TMD1[29] is<br>ADD_FCS | | 03h | PCnet-PCI II<br>Controller | 1 | 1 | 32-bit software<br>structures, non-burst<br>or burst access | 32-bit software<br>structures, non-burst<br>or burst access | All bits in CSR4 are<br>used, TMD1[29] is<br>ADD_FCS | | All Other | Undefined | Undefined | Undefined | Undefined | Undefined | Undefined | Read/Write accessible only when either the STOP or the SPND bit is set. The SWSTYLE register will contain the value 00h following H\_RESET and will be unaffected by S\_RESET or by setting the STOP bit. **BCR21: Interrupt Control** | BCR21: Interrupt Control | | | | | | | | |--------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Bit Nam | e Desc | ription | | | | | | | 31–16RES | | ved locations. Written as and read as undefined. | | | | | | | 15-0 INTCC | of this<br>any P<br>tion. I<br>ware | ved locations. The setting<br>register has no effect on<br>Cnet-PCI II controller func-<br>t is only included for soft-<br>compatibility with other<br>family devices. | | | | | | | | INTC | Write accessible always. ON is not affected by SET or by setting the STOP | | | | | | BCR22: PCI Latency Register Bit Name Description | Note | e that bits 15–0 i | n this regi | ister | |------|--------------------|-------------|-------| | are | programmable | through | the | | exte | ernal EEPROM. | | | 31–16RES Reserved locations. Written as ZEROs and read as undefined. 15-8 MAX\_LAT Maximum Latency. Specifies the maximum arbitration latency the PCnet-PCI II controller can sustain without causing problems to the network activity. The register value specifies the time in units of 1/4 microseconds. MAX\_LAT is aliased to the PCI configuration space register MAX\_LAT (offset 3Fh). The host should use the value in this register to determine the setting of the PCI Latency Timer register. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. MAX\_LAT is set to the value of FFh by H\_RESET which corresponds to a maximum latency of 63.75 microseconds. The actual maximum latency the PCnet-PCI II controller can handle is 153.6 µs which is also the value for the bus time-out (see CSR100). MAX\_LAT is not affected by S\_RESET or by setting the STOP bit. 7-0 MIN\_GNT Minimum Grant. Specifies the minimum length of a burst period the PCnet-PCI II controller needs to keep up with the network activity. The length of the burst period is calculated assuming a clock rate of 33 MHz. The register value specifies the time in units of 1/4 microseconds. MIN\_GNT is aliased to the PCI configuration space register MIN\_GNT (offset 3Eh). The host should use the value in this register to determine the setting of the PCI Latency Timer register. Read accessible always. Write accessible only when either the STOP or the SPND bit is set. MIN\_GNT is set to the value of 06h by H RESET which corre- sponds to a minimum grant of 1.5 microseconds. 1.5 microseconds is the time it takes to PCnet-PCI II controller to read/write 64 bytes. (16 DWord transfers in burst mode with one extra wait state per data phase inserted by the target.) Note that the default is only a typical value. It also does not take into account any descriptor accesses. MIN\_GNT is not affected by S\_RESET or by setting the STOP bit. ### Initialization Block When SSIZE32 (BCR20, bit 8) is set to ZERO, the software structures are defined to be 16 bits wide. The base address of the initialization block must be aligned to a DWord boundary, i.e. CSR1, bit 1 and 0 must be cleared to ZERO. When SSIZE32 is set to ZERO, the initialization block looks like this: Table 34. Initialization Block (SSIZE32 = 0) | Address | Bits 15-13 | Bit 12 | Bits 11-8 | Bits 7-4 | Bits 3-0 | | | | | |----------|------------|------------|-------------|----------|----------|--|--|--|--| | IADR+00h | MODE 15-00 | | | | | | | | | | IADR+02h | | PADR 15-00 | | | | | | | | | IADR+04h | | | PADR 31-16 | | | | | | | | IADR+06h | | | PADR 47-32 | | | | | | | | IADR+08h | | | LADRF 15-00 | | | | | | | | IADR+0Ah | | | LADRF 31-16 | | | | | | | | IADR+0Ch | | | LADRF 47-32 | | | | | | | | IADR+0Eh | | | LADRF 63-48 | | | | | | | | IADR+10h | | | RDRA 15-00 | | | | | | | | IADR+12h | RLEN | 0 | RES | RDRA | 23–16 | | | | | | IADR+14h | | TDRA 15-00 | | | | | | | | | IADR+16h | TLEN | 0 | RES | TDRA | 23–16 | | | | | Table 35. Initialization Block (SSIZE32 = 1) | Address | Bits<br>31–28 | Bits<br>27–24 | Bits<br>23–20 | Bits<br>19–16 | Bits<br>15–12 | Bits<br>11–8 | Bits<br>7–4 | Bits<br>3–0 | |----------|---------------|---------------|---------------|---------------|---------------|--------------|-------------|-------------| | IADR+00h | TLEN | RES | RLEN | RES | | MC | DE | | | IADR+04h | | | | PADR | 31–00 | | | | | IADR+08h | | RI | S | | PADR 47–32 | | | | | IADR+0Ch | | | | LADR | 31–00 | | | | | IADR+10h | | LADR 63–32 | | | | | | | | IADR+14h | RDRA 31–00 | | | | | | | | | IADR+18h | | TDRA 31-00 | | | | | | | Note that the PCnet-PCI II controller performs DWord accesses to read the initialization block. This statement is always true, regardless of the setting of the SSIZE32 bit. When SSIZE32 (BCR20, bit 8) is set to ONE, the software structures are defined to be 32 bits wide. The base address of the initialization block must be aligned to a DWord boundary, i.e. CSR1, bits 1 and 0 must be cleared to ZERO. When SSIZE32 is set to ONE, the initialization block looks as shown in Table 35. ### **RLEN AND TLEN** When SSIZE32 (BCR20, bit 8) is set to ZERO, the software structures are defined to be 16 bits wide, and the RLEN and TLEN fields in the initialization block are each 3 bits wide. The values in these fields determine the number of transmit and receive Descriptor Ring Entries (DRE) which are used in the descriptor rings. Their meaning is as follows: Table 36. R/TLEN Decoding (SSIZE32 = 0) | R/TLEN | No. of DREs | |--------|-------------| | 000 | 1 | | 001 | 2 | | 010 | 4 | | 011 | 8 | | 100 | 16 | | 101 | 32 | | 110 | 64 | | 111 | 128 | If a value other than those listed in the above table is desired, CSR76 and CSR78 can be written after initialization is complete. When SSIZE32 (BCR20, bit 8) is set to ONE, the software structures are defined to be 32 bits wide, and the RLEN and TLEN fields in the initialization block are each 4 bits wide. The values in these fields determine the number of transmit and receive Descriptor Ring Entries (DRE) which are used in the descriptor rings. Their meaning is as follows: Table 37. R/TLEN Decoding (SSIZE32 = 1) | R/TLEN | No. of DREs | |--------|-------------| | 0000 | 1 | | 0001 | 2 | | 0010 | 4 | | 0011 | 8 | | 0100 | 16 | | 0101 | 32 | | 0110 | 64 | | 0111 | 128 | | 1000 | 256 | | 1001 | 512 | | 11XX | 512 | | 1X1X | 512 | If a value other than those listed in the above table is desired, CSR76 and CSR78 can be written after initialization is complete. #### **RDRA** and **TDRA** TDRA and RDRA indicate where the transmit and receive descriptor rings begin. Each DRE must be located at a 16-byte address boundary when SSIZE32 is set to ONE (BCR20, bit 8). Each DRE must be located at an 8-byte address boundary when SSIZE32 is set to ZERO (BCR20, bit 8). #### **LADRF** The Logical Address Filter (LADRF) is a 64-bit mask that is used to accept incoming Logical Addresses. If the first bit in the incoming address (as transmitted on the wire) is a ONE, it indicates a logical address. If the first bit is a ZERO, it is a physical address and is compared against the physical address that was loaded through the initialization block. 19436C-47 Figure 44. Address Match Logic A logical address is passed through the CRC generator, producing a 32 bit result. The high order 6 bits of the CRC is used to select one of the 64 bit positions in the Logical Address Filter. If the selected filter bit is set, the address is accepted and the frame is placed into memory. The Logical Address Filter is used in multicast addressing schemes. The acceptance of the incoming frame based on the filter value indicates that the message may be intended for the node. It is the node's responsibility to determine if the message is actually intended for the node by comparing the destination address of the stored message with a list of acceptable logical addresses. If the Logical Address Filter is loaded with all ZEROs and promiscuous mode is disabled, all incoming logical addresses except broadcast will be rejected. ### **PADR** This 48-bit value represents the unique node address assigned by the ISO 8802-3 (IEEE/ANSI 802.3) and used for internal address comparison. PADR[0] is compared with the first bit in the destination address of the incoming frame. It must be ZERO since only the destination address of a unicast frames is compared to PADR. The six hex-digit nomenclature used by the ISO 8802-3 (IEEE/ANSI 802.3) maps to the PCnet-PCI II controller PADR register as follows: the first byte is compared with PADR[7:0], with PADR[0] being the least significant bit of the byte. The second ISO 8802-3 (IEEE/ANSI 802.3) byte is compared with PADR[15:8], again from the least significant bit to the most significant bit, and so on. The sixth byte is compared with PADR[47:40], the least significant bit being PADR[40]. #### **MODE** The mode register field of the initialization block is copied into CSR15 and interpreted according to the description of CSR15. ### **Receive Descriptors** When SWSTYLE (BCR20, bits 7–0) is set to ZERO, then the software structures are defined to be 16 bits wide, and receive descriptors, (CRDA = Current Receive Descriptor Address), are as shown in Table 38. When SWSTYLE (BCR 20, bits 7–0) is set to ONE or TWO, then the software structures are defined to be 32 bits wide, and receive descriptors, (CRDA = Current Receive Descriptor Address), are as shown in Table 39. When SWSTYLE (BCR 20, bits 7–0) is set to THREE, then the software structures are defined to be 32 bits wide, and receive descriptors, (CRDA = Current Receive Descriptor Address), are as shown in Table 40. | Address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7–0 | |----------|-------------|-----|------|------|------|------|-----|-----|--------------| | CRDA+00h | RBADR[15:0] | | | | | | | | | | CRDA+02h | OWN | ERR | FRAM | OFLO | CRC | BUFF | STP | ENP | RBADR[23:16] | | CRDA+04h | 1 | 1 | 1 | 1 | BCNT | | | | | | CRDA+06h | 0 | 0 | 0 | 0 | MCNT | | | | | Table 38. Receive Descriptor (SWSTYLE = 0) ### Table 39. Receive Descriptor (SWSTYLE = 1,2) | Address | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19–16 | 15–12 | 11–0 | |--------------|---------------|-----|------|------|-----|------|-----|--------|-----|-----|------|-----|-------|-------|------| | CRDA+00h | n RBADR[31:0] | | | | | | | | | | | | | | | | CRDA+04h | OW<br>N | ERR | FRAM | OFLO | CRC | BUFF | STP | ENP | BPE | PAM | LAFM | BAM | RES | 1111 | BCNT | | CRDA+08h | | | | R | CC | | | | | | RPC | | | 0000 | MCNT | | CRDA+0C<br>h | | | | | | | | RESER\ | /ED | | | | | | | ### Table 40. Receive Descriptor (SWSTYLE = 3) | Address | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19–16 | 15–12 | 11–0 | |--------------|--------------|----------|------|------|-----|----------|-----|---------|-------|-----|------|-----|-------|-------|------| | CRDA+00h | CRDA+00h RCC | | | | | | | RPC | | | | | 0000 | MCNT | | | CRDA+04h | OWN | ERR | FRAM | OFLO | CRC | BUF<br>F | STP | ENP | BPE | PAM | LAFM | BAM | RES | 1111 | BCNT | | CRDA+08h | | | | | | | F | RBADR[3 | 31:0] | | | | | | | | CRDA+0C<br>h | | RESERVED | | | | | | | | | | | | | | | П | N | л | n | |---|---|---|---| | | | | | | RMD | 0 | | | | non-integer multiple of eight bits | |------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Name | Description | | | in the frame. FRAM is not valid in internal loopback mode. FRAM is | | 31–0 | RBADR | Receive Buffer address. This field contains the address of the receive buffer that is associated | | | valid only when ENP is set and OFLO is not. FRAM is set by the PCnet-PCI II controller and cleared by the host. | | RMD | 14 | with this descriptor. | 28 | OFLO | Overflow error indicates that the receiver has lost all or part of the | | Bit | Name | Description | | | incoming frame, due to an inabili- | | | IVAIIIC | | | | ty to move data from the receive | | 31 | OWN | This bit indicates whether the descriptor entry is owned by the host (OWN = 0) or by the PC-net-PCI II controller (OWN = 1). The PCnet-PCI II controller | | | FIFO into a memory buffer before the internal FIFO overflowed. OFLO is valid only when ENP is not set. OFLO is set by the PC-net-PCI II controller and cleared by the host. | | | | clears the OWN bit after filling the buffer that the descriptor points to. The host sets the OWN bit after emptying the buffer. Once the PCnet-PCI II controller or host has relinquished ownership of a buffer, it must not change any field in the descriptor entry. | 27 | CRC | CRC indicates that the receiver has detected a CRC (FCS) error on the incoming frame. CRC is valid only when ENP is set and OFLO is not. CRC is set by the PCnet-PCI II controller and cleared by the host. | | 30 | ERR | ERR is the OR of FRAM, OFLO, CRC, BUFF or BPE. ERR is set by the PCnet-PCl II controller and cleared by the host. | 26 | BUFF | Buffer error is set any time the PCnet-PCI II controller does not own the next buffer while data chaining a received frame. This can occur in either of two ways: | | 29 | 9 FRAM | Framing error indicates that the incoming frame contains a non-integer multiple of eight bits | | | The OWN bit of the next buffer is ZERO. | | | | and there was an FCS error. If<br>there was no FCS error on the in-<br>coming frame, then FRAM will<br>not be set even if there was a | | | <ol> <li>FIFO overflow occurred be-<br/>fore the PCnet-PCI II control-<br/>ler was able to read the OWN<br/>bit of the next descriptor.</li> </ol> | nally in the FIFO, but will not be PAM is valid only when ENP is reported in the descriptor status set. PAM is set by the PCnet-PCI entry unless both BUFF and Il controller and cleared by the OFLO errors occur at the same host. time. BUFF is set by the PC-This bit does not exist when the net-PCI II controller and cleared PCnet-PCI II controller is proby the host. grammed to use 16-bit software 25 **STP** structures for the descriptor ring Start of Packet indicates that this is the first buffer used by the PCentries (BCR20, bits 7-0, SWnet-PCI II controller for this STYLE is cleared to ZERO). frame. If STP and ENP are both LAFM 21 Logical Address Filter Match is set to ONE, the frame fits into a set by the PCnet-PCI II controller single buffer. Otherwise, the when it accepts the received frame is spread over more than frame based on the value in the one buffer. When LAPPEN logical address filter register. (CSR3, bit 5) is cleared to ZERO. LAFM is valid only when ENP is STP is set by the PCnet-PCI II set. LAFM is set by the PCcontroller and cleared by the net-PCI II controller and cleared host. When LAPPEN is set to by the host. ONE, STP must be set by the Note that if DRCVBC (CSR15, bit host. 14) is cleared to ZERO, only 24 **ENP** End of Packet indicates that this BAM, but not LAFM will be set is the last buffer used by the PCwhen a Broadcast frame is renet-PCI II controller for this ceived, even if the Logical Adframe. It is used for data chaining dress Filter is programmed in buffers. If both STP and ENP are such a way that a Broadcast set, the frame fits into one buffer frame would pass the hash filter. and there is no data chaining. If DRCVBC is set to ONE and the ENP is set by the PCnet-PCI II Logical Address Filter is procontroller and cleared by the grammed in such a way that a host. Broadcast frame would pass the **BPE** 23 Bus Parity Error is set by the PChash filter. LAFM will be set on net-PCI II controller when a parity the reception of a Broadcast error occurred on the bus interframe. face during a data transfers to a This bit does not exist when the receive buffer. BPE is valid only PCnet-PCI II controller is prowhen ENP, OFLO or BUFF are grammed to use 16-bit software set. The PCnet-PCI II controller structures for the descriptor ring will only set BPE when the adentries (BCR20, bits 7-0, SWvanced parity error handling is STYLE is cleared to ZERO). enabled by setting APERREN 20 **BAM** Broadcast Address Match is set (BCR20, bit 10) to ONE. BPE is by the PCnet-PCI II controller set the PCnet-PCI II controller when it accepts the received and cleared by the host. frame because the frame's desti-This bit does not exist, when the nation address is of the type PCnet-PCI II controller is pro-"Broadcast". BAM is valid only grammed to use 16-bit software when ENP is set. BAM is set by structures for the descriptor ring the PCnet-PCI II controller and entries (BCR20, bits 7-0, SWcleared by the host. STYLE is cleared to ZERO). This bit does not exist when the 22 PAM Physical Address Match is set by PCnet-PCI II controller is prothe PCnet-PCI II controller when grammed to use 16-bit software it accepts the received frame due If a Buffer Error occurs, an Over- flow Error may also occur inter- tion address with the content of the physical address register. structures for the descriptor ring to a match of the frame's destina- | 19–16<br>15–12 | RES<br>ONES | entries (BCR20, bits 7–0, SW-STYLE is cleared to ZERO). Reserved locations. These locations should be read and written as ZEROs. These four bits must be written as ONEs. They are written by the host and unchanged by the PC-net-PCI II controller. | | runt to pass the internal address matching mechanism is: 18 bits of valid preamble plus a valid SFD detected, followed by 7 bytes of frame data. This requirement is unvarying, regardless of the address matching mechanisms in force at the time of reception. (I.e. physical, logical, broadcast or premiseurous). The | | | |----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 11-00 | BCNT | Buffer Byte Count is the length of the buffer pointed to by this descriptor, expressed as the two's complement of the length of the buffer. This field is written by the host and unchanged by the PC-net-PCI II controller. | 15–12ZEROS | broadcast or promiscuous). The PCnet-PCI II controller implementation of this counter may not be compatible with the ILACC RPC definition. This field is reserved. PCnet-PCI II controller will write ZEROs to | | | | D14D4 | | net-PGI II controller. | | these locations. | | | | RMD2<br>Bit | Name | Description | 11-0 MCNT | Message Byte Count is the length in bytes of the received message, expressed as an un- | | | | 31–24 | IRCC | Receive Collision Count. Indicates the accumulated number of collisions detected on the network since the last packet was received, excluding collisions that occurred during transmissions from this node. The PCnet-PCI II controller implementation of this | RMD3<br>Bit Name | signed binary integer. MCNT is valid only when ERR is clear and ENP is set. MCNT is written by the PCnet-PCI II controller and cleared by the host. Description | | | | | | counter may not be compatible with the ILACC RCC definition. If network statistics are to be monitored, then CSR114 should be used for the purpose of monitoring receive collisions instead of | the software struc | Reserved locations. Criptors (BCR20, bits 7–0) is set to ZERO, stures are defined to be 16 bits wide, criptors, (CXDA = Current Transmit | | | | 23–16 | SRPC | these bits. Runt Packet Count. Indicates the accumulated number of runts that were addressed to this node since the last time that a receive packet was successfully received and its corresponding RMD2 ring entry was written to by the PC-net-PCI II controller. In order to be included in the RPC value, a runt must be long enough to meet the minimum requirement of the internal address matching logic. The minimum requirement for a | Descriptor Address When SWSTYLE TWO, the software wide, and transr Transmit Descript 42. When SWSTYLE then the software wide, and transr | (BCR 20, bits 7–0) is set to ONE or e structures are defined to be 32 bits mit descriptors, (CXDA = Current for Address), are as shown in Table (BCR 20, bits 7–0) is set to THREE, structures are defined to be 32 bits mit descriptors, (CXDA = Current for Address), are as shown in Table for Address), are as shown in Table | | | **Table 41. Transmit Descriptor (SWSTYLE = 0)** | Address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7–0 | | | | |----------|-----|-------------|---------------------|--------------------|-----|-----|-----|-----|--------------|--|--|--| | CXDA+00h | | TBADR[15:0] | | | | | | | | | | | | CXDA+02h | OWN | ERR | ADD_/<br>NO_<br>FCS | MORE<br>/<br>LTINT | ONE | DEF | STP | ENP | TBADR[23:16] | | | | | Address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7–0 | |----------|------|------|-----------|------|---------------|----|---|---|-----| | CXDA+04h | 1 | 1 | 1 | 1 | BCNT | | | | | | CXDA+06h | BUFF | UFLO | EX<br>DEF | LCOL | LCAR RTRY TDR | | | | | ### **Table 42. Transmit Descriptor (SWSTYLE = 1,2)** | Address | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22–16 | 15–12 | 11–4 | 3–0 | |----------|------|-----------------------------------------------|-----------|------|------|------|------------|----|----|-------|-------|------|-----| | CXDA+00h | | TBADR[31:0] | | | | | | | | | | | | | CXDA+04h | OWN | N ERR NO_ / ONE DEF STP ENP BPE RES 1111 BCNT | | | | | | | | | | | | | CXDA+08h | BUFF | UFLO | EX<br>DEF | LCOL | LCAR | RTRY | TDR RES TR | | | | | TRC | | | CXDA+0Ch | | RESERVED | | | | | | | | | | | | ### Table 43. Transmit Descriptor (SWSTYLE = 3) | Address | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22–16 | 15–12 | 11–4 | 3–0 | |----------|------|-------------|---------------------|--------------------|------|------|-----|-----|-----|-------|-------|------|-----| | CXDA+00h | BUFF | UFLO | EX<br>DEF | LCOL | LCAR | RTRY | | | TDR | | | RES | TRC | | CXDA+04h | OWN | ERR | ADD_/<br>NO_<br>FCS | MORE<br>/<br>LTINT | ONE | DEF | STP | ENP | BPE | RES | 1111 | ВС | NT | | CXDA+08h | | TBADR[31:0] | | | | | | | | | | | | | CXDA+0Ch | | RESERVED | | | | | | | | | | | | | Bit | Name | Description | |------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31–0 | TBADR | Transmit Buffer address. This field contains the address of the transmit buffer that is associated with this descriptor. | | TMD1 | l | | | Bit | Name | Description | | 31 | OWN | This bit indicates whether the descriptor entry is owned by the host (OWN = 0) or by the PC-net-PCI II controller (OWN = 1). The host sets the OWN bit after filling the buffer pointed to by the descriptor entry. The PCnet-PCI II controller clears the OWN bit after transmitting the contents of the buffer. Both the PCnet-PCI II controller and the host must not alter a descriptor entry after it has relinquished ownership. | | 30 | ERR | ERR is the OR of UFLO, LCOL, LCAR, RTRY or BPE. ERR is set by the PCnet-PCI II controller and | cleared by the host. This bit is set in the current descriptor when the error occurs, and therefore may be set in any descriptor of a chained buffer transmission. 29 ADD\_FCS/NOBit 29 functions as when NO\_FCSSWSTYLE (BCR20, bits 7–0) is set to ONE (ILACC style). Otherwise bit 29 functions as ADD\_FCS. ADD\_FCS ADD\_FCS dynamically controls the generation of FCS on a frame by frame basis. It is valid only if the STP bit is set. When ADD\_FCS is set, the state of DXMTFCS is ignored and transmitter FCS generation is activated. When ADD\_FCS is cleared to ZERO, FCS generation is controlled by DXMTFCS. When APAD\_XMT (CSR4, bit 11) is set to ONE, the setting of ADD\_FCS has no effect. ADD\_FCS is set by the host, and is not changed by the PCnet-PCI II controller. This is a reserved bit in the C-LANCE | | | (Am79C90). This function differs from the corresponding ILACC function. | | | transmission has an error. The LTINTEN overrides the function of TOKINTD (CSR5, bit 15). | |----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NO_FCS | NO_FCS dynamically controls the generation of FCS on a frame by frame basis. It is valid only if the ENP bit is set. When NO_FCS is set, the state of DXMTFCS is ignored and transmitter FCS generation is deacti- | 27 | ONE | ONE indicates that exactly one retry was needed to transmit a frame. ONE flag is not valid when LCOL is set. The value of the ONE bit is written by the PC-net-PCI II controller. This bit has meaning only if the ENP bit is set. | | | | vated. When NO_FCS is cleared to ZERO, FCS generation is controlled by DXMTFCS. When APAD_XMT (CSR4, bit 11) is set to ONE, the setting of NO_FCS has no effect. NO_FCS is set by the host, and is not changed by the PCnet-PCI II controller. This is a reserved bit in the C-LANCE (Am79C90). This function is iden- | 26 | DEF | Deferred indicates that the PC-net-PCI II controller had to defer while trying to transmit a frame. This condition occurs if the channel is busy when the PCnet-PCI II controller is ready to transmit. DEF is set by the PCnet-PCI II controller and cleared by the host. | | | | tical to the corresponding ILACC function. | 25 | STP | Start of Packet indicates that this is the first buffer to be used by the | | 28 | MORE/LTINT | Bit 28 always function as MORE. The value of MORE is written by the PCnet-PCI II controller and is read by the host. When LTINTEN is cleared to ZERO (CSR5, bit 14), the PCnet-PCI II controller will never look at the content of bit 28, write operations by the host have no effect. When LTINTEN is set to ONE bit 28 changes its function to LTINT on host write | | | PCnet-PCI II controller for this frame. It is used for data chaining buffers. The STP bit must be set in the first buffer of the frame, or the PCnet-PCI II controller will skip over the descriptor and poll the next descriptor(s) until the OWN and STP bits are set. STP is set by the host and is not changed by the PCnet-PCI II controller. | | | | operations and on PCnet-PCI II controller read operations. | 24 | ENP | End of Packet indicates that this is the last buffer to be used by the PCnet-PCI II controller for this | | | MORE | MORE indicates that more than one retry was needed to transmit a frame. The value of MORE is written by the PCnet-PCI II controller. This bit has meaning only if the ENP bit is set. | | | frame. It is used for data chaining<br>buffers. If both STP and ENP are<br>set, the frame fits into one buffer<br>and there is no data chaining.<br>ENP is set by the host and is not<br>changed by the PCnet-PCI II con- | | | LTINT | LTINT is used to suppress interrupts after successful transmission on selected frames. When LTINT is cleared to ZERO and ENP is set to ONE, the PC-net-PCI II controller will not set TINT (CSR0, bit 9) after a successful transmission. TINT will only be set when the last descriptor of a frame has both LTINT and ENP set to ONE. When LTINT is cleared to ZERO, it will only cause the suppression of interrupts for successful transmission. TINT will always be set if the | 23 | BPE | troller. Bus Parity Error is set by the PC- net-PCI II controller when a parity error occurred on the bus inter- face during a data transfers from the transmit buffer associated with this descriptor. The PC- net-PCI II controller will only set BPE when the advanced parity error handling is enabled by set- ting APERREN (BCR20, bit 10) to ONE. BPE is set by the PC- net-PCI II controller and cleared by the host. | | 22-16 RES | This bit does not exist, when the PCnet-PCI II controller is programmed to use 16-bit software structures for the descriptor ring entries (BCR20, bits 7–0, SW-STYLE is cleared to ZERO). Reserved locations. | | | data from memory fast enough. UFLO indicates that the FIFO has emptied before the end of the frame was reached. When DXSUFLO (CSR3, bit 6) is cleared to ZERO, the transmitter is turned off when DIFLO error | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15–12ONES | These four bits must be written as ONEs. This field is written by the host and unchanged by the PCnet-PCI II controller. | | | occurs (CSR0, TXON = 0). When DXSUFLO is set to ONE, the PCnet-PCI II controller gracefully recovers from an UFLO er- | | 11-00 BCNT | Buffer Byte Count is the usable length of the buffer pointed to by this descriptor, expressed as the two's complement of the length of the buffer. This is the number of bytes from this buffer that will be transmitted by the PCnet-PCI II | | | ror. It scans the transmit descriptor ring until it finds the start of a new frame and starts a new transmission. UFLO is set by the PCnet-PCI II controller and cleared by the host. | | TMD2<br>Bit Name | controller. This field is written by<br>the host and is not changed by<br>the PCnet-PCI II controller. There<br>are no minimum buffer size re-<br>strictions. Description | 29 | EXDEF | Excessive Deferral. Indicates that the transmitter has experienced Excessive Deferral on this transmit frame, where Excessive Deferral is defined in ISO 8802-3 (IEEE/ANSI 802.3). Excessive Deferral will also set the interrupt | | 31 BUFF | Buffer error is set by the PC- net-PCI II controller during trans- mission when the PCnet-PCI II controller does not find the ENP flag in the current descriptor and does not own the next descriptor. This can occur in either of two ways: | 28 | LCOL | bit EXDINT (CSR5, bit 7). Late Collision indicates that a collision has occurred after the first slot time of the channel has elapsed. The PCnet-PCI II controller does not retry on late collisions. LCOL is set by the PCnet-PCI II controller and cleared by the host. | | 30 UFLO | <ol> <li>The OWN bit of the next descriptor is ZERO.</li> <li>FIFO underflow occurred before the PCnet-PCI II controller obtained the STATUS byte (TMD1[31:24]) of the next descriptor. BUFF is set by the PCnet-PCI II controller and cleared by the host.</li> <li>If a Buffer Error occurs, an Underflow Error will also occur. BUFF is not valid when LCOL or RTRY error is set during transmit data chaining. BUFF is set by the PCnet-PCI II controller and cleared by the host.</li> <li>Underflow error indicates that the</li> </ol> | 27 | LCAR | Loss of Carrier is set when the carrier is lost during a PCnet-PCI II controller-initiated transmission when in AUI mode and the device is operating in half-duplex mode. The PCnet-PCI II controller does not retry upon loss of carrier. It will continue to transmit the whole frame until done. LCAR will not be set when the device is operating in full-duplex mode and the AUI port is active. LCAR is not valid in Internal Loopback Mode. LCAR is set by the PCnet-PCI II controller and cleared by the host. In 10BASE-T mode, LCAR will be set when the T-MAU was in Link Fail state during the transmis- | | | transmitter has truncated a mes-<br>sage because it could not read | | | sion. | | 26 RTRY | Retry error indicates that the transmitter has failed after 16 attempts to successfully transmit a message, due to repeated collisions on the medium. If DRTY is set to ONE in the MODE register, RTRY will set after 1 failed transmission attempt. RTRY is set by the PCnet-PCI II controller and cleared by the host. | 15–4 RES<br>3–0 TRC | to maintain full compatibility with the C-LANCE device (Am79C90). Reserved locations. Transmit Retry Count. Indicates the number of transmit retries of the associated packet. The maximum count is 15. However, if a RETRY error occurs, the count will roll over to ZERO. In this case | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 25-16TDR | Time Domain Reflectometer reflects the state of an internal PC-net-PCI II controller counter that counts at a 10 MHz rate from the start of a transmission to the occurrence of a collision or loss of carrier. This value is useful in determining the approximate distance to a cable fault. The TDR value is written by the PCnet-PCI II controller and is valid only if | TMD3 | only, the Transmit Retry Count value of ZERO should be interpreted as meaning 16. TRC is written by the PCnet-PCI II controller into the last transmit descriptor of a frame, or when an error terminates a frame. Valid only when OWN is cleared to ZERO. | | | RTRY is set. | Bit Name | Description | | | Note that 10 MHz gives very low resolution and in general has not been found to be particularly useful. This feature is here primarily | 31–0 RES | Reserved locations. | 165 # REGISTER SUMMARY PCI Configuration Registers | Offset | Name | Width in Bit | Access Mode | Default Value | |---------|---------------------------------------|--------------|-------------|---------------| | 00h | PCI Vendor ID | 16 | RO | 1022h | | 02h | PCI Device ID | 16 | RO | 2000h | | 04h | PCI Command | 16 | RW | 0000h | | 06h | PCI Status | 16 | RW | 0280h | | 08h | PCI Revision ID | 8 | RO | 1xh | | 09h | PCI Programming IF | 8 | RO | 00h | | 0Ah | PCI Sub-Class | 8 | RO | 00h | | 0Bh | PCI Base-Class | 8 | RO | 02h | | 0Ch | Reserved | 8 | RO | 00h | | 0Dh | PCI Latency Timer | 8 | RO | 00h | | 0Eh | PCI Header Type | 8 | RO | 00h | | 0Fh | Reserved | 8 | RO | 00h | | 10h | PCI I/O Base Address | 32 | RW | 0000 0001h | | 14h | PCI Memory Mapped I/O Base<br>Address | 32 | RW | 0000 0000h | | 18h-2Fh | Reserved | 8 | RO | 00h | | 30h | PCI Expansion ROM Base Address | 8 | RO | 0000 0000h | | 34–3Bhh | Reserved | 8 | RO | 00h | | 3Ch | PCI Interrupt Line | 8 | RW | 00h | | 3Dh | PCI Interrupt Pin | 8 | RO | 01h | | 3Eh | PCI MIN_GNT | 8 | RO | 06h | | 3Fh | PCI MAX_LAT | 8 | RO | FFh | | 40h–FFh | Reserved | 8 | RO | 00h | Am79C970A **Note:** RO = read only, RW = read/write, x = silicon-revision dependent 166 ### **Control and Status Registers** | RAP Addr | Symbol | Default Value | Comments | Use | |----------|--------|----------------|-------------------------------------------------------|-----| | 00 | CSR0 | uuuu 0004 | PCnet-PCI II Controller Status Register | R | | 01 | CSR1 | uuuu uuuu | Lower IADR]: Maps to Location 16 | S | | 02 | CSR2 | uuuu uuuu | Upper IADR: Maps to Location 17 | S | | 03 | CSR3 | uuuu 0000 | Interrupt Masks and Deferral Control | S | | 04 | CSR4 | uuuu 0115 | Test and Features Control | R | | 05 | CSR5 | uuuu 0000 | Extended Control and Interrupt | R | | 06 | CSR6 | uuuu uuuu | RXTX: RX/TX Encoded Ring Lengths | S | | 07 | CSR7 | uuuu uuuu | Reserved | | | 08 | CSR8 | uuuu uuuu | LADR0: Logical Address Filter LADRF[15:0] | S | | 09 | CSR9 | uuuu uuuu | LADR1: Logical Address Filter LADRF[31:16] | S | | 10 | CSR10 | uuuu uuuu | LADR2: Logical Address Filter LADRF[47:32] | S | | 11 | CSR11 | uuuu uuuu | LADR3: Logical Address Filter LADRF[63:48] | S | | 12 | CSR12 | uuuu uuuu | PADR0: Physical Address Register PADR[15:0][ | S | | 13 | CSR13 | uuuu uuuu | PADR1: Physical Address Register PADR[31:16] | S | | 14 | CSR14 | uuuu uuuu | PADR2: Physical Address Register PADR[47:32] | S | | 15 | CSR15 | see reg. desc. | MODE: Mode Register | S | | 16 | CSR16 | uuuu uuuu | IADR[15:0]: Base Address of INIT Block Lower (Copy) | Т | | 17 | CSR17 | uuuu uuuu | IADR[31:16]: Base Address of INIT Block Upper (Copy) | Т | | 18 | CSR18 | uuuu uuuu | CRBAL: Current Receive Buffer Address Lower | Т | | 19 | CSR22 | uuuu uuuu | CRBAU: Current Receive Buffer Address Upper | Т | | 20 | CSR20 | uuuu uuuu | CXBAL: Current Transmit Buffer Address Lower | Т | | 21 | CSR21 | uuuu uuuu | CXBAU: Current Transmit Buffer Address Upper | Т | | 22 | CSR22 | uuuu uuuu | NRBAL: Next Receive Buffer Address Lower | Т | | 23 | CSR23 | uuuu uuuu | NRBAU: Next Receive Buffer Address Upper | Т | | 24 | CSR24 | uuuu uuuu | BADRL: Base Address of Receive Ring Lower | S | | 25 | CSR25 | uuuu uuuu | BADRU: Base Address of Receive Ring Upper | S | | 26 | CSR26 | uuuu uuuu | NRDAL: Next Receive Descriptor Address Lower | Т | | 27 | CSR27 | uuuu uuuu | NRDAU: Next Receive Descriptor Address Upper | Т | | 28 | CSR28 | uuuu uuuu | CRDAL: Current Receive Descriptor Address Lower | Т | | 29 | CSR29 | uuuu uuuu | CRDAU: Current Receive Descriptor Address Upper | Т | | 30 | CSR30 | uuuu uuuu | BADXL: Base Address of Transmit Descriptor Ring Lower | S | | 31 | CSR31 | uuuu uuuu | BADXU: Base Address of Transmit Descriptor Ring Upper | S | | 32 | CSR32 | uuuu uuuu | NXDAL: Next XMT Descriptor Address Lower | Т | | 33 | CSR33 | uuuu uuuu | NXDAU: Next XMT Descriptor Address Upper | Т | | 34 | CSR34 | uuuu uuuu | CXDAL: Current Transmit Descriptor Address Lower | Т | | 35 | CSR35 | uuuu uuuu | CXDAU: Current Transmit Descriptor Address Upper | Т | | 36 | CSR36 | uuuu uuuu | NNRDAL: Next Next Receive Descriptor Address Lower | Т | | 37 | CSR37 | uuuu uuuu | NNRDAU: Next Next Receive Descriptor Address Upper | Т | **Note:** u = undefined value, R = Running register, S = Setup register, T = Test register ## **Control and Status Registers (continued)** | RAP Addr | Symbol | Default Value | Comments | Use | |----------|--------|----------------|-----------------------------------------------------|-----| | 38 | CSR38 | uuuu uuuu | NNXDAL: Next Next Transmit Descriptor Address Lower | Т | | 39 | CSR39 | uuuu uuuu | NNXDAU: Next Next Transmit Descriptor Address Upper | Т | | 40 | CSR40 | uuuu uuuu | CRBC: Current Receive Byte Count | Т | | 41 | CSR41 | uuuu uuuu | CRST: Current Receive Status | Т | | 42 | CSR42 | uuuu uuuu | CXBC: Current Transmit Byte Count | Т | | 43 | CSR43 | uuuu uuuu | CXST: Current Transmit Status | Т | | 44 | CSR44 | uuuu uuuu | NRBC: Next Receive Byte Count | Т | | 45 | CSR45 | uuuu uuuu | NRST: Next Receive Status | Т | | 46 | CSR46 | uuuu uuuu | POLL: Poll Time Counter | Т | | 47 | CSR47 | uuuu uuuu | PI: Polling Interval | S | | 48 | CSR48 | uuuu uuuu | Reserved | | | 49 | CSR49 | uuuu uuuu | Reserved | | | 50 | CSR50 | uuuu uuuu | Reserved | | | 51 | CSR51 | uuuu uuuu | Reserved | | | 52 | CSR52 | uuuu uuuu | Reserved | | | 53 | CSR53 | uuuu uuuu | Reserved | | | 54 | CSR54 | uuuu uuuu | Reserved | | | 55 | CSR55 | uuuu uuuu | Reserved | | | 56 | CSR56 | uuuu uuuu | Reserved | | | 57 | CSR57 | uuuu uuuu | Reserved | | | 58 | CSR58 | see reg. desc. | SWS: Software Style | S | | 59 | CSR59 | uuuu uuuu | Reserved | | | 60 | CSR60 | uuuu uuuu | PXDAL: Previous Transmit Descriptor Address Lower | Т | | 61 | CSR61 | uuuu uuuu | PXDAU: Previous Transmit Descriptor Address Upper | Т | | 62 | CSR62 | uuuu uuuu | PXBC: Previous Transmit Byte Count | Т | | 63 | CSR63 | uuuu uuuu | PXST: Previous Transmit Status | Т | | 64 | CSR64 | uuuu uuuu | NXBA: Next Transmit Buffer Address Lower | Т | | 65 | CSR65 | uuuu uuuu | NXBAU: Next Transmit Buffer Address Upper | Т | | 66 | CSR66 | uuuu uuuu | NXBC: Next Transmit Byte Count | Т | | 67 | CSR67 | uuuu uuuu | NXST: Next Transmit Status | Т | | 68 | CSR68 | uuuu uuuu | Reserved | | | 69 | CSR69 | uuuu uuuu | Reserved | | | 70 | CSR70 | uuuu uuuu | Reserved | | | 71 | CSR71 | uuuu uuuu | Reserved | | | 72 | CSR72 | uuuu uuuu | RCVRC: Receive Ring Counter | Т | | 73 | CSR73 | uuuu uuuu | Reserved | | | 74 | CSR74 | uuuu uuuu | XMTRC: Transmit Descriptor Ring Counter | Т | | 75 | CSR75 | uuuu uuuu | Reserved | | | 76 | CSR76 | uuuu uuuu | RCVRL: Receive Descriptor Ring Length | S | | 77 | CSR77 | uuuu uuuu | Reserved | | | 78 | CSR78 | uuuu uuuu | XMTRL: Transmit Descriptor Ring Length | S | | 79 | CSR79 | uuuu uuuu | Reserved | | | 80 | CSR80 | uuuu 1410 | DMATCFW: DMA Transfer Counter and FIFO Watermark | S | | 81 | CSR81 | uuuu uuuu | Reserved | | | 82 | CSR82 | uuuu 0000 | DMABAT: Bus Activity Timer | S | ## **Control and Status Registers (continued)** | RAP Addr | Symbol | Default<br>Value | Comments | Use | |----------|--------|------------------|--------------------------------------------------|-----| | 83 | CSR83 | uuuu uuuu | Reserved | | | 84 | CSR84 | uuuu uuuu | DMABA: Address Register Lower | Т | | 85 | CSR85 | uuuu uuuu | DMABAU: Address Register Upper | Т | | 86 | CSR86 | uuuu uuuu | DMABC: Buffer Byte Counter | T | | 87 | CSR87 | uuuu uuuu | Reserved | | | 88 | CSR88 | 0242 1003 | Chip ID Register Lower | T | | 89 | CSR89 | uuuu 0262 | Chip ID Register Upper | Т | | 90 | CSR90 | uuuu uuuu | Reserved | | | 91 | CSR91 | uuuu uuuu | Reserved | | | 92 | CSR92 | uuuu uuuu | Reserved | | | 93 | CSR93 | uuuu uuuu | Reserved | | | 94 | CSR94 | uuuu 0000 | XMTTDR: Transmit Time Domain Reflectometry Count | Т | | 95 | CSR95 | uuuu uuuu | Reserved | | | 96 | CSR96 | uuuu uuuu | Reserved | | | 97 | CSR97 | uuuu uuuu | Reserved | | | 98 | CSR98 | uuuu uuuu | Reserved | | | 99 | CSR99 | uuuu uuuu | Reserved | | | 100 | CSR100 | uuuu 0200 | Bus Time-Out | S | | 101 | CSR101 | uuuu uuuu | Reserved | | | 102 | CSR102 | uuuu uuuu | Reserved | | | 103 | CSR103 | uuuu 0105 | Reserved | | | 104 | CSR104 | uuuu uuuu | Reserved | | | 105 | CSR105 | uuuu uuuu | Reserved | | | 106 | CSR106 | uuuu uuuu | Reserved | | | 107 | CSR107 | uuuu uuuu | Reserved | | | 108 | CSR108 | uuuu uuuu | Reserved | | | 109 | CSR109 | uuuu uuuu | Reserved | | | 110 | CSR110 | uuuu uuuu | Reserved | | | 111 | CSR111 | uuuu uuuu | Reserved | | | 112 | CSR112 | uuuu 0000 | Missed Frame Count | R | | 113 | CSR113 | uuuu uuuu | Reserved | | | 114 | CSR114 | uuuu 0000 | Receive Collision Count | R | | 115 | CSR115 | uuuu uuuu | Reserved | | | 116 | CSR116 | uuuu uuuu | Reserved | | | 117 | CSR117 | uuuu uuuu | Reserved | | | 118 | CSR118 | uuuu uuuu | Reserved | | | 119 | CSR119 | uuuu uuuu | Reserved | | | 120 | CSR120 | uuuu uuuu | Reserved | | | 121 | CSR121 | uuuu uuuu | Reserved | | | 122 | CSR122 | uuuu 0000 | Receive Frame Alignment Control | S | | 123 | CSR123 | uuuu uuuu | Reserved | | | 124 | CSR124 | uuuu 0000 | Test Register 1 | | | 125 | CSR125 | uuuu uuuu | Reserved | | | 126 | CSR126 | uuuu uuuu | Reserved | | | 127 | CSR127 | uuuu uuuu | Reserved | Т | ### **BUS CONFIGURATION REGISTERS** | | | | | Progra | nmability | |-------|----------|---------|-----------------------------|--------|-----------| | BCR | MNEMONIC | Default | Description | User | EEPROM | | 0 | MSRDA | 0005h | Reserved | No | No | | 1 | MSWRA | 0005h | Reserved | No | No | | 2 | MC | 0002h | Miscellaneous Configuration | Yes | Yes | | 3 | Reserved | N/A | Reserved | No | No | | 4 | LNKST | 00C0h | Link Status LED | Yes | No | | 5 | LED1 | 0084h | LED1 Status | Yes | No | | 6 | LED2 | 0088h | LED2 Status | Yes | No | | 7 | LED3 | 0090h | LED3 Status | Yes | No | | 8 | Reserved | N/A | Reserved | No | No | | 9 | FDC | 0000h | Full-Duplex Control | Yes | Yes | | 10–15 | Reserved | N/A | Reserved | No | No | | 16 | IOBASEL | N/A | Reserved | Yes | Yes | | 17 | IOBASEU | N/A | Reserved | Yes | Yes | | 18 | BSBC | 9001h | Burst Size and Bus Control | Yes | Yes | | 19 | EECAS | 0002h | EEPROM Control and Status | Yes | No | | 20 | sws | 0200h | Software Style | Yes | No | | 21 | INTCON | N/A | Reserved | Yes | Yes | | 22 | PCILAT | FF06h | PCI Latency | Yes | Yes | ### **ABSOLUTE MAXIMUM RATINGS** Ambient Temperature Under Bias . . –65°C to +125°C Supply Voltage to AV<sub>SS</sub> or V<sub>SSB</sub> (AV<sub>DD</sub>, V<sub>DD</sub>, V<sub>DDB</sub>) . . . . . . . . . 0.3 V to +6.0V Stresses above those listed under Absolute Maximum Ratings may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to Absolute Maximum Ratings for extended periods may affect device reliability. Storage Temperature . . . . . . . . . -65°C to +150°C ### **OPERATING RANGES** | Commercial (C) Devices | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ambient Temperature (T <sub>A</sub> ) 0 $^{\circ}$ C to + 70 $^{\circ}$ C | | Industrial (I) Devices | | Ambient Temperature (T <sub>A</sub> )40°C to + 85°C | | Supply Voltages | | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ | | All inputs within the range: $ AV_{SS} - 0.5 \ V \leq V_{IN} \leq \\ AV_{DD} + 0.5 \ V, \text{ or } \\ AV_{DD} + 0.5 \ V, \text{ or } \\ V_{SS} - 0.5 \ V \leq V_{IN} \leq V_{DD} + 0.5 \ V, \text{ or } \\ V_{SSB} - 0.5 < V_{IN} < V_{DDB} + 0.5 V $ | | Operating ranges define those limits between which the functionality of the device is guaranteed. | ## DC CHARACTERISTICS over COMMERCIAL and INDUSTRIAL operating ranges unless otherwise specified | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Units | |---------------------|----------------------------------------|--------------------------------------------------------------------------------------|---------------------------|---------------------------|-------| | | t Voltage for 5 V Signaling | | | | | | V <sub>IL</sub> | Input LOW Voltage | | | 0.8 | V | | V <sub>IH</sub> | Input HIGH Voltage | | 2.0 | | V | | Digital Outp | out Voltage for 5 V Signaling | | | l l | | | V <sub>OL</sub> | Output LOW Voltage | $I_{OL1} = 3 \text{ mA}$ $I_{OL2} = 6 \text{ mA}$ $I_{OL3} = 12 \text{ mA (Note 1)}$ | | 0.45 | V | | V <sub>OH</sub> | Output HIGH Voltage (Note 2) | I <sub>OH</sub> = -2 mA (Note 3) | 2.4 | | V | | Digital Inpu | t Leakage Current for 5 V Signaling | | | | | | I <sub>IX</sub> | Input Low Leakage Current (Note 4) | $V_{IN} = 0 \text{ V}, V_{DD} = V_{DDB} = 5 \text{ V}$ | -10 | 10 | μΑ | | Digital Outp | out Leakage Current for 5 V Signaling | | • | | | | I <sub>OZL</sub> | Output Low Leakage Current (Note 5) | V <sub>OUT</sub> = 0.4V | | -10 | μA | | I <sub>OZH</sub> | Output High Leakage Current (Note 5) | $V_{OUT} = V_{DD}, V_{DDB}$ | | 10 | μA | | Digital Inpu | t Voltage for 3.3 V Signaling | | • | | | | V <sub>IL</sub> | Input LOW Voltage | | -0.5 | 0.325<br>V <sub>DDB</sub> | V | | V <sub>IH</sub> | Input HIGH Voltage | | 0.475<br>V <sub>DDB</sub> | V <sub>DDB</sub><br>+ 0.5 | V | | Digital Outp | out Voltage for 3.3 V Signaling | | - | | | | V <sub>OL</sub> | Output LOW Voltage | I <sub>OL</sub> = 1.5 mA | | 0.1 V <sub>DDB</sub> | V | | V <sub>OH</sub> | Output HIGH Voltage (Note 2) | I <sub>OH</sub> = -0.5 mA | 0.9 V <sub>DDB</sub> | | V | | Digital Inpu | t Leakage Current for 3.3 V Signaling | | | ı. L | | | I <sub>IX</sub> | Input Low Leakage Current | V <sub>IN</sub> = 0 V, V <sub>DD</sub> = V <sub>DDB</sub> = 3.3 V (Note 4) | -10 | 10 | μΑ | | Digital Outp | out Leakage Current for 3.3 V Signalin | g | | ı L | | | I <sub>OZL</sub> | Output Low Leakage Current (Note 5) | V <sub>OUT</sub> = 0.4V | | -10 | μA | | I <sub>OZH</sub> | Output High Leakage Current (Note 5) | $V_{OUT} = V_{DD}, V_{DDB}$ | | 10 | μΑ | # DC CHARACTERISTICS over COMMERCIAL and INDUSTRIAL operating ranges unless otherwise specified (continued) | Parameter<br>Symbol | Parameter Description | Test Conditions | | Min | Max | Units | |------------------------|---------------------------------------------------------------------|----------------------------------------------------------|--------|-----------------------|-----------------------|-------| | Crystal Inpu | ut Current | | | l . | | | | V <sub>ILX</sub> | XTAL1 Input LOW Voltage<br>Threshold | V <sub>IN</sub> = External Clock | | -0.5 | 0.8 | V | | $V_{IHX}$ | XTAL1 Input HIGH Voltage<br>Threshold | V <sub>IN</sub> = External Clock | | VDD – 0.8 | VDD + 0.5 | V | | I <sub>ILX</sub> | XTAL1 Input LOW Current | V <sub>IN</sub> = External Clock | Active | -120 | 0 | μΑ | | | | $V_{IN} = VSS$ | Sleep | -10 | +10 | μΑ | | I <sub>IHX</sub> | XTAL1 Input HIGH Current | V <sub>IN</sub> = External Clock | Active | 0 | 120 | μΑ | | | | $V_{IN} = VDD$ | Sleep | | 400 | μA | | Power Supp | oly Current | | | | ' | | | I <sub>DD</sub> | Active Power Supply Current | XTAL1 = 20 MHz,<br>CLK = 33 MHz | | | 90 | mA | | I <sub>DDCOMA</sub> | Sleep Mode Power Supply<br>Current | SLEEP active<br>AWAKE = 0 (BCR2, bit | 2) | | 200 | μΑ | | I <sub>DDSNOOZE</sub> | Auto Wake Mode Power Supply<br>Current | SLEEP active<br>AWAKE = 1 (BCR2, bit | 2) | | 10 | mA | | I <sub>DDMAGIC0</sub> | Magic Packet Mode Power<br>Supply Current | CLK = 0 MHz (Note 10) | ) | | 47 | mA | | I <sub>DDMAGIC33</sub> | Magic Packet Mode Power<br>Supply Current | CLK = 33 MHz (Note 1) | 0) | | 80 | mA | | Pin Capacit | ance | | | | <u>l</u> | | | C <sub>IN</sub> | Input Pin Capacitance | FC = 1 MHz (Note 6) | | | 10 | pF | | C <sub>IDSEL</sub> | IDSEL Pin Capacitance | FC = 1 MHz (Note 6) | | | 8 | pF | | Co | I/O or Output Pin Capacitance | FC = 1 MHz (Note 6) | | | 10 | pF | | C <sub>CLK</sub> | CLK Pin Capacitance | FC = 1 MHz (Note 6) | | 5 | 12 | pF | | | r Interface (10BASE-T) | | | | <u>l</u> | | | I <sub>IRXD</sub> | Input Current at RXD± | $AV_{SS} < V_{IN} < AV_{DD}$ | | -500 | 500 | μA | | $R_{RXD}$ | RXD± Differential Input<br>Resistance | | | 10 | | ΚΩ | | V <sub>TIVB</sub> | RXD+, RXD- Open Circuit I <sub>IN</sub> = 0 mA Input Voltage (Bias) | | | AV <sub>DD</sub> -3.0 | AV <sub>DD</sub> -1.5 | V | | V <sub>TIDV</sub> | Differential Mode Input Voltage<br>Range (RXD±) | AV <sub>DD</sub> = 5.0 V | | -3.1 | 3.1 | V | | V <sub>TSQ+</sub> | RXD Positive Squelch Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 0 (CSR15, bit 9) | | 300 | 520 | mV | | $V_{TSQ-}$ | RXD Negative Squelch Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 0 (CSR15, bit 9) | | -520 | -300 | mV | | V <sub>THS+</sub> | RXD Post-Squelch Positive<br>Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 0 (CSR15, bit 9) | | 150 | 293 | mV | | V <sub>THS</sub> - | RXD Post-Squelch Negative<br>Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 1 LRT = 0 (CSR15, bit 9) | - | -293 | -150 | mV | | V <sub>LTSQ+</sub> | RXD Positive Squelch Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 1 (CSR15, bit 9) | | 180 | 312 | mV | | V <sub>LTSQ</sub> _ | RXD Negative Squelch Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 1 (CSR15, bit 9) | | -312 | -180 | mV | | V <sub>LTHS+</sub> | RXD Post-Squelch Positive<br>Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 1 (CSR15, bit 9) | | 90 | 176 | mV | | V <sub>LTHS</sub> - | RXD Post-Squelch Negative<br>Threshold (Peak) | Sinusoid 5 MHz $\leq$ f $\leq$ 10 LRT = 1 (CSR15, bit 9) | | -176 | -90 | mV | ## DC CHARACTERISTICS over COMMERCIAL and INDUSTRIAL operating ranges unless otherwise specified (continued) | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Units | |---------------------|------------------------------------------------------------------------------|------------------------------------|-----------------------|-----------------------|-------| | Twisted Pair | Interface (10BASE-T) (Continued) | • | <del>-1</del> | <del></del> | | | V <sub>RXDTH</sub> | RXD Switching Threshold | (Note 6) | -35 | 35 | mV | | $V_{TXH}$ | TXD± and TXP± Output HIGH Voltage | AV <sub>SS</sub> = 0 V | AV <sub>DD</sub> -0.6 | $AV_DD$ | V | | $V_{TXL}$ | TXD± and TXP± Output LOW Voltage | $AV_{DD} = 5 V$ | AV <sub>SS</sub> | AV <sub>SS</sub> +0.6 | V | | $V_{TXI}$ | TXD± and TXP± Differential Output Voltage Imbalance | | -40 | 40 | mV | | V <sub>TXOFF</sub> | TXD± and TXP± Idle Output Voltage | | | 40 | mV | | $R_{TX}$ | TXD±, TXP± Differential Driver Output Impedance | (Note 6) | | 80 | Ω | | Attachment | Unit Interface (AUI) | | 1 | <u>.</u> | | | I <sub>IAXD</sub> | Input Current at DI+ and DI- | $-1V < V_{IN} < AV_{DD} + 0.5 V$ | -500 | +500 | μΑ | | I <sub>IAXC</sub> | Input Current at CI+ and CI- | $-1V < V_{IN} < AV_{DD} + 0.5 V$ | -500 | +500 | μA | | V <sub>AOD</sub> | Differential Output Voltage (DO+)-<br>(DO-) | $R_L = 78 \Omega$ | 630 | 1200 | mV | | V <sub>AODOFF</sub> | Transmit Differential Output Idle Voltage | $R_L = 78 \Omega \text{ (Note 9)}$ | -40 | 40 | mV | | I <sub>AODOFF</sub> | Transmit Differential Output Idle Current | $R_L = 78 \Omega \text{ (Note 8)}$ | -1 | 1 | mA | | V <sub>CMT</sub> | Transmit Output Common Mode<br>Voltage | $R_L = 78 \Omega$ | 2.5 | AV <sub>DD</sub> | V | | V <sub>ODI</sub> | DO± Transmit Differential Output<br>Voltage Imbalance | $R_L = 78 \Omega \text{ (Note 7)}$ | | 25 | mV | | $V_{ATH}$ | Receive Data Differential Input<br>Threshold | | -35 | 35 | mV | | $V_{ASQ}$ | DI± and CI± Differential Input Threshold (Squelch) | -275 | -160 | mV | | | V <sub>IRDVD</sub> | DI± and CI± Differential Mode Input<br>Voltage Range | -1.5 | 1.5 | V | | | V <sub>ICM</sub> | DI± and CI± Input Bias Voltage | I <sub>IN</sub> = 0 mA | AV <sub>DD</sub> -3.0 | AV <sub>DD</sub> -1.0 | V | | V <sub>OPD</sub> | DO± Undershoot Voltage at ZERO Differential on Transmit Return to ZERO (ETD) | (Note 9) | | -100 | mV | ### Notes: - 1. $I_{OL1}$ applies to AD[31:0], $C/\overline{BE}$ [3:0], PAR and $\overline{REQ}$ . - $I_{OL2}$ applies to $\overline{\text{DEVSEL}}$ , $\overline{\text{FRAME}}$ , $\overline{\text{INTA}}$ , $\overline{\text{IRDY}}$ , $\overline{\text{PERR}}$ , $\overline{\text{STOP}}$ , $\overline{\text{TRDY}}$ , $\overline{\text{EECS}}$ , $\overline{\text{ERA}}$ [7:0], $\overline{\text{ERACLK}}$ , $\overline{\text{EROE}}$ , $\overline{\text{DXCVR}}$ /NOUT, $\overline{\text{ERD7/TXDAT}}$ , $\overline{\text{ERD6/TXEN}}$ and $\overline{\text{TDO}}$ . - I<sub>OL3</sub> applies to EESK/LED1/SFBD, LED2/SRDCLK, EEDO/LED3/SRD, and EEDI/LNKST. - 2. V<sub>OH</sub> does not apply to open-drain output pins. - 3. Outputs are CMOS and will be driven to rail if the load is not resistive. - 4. $I_{IX}$ applies to all input pins except XTAL1. - 5. $I_{OZI}$ and $I_{OZH}$ apply to all three-state output pins and bi-directional pins. - 6. Parameter not tested. Value determined by characterization. - 7. Tested, but to values in excess of limits. Test accuracy not sufficient to allow screening guard bands. - 8. Correlated to other tested parameters--not tested directly. - 9. Test not implemented to data sheet specification. - 10. The power supply current in Magic Packet mode is linear. For example, at CLK = 20 MHz the maximum Magic Packet mode power supply current would be 67 mA. # SWITCHING CHARACTERISTICS: Bus Interface (Unless otherwise noted, parametric values are the same between Commercial devices and Industrial devices.) | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Unit | |------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----|-----|------| | Clock Timing | <del>!</del> | | | ! | 4 | | F <sub>CLK</sub> | CLK Frequency | | 0 | 33 | MHz | | t <sub>CYC</sub> | CLK Period | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 30 | ∝ | ns | | t <sub>HIGH</sub> | CLK High Time | @ 2.0 V for V <sub>DDB</sub> = 5 V<br>@ 0.475 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 12 | | ns | | t <sub>LOW</sub> | CLK Low Time | @ 0.8 V for V <sub>DDB</sub> = 5 V<br>@ 0.325 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 12 | | ns | | t <sub>FALL</sub> | CLK Fall Time | Over 2 V p-p for $V_{DDB} = 5 V$<br>Over 0.4 $V_{DDB}$ p-p for $V_{DDB} = 3.3 V$ (Note 1) | 1 | 4 | V/ns | | <sup>t</sup> RISE | CLK Rise Time | Over 2 V p-p for $V_{DDB} = 5 V$<br>Over 0.4 $V_{DDB}$ p-p for $V_{DDB} = 3.3 V$ (Note 1) | 1 | 4 | V/ns | | Output and Flo | pat Delay Timing | • | | | | | t <sub>VAL</sub> | AD[31:00], C/BE[3:0], PAR,<br>FRAME, IRDY, TRDY, STOP,<br>DEVSEL, PERR, SERR<br>Valid Delay | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 2 | 11 | ns | | t <sub>VAL</sub> (REQ) | REQ Valid Delay | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 2 | 12 | ns | | t <sub>ON</sub> | AD[31:00], C/BE[3:0], PAR, FRAME, IRDY, TRDY, STOP, DEVSEL Active Delay | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 2 | 11 | ns | | t <sub>OFF</sub> | AD[31:00], C/BE[3:0], PAR, FRAME, IRDY, TRDY, STOP, DEVSEL Float Delay | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | | 28 | ns | | Setup and Hole | d Timing | | | | | | t <sub>SU</sub> | AD[31:00], C/BE[3:0], PAR, FRAME, IRDY, TRDY, STOP, LOCK, DEVSEL, IDSEL Setup Time | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 7 | | ns | | t <sub>H</sub> | AD[31:00], C/BE[3:0], PAR,<br>FRAME, IRDY, TRDY, STOP,<br>LOCK, DEVSEL, IDSEL<br>Hold Time | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 0 | | ns | | t <sub>SU</sub> (GNT) | GNT Setup Time | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 10 | | ns | | t <sub>H</sub> (GNT) | GNT Hold Time | @ 1.5 V for V <sub>DDB</sub> = 5 V<br>@ 0.4 V <sub>DDB</sub> for V <sub>DDB</sub> = 3.3 V | 0 | | ns | ### **SWITCHING CHARACTERISTICS: Bus Interface (continued)** | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Unit | | |---------------------------|------------------------------------|------------------------|------|-----|------|--| | EEPROM Timing | | | | | | | | f <sub>EESK</sub> (EESK) | EESK Frequency | @ 1.5 V for V (Note 2) | | 650 | KHz | | | t <sub>HIGH</sub> (EESK) | EESK High Time | @ 0.2 V | 780 | | ns | | | t <sub>LOW</sub> | EESK Low Time | @ 0.8 V | 780 | | ns | | | t <sub>VAL</sub> (EEDI) | EEDI Valid Output Delay from EESK | @ 1.5 V for V (Note 2) | -15 | 15 | ns | | | t <sub>VAL</sub> (EESK) | EECS Valid Output Delay from EESK | @ 1.5 V for V (Note 2) | -15 | 15 | ns | | | t <sub>LOW</sub> (EECS) | EECS Low Time | @ 1.5 V for V (Note 2) | 1550 | | ns | | | t <sub>SU</sub> (EEDO) | EEDO Setup Time to EESK | @ 1.5 V for V (Note 2) | 50 | | ns | | | t <sub>H</sub> (EEDO) | EEDO Hold Time from EESK | @ 1.5 V for V (Note 2) | 0 | | ns | | | Expansion ROM | Interface Timing | 1 | 1 | | I. | | | t <sub>VAL</sub> (ERA) | ERA Valid Delay from CLK | @ 1.5 V | | | ns | | | t <sub>VAL</sub> (EROE) | EROE Valid Delay from CLK | @ 1.5 V | | | ns | | | t <sub>VAL</sub> (ERACLK) | ERACLK Valid Delay from CLK | @ 1.5 V | | | ns | | | t <sub>SU</sub> (ERD) | ERD Setup Time to CLK | @ 1.5 V | | | ns | | | t <sub>H</sub> (ERD) | ERD Hold Time to CLK | @ 1.5 V | | | ns | | | JTAG (IEEE 114 | 9.1) Test Signal Timing | 1 | 1 | | I. | | | t <sub>J1</sub> | TCK Frequency | | | 10 | MHz | | | t <sub>J2</sub> | TCK Period | | 100 | | | | | t <sub>J3</sub> | TCK High Time | @ 2.0 V | 45 | | ns | | | t <sub>J4</sub> | TCK Low Time | @ 0.8 V | 45 | | ns | | | t <sub>J5</sub> | TCK Rise Time | | | 4 | ns | | | t <sub>J6</sub> | TCK Fall Time | | | 4 | ns | | | t <sub>J7</sub> | TDI, TMS Setup Time | | 8 | | ns | | | t <sub>J8</sub> | TDI, TMS Hold Time | | 10 | | ns | | | t <sub>9</sub> | TDO Valid Delay | | 3 | 30 | ns | | | t <sub>J9</sub> | TDO Float Delay | | | 50 | ns | | | t <sub>J11</sub> | All Outputs (Non-Test) Valid Delay | | 3 | 25 | ns | | | t <sub>J12</sub> | All Outputs (Non-Test) Float Delay | | | 36 | ns | | | t <sub>J13</sub> | All Outputs (Non-Test) Setup Time | | 8 | | ns | | | t <sub>J4</sub> | All Outputs (Non-Test) Hold Time | | 7 | | ns | | ### Note: <sup>1.</sup> Not tested; parameter guaranteed by characterization. <sup>2.</sup> Parameter value is given for automatic EEPROM read operation. When EEPROM port (BCR19) is used to access the EEPROM, software is responsible for meeting EEPROM timing requirements. # SWITCHING CHARACTERISTICS: 10BASE-T Interface (Unless otherwise noted, parametric values are the same between Commercial devices and Industrial devices.) | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Unit | |---------------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------|--------------|------| | Transmit Timi | ng | | • | <u>.</u> | | | t <sub>TETD</sub> | Transmit Start of Idle | | 250 | 350 | ns | | t <sub>TR</sub> | Transmitter Rise Time | (10% to 90%) | | 5.5 | ns | | t <sub>TF</sub> | Transmitter Fall Time | (90% to 10%) | | 5.5 | ns | | t <sub>TM</sub> | Transmitter Rise and Fall Time<br>Mismatch | $(t_{TM} = t_{TR} - t_{TF} )$ | | 1 | ns | | t <sub>XMTON</sub> | XMT Asserted Delay | | | 100 | ns | | t <sub>XMTOFF</sub> | XMT Deasserted Delay | | 20 | 62 | ms | | t <sub>PERLP</sub> | Idle Signal Period | | 8 | 24 | ms | | t <sub>PWLP</sub> | Idle Link Pulse Width | (Note 1) | 75 | 120 | ns | | t <sub>PWPLP</sub> | Predistortion Idle Link Pulse Width | (Note 1) | 45 | 55 | ns | | t <sub>JA</sub> | Transmit Jabber Activation Time | | 20 | 150 | ms | | t <sub>JR</sub> | Transmit Jabber Reset Time | | 250 | 750 | ms | | t <sub>JREC</sub> | Transmit Jabber Recovery Time<br>(Minimum time gap between transmitted<br>frames to prevent jabber activation) | | 1.0 | | μs | | Receiving Tim | ing | | • | | | | t <sub>PWNRD</sub> | RXD Pulse Width Not to Turn Off Internal<br>Carrier Sense | V <sub>IN</sub> > V <sub>THS</sub> (min) | 136 | | ns | | t <sub>PWROFF</sub> | RXD Pulse Width To Turn Off | V <sub>IN</sub> > V <sub>THS</sub> (min) | | 200 | ns | | t <sub>RETD</sub> | Receive Start of Idle | | 200 | | ns | | <sup>t</sup> RCVON | RCV Asserted Delay | | TRON<br>-50 | TRON<br>+100 | ns | | t <sub>RCVON</sub> | RCV Deasserted Delay | | 20 | 62 | ms | | Collision Dete | ction and SQE Test | • | | • | - | | t <sub>COLON</sub> | COL Asserted Delay | | 750 | 900 | ns | | t <sub>COLOFF</sub> | COL Deasserted Delay | | 20 | 62 | ms | ### Note: <sup>1.</sup> Not tested; parameter guaranteed by characterization. ## SWITCHING CHARACTERISTICS: AUI (Unless otherwise noted, parametric values are the same between Commercial devices and Industrial devices.) | Parameter<br>Symbol | Parameter Description | Test Conditions | Min | Max | Unit | |---------------------|--------------------------------------------|-------------------------------------|--------|--------|------| | AUI Port | | - | | • | | | t <sub>DOTR</sub> | DO+, DO- Rise Time (10% to 90%) | | 2.5 | 5.0 | ns | | t <sub>DOTF</sub> | DO+, DO- Fall Time (10% to 90%) | | 2.5 | 5.0 | ns | | t <sub>DORM</sub> | DO+, DO- Rise and Fall Time Mismatch | | | 1.0 | ns | | t <sub>DOETD</sub> | DO± End of Transmission | | 200 | 375 | ns | | t <sub>PWODI</sub> | DI Pulse Width Accept/Reject Threshold | V <sub>IN</sub> > VASQ (Note 1) | 15 | 45 | ns | | t <sub>PWKDI</sub> | DI Pulse Width Maintain/Turn-Off Threshold | V <sub>IN</sub> > VASQ (Note 2) | 136 | 200 | ns | | t <sub>PWOCI</sub> | CI Pulse Width Accept/Reject Threshold | V <sub>IN</sub> > VASQ (Note 3) | 10 | 26 | ns | | t <sub>PWKCI</sub> | CI Pulse Width Maintain/Turn-Off Threshold | V <sub>IN</sub> > VASQ (Note 4) | 90 | 160 | ns | | Internal MEND | EC Clock Timing | | | • | | | t <sub>X1</sub> | XTAL1 Period | V <sub>IN</sub> = External Clock | 49.995 | 50.001 | ns | | t <sub>X1H</sub> | XTAL1 HIGH Pulse Width | V <sub>IN</sub> = External Clock | 20 | | ns | | t <sub>X1L</sub> | XTAL1 LOW Pulse Width | V <sub>IN</sub> = External Clock | 20 | | ns | | t <sub>X1R</sub> | XTAL1 Rise Time | V <sub>IN</sub> = External Clock | | 5 | ns | | t <sub>X1F</sub> | XTAL1 Fall Time | V <sub>IN</sub> = External Clock | | 5 | ns | ### Note: - 1. DI pulses narrower than $t_{PWODI}$ (min) will be rejected; pulses wider than $t_{PWODI}$ (max) will turn internal DI carrier sense on. - 2. DI pulses narrower than t<sub>PWKDI</sub> (min) will maintain internal DI carrier sense on; pulses wider than t<sub>PWKDI</sub> (max) will turn internal DI carrier sense off. - 3. Cl pulses narrower than $t_{PWOCI}$ (min) will be rejected; pulses wider than $t_{PWOCI}$ (max) will turn internal Cl carrier sense on. - 4. CI pulses narrower than t<sub>PWKCI</sub> (min) will maintain internal CI carrier sense on; pulses wider than t<sub>PWKCI</sub> (max) will turn internal CI carrier sense off. # SWITCHING CHARACTERISTICS: EADI (Unless otherwise noted, parametric values are the same between Commercial devices and Industrial devices.) | Parameter<br>Symbol | Parameter Name | Test Condition | Min | Max | Unit | |---------------------|-------------------------------------------------|----------------|------------|--------|------| | t <sub>EAD1</sub> | SRD Setup to SRDCLK | @ 1.5 V | 40 | | ns | | t <sub>EAD2</sub> | SRD Hold to SRDCLK | @ 1.5 V | 40 | | ns | | t <sub>EAD3</sub> | SF/BD Change to SRDCLK | @ 1.5 V | <b>–15</b> | +15 | ns | | t <sub>EAD4</sub> | EAR Deassertion to SRDCLK (First Rising Edge) | @ 1.5 V | 50 | | ns | | t <sub>EAD5</sub> | EAR Assertion after SFD Event (Frame Rejection) | @ 1.5 V | 200 | 51,090 | ns | | t <sub>EAD6</sub> | EAR Assertion | @ 1.5 V | 110 | | ns | ### A KEY TO SWITCHING WAVEFORMS KS000010 ### **SWITCHING TEST CIRCUITS** 19436C-48 **Normal and Tri-State OutPuts** ### **SWITCHING TEST CIRCUITS** 19436C-49 ### **AUI DO Switching Test Circuit** 19436C-50 ### **TXD Switching Test Circuit** 19436C-51 **TXP Outputs Test Circuit** ### **SWITCHING WAVEFORMS: SYSTEM BUS INTERFACE** ### **CLK Waveform for 5 V Signaling** 19436C-53 ### **CLK Waveform for 3.3 V Signaling** 19436C-54 **Input Setup and Hold Timing** ### SWITCHING WAVEFORMS: SYSTEM BUS INTERFACE 19436C-55 ### **Output Valid Delay Timing** 19436C-56 ### **Output Tri-state Delay Timing** 19436C-57 ### **Automatic EEPROM Read Functional Timing** ## **SWITCHING WAVEFORMS: SYSTEM BUS INTERFACE** 19436C-58 ## **Automatic EEPROM Read Timing** 19436C-59 ## **Expansion ROM Read Timing** # **SWITCHING WAVEFORMS: SYSTEM BUS INTERFACE** JTAG (IEEE 1149.1) TCK Waveform for 5 V Signaling 19436C-61 JTAG (IEEE 1149.1) Test Signal Timing # **SWITCHING WAVEFORMS: 10BASE-T INTERFACE** 19436A-61 # **Transmit Timing** 19436A-62 **Idle Link Test Pulse** # **SWITCHING WAVEFORMS: 10BASE-T INTERFACE** 19436C-62 # Receive Thresholds (LRT = 1) 19436C-63 Receive Thresholds (LRT = 0) ## **SWITCHING WAVEFORMS: AUI** **Note 1:** Internal signal and is shown for clarification only. #### **Transmit Timing—Start of Packet** Note 1: Internal signal and is shown for clarification only. Transmit Timing—End of Packet (Last Bit = 0) # **SWITCHING WAVEFORMS: AUI** Note 1: Internal signal and is shown for clarification only. Transmit Timing—End of Packet (Last Bit = 1) 188 # **SWITCHING WAVEFORMS: AUI** ## **Receive Timing Diagram** 19436C-68 ## **Collision Timing Diagram** 19436C-69 **Port DO ETD Waveform** # **SWITCHING WAVEFORMS: EADI** **EADI Reject Timing** ## **PHYSICAL DIMENSIONS\*** #### **PQB132** Plastic Quad Flat Pack, Trimmed and Formed (measured in inches) #### Trademarks Copyright © 2000 Advanced Micro Devices, Inc. All rights reserved. AMD, the AMD logo, and combinations thereof are trademarks of Advanced Micro Devices, Inc. ${\bf Embedded\ Erase\ and\ Embedded\ Program\ are\ trademarks\ of\ Advanced\ Micro\ Devices,\ Inc.}$ Product names used in this publication are for identification purposes only and may be trademarks of their respective companies. ## **PHYSICAL DIMENSIONS** #### **PQB132** Molded Carrier Ring Plastic Quad Flat Pack (measured in inches, Ring measured in millimeters) # PHYSICAL DIMENSIONS\* PQT144 ## Thin Quad Flat Pack (measured in inches) 16-038-PQT-2\_AH PQT144 5-4-95 ae <sup>\*</sup>For reference only. BSC is an ANSI standard for Basic Space Centering. # **PCnet-PCI II Compatible Media Interface Modules** # PCnet-PCI II COMPATIBLE 10BASE-T FILTERS AND TRANSFORMERS The table below provides a sample list of PCnet-PCI II compatible 10BASE-T filter and transformer modules available from various vendors. Contact the respective manufacturer for a complete and updated listing of components. | Manufacturer | Part No. | Package | Filters<br>and<br>Transformers | Filters<br>Transformers<br>and Choke | Filters<br>Transformers<br>Dual Chokes | Filters<br>Transformers<br>Resistors<br>Dual Chokes | |-------------------|--------------|----------------|--------------------------------|--------------------------------------|----------------------------------------|-----------------------------------------------------| | Bel Fuse | A556-2006-DE | 16-pin 0.3 DIL | V | | | | | Bel Fuse | 0556-2006-00 | 14-pin SIP | V | | | | | Bel Fuse | 0556-2006-01 | 14-pin SIP | | | V | | | Bel Fuse | 0556-6392-00 | 16-pin 0.5 DIL | | | V | | | Halo Electronics | FD02-101G | 16-pin 0.3 DIL | V | | | | | Halo Electronics | FD12-101G | 16-pin 0.3 DIL | | V | | | | Halo Electronics | FD22-101G | 16-pin 0.3 DIL | | | V | | | PCA Electronics | EPA1990A | 16-pin 0.3 DIL | V | | | | | PCA Electronics | EPA2013D | 16-pin 0.3 DIL | | V | | | | PCA Electronics | EPA2162 | 16-pin 0.3 SIP | | | V | | | Pulse Engineering | PE-65421 | 16-pin 0.3 DIL | V | | | | | Pulse Engineering | PE-65434 | 16-pin 0.3 SIL | | | V | | | Pulse Engineering | PE-65445 | 16-pin 0.3 DIL | | | V | | | Pulse Engineering | PE-65467 | 12-pin 0.5 SMT | | | | <b>√</b> | | Valor Electronics | PT3877 | 16-pin 0.3 DIL | V | | | | | Valor Electronics | FL1043 | 16-pin 0.3 DIL | | | $\sqrt{}$ | | # PCnet-PCI II Compatible AUI Isolation Transformers The table below provides a sample list of PCnet-PCI II compatible AUI isolation transformers available from various vendors. Contact the respective manufacturer for a complete and updated listing of components. | Manufacturer | Part No. | Package | Description | |-------------------|--------------|----------------|-------------| | Bel Fuse | A553-0506-AB | 16-pin 0.3 DIL | 50 μH | | Bel Fuse | S553-0756-AE | 16-pin 0.3 SMD | 75 μH | | Halo Electronics | TD01-0756K | 16-pin 0.3 DIL | 75 μH | | Halo Electronics | TG01-0756W | 16-pin 0.3 SMD | 75 μH | | PCA Electronics | EP9531-4 | 16-pin 0.3 DIL | 50 μH | | Pulse Engineering | PE64106 | 16-pin 0.3 DIL | 50 μH | | Pulse Engineering | PE65723 | 16-pin 0.3 SMT | 75 μH | | Valor Electronics | LT6032 | 16-pin 0.3 DIL | 75 µH | | Valor Electronics | ST7032 | 16-pin 0.3 SMD | 75 μH | # PCnet-PCI II Compatible DC/DC Converters The table below provides a sample list of PCnet-PCI II compatible DC/DC converters available from various vendors. Contact the respective manufacturer for a complete and updated listing of components. | Manufacturer | Part No. | Package | Voltage | Remote On/Off | |-------------------|------------|------------|---------|---------------| | Halo Electronics | DCU0-0509D | 24-pin DIP | 5/-9 | No | | Halo Electronics | DCU0-0509E | 24-pin DIP | 5/-9 | Yes | | PCA Electronics | EPC1007P | 24-pin DIP | 5/-9 | No | | PCA Electronics | EPC1054P | 24-pin DIP | 5/-9 | Yes | | PCA Electronics | EPC1078 | 24-pin DIP | 5/-9 | Yes | | Valor Electronics | PM7202 | 24-pin DIP | 5/-9 | No | | Valor Electronics | PM7222 | 24-pin DIP | 5/-9 | Yes | # MANUFACTURER CONTACT INFORMATION Contact the following companies for further information on their products. | Company | U.S. and Domestic | Asia | Europe | |--------------------|----------------------------------------------|----------------------------|---------------| | Bel Fuse | Phone: (201) 432-0463 | 852-328-5515 | 33-1-69410402 | | | FAX: (201) 432-9542 | 852-352-3706 | 33-1-69413320 | | Halo Electronics | Phone: (415) 969-7313<br>FAX: (415) 367-7158 | 65-285-1566<br>65-284-9466 | | | PCA Electronics | Phone: (818) 892-0761 | 852-553-0165 | 33-1-44894800 | | (HPC in Hong Kong) | FAX: (818) 894-5791 | 852-873-1550 | 33-1-42051579 | | Pulse Engineering | Phone: (619) 674-8100 | 852-425-1651 | 353-093-24107 | | | FAX: (619) 675-8262 | 852-480-5974 | 353-093-24459 | | Valor Electronics | Phone: (619) 537-2500 | 852-513-8210 | 49-89-6923122 | | | FAX: (619) 537-2525 | 852-513-8214 | 49-89-6926542 | # Recommendation for Power and Ground Decoupling The mixed analog/digital circuitry in the PCnet-PCI II make it imperative to provide noise-free power and ground connections to the device. Without clean power and ground connections, a design may suffer from high bit error rates or may not function at all. Hence, it is highly recommended that the guidelines presented here are followed to ensure a reliable design. Decoupling/Bypass Capacitors: Adequate decoupling of the power and ground pins and planes is required by all PCnet-PCI II designs. This includes both low-frequency bulk capacitors and high frequency capacitors. It is recommended that at least one low-frequency bulk (e.g. $22 \mu F$ ) decoupling capacitor be used in the area of the PCnet-PCI II device. The bulk capacitor(s) should be connected directly to the power and ground planes. In addition, **at least 8** high frequency decoupling capacitors (e.g. $0.1~\mu F$ multilayer ceramic capacitors) should be used around the periphery of the PCnet-PCI II device to prevent power and ground bounce from affecting device operation. To reduce the inductance between the power and ground pins and the capacitors, the pins should be connected directly to the capacitors, rather than through the planes to the capacitors. The suggested connection scheme for the capacitors is shown in the figure below. Note also that the traces connecting these pins to the capacitors should be as wide as possible to reduce inductance (15 mils is desirable). 19436C-73 The most critical pins in the layout of a PCnet-PCI II design are the 4 analog power and 2 analog ground pins, AVDD[1–4] and AVSS[1–2], respectively. All of these pins are located in one corner of the device, the "analog corner." Specific functions and layout requirements of the analog power and ground pins are given below. AVSS1 and AVDD3: These pins provide the power and ground for the Twisted Pair and AUI drivers. In addition AVSS1 serves as the ground for the logic interfaces in the 20 MHz Crystal Oscillator. Hence, these pins can be very noisy. A dedicated 0.1 $\mu F$ capacitor between these pins is recommended. AVSS2 and AVDD2: These pins are the most critical pins on the PCnet-PCI II device because they provide the power and ground for the phase-lock loop (PLL) portion of the chip. The voltage-controlled oscillator (VCO) portion of the PLL is sensitive to noise in the 60 kHz – 200 kHz. range. To prevent noise in this frequency range from disrupting the VCO, it is **strongly recommended** that the low-pass filter shown below be implemented on these pins. To determine the value for the resistor and capacitor, the formula is: Where R is in Ohms and C is in microfarads. Some possible combinations are given below. To minimize the voltage drop across the resistor, the R value should not be more than 10 W. | R | С | |-------|-------| | 2.7 Ω | 33 µF | | 4.3 Ω | 22 µF | | 6.8 Ω | 15 μF | | 10 Ω | 10 μF | AVSS2 and AVDD2/AVDD4: These pins provide power and ground for the AUI and twisted pair receive circuitry. In addition, as mentioned earlier, AVSS2 and AVDD2 provide power and ground for the phase-lock loop portion of the chip. Except for the filter circuit already mentioned, no specific decoupling is necessary on these pins. AVDD1: AVDD1 provides power for the control and interface logic in the PLL. Ground for this logic is provided by digital ground pins. No specific decoupling is necessary on this pin. Special Note for Adapter Cards: In adapter card designs, it is important to utilize all available powerand ground pins available on the bus edge connector. In addition, the connection from the bus edge connector to the power or ground plane should be made through more than one via and with wide traces (15 mils desirable) wherever possible. Following these recommendations results in minimal inductance in the power and ground paths. By minimizing this inductance, ground bounce is minimized. See also the PCnet Family Board Design and Layout Recommendations applications note (PID# 19595) for additional information. # **Alternative Method for Initialization** The PCnet-PCI II controller may be initialized by performing I/O writes only. That is, data can be written directly to the appropriate control and status registers (CSR instead of reading from the initialization Block in memory). The registers that must be written are shown in the table below. These register writes are followed by writing the START bit in CSR0. | Control and Status Register | Comment | |-----------------------------|--------------| | CSR2 | IADR[31:16]* | | CSR8 | LADRF[15:0] | | CSR9 | LADRF[31:16] | | CSR10 | LADRF[47:32] | | CSR11 | LADRF[63:48] | | CSR12 | PADR[15:0] | | CSR13 | PADR[31:16] | | CSR14 | PADR[47:32] | | CSR15 | Mode | | CSR24-25 | BADR | | CSR30-31 | BADX | | CSR47 | POLLINT | | CSR76 | RCVRL | | CSR78 | XMTRL | #### Note: <sup>1.</sup> The INIT bit must not be set or the initialization block will be accessed instead. <sup>\*</sup> Needed only if SSIZE32 = 0. # Look-Ahead Packet Processing (LAPP) Concept #### **Introduction of the LAPP Concept** A driver for the PCnet-PCI II controller would normally require that the CPU copy receive frame data from the controllers buffer space to the applications buffer space after the entire frame has been received by the control- ler. For applications that use a ping-pong windowing style, the traffic on the network will be halted until the current frame has been completely processed by the entire application stack. This means that the time be- tween last byte of a receive frame arriving at the clients Ethernet controller and the clients transmission of the first byte of the next outgoing frame will be separated by: - The time that it takes the clients CPUs interrupt procedure to pass software control from the current task to the driver - plus the time that it takes the client driver to pass the header data to the application and request an application buffer - plus the time that it takes the application to generate the buffer pointer and then return the buffer pointer to the driver - 4. plus the time that it takes the client driver to transfer all of the frame data from the controllers buffer space into the applications buffer space and then call the application again to process the complete frame - 5. plus the time that it takes the application to process the frame and generate the next outgoing frame - plus the time that it takes the client driver to set up the descriptor for the controller and then write a TDMD bit to CSR0 The sum of these times can often be about the same as the time taken to actually transmit the frames on the wire, thereby yielding a network utilization rate of less than 50%. An important thing to note is that the PCnet-PCI II controllers data transfers to its buffer space are such that the system bus is needed by the PCnet-PCI II controller for approximately 4% of the time. This leaves 96% of the system bus bandwidth for the CPU to perform some of the inter-frame operations in advance of the completion of network receive activity, if possible. The question then becomes: how much of the tasks that need to be performed between reception of a frame and transmission of the next frame can be performed before the reception of the frame actually ends at the network, and how can the CPU be instructed to perform these tasks during the network reception time? The answer depends upon exactly what is happening in the driver and application code, but the steps that can be performed at the same time as the receive data are arriving include as much as the first 3 steps and part of the 4 th step shown in the sequence above. By performing these steps before the entire frame has arrived, the frame throughput can be substantially increased. A good increase in performance can be expected when the first 3 steps are performed before the end of the network receive operation. A much more significant performance increase could be realized if the PC-net-PCI II controller could place the frame data directly into the applications buffer space; (i.e., eliminate the need for step 4.) In order to make this work, it is necessary that the application buffer pointer be determined before the frame has completely arrived, then the buffer pointer in the next descriptor for the receive frame would need to be modified in order to direct the PCnet-PCI II controller to write directly to the application buffer. More details on this operation will be given later. An alternative modification to the existing system can gain a smaller, but still significant improvement in performance. This alternative leaves step 4 unchanged in that the CPU is still required to perform the copy operation, but it allows a large portion of the copy operation to be done before the frame has been completely received by the controller; i.e., the CPU can perform the copy operation of the receive data from the PCnet-PCI II controllers buffer space into the application buffer space before the frame data has completely arrived from the network. This allows the copy operation of step 4 to be performed concurrently with the arrival of network data, rather than sequentially, following the end of network receive activity. #### **Outline of the LAPP Flow** This section gives a suggested outline for a driver that utilizes the LAPP feature of the PCnet-PCI II controller. **Note**: The labels in the following text are used as references in the timeline diagram that follows. #### SETUP: The driver should set up descriptors in groups of 3, with the OWN and STP bits of each set of three descriptors to read as follows: 11b, 10b, 00b. An option bit (LAPPEN) exists in CSR3, bit position 5; the software should set this bit; When set, the LAPPEN bit directs the PCnet-PCI II controller to generate an INTERRUPT when STP has been written to a receive descriptor by the PCnet-PCI II controller. #### FLOW: The PCnet-PCI II controller polls the current receive descriptor at some point in time before a message arrives. The PCnet-PCI II controller determines that this receive buffer is OWNed by the PCnet-PCI II controller and it stores the descriptor information to be used when a message does arrive. - N0: Frame preamble appears on the wire, followed by SFD and destination address. - N1: The 64th byte of frame data arrives from the wire. This causes the PCnet-PCI II controller to begin frame data DMA operations to the first buffer. - C0: When the 64th byte of the message arrives, the PCnet-PCI II controller performs a lookahead operation to the next receive descriptor. This descriptor should be owned by the PCnet-PCI II controller. - C1: The PCnet-PCI II controller intermittently requests the bus to transfer frame data to the first buffer as it arrives on the wire. - S1: The driver remains idle. - C2: When the PCnet-PCI II controller has completely filled the first buffer, it writes status to the first descriptor. - C3: When the first descriptor for the frame has been written, changing ownership from the PCnet-PCI II controller to the CPU, the PCnet-PCI II controller will generate an SRP INTERRUPT. (This interrupt appears as a RINT interrupt in CSR0). - S1: The SRP INTERRUPT causes the CPU to switch tasks to allow the PCnet-PCI II controllers driver to run. - C4: During the CPU interrupt-generated task switching, the PCnet-PCI II controller is performing a lookahead operation to the third descriptor. At this point in time, the third descriptor is owned by the CPU. Note: Even though the third buffer is not owned by the PCnet-PCI II controller, existing AMD Ethernet ontrollers will continue to perform data DMA into the buffer space that the controller already owns (i.e., buffer number 2). The controller does not know if buffer space in buffer number 2 will be sufficient or not, for this frame, but it has no way to tell except by trying to move the entire message into that space. Only when the message does not fit will it signal a buffer error condition – there is no need to panic at the point that it discovers that it does not yet own descriptor number 3. - S2: The first task of the drivers interrupt service routine is to collect the header information from the PCnet-PCI II controllers first buffer and pass it to the application. - S3: The application will return an application buffer pointer to the driver. The driver will add an offset to the application data buffer pointer, since the PCnet-PCI II controller will be placing the first portion of the message into the first and second buffers. (The modified application data buffer pointer will only be directly used by the PCnet-PCI II controller when it reaches the third buffer.) The driver will place the modified data buffer pointer into the final descriptor of the group (#3) and will grant ownership of this descriptor to the PCnet-PCI II controller. - C5: Interleaved with S2, S3 and S4 driver activity, the PCnet-PCI II controller will write frame data to buffer number 2. - S4: The driver will next proceed to copy the contents of the PCnet-PCI II controllers first buffer to the beginning of the application space. This copy will be to the exact (unmodified) buffer pointer that was passed by the application. - S5: After copying all of the data from the first buffer into the beginning of the application data buffer, the driver will begin to poll the ownership bit of the second descriptor. The driver is waiting for the PCnet-PCI II controller to finish filling the second buffer. - C6: At this point, knowing that it had not previously owned the third descriptor, and knowing that the current message has not ended (there is more data in the FIFO), the PCnet-PCI II controller will make a last ditch lookahead to the final (third) descriptor. This time, the ownership will be TRUE (i.e. the descriptor belongs to the controller), because the driver wrote the application pointer into this descriptor and then changed the ownership to give the descriptor to the PCnet-PCI II controller - back at S3. Note that if steps S1, S2 and S3 have not completed at this time, a BUFF error will result. - C7: After filling the second buffer and performing the last chance lookahead to the next descriptor, the PCnet-PCI II controller will write the status and change the ownership bit of descriptor number 2. - S6: After the ownership of descriptor number 2 has been changed by the PCnet-PCI II controller, the next driver poll of the 2nd descriptor will show ownership granted to the CPU. The driver now copies the data from buffer number 2 into the middle section of the application buffer space. This operation is interleaved with the C7 and C8 operations. - C8: The PCnet-PCI II controller will perform data DMA to the last buffer, whose pointer is pointing to application space. Data entering the last buffer will not need the infamous double copy that is re- - quired by existing drivers, since it is being placed directly into the application buffer space. - N2: The message on the wire ends. - S7: When the driver completes the copy of buffer number 2 data to the application buffer space, it begins polling descriptor number 3. - C9: When the PCnet-PCI II controller has finished all data DMA operations, it writes status and changes ownership of descriptor number 3. - S8: The driver sees that the ownership of descriptor number 3 has changed, and it calls the application to tell the application that a frame has arrived. - S9: The application processes the received frame and generates the next TX frame, placing it into a TX buffer. - S10: The driver sets up the TX descriptor for the PCnet-PCI II controller. 19436B-75 Figure D1. LAPP Timeline ## **LAPP Software Requirements** Software needs to set up a receive ring with descriptors formed into groups of 3. The first descriptor of each group should have OWN = 1 and STP = 1, the second descriptor of each group should have OWN = 1 and STP = 0. The third descriptor of each group should have OWN = 0 and STP = 0. The size of the first buffer (as indicated in the first descriptor), should be at least equal to the largest expected header size; however, for maximum efficiency of CPU utilization, the first buffer size should be larger than the header size. It should be equal to the expected number of message bytes, minus the time needed for Interrupt latency and minus the application call latency, minus the time needed for the driver to write to the third descriptor, minus the time needed for the driver to copy data from buffer #1 to the application buffer space, and minus the time needed for the driver to copy data from buffer #2 to the applica- 206 Am79C976 tion buffer space. Note that the time needed for the copies performed by the driver depends upon the sizes of the 2nd and 3rd buffers, and that the sizes of the second and third buffers need to be set according to the time needed for the data copy operations! This means that an iterative self-adjusting mechanism needs to be placed into the software to determine the correct buffer sizing for optimal operation. Fixed values for buffer sizes may be used; in such a case, the LAPP method will still provide a significant performance increase, but the performance increase will not be maximized. The following diagram illustrates this setup for a receive ring size of 9: 19436B-76 Figure D2. LAPP 3 Buffer Grouping #### **LAPP Rules for Parsing of Descriptors** When using the LAPP method, software must use a modified form of descriptor *parsing* as follows: - Software will examine OWN and STP to determine where a RCV frame begins. RCV frames will only begin in buffers that have OWN = 0 and STP = 1. - Software shall assume that a frame continues until it finds either ENP = 1 or ERR= 1. - Software must discard all descriptors with OWN = 0 and STP = 0 and move to the next descriptor when searching for the beginning of a new frame; ENP and ERR should be ignored by software during this search. - Software cannot change an STP value in the receive descriptor ring after the initial setup of the ring is complete, even if software has ownership of the STP descriptor unless the previous STP descriptor in the ring is also OWNED by the software. When LAPPEN = 1, then hardware will use a modified form of descriptor parsing as follows: - The controller will examine OWN and STP to determine where to begin placing a RCV frame. A new RCV frame will only begin in a buffer that has OWN= 1 and STP = 1. - The controller will always obey the OWN bit for determining whether or not it may use the next buffer for a chain. - The controller will always mark the end of a frame with either ENP = 1 or ERR= 1. The controller will discard all descriptors with OWN = 1 and STP = 0 and move to the next descriptor when searching for a place to begin a new frame. It discards these descriptors by simply changing the ownership bit from OWN=1 to OWN = 0. Such a descriptor is unused for receive purposes by the controller, and the driver must recognize this. (The driver will recognize this if it follows the software rules). The controller will ignore all descriptors with OWN = 0 and STP = 0 and move to the next descriptor when searching for a place to begin a new frame. In other words, the controller is allowed to skip entries in the ring that it does not own, but only when it is looking for a place to begin a new frame. # Some Examples of LAPP Descriptor Interaction Choose an expected frame size of 1060 bytes. Choose buffer sizes of 800, 200 and 200 bytes. Assume that a 1060 byte frame arrives correctly, and that the timing of the early interrupt and the software is smooth. The descriptors will have changed from: | Descriptor | Before the Frame Arrives | | | After | the Frame A | Comments | | |------------|--------------------------|-----|------------------|-------|-------------|------------------|-------------------------------| | Number | OWN | STP | ENP <sup>†</sup> | OWN | STP | ENP <sup>†</sup> | (After frame arrival) | | 1 | 1 | 1 | Х | 0 | 1 | 0 | Bytes 1–800 | | 2 | 1 | 0 | Х | 0 | 0 | 0 | Bytes 801–1000 | | 3 | 0 | 0 | Х | 0 | 0 | 1 | Bytes 1001–1060 | | 4 | 1 | 1 | Х | 1 | 1 | Х | Controller's current location | | 5 | 1 | 0 | Х | 1 | 0 | Х | Not yet used | | 6 | 0 | 0 | Х | 0 | 0 | Х | Not yet used | | etc. | 1 | 1 | Х | 1 | 1 | Х | Not yet used | <sup>†</sup> ENP or ERR ■ Assume that instead of the expected 1060 byte frame, a 900 byte frame arrives, either because there was an error in the network, or because this is the last frame in a file transmission sequence. | Descriptor | Before | Before the Frame Arrives After the Frame Arrived | | | | Comments | | |------------|--------|--------------------------------------------------|------------------|-----|-----|------------------|-------------------------------| | Number | OWN | STP | ENP <sup>†</sup> | OWN | STP | ENP <sup>†</sup> | (After frame arrival) | | 1 | 1 | 1 | Х | 0 | 1 | 0 | Bytes 1–800 | | 2 | 1 | 0 | Х | 0 | 0 | 1 | Bytes 801–900 | | 3 | 0 | 0 | Х | 0 | 0 | ?* | Discarded buffer | | 4 | 1 | 1 | Х | 1 | 1 | Х | Controller's current location | | 5 | 1 | 0 | Х | 1 | 0 | Х | Not yet used | | 6 | 0 | 0 | Х | 0 | 0 | Х | Not yet used | | etc. | 1 | 1 | X | 1 | 1 | Х | Not yet used | <sup>†</sup> ENP or ERR Note that the PCnet-PCI II controller might write a ZERO to ENP location in the 3rd descriptor. Here are the two possibilities: - If the controller finishes the data transfers into buffer number 2 after the driver writes the applications modified buffer pointer into the third descriptor, then the controller will write a ZERO to ENP for this buffer and will write a ZERO to OWN and STP. - 2. If the controller finishes the data transfers into buffer number 2 before the driver writes the applications modified buffer pointer into the third descriptor, then the controller will complete the frame in buffer number two and then skip the then unowned third buffer. In this case, the PCnet-PCI II controller will not have had the opportunity to RESET the ENP bit in this descriptor, and it is possible that the software left this bit as ENP=1 from the last time through the ring. Therefore, the software must treat the location as a don't care; The rule is, after finding ENP=1 (or ERR=1) in descriptor number 2, the software must ignore ENP bits until it finds the next STP=1. - Assume that instead of the expected 1060 byte frame, a 100 byte frame arrives, because there was an error in the network, or because this is the last frame in a file transmission sequence, or perhaps because it is an acknowledge frame. - \* Same as note in case 2 above, except that in this case, it is very unlikely that the driver can respond to the interrupt and get the pointer from the application before the PCnet-PCI II controller has completed its poll of the next descriptors. This means that for almost all occurrences of this case, the PCnet-PCI II controller will not find the OWN bit set for this descriptor and therefore, the ENP bit will almost always contain the old value, since the PCnet-PCI II controller will not have had an opportunity to modify it. - \*\* Note that even though the PCnet-PCI II controller will write a ZERO to this ENP location, the software should treat the location as a don't care, since after finding the ENP=1 in descriptor number 2, the software should ignore ENP bits until it finds the next STP=1. | Descriptor | Before | e the Frame A | rrives | After | the Frame A | Comments | | |------------|--------|---------------|--------------------------|-------|------------------|-----------------------|-------------------------------| | Number | OWN | STP | ENP <sup>†</sup> OWN STP | | ENP <sup>†</sup> | (After frame arrival) | | | 1 | 1 | 1 | Х | 0 | 1 | 1 | Bytes 1–100 | | 2 | 1 | 0 | Х | 0 | 0 | 0** | Discarded buffer | | 3 | 0 | 0 | Х | 0 | 0 | ?* | Discarded buffer | | 4 | 1 | 1 | Х | 1 | 1 | Х | Controller's current location | | 5 | 1 | 0 | Х | 1 | 0 | Х | Not yet used | | 6 | 0 | 0 | Х | 0 | 0 | Х | Not yet used | | etc. | 1 | 1 | Х | 1 | 1 | Х | Not yet used | <sup>†</sup> ENP or ERR #### **Buffer Size Tuning** For maximum performance, buffer sizes should be adjusted depending upon the expected frame size and the values of the interrupt latency and application call latency. The best driver code will minimize the CPU utilization while also minimizing the latency from frame end on the network to frame sent to application from driver (frame latency). These objectives are aimed at increasing throughput on the network while decreasing CPU utilization. Note that the buffer sizes in the ring may be altered at any time that the CPU has ownership of the corresponding descriptor. The best choice for buffer sizes will maximize the time that the driver is swapped out, while minimizing the time from the last byte written by the PCnet-PCI II controller to the time that the data is passed from the driver to the application. In the diagram, this corresponds to maximizing S0, while minimizing the time between C9 and S8. (The timeline happens to show a minimal time from C9 to S8.) Note that by increasing the size of buffer number 1, we increase the value of S0. However, when we increase the size of buffer number 1, we also increase the value of S4. If the size of buffer number 1 is too large, then the driver will not have enough time to perform tasks S2, S3, S4, S5 and S6. The result is that there will be delay from the execution of task C9 until the execution of task S8. A perfectly timed system will have the values for S5 and S7 at a minimum. An average increase in performance can be achieved if the general guidelines of buffer sizes in figure 2 is followed. However, as was noted earlier, the correct sizing for buffers will depend upon the expected message size. There are two problems with relating expected message size with the correct buffer sizing: - Message sizes cannot always be accurately predicted, since a single application may expect different message sizes at different times, therefore, the buffer sizes chosen will not always maximize throughput. - 2. Within a single application, message sizes might be somewhat predictable, but when the same driver is to be shared with multiple applications, there may not be a common predictable message size. Additional problems occur when trying to define the correct sizing because the correct size also depends upon the interrupt latency, which may vary from system to system, depending upon both the hardware and the software installed in each system. In order to deal with the unpredictable nature of the message size, the driver can implement a self tuning mechanism that examines the amount of time spent in tasks S5 and S7 as such: while the driver is polling for each descriptor, it could count the number of poll operations performed and then adjust the number 1 buffer size to a larger value, by adding "t" bytes to the buffer count, if the number of poll operations was greater than "x". If fewer than "x" poll operations were needed for each of S5 and S7, then the software should adjust the buffer size to a smaller value by, subtracting "y" bytes from the buffer count. Experiments with such a tuning mechanism must be performed to determine the best values for "X" and "y". Note whenever the size of buffer number 1 is adjusted, buffer sizes for buffer number 2 and buffer 3 should also be adjusted. In some systems, the typical mix of receive frames on a network for a client application consists mostly of large data frames, with very few small frames. In this case, for maximum efficiency of buffer sizing, when a frame arrives under a certain size limit, the driver should not adjust the buffer sizes in response to the short frame. # An Alternative LAPP Flow—the TWO Interrupt Method An alternative to the above suggested flow is to use two interrupts, one at the start of the receive frame and the other at the end of the receive frame, instead of just looking for the SRP interrupt as was described above. This alternative attempts to reduce the amount of time that the software wastes while polling for descriptor own bits. This time would then be available for other CPU tasks. It also minimizes the amount of time the CPU needs for data copying. This savings can be applied to other CPU tasks. The time from the end of frame arrival on the wire to delivery of the frame to the application is labeled as frame latency. For the one-interrupt method, frame latency is minimized, while CPU utilization increases. For the two-interrupt method, frame latency becomes greater, while CPU utilization decreases. Note that some of the CPU time that can be applied to non-Ethernet tasks is used for task switching in the CPU. One task switch is required to swap a non-Ethernet task into the CPU (after S7A) and a second task switch is needed to swap the Ethernet driver back in again (at S8A). If the time needed to perform these task switches exceeds the time saved by not polling descriptors, then there is a net loss in performance with this method. Therefore, the LAPP method implemented should be carefully chosen. 210 Am79C976 Figure D3 shows the event flow for the two-interrupt method: 19436B-77 211 Figure D3. LAPP Timeline for TWO-INTERRUPT Method Figure D4 shows the buffer sizing for the two-interrupt method. Note that the second buffer size will be about the same for each method. 19436B-78 Figure D4. LAPP 3 Buffer Grouping for TWO-INTERRUPT Method There is another alternative which is a marriage of the two previous methods. This third possibility would use the buffer sizes set by the two-interrupt method, but would use the polling method of determining frame end. This will give good frame latency but at the price of very high CPU utilization. And still, there are even- more compromise positions that use various fixed buffer sizes and effectively, the flow of the one-interrupt method. All of these compromises will reduce the complexity of the one-interrupt method by removing the heuristic buffer sizing code, but they all become less efficient than heuristic code would allow. 212 Am79C976 # PCnet-PCI II and PCnet-PCI Differences #### **OVERVIEW** This appendix summarizes the enhancements of the Am79C970A PCnet-PCI II controller over the Am79C970 PCnet-PCI controller. The feature summary is followed by a detailed list of all register bit changes. The document also compares the pinout of the PCnet-PCI II controller with the pinout of the PCnet-PCI and the Am79C974 PCnet-SCSI (also known as Golden Gate) to show that the Flex-I/O footprint is continued to be supported. #### **NEW FEATURES** - Three Volt support for PCI bus interface - Full Duplex Ethernet - 272-byte Transmit FIFO, 256-byte Receive FIFO - Enhanced PCI bus transfer cycles: - No more address stepping - Initialization Block read in non-burst (default) or burst mode - Added new software style and reordered the descriptor entries to allow burst transfers for both, descriptor read and write accesses - FIFO DMA bursts length programmable from 1 to indefinite - Type of memory command for burst read transfers programmable to be either Memory Read Line or Memory Read Multiple (controlled by MEMCMD, BCR18, bit 9) - Support for fast back-to-back slave transactions even when the first transaction is addressing a different target MEMCMD, BCR18, bit 9) - Enhanced disconnect of I/O burst access - Allows I/O resources to be memory mapped - Eight-bit programmable PCI Latency Timer. MIN\_GNT and MAX\_LAT programmable via EEPROM - System interrupt for data parity error, master abort or target abort in master cycles - Network activity is terminated in an orderly sequence after a master or target abort - Advanced parity error handling. Mode has enable bit and status bit in RMD1 and TMD1. All network - activity is terminated in an orderly sequence. Will only work with 32-bit software structures. - All registers in the PCI configuration space are cleared by H RESET - Expansion ROM interface supporting devices of up to 64 K x 8. One external address latch is required. - Reading from the S\_RESET port returns TRDY right away - REQ deassertion programmable to adapt to the requirements of some embedded systems - INTA pin programmable for pulse mode to adapt to the requirements of some embedded systems - Some previously reserved locations in the EEPROM map are now used for new features - Suspend mode for graceful stop and access to the CSR without reinitialization - User Interrupt - Reduced number of transmit interrupts: - Transmit OK disable (CSR5, bit 15). When bit is set to ONE, a transmit interrupt is only generated on frames that suffer an error. - Last Transmit Interrupt. TMD1, bit 28 is read by the PCnet-PCI II controller to determine if an interrupt should be generated at the end of the frame. Only interrupts for successful transmission can be suppressed. Enabled by LTINTEN (CSR5, bit 14). - Disable Transmit Stop on Underflow (CSR3, bit 6) bit. PCnet-PCI controller recovers automatically from transmit underflow. - Interrupt indication when coming out of sleep mode - Interrupt indication for Excessive Deferral - Address match information in Receive Descriptor - Asserting SLEEP shuts down the entire device - S\_RESET (reading the RESET register) does not affect the TMAU, except for the T-MAU in snooze mode - LED registers programmable via EEPROM. - Magic Packet Mode - EADI interface. Multiplexed with the same LED pins as for the Am79C965 PCnet-32. - JTAG interface - Fourth LED supported - Pin to disable external transceiver or DC-to-DC converter. Polarity of assertion state programmable # LIST OF REGISTER BIT CHANGES # PCI Configuration Space #### **Command Register** - ADSTEP (bit 7) now hardwired to ZERO. Was hardwired to ONE. - MEMEN (bit 1) now read/write accessible. Was hardwired to ZERO. #### **Status Register** - PERR (bit 15) now cleared by H\_RESET. Was not effected by H\_RESET. - SERR (bit 14) now cleared by H\_RESET. Was not effected by H\_RESET. - RMABORT (bit 13) now cleared by H\_RESET. Was not effected by H\_RESET. - RTABORT (bit 12) now cleared by H\_RESET. Was not effected by H\_RESET. - STABORT (bit 11) now cleared by H\_RESET. Was not effected by H\_RESET. - DATAPERR (bit 8) now cleared by H\_RESET. Was not effected by H\_RESET. - FBTBC (bit 7) now hardwired to ONE. Was hardwired to ZERO. #### **Revision ID Register** ■ This 8-bit register is now hardwired to 1xh. It was hardwired to 0xh. #### **Latency Timer Register** ■ This 8-bit register is now read/write accessible. Was hardwired to ZERO. #### I/O Base Address Register ■ IOBASE (bits 31--5) now cleared by H\_RESET. Was not effected by H\_RESET. #### Memory Mapped I/O Base Address Register New 32-bit register. Was reserved, read as ZERO, writes have no effect. #### **Expansion ROM Base Address Register** New 32-bit register. Was reserved, read as ZERO, writes have no effect. #### **Interrupt Line Register** ■ This 8-bit register is now cleared by H\_RESET. Was not effected by H\_RESET. #### MIN\_GNT Register ■ New 8-bit register. Was reserved, read as ZERO, writes have no effect. #### MAX\_LAT Register New 8-bit register. Was reserved, read as ZERO, writes have no effect. #### **Control And Status Registers** # CSR0: PCnet-PCI II controller Control and Status Register ■ In addition to the existing interrupt flags, INTR (bit 7), the interrupt summary bit, is also affected by the new interrupt flags Excessive Deferral Interrupt (EXDINT), Magic Packet Interrupt (MPINT) Sleep Interrupt (SLPINT), System Interrupt (SINT) and User Interrupt (UINT). #### **CSR3: Interrupt Masks and Deferral Control** New bit: DXSUFLO (bit 6), Disable Transmit Stop on Underflow error. Was reserved location, read and written as ZERO. #### **CSR4: Test and Features Control** - New bit: UINTCMD (bit 7), User Interrupt Command. Was reserved location, read and written as ZERO. - New bit: UINT (bit 6), User Interrupt. Was reserved location, read as ZERO, written as ONE or ZERO. #### CSR5: - New bit: TOKINTD (bit 15), Transmit OK Interrupt Disable. Was reserved location, read and written as ZERO. - New bit: LTINTEN (bit 14), Last Transmit Interrupt Enable. Was reserved location, read and written as ZERO. - New bit: SINT (bit 11), System Interrupt. Was reserved location, read and written as ZERO. - New bit: SINTE (bit 10), System Interrupt Enable. Was reserved location, read and written as ZERO. - New bit: SLPINT (bit 9), Sleep Interrupt. Was reserved location, read and written as ZERO. - New bit: SLPINTE (bit 8), Sleep Interrupt Enable. Was reserved location, read and written as ZERO. - New bit: EXDINT (bit 7), Excessive Deferral Interrupt. Was reserved location, read and written as ZERO. - New bit: EXDINTE (bit 6), Excessive Deferral Interrupt Enable. Was reserved location, read and written as ZERO. - New bit: MPPLBA (bit 5), Magic Packet Physical Logical Broadcast Accept. Was reserved location, read and written as ZERO. - New bit: MPINT (bit 4), Magic Packet Interrupt. Was reserved location, read and written as ZERO. - New bit: MPINTE (bit 3), Magic Packet Interrupt Enable. Was reserved location, read and written as ZERO. - New bit: MPEN (bit 2), Magic Packet Enable. Was reserved location, read and written as ZERO. - New bit: MPMODE (bit 1), Magic Packet Mode. Was reserved location, read and written as ZERO. - New bit: SPND (bit 0), Suspend. Was reserved location, read and written as ZERO. #### **CSR58: Software Style** - New bit: APERREN (bit 10), Advanced Parity Error Handling Enable. Was reserved location, read and written as ZERO. - SWSTYLE (bits 7–0), Software Style. New option, value of THREE selects new PCnet-PCI controller style that reorders 32-bit descriptor entries to allow burst accesses. # **CSR80: DMA Transfer Counter and FIFO Threshold Control** - RCVFW (bits 13–12), Receive FIFO Watermark. Decoding adjusted for the larger FIFO size. - XMTSP (bits 11–10), Transmit Start Point. Decoding adjusted for the larger FIFO size. - XMTFW (bits 9–8), Transmit FIFO Watermark. Decoding adjusted for the larger FIFO size. - DMATC (bits 7–0), DMA Transfer Count. Function of the counter is optimized for the PCI bus environment. #### **CSR82: Bus Activity Timer** ■ DMABAT (bits 15–0), DMA Bus Activity Timer. Function of the counter is optimized for the PCI bus environment. #### **CSR88: Chip ID Lower** ■ New value: 1003h. Was 0003h. #### **CSR89: Chip ID Upper** New value: 0262h. Was 0243h. #### **CSR100: Bus Timeout** Default value now 0600h (153.6 μs) to adjust to the larger FIFO size. Default value was 0200h (51.2 μs). #### **CSR112: Missed Frame Count** Counter is stopped while the device is in suspend mode #### **Bus Configuration Registers** #### **BCR2: Miscellaneous Configuration** - New bit: INTLEVEL (bit 7), Interrupt Level. Was reserved location, read and written as ZERO. - New bit: DXCVRCTL (bit 5), DXCVR Control. Was reserved location, read and written as ZERO. - New bit: DXCVRPOL (bit 4), DXCVR Polarity. Was reserved location, read and written as ZERO. New bit: EADISEL (bit 3), EADI Select. Was reserved location, read and written as ZERO. #### **BCR4: Link Status LED** - Register is now programmable through the EEPROM - New bit: MPSE (bit 9), Magic Packet Status Enable. Was reserved location, read and written as ZERO. - New bit: FDLSE (bit 8), Full Duplex Link Status Enable. Was reserved location, read and written as ZERO. - COLE (bit 0), Collision Status Enable. Corrected behavior of function. LED will not light up due to SQE test collision signal. #### **BCR5: LED1 Status** - Register is now programmable through the EEPROM - New bit: MPSE (bit 9), Magic Packet Status Enable. Was reserved location, read and written as ZERO. - New bit: FDLSE (bit 8), Full Duplex Link Status Enable. Was reserved location, read and written as ZERO. - COLE (bit 0), Collision Status Enable. Corrected behavior of function. LED will not light up due to SQE test collision signal. #### **BCR6: LED2 Status** New register. Was reserved location, the settings of the register have no effect on the operation of the device. #### **BCR7: LED3 Status** - Register is now programmable through the EEPROM - New bit: MPSE (bit 9), Magic Packet Status Enable. Was reserved location, read and written as ZERO. - New bit: FDLSE (bit 8), Full Duplex Link Status Enable. Was reserved location, read and written as ZERO. - COLE (bit 0), Collision Status Enable. Corrected behavior of function. LED will not light up due to SQE test collision signal. #### **BCR9: Full Duplex Control** New register. Was reserved location, read and written as ZERO. #### BCR16: I/O Base Address Lower ■ This register is no longer programmable through the EEPROM. The register is reserved and has no effect on the operation of the device. It is only used in the PCnet-32. #### BCR17: I/O Base Address Upper ■ This register is no longer programmable through the EEPROM. The register is reserved and has no ef- 215 fect on the operation of the device. It is only used in the PCnet-32. #### **BCR18: Burst Size and Bus Control** - New bits: ROMTMG (bits 15–12), Expansion ROM Timing. Was reserved location, read and written as ZERO. - New bit: MEMCMD (bit 9), Memory Command. Was reserved location, read and written as ZERO. - New bit: EXTREQ (bit 8), Extended Request. Was reserved location, read and written as ONE. - BREADE (bit 6), Burst Read Enable. Extended functionality of bit. Besides enabling burst read accesses to the transmit buffer, BREADE will now also enable burst read accesses to the initialization block and, if SWSTYLE = 3, to the descriptor ring entries. - BWRITE (bit 5), Burst Write Enable. Extended functionality of bit. Besides enabling burst write accesses to the receive buffer, BWRITE will now also enable burst write accesses to the descriptor ring entries, if SWSTYLE = 3. - LINBC (bits 2–0), Linear Burst Count. These bits are now reserved and have no effect on the operation of the device. #### **BCR20: Software Style** - New bit: APERREN (bit 10), Advanced Parity Error Handling Enable. Was reserved location, read and written as ZERO. - SWSTYLE (bits 7–0), Software Style. New option, value of THREE selects new PCnet-PCI controller style that reorders 32-bit descriptor entries to allow burst accesses. #### **BCR21: Interrupt Control** ■ This register is no longer programmable through the EEPROM. The register is reserved and has no effect on the operation of the device. It is only used in the PCnet-32. #### **BCR22: PCI Latency** New register. Was reserved location, read and written as ZERO. #### **Receive Descriptor** #### RMD1 - New bit: BPE (bit 23), Bus Parity Error. This bit is active only if 32-bit software structures are used for the descriptor ring entries (SWSTYLE = ONE, TWO or THREE) and if APERREN (BCR20, bit 10) is set to ONE. Was reserved location, read and written as ZERO. - New bit: PAM (bit 22), Physical Address Match. This bit is active only if 32-bit software structures are used for the descriptor ring entries (SWSTYLE = ONE, TWO or THREE). Was reserved location, read and written as ZERO. - New bit: LAFM (bit 21), Logical Address Filter Match. This bit is active only if 32-bit software structures are used for the descriptor ring entries (SW-STYLE = ONE, TWO or THREE). Was reserved location, read and written as ZERO. - New bit: BAM (bit 20), Broadcast Address Match. This bit is active only if 32-bit software structures are used for the descriptor ring entries (SWSTYLE = ONE, TWO or THREE). Was reserved location, read and written as ZERO. ## **Transmit Descriptor** #### TMD1 - New bit: LTINT (bit 28), Last Transmit Interrupt. This bit is only active, if LTINTEN (CSR5, bit 14) is set to ONE. This bit location is shared with the MORE status bit. The host will write the bit as LTINT and read it as MORE. The P2 will read the bit as LTINT and write it as MORE. - New bit: BPE (bit 23), Bus Parity Error. This bit is only active, if 32-bit software structures are used for the descriptor ring entries (SWSTYLE = ONE, TWO or THREE) and if APERREN (BCR20, bit 10) is set to ONE. Was reserved location, read and written as ZERO. # **LIST OF PIN CHANGES** | Pin No. | PCnet-SCSI | PCnet-PCI | PCnet-PCI II | Comment | |---------|------------|-----------|----------------|-----------------------------------------------------------------------------------------------------------------| | 9 | IDSELA | NC | TDI | CIN must be 8 pF maximum. (PCI spec. on IDSEL input). | | 58 | PWDN | NC | EAR | Inputs only, EAR is ignored until EADI interface is enabled. | | 60 | SCSICLK | NC | EROE | External SCSI components must be depopulated. | | 62 | BUSY/NOUT | NOUT | DXCVR/NOUT | External SCSI components must be depopulated. | | 64 | SCSI BSY | NC | ERACLK | External SCSI components must be depopulated. | | 65 | SCSI ATN | NC | ERA7 | External SCSI components must be depopulated. | | 66 | SCSI RST | NC | ERA6 | External SCSI components must be depopulated. | | 68 | SCSI DS | NC | ERA5 | External SCSI components must be depopulated. | | 69 | SCSI SD1 | NC | ERA4 | External SCSI components must be depopulated. | | 70 | SCSI SD2 | NC | ERA3 | External SCSI components must be depopulated. | | 71 | SCSI SD3 | NC | ERA2 | External SCSI components must be depopulated. | | 73 | SCSI SD4 | NC | ERA1 | External SCSI components must be depopulated. | | 74 | SCSI SD5 | NC | ERA0 | External SCSI components must be depopulated. | | 75 | SCSI SD6 | NC | ERD7/TXDAT | External SCSI components must be depopulated. | | 77 | SCSI SD7 | NC | ERD6/TXEN | External SCSI components must be depopulated. | | 78 | SCSI SDP | NC | ERD5 | External SCSI components must be depopulated. | | 80 | SCSI SEL | NC | ERD4/TXCLK | External SCSI components must be depopulated. | | 81 | SCSI REQ | NC | ERD3/CLSN | External SCSI components must be depopulated. | | 83 | SCSI ACK | NC | ERD2/RXEN | External SCSI components must be depopulated. | | 85 | SCSI MSG | NC | ERD1/RXCLK | External SCSI components must be depopulated. | | 86 | SCSI C/D | NC | ERD0/RXDAT | External SCSI components must be depopulated. | | 87 | SCSI I/O | NC | LED2/SRDCLK | External SCSI components must be depopulated. | | 110 | EEDO/LED3 | EEDO/LED3 | EEDO/LED3/SRD | EADI interface is only active when enabled by setting a bit in a BCR. | | 112 | EESK/LED1 | EESK/LED1 | EESK/LED1/SFBD | EADI interface is only active when enabled by setting a bit in a BCR. | | 116 | RESERVED | RESERVED | RESERVED | | | 118 | ĪNTB | NC | TCK | TCK is the JTAG clock input. The JTAG interface is inactive, until TCK is running. TCK has an internal pull-up. | | 124 | GNTA | NC | TMS | TMS is the JTAG test mode select input. TMS is only active if TCK is running. | | 127 | REQA | NC | TDO | JTAG TDO output is tri-state after power-on reset. | # Am79C970A PCnet-PCI II # Silicon Errata Report #### Am79C970A PC-net-PCI II Rev B2 Silicon Errata The items below are the known errata for Rev B2 silicon. Rev B2 silicon is the production silicon. This device has a total of nine known errata. One is AC timing related and the other eight are functional errata. The AC issue is related to an extended maximum limit on tval for specific pins. The eight functional errata are related to the DWIO mode operation, the JTAG mode operation, the GPSI port, bus parking operation, LED status indication, LAPP mode operation, excess deferral interrupt operation, and false BABL indication, respectively. The "**Description**" section of this document gives an external description of the problem. The "**Implication**" section explains how the device behaves and its impact on the system. The "**Workaround**" section describes a work around for the problem. The "**Status**" section indicates when and how the problem will be fixed. Current package marking for this revision: Line 1: <Logo> Line 2: PCnet(tm)-PCI II Line 3: Am79C970AKC (Assuming package is PQFP) Line 4: <Date Code> A/B (Where A = Fab 15 & B = Fab 14) Line 5: (c) 1994 AMD Value of chip id registers, CSR89+CSR88 [31:0] for this revision = 62621003h. (When read in 16 bit mode.) PCI Configuration Register (offset 0x08h) = xxxxxx16h. 1) Description: The PCnet-PCI II device exceeds one PCI timing parameter by one ns. **Implication:** The device exceeds the PCI timing parameter for tval on certain signals. Under worst-case conditions the *tval for AD, C/BE#, and PAR* can exceed 11 ns. All other AC timing parameters meet the PCI specification values. All PCnet-PCI II production devices are screened to this new tval maximum limit, except those material with a mark date code of 9525APA. Devices with this date code were screened to the previous tval max, limit of 14.0 ns for AD, C/BE#, and PAR signals. | Parameter | PCI Spec Min | PCI Spec<br>Max | B2 Min | B2 Max | |--------------------------------------------------|--------------|-----------------|--------------|--------------| | Valid Delay Timing | | | | | | t <sub>VAL</sub> (AD, C/BE#, PAR) | 2.0 | 11.0 | same as spec | 12.0 | | t <sub>VAL</sub> (all other signals except REQ#) | 2.0 | 11.0 | same as spec | same as spec | | t <sub>VAL</sub> (REQ#) | 2.0 | 12.0 | same as spec | same as spec | | Setup Timing | | | | | | t <sub>SU</sub> (all signals except GNT#) | 7.0 | _ | same as spec | | | t <sub>SU</sub> (GNT#) | 10.0 | _ | same as spec | _ | | Hold Timing | | | | | | t <sub>H</sub> (all signals) | 0 | _ | same as spec | _ | <u>Note</u>: The **B2 Max** column shows the absolute worst-case value for this parameter. This value is guaranteed over the data sheet-specified Vcc and temperature ranges. The worst-case value is determined based on preliminary characterization data. Upon completion of device characterization, this value may be improved. Workaround: None. **Status:** No current plan to fix this item. Am79C976 219 2) Description: The PERR# output glitches when configuring the PCnet-PCI II device to operate in DWIO (Double-Word I/O) mode and the PERREN bit in the PCI Command Register is set. The glitch occurs near the end of the slave write cycle to offset 10H. **Implication:** Due to the glitch on PERR# during the DWIO initialization cycle, tval of PERR# is more than 11 ns during the cycle immediately following the initialization cycle. tval of PERR# could be 12 ns during that cycle. tval of PERR# is guaranteed to be 11 ns on all other cycles. There is no jeopardy to customers using AMD drivers. AMD drivers do not place the device into DWIO mode. Setting the device into 32-bit I/O mode is usually the first operation after a hardware reset or a software reset, so the workaround described below need only to take place once during DWIO initialization. All software, including diagnostic programs, should be reviewed. Word I/O mode is not affected. **Workaround:** Do not set the PERREN bit (bit 6 in the PCI Command Register) while initializing to DWIO mode. Once the device is in DWIO mode, the PERREN bit can then be set to enable parity error response functions. Status: No current plan to fix this item. 3) Description: The DXCVR and ERA[7:0] pins may output unexpected values in JTAG mode. **Implication:** Normal JTAG testing is not affected. NAND Tree testing is not affected. Workaround: Ignore the outputs on the DXCVR and the ERA[7:0] pins in JTAG mode. Status: No current plan to fix this item. **4) Description:** The *GPSI (General Purpose Serial Interface) mode does not function*, in contrast to previous versions of the PCnet-PCI II data sheet specifications which indicated that it does function. **Implication:** The GPSI mode cannot be used. This impacts all applications that interface the PCnet-PCI II device to other devices via the GPSI port, such as interfacing to an external SIA and transceiver combination. **Workaround:** None. Do not use the device in GPSI mode. All references to the GPSI mode has been deleted from this version of the PCnet-PCI II datasheet specification. **Status:** No current plan to fix this item. 5) Description: When *last-bus-mastering parking* is selected and when the PCnet-PCI II controller is parked more than 33 PCI clock cycles after the controller has completed a DMA write cycle, if the parking GNT# is asserted at the same time of PCnet-PCI II controller's assertion of REQ#, in an extreme boundary case, the following DMA write may contain incorrect data. Implication: The device only has this problem under the above described extreme boundary condition. **Workaround:** Do not use last-bus-master parking. Or, when using last-bus-master parking, ensure that the PCnet-PCI II controller's parking GNT# is asserted within 33 PCI clocks after the controller has completed a bus mastering cycle. Status: No current plan to fix this item. **6) Description:** The *Link Status LED appears to be stuck ON* when the TMAU receive pins (RXD±) are receiving negative polarity link pulses and the Disable Automatic Polarity Correction bit (DAPC; CSR15, bit 11) is set. **Implication:** The Link Status LED may not indicate correct link status. Workaround: Do not set the DAPC bit to one. Always use the automatic polarity correction feature. Status: No current plan to fix this item. 7) **Description:** The *LAPP mode does not function properly* on the PCnet-PCI II device. In LAPP mode, the PCnet-PCI II device might skip buffers when writing a receive frame to memory. Implication: The LAPP function cannot be used. Workaround: None. **Status:** No current plan to fix this item. **8) Description:** When a *transmit frame has excessively deferred* to receive activity, the EXDEF bit is not set in the transmit descriptor. **Implication:** Software cannot use the EXDEF bit in the transmit descriptor as an indication of excessive deferral **Workaround:** The excessive deferral interrupt (EXDINT; CSR5, bit 7) does function correctly. User can enable this interrupt by setting the EXDINTE bit in CSR5. Status: No current plan to fix this item. 9) Description: The PCnet-PCI device will *intermittently give BABL error indications* when the network traffic has frames equal to or greater than 1518 bytes. **Implication:** False BABL errors on the receiving station can be passed up to the upper layer software if the PCnet-PCI II device is just coming out of deferral and the multi-purpose counter used to count the number of bytes received reaches 1518 at the same time. If the network is heavily loaded with full-size frames, then the probability of a false BABL error is high. **Workaround:** There are two possible workarounds. - 1. If the user has no intention to transmit frames larger than 1518 bytes, then the BABL bit may be masked to ignore babble errors. In this case the false babble error will not cause an interrupt, nor will it be passed to the higher level software. - 2. Check to see if the device is transmitting in ISR (Interrupt Service Routine), which is induced by the BABL error. The BCRs which control the LED settings can be programmed to indicate a transmit activity, assuming the interrupt latency is not longer than one minimum IFG (inter-frame gap) time. ``` If (ISR_LATENCY <9.6 us) True_bable_err=BABL*(TINT + XMT_LED) {i.e. False_bable_err=~(BABL*(TINT + XMT_LED))} else ``` Cannot tell if the BABL error is true or false just by reading BABL, TINT, XMT\_LED bits in ISR. Status: No current plan to fix this item. The contents of this document are provided in connection with Advanced Micro Devices, Inc. ("AMD") products. AMD makes no representations or warranties with respect to the accuracy or completeness of the contents of this publication and reserves the right to make changes to specifications and product descriptions at any time without notice. No license, whether express, implied, arising by estoppel or otherwise, to any intellectual property rights is granted by this publication. Except as set forth in AM's Standard Terms and Conditions of Sale, AMD assumes no liability whatsoever, and disclaims any express or implied warranty, relating to its products including, but not limited to, the implied warranty of merchantability, fitness for a particular purpose, or infringement of any intellectual property right. AMD's products are not designed, intended, authorized or warranted for use as components in systems intended for surgical implant into the body, or in other applications intended to support or sustain life, or in any other application in which the failure of AMD's product could create a situation where personal injury, death, or severe property or environmental damage may occur. AMD reserves the right to discontinue or make changes to its products at any time without notice. #### Trademarks Copyright © 2000 Advanced Micro Devices, Inc. All rights reserved. AMD, the AMD logo, and combinations thereof are trademarks of Advanced Micro Devices, Inc. PCnet, Magic Packet, and Tri-State are trademarks of Advanced Micro Devices, Inc. Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.