# ASSP Communication Network # LAN Controller with PC Card, ISA Bus, and General-purpose Bus Interfaces # **MB86967** #### **■ DESCRIPTION** The MB86967 is a highly-integrated, high-performance single-chip Ethernet LAN controller which contains a PC card interface based on the JEIDA4.2 standard, an ISA bus interface that can be connected directly to the ISA bus, a general-purpose bus interface, a Manchester encoder/decoder based on the IEEE802.3 standard, and 10BASE-T transceiver. The LAN controller and buffer manager are software compatible with the MB86965A and MB86964. The buffer manager has functions for arbitration and buffer management of external buffer memory (SRAM) which can be expanded to 32 KB. These functions provide simultaneous access from the host and data link controller and updating of transmit and receive buffer pointers. This permits substantial reduction of software overhead in buffer management. The Manchester encoder/decoder and 10BASE-T transceiver can be easily interfaced with twisted-pair cable just by addition of a pulse transformer and filter. Mode pin setting allows the system interface to switch between the PC card interface, ISA bus interface, and general-purpose bus interface. When in the ISA bus interface mode, two modes can be selected: a jumperless mode allowing software setting of I/O addresses and interrupt signals, and a jumper mode allowing DIPswitch setting. #### **■ FEATURES** System Interface - Allows switching between PC card interface, ISA bus interface, and general-purpose bus interface - Allows byte swapping of word data according to host CPU (in ISA bus mode and general-purpose bus mode) (Continued) #### **■ PACKAGE** #### (Continued) - Has functions for high-speed burst DMA transfer and single DMA transfer (slave operation) (in ISA bus mode and general-purpose bus mode) - Provides node ID EEPROM interface (in ISA bus mode) - Allows software setting of I/O addresses and interrupt signals (in jumperless mode of ISA bus mode) - Can be connected to 8-bit and 16-bit standard microprocessor buses (in general-purpose bus mode) - Provides JEIDA protocol interface (in PC card mode) - Has overlapping address window function (in PC card mode) - Has memory control (common memory, attribute memory, I/O addresses) (in PC card mode) #### LAN Interface - Contains Manchester encoder/decoder based on IEEE802.3 standard and 10BASE-T transceiver - · Has functions for jabber control, link test, and SQE test - Has functions for inversion detection and automatic correction - Contains LED driver for monitoring network status (link test, collision, transmitting and receiving) - Has function for 10BASE-T external loopback (full-duplex) #### Controller - Software compatible with MB86965A and MB86964 - Has dual-bank transmit buffer and ring receive buffer (expandable to 32 KB) set by program - · Contains 64-bit hash table for multicast address filter - Has function for removing receive long packets (1792-byte or more receive packets) - Has two power-down modes; standby mode (continued crystal oscillation) and shut-down mode (stopped crystal oscillation) #### Others - Aluminum two-layer wiring CMOS technology - 100-pin LQFP package - Power-supply voltage of 5 V ±5% #### ■ PIN ASSIGNMENT #### • PC card mode | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | |---------|-------------------|-----|---------|-------------------|-----|---------|-------------------|-------|---------|-------------------|-----| | 1 | V <sub>DD</sub> 1 | Р | 26 | V <sub>DD</sub> 2 | Р | 51 | V <sub>DD</sub> 3 | Р | 76 | GNDA2 | G | | 2 | INPACK | 0 | 27 | PD11 | BD | 52 | MODE0/LEDL | IU/OD | 77 | TPOPB | 0 | | 3 | WAIT | 0 | 28 | PD4 | BD | 53 | BA6 | 0 | 78 | TPOPA | 0 | | 4 | PA0 | ID | 29 | PD3 | BD | 54 | BA5 | 0 | 79 | TPONA | 0 | | 5 | PA1 | ID | 30 | BCS | 0 | 55 | BA4 | 0 | 80 | TPONB | 0 | | 6 | PA2 | ID | 31 | GND3 | G | 56 | BA3 | 0 | 81 | VDDA2 | Р | | 7 | PA3 | ID | 32 | BWE | 0 | 57 | GND5 | G | 82 | CE1 | IU | | 8 | PA4 | ID | 33 | BOE | 0 | 58 | BA2 | 0 | 83 | CE2 | IU | | 9 | PA5 | ID | 34 | BD7 | В | 59 | BA1 | 0 | 84 | IOIS16 | 0 | | 10 | PA6 | ID | 35 | BD6 | В | 60 | BA0 | 0 | 85 | PD10 | BD | | 11 | PA7 | ID | 36 | BD5 | В | 61 | CLKO | 0 | 86 | GND6 | G | | 12 | PA8 | ID | 37 | BD4 | В | 62 | CLKI | | 87 | PD2 | BD | | 13 | PA9 | ID | 38 | BD3 | В | 63 | RESET2 | ISD | 88 | PD9 | BD | | 14 | PA10 | ID | 39 | BD2 | В | 64 | RESET1 | ISU | 89 | PD1 | BD | | 15 | IORD | IU | 40 | BD1 | В | 65 | LEDR | OD | 90 | PD8 | BD | | 16 | GND1 | G | 41 | BD0 | В | 66 | LEDT | OD | 91 | PD0 | BD | | 17 | IOWR | IU | 42 | BA14 | 0 | 67 | GNDA1 | G | 92 | IREQ | 0 | | 18 | PD15 | BD | 43 | BA13 | 0 | 68 | LEDC | OD | 93 | REG | IU | | 19 | PD14 | BD | 44 | BA12 | 0 | 69 | NC0 | | 94 | V <sub>DD</sub> 4 | Р | | 20 | PD7 | BD | 45 | BA11 | 0 | 70 | VDDA1 | Р | 95 | WE | IU | | 21 | PD13 | BD | 46 | GND4 | G | 71 | TPIP | | 96 | OE | IU | | 22 | PD6 | BD | 47 | BA10 | 0 | 72 | TPIN | - | 97 | ROMAD | 0 | | 23 | PD12 | BD | 48 | BA9 | 0 | 73 | GNDM | I | 98 | ROMS | 0 | | 24 | GND2 | G | 49 | BA8 | 0 | 74 | NC1 | _ | 99 | ROMRD | 0 | | 25 | PD5 | BD | 50 | BA7 | 0 | 75 | NC2 | _ | 100 | GND7 | G | I: Input P: Power supply O:Output ID: Input with pull-down resistor IS: Schmitt input BD: Input/output with pull-down resistor IU: Input with pull-up resistor G:Ground B: Input/output OD:Open-drain output #### • ISA bus mode | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | |---------|-------------------|-----|---------|-------------------|-----|---------|-------------------|------|---------|-------------------|-----| | 1 | V <sub>DD</sub> 1 | Р | 26 | V <sub>DD</sub> 2 | Р | 51 | V <sub>DD</sub> 3 | Р | 76 | GNDA2 | G | | 2 | DREQ | 0 | 27 | SD11 | BD | 52 | LEDL | OD | 77 | TPOPB | 0 | | 3 | IOCHRDY | OD | 28 | SD4 | BD | 53 | BA6 | 0 | 78 | TPOPA | 0 | | 4 | SA0 | ID | 29 | SD3 | BD | 54 | BA5 | 0 | 79 | TPONA | 0 | | 5 | SA1 | ID | 30 | BCS | 0 | 55 | BA4 | 0 | 80 | TPONB | 0 | | 6 | SA2 | ID | 31 | GND3 | G | 56 | BA3 | 0 | 81 | VDDA2 | Р | | 7 | SA3 | ID | 32 | BWE | 0 | 57 | GND5 | G | 82 | SBHE | IU | | 8 | SA4 | ID | 33 | BOE | 0 | 58 | BA2 | 0 | 83 | DMACK | IU | | 9 | SA5 | ID | 34 | BD7 | В | 59 | BA1 | 0 | 84 | IOIS16 | OD | | 10 | SA6 | ID | 35 | BD6 | В | 60 | BA0 | 0 | 85 | SD10 | BD | | 11 | SA7 | ID | 36 | BD5 | В | 61 | CLKO | 0 | 86 | GND6 | G | | 12 | SA8 | ID | 37 | BD4 | В | 62 | CLKI | I | 87 | SD2 | BD | | 13 | SA9 | ID | 38 | BD3 | В | 63 | AEN | ISD | 88 | SD9 | BD | | 14 | ALE | ID | 39 | BD2 | В | 64 | CHRESET | ISU | 89 | SD1 | BD | | 15 | <del>IOR</del> | IU | 40 | BD1 | В | 65 | EOP | ID | 90 | SD8 | BD | | 16 | GND1 | G | 41 | BD0 | В | 66 | LEDT | OD | 91 | SD0 | BD | | 17 | IOW | IU | 42 | BA14 | 0 | 67 | GNDA1 | G | 92 | IREQ0 | 0 | | 18 | SD15 | BD | 43 | BA13 | 0 | 68 | LEDC | OD | 93 | ENHB | 0 | | 19 | SD14 | BD | 44 | BA12 | 0 | 69 | IREQ1/IOSEL0 | IU/O | 94 | V <sub>DD</sub> 4 | Р | | 20 | SD7 | BD | 45 | BA11 | 0 | 70 | VDDA1 | Р | 95 | ENLB | 0 | | 21 | SD13 | BD | 46 | GND4 | G | 71 | TPIP | I | 96 | EEPDO | IU | | 22 | SD6 | BD | 47 | BA10 | 0 | 72 | TPIN | I | 97 | EEPDI | 0 | | 23 | SD12 | BD | 48 | BA9 | 0 | 73 | MODE/LEDR | I/OD | 98 | EEPCS | 0 | | 24 | GND2 | G | 49 | BA8 | 0 | 74 | IREQ2/IOSEL1 | IU/O | 99 | EEPSK | 0 | | 25 | SD5 | BD | 50 | BA7 | 0 | 75 | IREQ3/IOSEL2 | IU/O | 100 | GND7 | G | I: Input P: Power supply O:Output ID: Input with pull-down resistor IS: Schmitt input BD: Input/output with pull-down resistor IU: Input with pull-up resistor G:Ground B: Input/output OD:Open-drain output ### • General-purpose bus mode | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | Pin no. | Symbol | I/O | |---------|-------------------|-----|---------|-------------------|-----|---------|-------------------|-----|---------|-------------------|-----| | 1 | V <sub>DD</sub> 1 | Р | 26 | V <sub>DD</sub> 2 | Р | 51 | V <sub>DD</sub> 3 | Р | 76 | GNDA2 | G | | 2 | DREQ | 0 | 27 | SD11 | BD | 52 | MODE0 | IU | 77 | TPOPB | 0 | | 3 | READY | 0 | 28 | SD4 | BD | 53 | BA6 | 0 | 78 | TPOPA | 0 | | 4 | SA0 | ID | 29 | SD3 | BD | 54 | BA5 | 0 | 79 | TPONA | 0 | | 5 | SA1 | ID | 30 | BCS | 0 | 55 | BA4 | 0 | 80 | TPONB | 0 | | 6 | SA2 | ID | 31 | GND3 | G | 56 | BA3 | 0 | 81 | VDDA2 | Р | | 7 | SA3 | ID | 32 | BWE | 0 | 57 | GND5 | G | 82 | ECS | I | | 8 | MODE1 | ID | 33 | BOE | 0 | 58 | BA2 | 0 | 83 | N.C | _ | | 9 | N.C | _ | 34 | BD7 | В | 59 | BA1 | 0 | 84 | N.C | _ | | 10 | RDYPOL | ID | 35 | BD6 | В | 60 | BA0 | 0 | 85 | SD10 | BD | | 11 | BHE | ID | 36 | BD5 | В | 61 | CLKO | 0 | 86 | GND6 | G | | 12 | DMACK | ID | 37 | BD4 | В | 62 | CLKI | I | 87 | SD2 | BD | | 13 | EOP | ID | 38 | BD3 | В | 63 | N.C | _ | 88 | SD9 | BD | | 14 | N.C | _ | 39 | BD2 | В | 64 | HWRST | ISU | 89 | SD1 | BD | | 15 | ĪOR | lu | 40 | BD1 | В | 65 | LEDR | OD | 90 | SD8 | BD | | 16 | GND1 | G | 41 | BD0 | В | 66 | N.C | _ | 91 | SD0 | BD | | 17 | IOW | lu | 42 | BA14 | 0 | 67 | GNDA1 | G | 92 | INT | 0 | | 18 | SD15 | BD | 43 | BA13 | 0 | 68 | N.C | _ | 93 | LEDT | OD | | 19 | SD14 | BD | 44 | BA12 | 0 | 69 | N.C | _ | 94 | V <sub>DD</sub> 4 | Р | | 20 | SD7 | BD | 45 | BA11 | 0 | 70 | VDDA1 | Р | 95 | LEDL | OD | | 21 | SD13 | BD | 46 | GND4 | G | 71 | TPIP | I | 96 | LEDC | OD | | 22 | SD6 | BD | 47 | BA10 | 0 | 72 | TPIN | I | 97 | N.C | _ | | 23 | SD12 | BD | 48 | BA9 | 0 | 73 | GNDM | G | 98 | SB/SW | 0 | | 24 | GND2 | G | 49 | BA8 | 0 | 74 | N.C | _ | 99 | N.C | _ | | 25 | SD5 | BD | 50 | BA7 | 0 | 75 | N.C | _ | 100 | GND7 | G | I: Input P: Power supply O:Output ID: Input with pull-down resistor IS: Schmitt input BD: Input/output with pull-down resistor IU: Input with pull-up resistor G:Ground B: Input/output OD:Open-drain output ### **■ PIN DESCRIPTION** # • System interface pins in PC card mode | Pin no. | Symbol | Pin name | I/O | Function | |--------------------------------------------------|-------------|----------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 to 23,<br>25,<br>27 to 29,<br>85,<br>87 to 91 | PD0 to PD15 | PC CARD DATA BUS | BD | PD15 for most significant bit and PD0 for least significant bit. A built-in 150-k $\Omega$ pull-down resistor eliminates the need for any resistor on the card. | | 4 to 14 | PA0 to PA10 | PC CARD ADDRESS<br>BUS | ID | PA10 for most significant bit and PA0 for least significant bit. PA0 is invalid at word access. A built-in 150-k $\Omega$ pull-down resistor eliminates the need for any resistor on the card. | | 82 | CE1 | CARD ENABLE 1,2 | IU | CE1 controls even addresses and CE2 controls odd | | 83 | CE2 | | | addresses. At power-on or after reset-canceling, these pins must be kept High for 20 ms to initialize the I/O card. | | 96 | OE | OUTPUT ENABLE | IU | This pin is used to control the output of read data from attribute memory space. | | 95 | WE | WRITE ENABLE | IU | This pin is used to control a write operation to attribute memory space. | | 93 | REG | REGISTER SELECT | IU | This pin must be kept Non-active High at access to common memory. Keeping this pin Low accesses attribute memory by OE/WE. The I/O area is accessed by IORD/IOWE. Attribute memory is allocated only to even addresses. Therefore, for word access, data signals PD0 to PD7 are valid and PD8 to PD15 are invalid. Access to odd addresses is disabled at byte access. When setting IORD/IOWE Low during DMA operation, REG must be kept High to prevent illegal access. | | 64 | RESET1 | HARDWARE RESET1<br>(Active High) | ISU | This pin is used to clear the card configuration register (CCR), set the card to an unset state (IC card interface mode), and initialize the pointers and registers in the LAN controller and 10BASE-T transceiver. When power is applied to the card, the system must keep this pin High or high-impedance for 1 ms after the power supply has stabilized. A built-in 150-k $\Omega$ pull-down resistor eliminates the need for any resistor on the card. | | 63 | RESET2 | HARDWARE RESET2<br>(Active High) | ISD | This pin is internally ORed with RESET1 and contains a 50-k $\Omega$ pull-down resistor. | | 15 | IORD | I/O READ | IU | This pin is used to read data from the I/O area. The MB86967 sends no response to IORD until a write operation to the CCR sets the card to the I/O card interface mode. | | 17 | IOWR | I/O WRITE | IU | This pin is used to write data to the I/O area. The MB86967 sends no response to IOWR until a write operation to the CCR sets the card to the I/O card interface mode. | | 3 | WAIT | WAIT | 0 | A Low level is output to this pin to delay the end of an I/O access cycle in progress. | | Pin no. | Symbol | Pin name | I/O | Function | |---------|--------|----------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | INPACK | INPUT RESPONSE | 0 | When CE,REG, and IORD are 0s and the address on the address bus agrees with the I/O port in the card, a Low level is output to this pin. When I/O addresses are independent, a Low level is always output to this pin when CE,REG, and IORD are 0s. | | 84 | IOIS16 | 16-BIT I/O PORT | 0 | When 16-bit access (word access) to the I/O port is possible, a Low level is output to this pin. When a High level is output to this pin, the system has 8-bit access (byte access). | | | | | | Note: In the IC memory interface mode (no write operation to the CCR) when power is applied and a reset is canceled, this pin serves as a WP+ (write-protect) pin. Under this condition, a High level is output to this pin (write-protect). 1 should be set in the device ID tuple, WPS, in the CIS to perform a write operation to the card. | | 92 | IREQ | INTERRUPT<br>REQUEST | 0 | A Low level is output to this pin to request software service from the system. For no interrupt request, a High level is output to this pin. An interrupt signal is sent to one of the interrupt request signals on the bus in the system via the socket interface. Note: In IC memory interface mode (no write | | | | | | operation to the CCR) when power is applied and a reset is canceled, this pin serves as a +RDY/BSY pin. Under this condition, a High level (+RDY) is output to this pin. | | 98 | ROMS | ROM SELECT | 0 | This pin is used for output of EEPROM OR FLASH chip select signals. | | 99 | ROMRD | ROM READ | 0 | This pin is used for output of EEPROM OR FLASH read signals. | | 97 | ROMAD | ROM ADDRESS | 0 | This pin is used when I/O-reading the I/O number. Connection of this pin to the most significant address of EEPROM OR FLASH permits I/O-reading of address space in the upper half of ROM. For a write operation, both the write enable (WE) and I/O write (IOWR) pins must be enabled. If there is no need to set the ID number in the CIS for I/O-reading, this pin should be kept open. | # • System interface pins in ISA bus mode | Pin no. | Symbol | Pin name | I/O | | | Fui | nction | |--------------------------------------------------|-------------|--------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------| | 18 to 23,<br>25,<br>27 to 29,<br>85,<br>87 to 91 | SD0 to SD15 | SYSTEM DATA BUS | BD | exchange<br>MB86967<br>the 8-bit b | These pins are used as data buses for data exchange between the host system and the MB86967. They are also used for DMA transfer. I the 8-bit bus mode (bit 5 of DLCR6 = 1), only the lower bits (SD0 to SD7) are used. | | | | 4 to 13 | SA0 to SA9 | SYSTEM ADDRESS<br>BUS | ID | | | | nput of system address controller registers. | | 64 | CHRESET | CHIP RESET<br>(Active High) | ISU | This pin is | s used for | r input | of hardware reset signals. | | 15 | IOR | I/O READ<br>(Active Low) | IU | This pin is | s used for | r input | of I/O read strobe signals. | | 17 | IOW | I/O WRITE<br>(Active Low) | IU | This pin is | s used for | r input | of I/O write strobe signals. | | 63 | AEN | ADDRESS ENABLE<br>(Active High) | ISD | | | | of signals indicating that the he system bus. | | 65 | EOP | END OF PROCESS<br>(Active High or Active<br>Low) | ID | This pin is used for input of signals indicating the en of DMA transfer between the buffer memory and hos system. At input of EOP, the next BREQ is not output and the handshaking cycle is terminated. | | | the buffer memory and host the next BREQ is not output | | 14 | ALE | ADDRESS LATCH<br>ENABLE | ID | This pin is used for input of signals indicating that the addresses of SA0 to SA9 are determined. | | | | | 82 | SBHE | SYSTEM BUS HIGH<br>ENABLE | IU | the 16-bit 0), this pir | data bus<br>n, togethe | mode<br>er with | olling byte/word transfer. In (bit 5 (SB/SW) of DLCR6 = SA0, controls word transfer and lower bytes on the data | | | | | | SB/SW | SBHE | SA0 | Function | | | | | | 0 | 0 | 0 | Word transfer | | | | | | 0 | 0 | 1 | Transfer of upper bytes on data bus (SD15 to SD8) | | | | | | 0 | 1 | 0 | Transfer of lower bytes on data bus (SD7 to SD0) | | | | | | 0 | 1 | 1 | Unused | | | | | | 1 | × | × | Byte transfer<br>(SD7 to SD0) | | | | | | ×: don't ca | are | | | | 2 | DREQ | DMA REQUEST<br>(Active High) | 0 | This pin is signals. | s used for | r outpu | it of DMA transfer request | | Pin no. | Symbol | Pin name | I/O | | | Functio | n | |----------------------|-------------------------------------------------------|----------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------|-------------|-------------|--------------------------------------------------------| | 69<br>74<br>75<br>92 | IREQ1/IOSEL0<br>IREQ2/IOSEL1<br>IREQ3/IOSEL2<br>IREQ0 | INTERRUPT<br>REQUEST 0 to 3<br>(Active High) | IU/O | IU/O Jumperless Mode These pins are used for output of IR IREQ0 to IREQ3 is selected by conf EEPROM. | | | | | | | I/O ADDRESS<br>SELECT | | | s are use | | the I/O base controller is allocated. | | | | | | IOSEL2 | IOSEL1 | IOSEL0 | I/O Base Address | | | | | | 0 | 0 | 0 | 260н to 27Fн | | | | | | 0 | 0 | 1 | 280н to 29Fн | | | | | | 0 | 1 | 0 | 2A0н to 2BFн | | | | | | 0 | 1 | 1 | 240н to 25Fн | | | | | | 1 | 0 | 0 | 340н to 35Fн | | | | | | 1 | 0 | 1 | 320н to 33Fн | | | | | | 1 | 1 | 0 | 380н to 39Fн | | | | | | 1 | 1 | 1 | 300н to 31Fн | | 83 | DMACK | DMA<br>ACKNOWLEDGE | I | signals ind | dicating th | at the DM | MAC acknowledge AC is ready to transmit buffer memory. | | 3 | IOCHRDY | I/O CHANNEL READY<br>(Active Low,<br>open-drain output) | OD | | | | signals indicating<br>the host system. | | 84 | IOCS16 | I/O CHANNEL<br>SELECT 16<br>(Active Low,<br>open-drain output) | OD | | | | signals indicating that bit I/O access cycle. | | 93 | ENHB | ENABLE DATA HIGH (Active Low) | 0 | | | | enable signals for an us transceiver. | | 95 | ENLB | ENABLE DATA LOW<br>(Active Low) | 0 | | | | enable signals for an<br>is transceiver. | | 99 | EEPSK | SHIFT CLOCK | 0 | This pin is pulses. | used for | output of E | EEPROM shift clock | | 97 | EEPDI | DATA IN | 0 | This pin is | connecte | ed to DATA | N pin of EEPROM. | | 96 | EEPDO | DATA OUT | IU | This pin is | connecte | ed to DATA | OUT pin of EEPROM. | | 98 | EECS | EEPROM CHIP<br>SELECT<br>(Active High) | 0 | This pin is signals. | used for | output of E | EEPROM chip select | ### • System interface pins in general-purpose mode | Pin no. | Symbol | Pin name | I/O | | | Fui | nction | |--------------------------------------------------|-------------|------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | 18 to 23,<br>25,<br>27 to 29,<br>85,<br>87 to 91 | SD0 to SD15 | SYSTEM DATA BUS | BD | between t<br>are also u<br>(bit 5 of D | These pins are used as a data bus for data exclude between the host system and the MB86967. The are also used for DMA transfer. In the 8-bit bus (bit 5 of DLCR6 = 1), only the 8 lower bits (SD0 SD7) are used. | | | | 4 to 7 | SA0 to SA3 | SYSTEM ADDRESS<br>BUS | ID | | r selectin | g MB8 | nput of system address<br>6967 registers, BOOT | | 82 | ECS | ENABLE CHIP<br>SELECT | IU | This pin is signals. | s used for | rinput | of Active-Low chip select | | 64 | HWRST | CHIP RESET | ISU | This pin is<br>(Active Hi | | rinput | of hardware reset signals | | 15 | IOR | I/O READ | IU | This pin is<br>(Active Lo | | rinput | of I/O read strobe signals | | 17 | MOI | I/O WRITE | IU | This pin is<br>(Active Lo | | rinput | of I/O write strobe signals | | 13 | EOP | END OF PROCESS | ID | of DMA tra<br>system. A<br>and the ha | ansfer be<br>.t EOP in<br>andshaki | tween put, the | of signals indicating the end<br>the buffer memory and host<br>e next DREQ is not output<br>le is terminated. Either<br>v can be selected. | | 12 | DMACK | DMA<br>ACKNOWLEDGE | ID | This pin is used for input of Active-Low signals and for connection of DMAC acknowledge signals indicating that the DMAC is read for transmitting and receiving data to and from buffer memory. | | | | | 11 | BHE | SYSTEM BUS HIGH<br>ENABLE | ID | for control<br>bus mode<br>together v | lling byte,<br>(bit 5 (S<br>vith SA0, | /word t<br>B/SW)<br>contro | of Active-Low signals and transfer. In the 16-bit data of DLCR6 = 0), this pin, ols word transfer and the er bytes on the data bus. | | | | | | SB/SW | SBHE | SA0 | Function | | | | | | 0 | 0 | 0 | Word transfer | | | | | | 0 | 0 | 1 | Transfer of upper bytes on data bus (SD15 to SD8) | | | | | | 0 | 1 | 0 | Transfer of lower bytes on data bus (SD7 to SD0) | | | | | | 0 | 1 | 1 | Unused | | | | | | 1 | × | × | Byte transfer<br>(SD7 to SD0) | | | | | | ×: don't ca | are | | | | 92 | INT | INTERRUPT<br>REQUEST | 0 | This pin is used for output of Active-Low interrupt request signals. | | | | | 2 | DREQ | DMA REQUEST<br>(Active High) | 0 | This pin is signals. | used for | rinput | of DMA transfer request | # (Continued) | Pin no. | Symbol | Pin name | I/O | Function | |---------|--------|--------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | READY | READY | 0 | This pin is used for output of signals indicating READY for handshaking with the host system. Either Active High or Active Low can be selected. | | 10 | RDYPOL | READY POLARITY | ID | This pin is used for selecting the polarity of the READY signal. 1: Active High 0: Active Low | | 98 | SB/SW | SYSTEM BYTE/WORD CONFIGURATION | 0 | This pin is used for output of signals indicating the system bus width. The value of bit 5 of the internal register DLCR6 is reversed. Low: 8-bit data bus mode High: 16-bit data bus mode | | 8 | MODE1 | MODE1 | ID | This pin is used for setting to general-purpose bus mode. | ### • Network interface pins in PC card mode, ISA bus mode, and general-purpose bus mode | Pin no. | Symbol | Pin name | I/O | Function | |-------------------------------------------------------------------------|----------------------------------|------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 68 (PC card mode)<br>68 (ISA bus mode)<br>96 (General-purpose bus mode) | LEDC | COLLISION<br>LED | OD | These pins are used for driving the LED indicating the occurrence of collisions (open-drain output). | | 52 (PC card mode) 52 (ISA bus mode) 95 (General-purpose bus mode) | LEDL | LINK LED | OD | These pins are used for driving the LED indicating the status of the link test (opendrain output). These pins are placed in the link-passed state when the link test is enabled. A Low level is output to this pin when the link test is disabled. When in the power-down or shut-down mode, these pins enter the high-impedance state, regardless of the status of the link test. | | 66(PC card mode)<br>66 (ISA bus mode)<br>93 (General-purpose bus mode) | LEDT | TRANSMIT<br>LET | OD | These pins are used for driving the LED indicating transmit-on status (open-drain output). | | 65 (PC card mode) 73 (ISA bus mode) 65 (General-purpose bus mode) | LEDR | RECEIVE LET | OD | These pins are used for driving the LED indicating receive-on status (open-drain output). | | 77<br>78<br>79<br>80 | TPOPB<br>TPOPA<br>TPONA<br>TPONB | TWISTED<br>PAIR OUTPUT | 0 | These pins are used for output of differential transmit signals from the built-in 10BASE-T transceiver. Preconditioning is performed by two output pins and external filters. | | 71<br>72 | TPIP<br>TPIN | TWISTED<br>PAIR INPUT | I | These pins are used for input of receive signals from the twisted-pair cable. | ### • Buffer memory interface pins in PC card mode, ISA bus mode, and general-purpose bus mode | Pin no. | Symbol | Pin name | I/O | Function | |-------------------------------------------------|-------------|------------------------------|-----|--------------------------------------------------------------------------------------------------------| | 34 to 41 | BD0 to BD7 | BUFFER MEMORY<br>DATA BUS | В | These pins are used as data buses for data exchange between the SRAM buffer memory and the MB86967. | | 42 to 45,<br>47 to 50,<br>53 to 56,<br>58 to 60 | BA0 to BA14 | BUFFER MEMORY<br>ADDRESS BUS | 0 | These pins permit addressing of external SRAM buffer memory expandable to 32 Kbytes. | | 33 | BOE | BUFFER OUTPUT<br>ENABLE | 0 | This pin is used for output of Active-Low signals and for enabling buffer memory at a read operation. | | 32 | BWE | BUFFER WRITE<br>ENABLE | 0 | This pin is used for output of Active-Low signals and for enabling buffer memory at a write operation. | | 30 | BCS | BUFFER RAM CHIP<br>SELECT | 0 | This pin is used for output of Active-Low signals and RAM chip select signals. | # • Other pins in PC card mode, ISA bus mode, and general-purpose bus mode | Pin no. | Symbol | Pin name | I/O | Function | |-----------------------------------------------|----------------------------------------|-----------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 52 | MODE/LEDL<br>(PC card mode) | MODE SELECT/<br>LINK LED | IU/OD | This pin serves as a mode select pin or a pin for driving the LED indicating the status of the link | | | LEDL<br>(ISA bus mode) | | OD | test according to the mode used. It is pulled-up internally. | | | MODE<br>(General-purpose<br>bus mode) | | IU | | | 73 | GNDM<br>(PC card mode) | MODE SELECT/<br>RECEIVE LED | G | This pin serves as a mode select pin or a pin for driving the LED indicating the receive status | | | MODE/LEDR<br>(ISA bus mode) | | I/OD | according to the mode used. It serves as a GND pin in the PC card mode and general-purpose bus mode. | | | GNDM<br>(General-purpose<br>bus mode) | | G | bus mode. | | 61<br>62 | CLKO<br>CLKI | CRYSTAL<br>OSCILLATOR | 0 | Connect an external 20-MHz crystal oscillator. Input external clock pulses to CLKI. The wiring between CLKO/CLKI and the crystal oscillator should be as short as possible to prevent crosstalk with other signal lines. | | 1,<br>26,<br>51,<br>94 | V <sub>DD</sub> 1 to V <sub>DD</sub> 4 | DIGITAL V <sub>DD</sub> | _ | These pins are used for power supply to the digital sections. | | 70<br>81 | VDDA1<br>VDDA2 | ANALOG VDD | _ | These pins are used for power supply to the encoder/decoder and 10BASE-T transceiver. | | 16,<br>24,<br>31,<br>46,<br>57,<br>86,<br>100 | GND1 to GND7 | DIGITAL<br>GROUND | | These pins are used for grounding the digital sections. | | 67<br>76 | GNDA1<br>GNDA2 | ANALOG<br>GROUND | _ | These pins are used for grounding the encoder/decoder and 10BASE-T transceiver. | #### **■ SETTING EACH MODE** | Pin 73 | Pin 52 | Pin 8 | Pin 41 (BD0) | Operation Mode | |--------|--------|-------|---------------------------------------------------|----------------------------| | 1 | | | External pull-up*1 ISA bus mode (Jumperless mode) | | | I | × | X | External pull-down*2 | ISA bus mode (Jumper mode) | | 0 | 1 | × | × | PC card mode*3 | | 0 | 0 | 0 | × | General-purpose bus mode | x: don't care <sup>\*1:</sup> To set the jumperless mode, pull up pin 41 (BD0) at about 50 k $\Omega$ to 150 k $\Omega$ . \*2: To set the jumper mode, pull down pin 41 (BD0) at about 50 k $\Omega$ to 150 k $\Omega$ . \*3: The PC card mode has a bug. Please refer to the Page 58 errata sheet in this document. #### **■ BLOCK DIAGRAM** #### **■ BLOCK DESCRIPTION** The MB86967 has five functional blocks. The functions of each block in the PC card mode, ISA mode, and general-purpose bus mode is explained below. #### 1. 10BASE-T Transceiver The 10BASE-T transceiver pre-distorts transmit packets from the Manchester encoder/decoder to be suitable for use in the 10BASE-T jitter template. Filtering is performed by an external active filter. The transceiver passes the received packets through an internal receive filter and transfers them to the encoder/decoder. #### Manchester Encoder/Decoder The Manchester encoder/decoder converts NRZ-formatted transmit packets from the data link controller into Manchester code and transfers them to the 10BASE-T transceiver. The encoder/decoder converters the receive packets from the transceiver from Manchester code to NRZ format and transfers them to the data link controller. #### 3. Data Link Controller The data link controller performs the function of the data link layer specified in the IEEE802.3 standard. At transmitting, the controller attaches the preamble and CRC code to transmit data from buffer memory and transmits it as serial data to the Manchester encoder/decoder. In the event of a collision, the controller automatically executes the back-off algorithm for re-transmission. At receiving, the data link controller performs address-matching and error checks for receive packets from the Manchester encoder/decoder, removes the preamble and CRC code from the packets, and converts them to serial data before writing to buffer memory. The data link controller has a multicast address filter to recognize up to 64 groups of multicast addresses. #### 4. Buffer Manager The MB86967 needs external SRAM (expandable to 32 Kbytes) for buffering transmit and receive data. Buffer memory is divided into a dual-bank transmit buffer and ring receive buffer where all processing such as arbitration of access from the system and network and updating of buffer pointers is performed automatically by the buffer manager. The transmit buffer has a packet chain function for continuously transmitting the packets of data stored in it using one transmit-start instruction. #### 5. System Interface Like the MB86965B and MB86964, the mode pin setting allows the system interface to switch between the general-purpose interface, ISA bus interface enabling direct interface with the ISA bus, and PC card interface based on the JEIDA4.2 standard. When in the ISA bus interface mode, a serial EEPROM can be connected for storing node IDs and two modes can be selected: a jumperless mode allowing software setting of I/O addresses and interrupt signals for the LAN controller, and a jumper mode allowing DIP-switch setting. #### **■ FUNCTIONAL DESCRIPTION** #### 1. Local Buffer Configurations The MB86967 is designed to operate with local buffer which holds packets received from the host processor prior to transmission and assembles packets received from the network before they are delivered to the host processor. The buffer is implemented by using a single byte-wide SRAM whose size is selected via DLCR6<1> as 8 kbytes (DLCR6<1> = 0) or 32 kbytes DLCR6<1> = 1). See Buffer Access section for information on how the host accesses the buffer memory. #### 2. Crystal Oscillator The clock rate of 10 Mbits/s specified by the international LAN standard, ISO/ANSI/IEEE 8802-3, is derived from an on-chip oscillator that is controlled by a 20 MHz crystal connected across pins 61 and 62 (CLKO and CLKI). Capacitance specified by the crystal manufacturer must be connected as shown in Figure 1 to stabilize the effects of stray capacitance that may vary crystal frequency. The 20 MHz clock also serves as an internal phase-locked loop (PLL) reference for decoder clock recovery. Use a crystal with the following specifications: quartz (AT-cut); 20-MHz; frequency acurracy of ±50ppm at 25°C and ±100ppm at 0°C to 70°C; parallel resonant with 20 pF-load in fundamental mode. #### 3. Byte-Order Control Byte-order control provided by BYTESWEAP bit, DLCR7<0>, provides compatibility with various higher-level protocols, such as TCP/IP and XNS. These protocols may have a different order for transmission of the bytes within a word. When BYTESWEAP is low, the least-significant byte of the word transmits first, followed by the most-significant. When BYTESWEAP is set high, the byte order reverses. This feature applies only when the system bus operates in 16-bit (word) mode. The byte-order control works by reversing, or not reversing, the bytes of all words as they pass between the buffer memory and the system bus. Thus all data stored in the transmit buffer or retrieved from the receive buffer is affected, including nontransmitted headers. This control bit does not affect the MB86967 registers other than the Buffer Memory Port registers, BMPR8 and BMPR9. When using this feature, ensure the reversal of header information as well as packet data in the software driver code. See Table 1 for examples of using least..most and most..least byte ordering. #### 4. Register Access The MB86967 includes four sets of user-accessible registers, all of which are accessible as bytes or words. Each register set contains eight registers. Direct access is available to two sets of registers in the device's register set at a time, via register addresses 00H through 0FH. The Data Link Control Registers set (DLCR0 - DLCR7) is always accessible via addresses 00H to 07H. Access to one of the remaining three sets is accomplished by programming the register bank select bits, DLCR7<3:2>. This selects the register set accessible via addresses 08H to 0FH. The bank-switched registers are the Node ID set , DLCR7 - DLCR15, (for setting the Ethernet Address and performing TDR diagnostics), the Hash Table set, HT8 - HT15, (for setting up multicast address filtering) and the Buffer Memory Port set, BMPR7 - BMPR15. During operation (excluding initialization or diagnostics), the Buffer Memory Port set should normally be selected. **Table 1 Byte Ordering** | Data<15:8> | Data<7:0> | | | | | | | | |-------------------------------|-------------------------------|--|--|--|--|--|--|--| | FOR TRANSMIT PACKET | | | | | | | | | | LEASTMOST | | | | | | | | | | Transmit Length, high byte | Transmit Length, low byte | | | | | | | | | Destination Address, 2nd byte | Destination Address, 1st byte | | | | | | | | | Source Address, 2nd byte | Source Address, 1st byte | | | | | | | | | Length Field, low byte* | Length Field, high byte* | | | | | | | | | Data Field, 2nd byte | Data Field, 1st byte | | | | | | | | | MOST. | LEAST | | | | | | | | | Transmit Length, low byte* | Transmit Length, high byte* | | | | | | | | | Destination Addr, 1st byte | Destination Addr, 2nd byte | | | | | | | | | Source Addr, 1st byte | Source Addr, 2nd byte | | | | | | | | | Length Field, high byte | Length Field, low byte | | | | | | | | | Data Field, 1st byte | Data Field, 2nd byte | | | | | | | | | FOR RECE | FOR RECEIVE PACKET | | | | | | | | | LEASTMOST | | | | | | | | | | Unused, reserved | Receive Packet Status | | | | | | | | | Receive Length, high byte | Receive Length, low byte | | | | | | | | | Destination Address, 2nd byte | Destination Address, 1st byte | | | | | | | | | Source Address, 2nd byte | Source Address, 1st byte | | | | | | | | | Length Field, low byte* | Length Field, high byte* | | | | | | | | | Data Field, 2nd byte | Data Field, 1st byte | | | | | | | | | MOST. | LEAST | | | | | | | | | Receive Packet Status | Unused; reserved | | | | | | | | | Receive Length, low byte* | Receive Length, high byte* | | | | | | | | | Destination Addr, 1st byte | Destination Addr, 2nd byte | | | | | | | | | Source Addr, 1st byte | Source Addr, 2nd byte | | | | | | | | | Length Field, high byte | Length Field, low byte | | | | | | | | | Data Field, 1st byte | Data Field, 2nd byte | | | | | | | | Items shown with an asterisk are in numerically reversed byte order #### 5. Buffer Access The Buffer Memory Port register pair BMPR8 and BMPR9 provide 8- or 16-bit data access to the receive and transmit buffers through on-chip FIFOs. To eliminate the need for complicated directional control, FIFOs are dedicated to each direction of data transfer. Writing to the transmit buffer can be interleaved with reading from the receive buffer, with the MB86967 automatically maintaining buffer memory pointers, thus relieving the host of that task. The Buffer Memory port register pair is at address 08H when DLCR7<3:2> are programmed to '10' to select the Buffer Memory Port register set. When using DMA, the buffer memory port is automatically selected when the DMA Acknowledge input, DMACK, is asserted. The host accesses are byte-wide when the system is configured for byte-wide operation and word-wide when the system interface is configured for word-wide operation. In the latter mode, byte-wide access to the buffer memory port is not supported. Data can transfer from the host memory to the transmit buffer, or from the receive buffer to host memory by using string moves, single-transfer programmed I/O moves, or DMA. Select the method that yields the highest system-level efficiency. A rapid transfer process results in best performance. Slow transfer can result in poor throughput and performance, and cause the receive buffer to overflow and lose packets. #### 6. DMA Operation (ISA, Generic Mode Only) The MB86967 supports single-cycle and burst DMA operation for data transfers between the host and the packet buffer. Hand-shaking between the MB86967 and the external DMA controller is accomplished by the DREQ and DMACK signals. The end of process input, when asserted by the system DMA controller during a transfer cycle, terminates DMA activity after completion of the current cycle. If a DMA interrupt (DLCR3<5>) is enabled, the MB86967 generates an interrupt after completion of DMA activity. Usually only one DMA operation will be run at a time, although the MB86967 could run two interleaving operations, one reading and one writing. There is only one DMA EOP bit, and only one DREQ pin and one DMACK pin, so most hosts could not support more than one DMA operation at a time. #### 6.1 DMA Write (Transmit) ISA, Generic Mode Only Setting the TX DMA Enable bit, BMPR12<0>, enables DMA transfer of data packets from the host memory to the MB86967 transmit buffer. The DMA burst control bits, BMPR13<1:0>, set the maximum number of data transfer cycles (bytes or words) in a single bus acquisition to be 1, 4, 8, or 12. The MB86967, when ready to accept data from the host, sets the DMA request output, DREQ, and the host responds by asserting DMA acknowledge, DMACK, followed by Write Strobe, WR, and placing data on the data bus. The MB86967 asserts the RDY(RDY) output when ready to complete the current data-transfer cycle. (The assertive states of the RDY(RDY) output and the EOP(EOP) input are independently programmable.) The MB86967 accepts the data byte/word into its bus write FIFO and later moves it into buffer memory. At the close of a transfer cycle, the host negates WR. In burst mode and depending on the value of the DREQ EXTND bit, DLCR4<2>, the MB86967 negates DREQ at the next-to-last or last transfer cycle of the burst. The host DMA then completes the last one or two transfer cycles and negates DACK to terminate the burst. To start another burst, the MB86967 reasserts DREQ. The DMA controller asserts the end of process input, EOP(EOP), concurrent with the last required data-transfer cycle to indicate completion of the entire transfer process. This action sets the DMA EOP status bit, DLCR1<5>, and discontinues further data requests from the MB86967. The MB86967 will also generate an interrupt if the DMA EOP interrupt enable bit, DLCR3<5>, is high. The host can use this interrupt to begin action to close the process. The host should reset the MB86967 DMA logic and clear the interrupt by writing 00H to BMPR12. Note: DMA EOP, DLCR1<5> must be cleared to close the transmit DMA process before attempting another DMA process. This is accomplished by writing 00H to BMPR12. When this is done, the DMA EOP bit will clear automatically, clearing the EOP status and interrupt, (if enabled) so it is not necessary to clear the interrupt separately. After finishing the loading of packets into the buffer, the host initiates packet transmission. This is done by loading the number of packets to be transmitted into the Transmit Start Register, BMPR10<6:0>, and asserting the Transmit Start bit, TXST, of the same register, BMPR10<7>. #### 6.2 DMA Read (Receive) ISA, Generic Mode Only The MB86967 indicates that it has received packets and stored them in the packet buffer with status bits or interrupts. Before attempting to transfer a packet from the buffer, the host processor should read the RX BUF EMPTY bit, DLCR5<6>. If this bit is 0, there are one or more packets ready for transfer in the receive buffer. After reading each packet, the host will check this bit again to see if there are more. Prior to beginning the transfer of a packet from the receive buffer to host memory via DMA, the host must first read the four-byte receive packet header from the buffer to obtain the packet status and the length of the packet in bytes. Calculating from the packet length the number of DMA cycles needed to read the packet, the host will load that number into the cycle counter of the host DMA controller. Next, RX DMA EN, BMPR12<1>, is set to high to enable DMA read operation to transfer the packet to host memory. The DMA burst control bits, BMPR13<1:0>, set the maximum number of data transfer cycles (bytes or words) in a single bus acquisition to be 1, 4, 8, or 12. When it is ready to begin, the MB86967 asserts its DMA Request output, DREQ. The host responds by asserting DMA Acknowledge, DMACK, followed by the Read Strobe, RD. The MB86967 will assert its RDY(RDY) output when it has placed the byte/word on the data bus and is ready to complete the data transfer cycle. The system memory will accept the data, then the host negates RD. The MB86967 shifts the data down in its bus read FIFO, then moves its internal read pointer to point to the next byte/word in the buffer, moving it into the FIFO. In burst mode and depending on the value of the DREQ EXTND bit, DLCR4<2>, the MB86967 negates DREQ at the next-to-last or last transfer cycle of the burst. The host DMA then completes the last one or two transfer cycles and negates DMACK to terminate the burst. The MB86967 reasserts DREQ to repeat the process if it can transfer more data after the host negates DMACK. The DMA controller asserts the end of process input, EOP(EOP) concurrent with the last byte/word data transfer to indicate completion of the entire process. The MB86967 then stops requesting more DMA cycles. When EOP(EOP) is asserted by the host DMA controller, the DMA EOP bit, DLCR1<5>, will be set high, and an interrupt will also be generated, provided it is enabled by a high in the associated interrupt enable bit, DLCR3<5>. This interrupt can be used by the host to initiate the final actions to close the DMA process. The interrupt is cleared and the DMA is disabled and reset by writing 00H to the DMA Enable Register, BMPR12. Note: Clearing RX DMA EN must be done to close the receive DMA process before attempting another DMA process. This is accomplished by writing 00H to BMPR12. When this is done, the DMA EOP bit will clear automatically, clearing the EOP status and interrupt, so it is not necessary to clear the interrupt separately. After completion of the DMA process, RX DMA EN must be reasserted when the host wants to begin reading another packet from the receive buffer by using DMA. #### 7. Buffer Controller #### 7.1 General The MB86967 uses a dedicated buffer memory, organized as shown in Figure 2, for intermediate storage of packets to be transmitted, and of packets received from the network. The MB86967 can operate with 8 or 32 kilobytes of total buffer memory, including both transmit and receive spaces. Memory partitioning into transmit and receive sections is controlled by the system software. The total size of the transmit buffer space can be up to 16 kilobytes. The buffer memory not used for the transmitter is used for the receiver, and is automatically configured as a ring buffer. Packets are stored head-to-toe in the receive buffer, as they are in the transmit buffer. However, each packet in the receive buffer is aligned on an eight-byte boundary. As packets are being stored in the receive buffer, as the end of the linear addressing space is reached, the chip's receive write pointer automatically wraps around to the top of the receive addressing range to make a seamless ring. The receive read pointer does the same as the packets are read out to the system. By programming the sizes allocated to transmit and receive buffers, an optimum usage of the memory can be selected according to the demands of a particular application. The buffer controller keeps track of buffer memory partitioning and allocation and updates internal address pointers automatically for the tasks of transmit, retransmit, receive, rejection of packets with errors and data transfers to and from the host. The host and its drivers are thus relieved of buffer management functions, making the MB86967 easy to operate and substantially reducing software requirements. Packets with errors are normally automatically rejected by the MB86967 as are packets shorter than the IEEE minimum length packet of 60 bytes, excluding Preamble and CRC. Since these tasks can be done faster in hardware than in software, this not only off-loads the host system, but it also speeds up the communication processes, yielding higher throughput. As a result, the MB86967 can typically win benchmark performance tests over competing controllers. #### 7.2 Arbitration of Buffer Access The buffer controller automatically prioritizes and services requests for access to memory from the transmitter, receiver and host system. The MB86967's arbitration mechanism, illustrated in Figure 3, interleaves accesses to the buffer memory so that the operation appears to be simultaneous: data can be written to or read from the buffer memory by the host via Buffer Memory Port Register 8 (BMPR8), while data is being read from the buffer by the transmitter and/or written in for storage by the receiver. Each interface, whether host system or network access, appears to be served independently by the controller. Each interface has an associated FIFO to provide time for the buffer interleaving. Thus, packet data is pipelined through the system for highest performance and throughput, and the buffer controller supports all the cases of simultaneous access to the buffer memory as follows: - 1. Data from the network is stored in the receive buffer. - 2. The host retreives packets from the receive buffer. - 3. The host loads packet data into the transmit buffer. - 4. The transmitter obtains data for transmission from the transmit buffer. - 5. Any combination of the above can occur concurrently. #### 7.3 Transmit Buffer The section of the memory used by the transmitter can be configured by programming the Transmitter Buffer Size control bits, DLCR6<3:2>. Configurations include a single buffer 2 kilobytes long, or a pair of banks, each either 2, 4 or 8 kilobytes long, as illustrated in Figure 4. Within each buffer or bank, one or more packets can be written by the system until the available space is too small for another packet. When a single transmit buffer is used, the system and the transmitter time-share the use of the buffer. When two buffers are used, the system can load packets into one of the buffers while the contents of the other are being transmitted. Using dual buffers and loading multiple packets for 'packet chaining' gives the highest rate of transmission. At reset, internal pointers are initialized to point to the beginning of one of the transmit buffers. Each time the host writes data to the buffer via the Buffer Memory Port Register, an internal pointer is advanced to the next memory location within the transmit buffer. Once a data byte/word is written, it cannot be read and the internal pointer cannot be reversed. When the host completes loading the transmit buffer, it writes the number of packets it has loaded into TX PKT CNT, BMPR10<6:0> and sets the transmit start bit, BMPR10<7>. When this occurs, the MB86967 will switch banks and will start transmitting at the earliest opportunity. Another automatically-managed pointer, the transmit read pointer, sequences through the bank being transmitted to read the packet data into the transmitter through its FIFO. If a collision occurs, the packet will be automatically retransmitted after a pseudo-random waiting interval called the backoff interval. If there are multiple packets in the buffer, the MB86967 will continue down the list until all are transmitted. Upon reaching the end of the list or chain of packets, the transmitter will stop, update its status bits and, if enabled, generate an interrupt. The details of this operation are described in the section on packet transmission. #### 7.4 Transmit Packet Header As shown in Figure 5, each packet within one transmit bank is separated by a non-transmitted, two-byte header containing an 11-bit value which specifies the length of the associated packet in bytes. The length specification includes only what is stored in the buffer (shown in the figure as 'DATA'), which are the Destination ID, Source ID, Length, and Data fields of the packet. It does not include the Preamble and CRC fields which are generated by the MB86967 as it transmits the packet, and therefore are not stored in the buffer. #### 7.5 Receive Buffer Once initialized and enabled, the receiver will automatically load any error-free incoming packets which pass the address filter into the receive buffer through an on-chip FIFO. An interrupt can be provided to alert the host processor that a packet is available in the buffer. The host processor can read out received packets as they become available. Continuous reception can continue as long as the receive buffer does not become full. If the host processor reads the receive packets from the buffer promptly, the buffer will not fill up. If overflow does occur, the receiver will stop and an interrupt will be generated to indicate the problem. If this occurs, the buffer should be emptied so that reception can resume. As soon as space becomes available in the receive buffer, the receiver will automatically resume reception. The receive buffer size can vary between a maximum of 30 kilobytes when 2 kilobytes are allocated for the transmit section and a 32 kilobyte SRAM is used, to a minimum of 4 kilobytes if 4 kilobytes are allocated for the transmit section and an 8 kilobyte SRAM is used. The receive section dynamically allocates space for each individual incoming data packet, aligning each at an eight-byte 'page' boundary. Each received packet is preceded by a four byte header which provides packet status and the length of that data packet. The data packets are linked or chained by internal pointers which use the length value in the packet header to calculate the starting address of the next packet. This buffer format is shown in Figure 6. Since the MB86967 controls its dedicated buffer memory, FIFO size and depth are unimportant in this architecture, and need not be considered in system timing considerations. A status bit in one of the MB86967's internal registers informs the host when one or more packets are resident in the receive buffer and available to be read. The host retrieves these packets from the buffer memory by successive reads of BMPR8. Once a data byte/word is read from the buffer memory, internal pointers are advanced to the next byte/word. As data is thus read by the system, that memory becomes available for reception of new packets. The MB86967 automatically rejects an incoming packet if there is not enough buffer space to fully receive that packet. Therefore, there is no chance for packets already received to be 'overrun' by incoming packets. When DLCR5<5>, the ACPT BAD PKTS bit, is set to a '0' (disabled), detection of a bad incoming packet causes the MB86967 to release the buffer space in which that packet is contained and to reset its internal pointers so as to use that space for the next incoming packet. If this bit is set to a '1', a packet with a CRC or alignment error will be accepted and the appropriate error bits in the status field of its header will be set. The same applies to DLCR5<3>, ACPT SHORT PKTS, which when high allows retention of packets below 60 bytes in length, excluding Preamble and CRC (which is shorter than IEEE 802.3 minimum packet size). #### 7.6 Skip Packet Writing a '1' to BMPR14<2> commands the buffer controller to skip the balance of the current receive packet in memory. The bit can then be read to determine completion of the skip process is complete (within 300 ns). If there is another packet, the bit returns to 0 when the chip is ready to read the next packet. #### 7.7 Receive Packet Header The receive packet header contains four bytes and is stored in the receive buffer preceding each packet. The receive packet header comprises one byte of packet status, an unused byte and two bytes (11 bits) for packet length. Bits 1 through 4 of the status byte are an image of the same bits in the Receive Status Register, DLCR1, with respect to the packet that follows. Bit 5 is the GOOD PKT bit, which when set to 1 indicates that no errors were detected in the packet. Bits 0, 6 and 7 are unused and are always set to 0. See Table 2. The length stored in bytes 3 and 4 of the header specifies the length of the portion of the packet stored in the buffer. This length specification is in bytes, regardless of whether the system interface is programmed for byte or word mode. During reception, the MB86967 strips the Preamble field and checks and strips the CRC field, so, as is the case for the transmit buffer, those fields of the packet are not stored in the buffer. The length specification thus includes only the Destination ID, Source ID, Length, and Data fields of the incoming packet. | Condition | N/A<br>(Bit 7) | N/A<br>(Bit 6) | Good<br>PKT<br>(Bit 5) | RMT<br>0900H<br>(Bit 4) | SHORT<br>PKT ERR<br>(Bit 3) | ALIGN<br>ERR<br>(Bit 2) | CRC ERR<br>(Bit 1) | N/A<br>(Bit 0) | |----------------------|----------------|----------------|------------------------|-------------------------|-----------------------------|-------------------------|--------------------|----------------| | GOOD PACKET | 0 | 0 | 1 | 0/1 | Х | Χ | Х | Х | | PACKET WITH<br>ERROR | 0 | 0 | 0 | 0/1 | 0/1 | 0/1 | 0/1 | Х | Table 2 Receive Packet Header Status Indications 0/1 indicates that the value of the bit will be 0 or 1 depending on the condition of the packet. An 'X' indicates that the value should be ignored. #### 8. Transmitter Circuits Circuits within the transmitter include a transmitter state machine, a small FIFO for pipelining the packet data, preamble generator, CRC generator, parallel to serial converter, backoff generator, interpacket gap timer and time domain reflectometer (TDR) counter. Additional circuits involved in packet transmission are described in the Transceiver section of this document. The transmitter state machine provides sequencing of events for the transmitter, including idle, preamble, data, CRC, interpacket gap, jam and backoff. It detects various transmit error conditions and sets appropriate bits within the DLCR registers. The pipeline FIFO provides elastic buffering that the buffer controller can load with data to be transmitted. The chip's CRC generator calculates the 32-bit CRC on the destination and source address, the length field and the data field as specified by the ISO/ANSI/IEEE 8802-3 specification for Ethernet. This value is appended to the end of the packet when it is transmitted. #### 8.1 Media Access Control The MB86967 transmitter state machine implements the Carrier Sense, Multiple Access with Collision Detection (CSMA/CD) network media-access protocol. The MB86967 monitors the network for any other node's carrier, and defers transmission (collision avoidance) while other nodes are transmitting, except when DSC, DLCR4<0>, is high. Collision detection handles collisions that may still occur when two nodes separated on the network begin transmitting at nearly the same time. All nodes monitor the network for collisions and, when involved in one, transmit a 32-bit jam signal to reinforce the collision and then terminate transmission. After waiting a pseudorandom backoff interval, generated as described below, the node automatically retries transmission of the packet. Packets on the network must be separated by at least 9.6 microseconds, the 'interpacket gap' (IPG) during which the network medium is specified to be idle. The MB86967 transmitter state machine measures this IPG starting from the end of a packet on the network, and does not attempt to transmit until the end of the IPG. If carrier reappears on the network during the first two-thirds of the IPG, the MB86967 resets the timer to re—time the IPG from the end of the new transmission. Such an event can occur during a collision, since data and carrier indications can be corrupted by the superimposition of the two packets. During the last one-third of the IPG, the MB86967 ignores the occurrence of a carrier indication, in accordance with 8802-3, to ensure fairness and equality in access to the network. Thus, if one station begins transmission slightly ahead of another, there is no advantage to the earlier start. Both nodes transmit, a collision occurs, and backoff interval differentials resolve the media-access contention. #### 8.2 Transmit Packet Processing To transmit one or more packets, the host system first loads the packet(s), preceded by a two-byte header giving their lengths, into a transmit buffer by writing the data to the Buffer Memory Port Register, BMPR8. Only the destination address, source address, length and data fields of the packets are loaded by the system. After the packets are loaded into the transmit buffer, the system turns the transmitter on to initiate transmission. Observing the media access protocol, the MB86967 defers transmitting to carrier from other nodes, minimum interpacket gap intervals and backoff intervals, if any, and then begins to serialize the data. It generates the Preamble field at the beginning, and calculates and appends the CRC field at the end. Figure 7 illustrates the standard packet format. The serialized signal is routed to the transceiver section which encodes the data into the required Manchester code, appends an end-of-packet delimiter. The transmitter transmits the packets in the transmit buffer in the order in which they were loaded. If a collision is detected by the transceiver, the transmitter automatically retransmits the packet until successful or until 16 consecutive attempts have ended in collision. In the latter case, depending on the mode selection made at initialization time, the transmitter continues to try to transmit the same packet starting again with a collision count of zero, skips the current packet and tries to transmit the next packet starting with a collision count of zero, or halts and waits for instruction from the host. In the last case, the host can elect to terminate transmission attempts by setting ENADLC, DLCR6<7> to one, continue to attempt to transmit the same packet (collision counter reset), or skip the current packet and try to transmit the next packet(collision count is zero). #### 8.3 Backoff Generator A 17-bit pseudo-random number generator clocked at the 10 MHz bit rate provides the collision backoff function. Distances between stations become part of the randomizing function. The number generator is sampled at the time of collision, masking all but the appropriate number of bits specified by the 8802-3 backoff algorithm. This value is then counted down at the slot-time rate (512 bit times) to generate the backoff interval. For a first collision, only one bit is used, giving a backoff of either 51.2 microseconds or 0. For a second consecutive collision, two bits are used, and so forth, up to ten bits. From the tenth to the 16th collisions, 10 bits are used. This generates a pseudo-random backoff interval of from 0 to 52.38 ms, the so-called 'binary exponential backoff' for collisions per the 8802-3 standard. #### 8.4 Transmit Error Processing The MB86967 provides four transmit error status bits in its Transmit Status Register (DLCR0) for reporting the four possible transmit errors. The errors are: 1) loss of carrier during transmission, which usually indicates a medium fault or a collision, 2) collision, 3) 16 consecutive collisions and 4) jabber error, which occurs if the length of a single transmission substantially exceeds the time required to transmit a maximum length packet conforming to the standard. The latter three can be enabled separately to generate interrupts. A status bit in the Transmit Status Register is set in case a collision terminates transmission. Collision counter DLCR4<7:4>, automatically increments after each collision up to the sixteenth collision, at which time it rolls over to zero. Another status bit indicates that sixteen consecutive attempts to transmit a packet have been made and all have been terminated by collision. The occurrence of 16 collisions may indicate a network problem, such as a disconnected cable or terminator, that produces false collisions. While rare, 16 collisions may normally occur. #### 8.5 Time Domain Reflectometry When a node transmits, a short or open on the network causes a reflected signal to the node receiver, which can sometimes be detected. The reflection causes failure of the carrier sense or detection of a false collision. An open on the network may cause a false collision, whereas a short usually causes loss of carrier sense. Time domain reflectometry (TDR) allows estimates of the distance along the network cable from the node to the fault. The MB86967 is equipped with a special counter to perform the TDR function. The contents of the counter after any transmission can be determined by reading the Time Domain Reflectometry registers, DLCR14 (the least-significant byte) and DLCR15 (the most-significant byte). Only the lower 14 bits of the counter are equipped, which is more than is needed for an IEEE or Ethernet LAN. The top two bits, DLCR15<7:6>, are always 0. The TDR counter counts the actual number of bits transmitted for each packet before a collision indication, carrier loss indication or completion of transmission, whichever comes first. A complete transmission with no error indications clears the TDR counter. The elapsed time represents twice the signal delay from node to fault. To perform the TDR fault test, first enable interrupts for TMT OK, by setting DLCR2<7> high. An alternative to using the interrupt is to poll the TMT OK bit, looking for a high level. Set the 16 Collisions Register, BMPR11, to 07H for this test (no halt, skip-failed packet). Clear status bits by writing 0FF86H to the Receive and Transmit Status registers. Next, try to transmit a packet length of 600 or more bits. Up to 16 attempts may be made automatically, if collisions are indicated. Upon completion of the transmission attempts, TMT OK goes high, generating an interrupt if so enabled. When this occurs, read the Transmit Status register and the TDR register. #### 8.6 Interpreting the Results If the count is zero, no fault was detected. If the count is greater than zero, but smaller than the packet length, a cable fault may exist. If the count is less than 525, a real collision may have occurred during the test. Real collisions normally occur within the first 65 bytes of the packet, including preamble. Note the error status bits, COL and CR LOST. COL high suggests a cable open, whereas CR LOST suggests a short. Repeat the measurement several times, discarding any anomalous values, and average the rest. A cluster of readings at about the same value is a strong indicator of a valid fault measurement. If such a cluster of readings occurs, multiply the average of the cluster by 39 feet to estimate the distance from the node to the fault. [39 feet = $(100 \text{ ns} \times 0.8 \times 186,282 \text{ miles/second} \times 5280 \text{ feet/mile})/2$ ; this assumes the network is mostly coaxial cable with signal propagation speed of approximately $0.8 \times C$ , the speed of light.] #### 9. Receiver Circuits The receiver includes a receive state machine, serial-to-parallel conversion, pipe-line FIFO, preamble recognition, bit and byte-framing, address filtering, CRC and other error checking. Additional circuits involved in packet reception are described in the Transceiver section of this document. The receiver state machine provides sequencing of events for the receiver, including idle, busy, address filtering, and data storage, detects receive error conditions and sets appropriate bits within the DLC registers. A small data FIFO provides elastic buffering for synchronization with the buffer controller timing and buffering of data while the buffer controller is servicing other buffer memory access requests. #### 9.1 Monitoring the Network Whenever the data link section is enabled (ENA DLC bit, DLCR6<7>, is set to zero), the MB86967 constantly monitors the network for carrier. Signals that exceed the AC and DC squelch thresholds of the transceiver cause the internal carrier sense line to assert, which in turn causes the receiver to attempt to receive a packet. (The transmitter also uses the carrier sense function to defer to transmissions from other nodes.) The receiver monitors the serial data stream from the transceiver for the end-of-preamble bit pattern, a four-bit pattern of 1011 ending the preamble's pattern of alternating ones and zeros. This pattern also provides byte and field synchronization for the receiver; the bit immediately following the end of preamble is the first bit of the first byte of the packet's destination address field. When packet transmission is unflawed, carrier sense remains asserted for the duration of the packet, negating just after the last bit of the CRC field is received, when the transceiver detects the end-of-packet symbol at the end of the packet. Loss of carrier sense at any other time may also result from a collision or other network problems. #### 9.2 Address Filtering A receive packet can be filtered by applying selectable criteria to the contents of its Destination Address field, which is the first data-bearing field following immediately after the Preamble. There are several control bits in the MB86967's registers which provide programmability of the filter criteria. The contents of the Destination Address field can be of three basic types. The first data type which can occur in this 48-bit field is a single node address, the unique, single-node address, globally registered with the IEEE. This data type is indicated by a "0" in the first bit position of the address. The second type is the multicast address, an address for a pre-defined group of nodes. The multicast address is indicated by a "1" in the first bit position of the address. The MB86967 filters multicast addresses using a hash function and a 64-bit hash table. Thirdly, a broadcast address is defined as a special case of the multicast address which addresses all nodes on the local network. This address value consists of all "1"s. The MB86967 provides programmable address filtering logic for each of these address types. Among the address filtering selections possible with the MB86967 are the following examples: - 1. All Pass (no filtering) - 2. Node address and broadcast packets only - 3. Node address xxx.xxx, multicast addresses yyy.yyy and zzz.zzz and broadcast packets only #### 9.3 Hash Table The Hash Table provides a way to filter incoming multicast packets so the host processor need not process packets that are not of interest. The principle behind this filtering process is based on the arrangement of a large number of elements of an array, or database, to facilitate searching for elements associated with a given key or datum. The hash function is a mathematical or logical function that maps all elements in a domain onto a smaller domain called the hash table. Assume this hashing function as an example: treat the multicast address as a nonnegative 48-bit integer, divide this number by 64 and take the remainder. This function maps all multicast addresses into a 64-element hash table because the remainder must be an integer between 0 and 63. Applying this hashing function results in taking the least-significant six bits of the multicast address as an integer. In the hash table, for each element, 0 through 63, a single bit is stored to indicate if the address is accepted (1) or rejected (0). If, for example, the node belongs to three multicast groups, only three or fewer of the hash table elements store ones, and the rest store zeroes. The scheme allows the acceptance of any number of addresses, including all of them. However, while this filters out most nonspecific addresses, there may be addresses not of interest used on the network that also fall into the accept elements, so filtering may be imperfect. The actual hashing function used in the MB86967 is to calculate the CRC on the multicast address and to store the most-significant six bits of this calculation in a register . The six bits are used to address the elements of the hash table: the three MSBs are used as the Hash Table register address, and the three LSBs are used as the bit address within a register byte. If the addressed Hash Table element yields a '1' and the packet is a multicast packet (first bit of destination address equals 1), and it passes the error filters, the packet will be accepted. The hash filter criteria are only used on multicast addresses, which all start with a one. Node IDs that start with a zero are not filtered by the hash filter. The broadcast address, a special case of the multicast set wherein all the bits are ones, is accepted anyway unless the Reject All Packets mode is selected. The hash filter is used only when the Address Filter mode select bit AF1 is 1 and mode select bit AF0 is 0, selecting the Node ID, Broadcast, Multicast + Hash Table mode. Hash Table registers should only be accessed when the Receiver is disabled, i.e., when ENA DLC is high, to avoid interaction with the Receiver. There are eight bytes of registers in the Hash Table containing 64 one-bit elements, as shown in the Table 7. #### 9.4 Receive Packet Processing As a packet arrives from the network, its destination address field is tested for the various address filter criteria selected by the Address Filter Mode bits, DLCR5<1:0>, and the Hash Table. Only if the address meets the filter criteria selected will the packet be accepted for storage in the receive buffer. In addition, the packet must be error-free, unless the chip has been enabled to receive flawed packets for diagnostic purposes. If these conditions are met, the packet reception results in the packet being stored in the buffer, its 4-byte header being updated at the end of reception, the BUF EMPTY status bit, DLCR5<6>, being cleared, the RX PKT status bit, DLCR1<7>, being set high and an interrupt being generated if so enabled. The last four bytes of the packet are the CRC field and are checked for correct CRC. The CRC bytes are not transferred to the Receive Buffer. If the packet has an error and reception of such packets has not been enabled, it will be discarded and pointers will be reset to reuse the same portion of the receive buffer for the next packet to arrive. If a flawed packet is accepted for storage for diagnostic purposes, its error(s) will be reported in the status byte of its header (see Receive Packet Header section). #### 9.5 Receive Error Processing Status bits in the receive status register are set to indicate errors associated with packet reception. These errors are: 1) bus read error, which occurs if the host system attempts to read from an empty receive buffer (this need never occur if the RX BUF EMPTY bit is checked), 2) short packet error, 3) alignment error (incomplete byte fragment at end of packet), 4) CRC error and 5) buffer overflow, which occurs if the receive buffer space is insufficient to hold the entire received packet (the receive controller automatically removes such packets from the receive buffer and packets already stored in the buffer are not lost). Each of these receive error conditions may optionally generate an interrupt. None of these errors requires special host processing or intervention, other than optional tallying of the error for network management purposes. #### 10. 10BASE-T Transceiver The MB86967's transceiver section provides the electrical interface for RJ45 (10BASE-T) connections to the Ethernet local area network. Its functions include Manchester encoding and decoding of serial data streams to the transmitter and from the receiver, level conversion, collision detection, signal quality error (SQE) and link integrity testing, jabber control, loopback, and automatic correction of polarity reversal on the twisted-pair input. Also provided are outputs for transmit, collision and link test pass LEDs, and compatibility with unshielded twisted-pair cables. Receive threshold can be reduced to allow an extended range between nodes in low-noise environments. Programmable functions are controlled via BMPR13. Transceiver status is presented in BMPR15. #### 10.1 Data Encoder The encoder converts the serialized NRZ data from the transmitter to Manchester code, the format used on the network medium. In Manchester code a one is represented as a bit cell (nominally 100-nanoseconds) starting with a low, ending with a high, with a low-to-high transition at the midpoint; Manchester code for a zero is the inverse. The encoder also monitors the state of the internal transmit enable signal from the transmitter section and appends an end-of-packet symbol (illegal Manchester code) to the data stream when that signal is negated at the end of the CRC field of the transmitted packet. #### **10.2 Transmitter Circuits** The transceiver's transmitter section receives the encoded data from the Manchester encoder and the twisted-pair network via the TPO circuit. Advanced integrated pulse-shaping produces an output signal that is predistorted and prefiltered to meet the 10BASE-T jitter template on the TPON and TPOP pins. During idle periods, the MB86967 transmits link integrity test pulses on the TPO circuit if LINK TEST EN, BMPR13<5>, is asserted. #### 10.3 Jabber Control An on-chip watchdog timer prevents the chip from locking into a continuous transmit mode. When a transmission exceeds the maximum time limit (specified for the MB86967 as 20 to 150 msec), the watchdog timer disables the transmit and loopback functions and asserts the JABBER error status bit, DLCR0<3>, generating an interrupt if so enabled. Before the MB86967 can exit the jabber state, the transmit data circuit must remain idle for between 0.25 and 0.75 seconds. #### 10.4 SQE Test The transceiver supports the signal quality error (SQE) test function specified in the standard. After every successful transmission on the 10BASE-T network, the MB86967 transceiver section transmits the SQE signal to the controller for 10±5 bit times over the internal CI circuit. BMPR15<1> reflects the status of this SQE test. #### 10.5 Receive Input Circuits Valid received signals from the twisted-pair network connection (the TPI circuit) pass through on-chip filters to the data decoder. An internal intelligent squelch function discriminates noise from link test pulses and valid data streams. The receiver is activated only by valid data streams above the squelch level and with proper timing. If the differential signal at the TPI circuit inputs falls below 75% of the threshold level (unsquelched) for eight bit times (typical), the receiver enters the idle state. #### 10.6 Data Decoder The data decoder section performs three functions on the received data: clock recovery, carrier detection, and Manchester data decoding. Carrier detection is indicated to the receiver section by assertion of the internal carrier sense signal, which occurs shortly after the received data signals appear. Carrier sense status can be monitored via DLCR0<6>. Clock recovery and data separation are accomplished by an internal phase-locked loop. The recovered clock is supplied to the receiver together with the recovered NRZ serial data stream. #### 10.7 Reverse Polarity The transceiver polarity reverse circuit uses link pulses and end-of-frame data to determine the polarity of the received signal. A reversed polarity condition is detected when eight opposite receive link pulses are detected without receipt of a link pulse of the expected polarity. Reversed polarity is also detected if four frames are received with a reversed start-of-idle. Whenever polarity is reversed, these two counters are reset to zero. If the transceiver enters the link fail state and no valid data or link pulses are received within 96 to 128 milliseconds, polarity resets to the default uninverted condition. If Link Integrity testing is disabled, polarity detection is based only on received data. The transceiver automatically corrects reversed polarity. Polarity reversal is reported via BMPR15<3>. #### 10.8 Collision Detection The collision detection function operates on the twisted-pair side of the interface. A collision is defined as the simultaneous presence of valid signals on both the TPI circuit and the TPO circuit. The transceiver reports collisions to the back-end via an internal signal. If the TPI circuit is active while there is activity on the TPO circuit, the TPI data passes to the back-end as received data, disabling normal loopback. #### 10.9 Loopback The MB86967 provides the automatic local loopback function specified by the 10BASE-T standard for the twisted-pair port. This function is in effect except when the LBC bit, DLCR4<1>, is asserted. Data transmitted by the transmitter is passed through the data encoder, internally looped back within the MB86967 before the TPO drivers to the data decoder and returned to the receiver. This local loopback function is disabled when a data collision occurs, clearing the received data circuit in the transceiver for the data arriving at the twisted-pair inputs. The local loopback is also disabled during the link fail and jabber states. The MB86967 provides additional loopback testing functions controlled by LBC. When the twisted-pair port is selected and LBC is asserted, the loopback is forced regardless of the state of the TPI inputs or link test failure. During loopback, data is routed from the transmit buffer to the transmit section of the data link controller, through the Manchester encoder, back through the Manchester decoder, through the receiver section of the data link controller, and is then stored in the receive buffer. Software can then read and check the received packet that has traveled through the MB86967 transmit and receive sections. Receipt of the loopback data into the receive buffer can be disabled by asserting FILTER SELF RX, BMPR14<0>. The transmitted data is blocked from appearing at the network outputs while the MB86967 is in forced loopback mode (LBC asserted). #### 10.10 Link Integrity Test The link integrity test determines the status of the receive side twisted-pair cable. Link integrity testing is enabled when LINK TEST EN, BMPR13<5>, is set low. When enabled, the receiver recognizes the link integrity pulses transmitted in the absence of receive traffic. If no serial data stream or link integrity pulses are detected within 50 to 150 milliseconds, the MB86967 enters a link-fail state and disables the transmit and automatic local loopback functions. The MB86967 ignores any link integrity pulse with an interval less than 2 to 7 milliseconds. The MB86967 remains in the link-fail state until it detects either a serial data packet or two or more link integrity pulses. #### **■ CONTROL REGISTERS IN LAN CONTROLLER** These control registers are used in all modes (PC card mode, ISA bus mode, and general-purpose bus mode). The I/O address space between the base and 0 to F addresses has 32 control registers in the LAN controller for two address-extended bits (RBS1 and RBS0). The two address-extended bits (RBS1 and RBS0) are at bits 3 and 2 of the control register DLCR7 in the LAN controller (base address +7). - Notes:1. At reset, the LAN controller defaults to the 8-bit system interface. However, in the PC card mode, the 8-bit or 16-bit interface is set by bit 5 (IOIS8) of CCR1 at switching from the IC memory interface to the I/O card interface according to the CCR setting condition. - 2. The PC card mode does not support DMA. ### 1. Arrangement of Registers | De vieter vers | Ol | | System | Register bank | | | | |---------------------------------------|--------|---------|---------|---------------|---------|------|------| | Register name | Symbol | SA3/PA3 | SA2/PA2 | SA1/PA1 | SA0/PA0 | RBS1 | RBS0 | | Transmit status | DLCR0 | 0 | 0 | 0 | 0 | × | × | | Receive status | DLCR1 | 0 | 0 | 0 | 1 | × | × | | Transmit interrupt enable | DLCR2 | 0 | 0 | 1 | 0 | × | × | | Receive interrupt enable | DLCR3 | 0 | 0 | 1 | 1 | × | × | | Transmit mode | DLCR4 | 0 | 1 | 0 | 0 | × | × | | Receive mode | DLCR5 | 0 | 1 | 0 | 1 | × | × | | Control 1 | DLCR6 | 0 | 1 | 1 | 0 | × | × | | Control 2 | DLCR7 | 0 | 1 | 1 | 1 | × | × | | Node ID 0 | DLCR8 | 1 | 0 | 0 | 0 | 0 | 0 | | Node ID 1 | DLCR9 | 1 | 0 | 0 | 1 | 0 | 0 | | Node ID 2 | DLCR10 | 1 | 0 | 1 | 0 | 0 | 0 | | Node ID 3 | DLCR11 | 1 | 0 | 1 | 1 | 0 | 0 | | Node ID 4 | DLCR12 | 1 | 1 | 0 | 0 | 0 | 0 | | Node ID 5 | DLCR13 | 1 | 1 | 0 | 1 | 0 | 0 | | TDR0 | DLCR14 | 1 | 1 | 1 | 0 | 0 | 0 | | TDR1 | DLCR15 | 1 | 1 | 1 | 1 | 0 | 0 | | Multicast address 0 | MAR8 | 1 | 0 | 0 | 0 | 0 | 1 | | Multicast address 1 | MAR9 | 1 | 0 | 0 | 1 | 0 | 1 | | Multicast address 2 | MAR10 | 1 | 0 | 1 | 0 | 0 | 1 | | Multicast address 3 | MAR11 | 1 | 0 | 1 | 1 | 0 | 1 | | Multicast address 4 | MAR12 | 1 | 1 | 0 | 0 | 0 | 1 | | Multicast address 5 | MAR13 | 1 | 1 | 0 | 1 | 0 | 1 | | Multicast address 6 | MAR14 | 1 | 1 | 1 | 0 | 0 | 1 | | Multicast address 7 | MAR15 | 1 | 1 | 1 | 1 | 0 | 1 | | Buffer memory port | BMPR8 | 1 | 0 | 0 | 0 | 1 | 0 | | Transmit packet count | BMPR10 | 1 | 0 | 1 | 0 | 1 | 0 | | 16 collision | BMPR11 | 1 | 0 | 1 | 1 | 1 | 0 | | DMA enable | BMPR12 | 1 | 1 | 0 | 0 | 1 | 0 | | DMA burst/transceiver mode | BMPR13 | 1 | 1 | 0 | 1 | 1 | 0 | | Receive control/transceiver interrupt | BMPR14 | 1 | 1 | 1 | 0 | 1 | 0 | | Transceiver status/control | BMPR15 | 1 | 1 | 1 | 1 | 1 | 0 | ### 2. Explanation of Control Registers in LAN Controller ### 2.1 Data Link Controller Register ### (1) DLCR0: Transmit Status Register DLCR0 indicates the transmit status of the data link controller. The external interrupt INT is asserted by setting the bits of DLCR2 corresponding to the status bits, bit 7 and bit 3 to 0. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|-----------|---------|---------|---------|---------|---------|---------------| | Read | TMT OK | NET BSY | TMT REC | SRT RKT | JABBER | COL | 16 COL | BUS WR<br>ERR | | Write | BIT CLR | _ | _ | _ | BIT CLR | BIT CLR | BIT CLR | BIT CLR | | Initial Value | 0 | Undefined | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | |---------|-----------------------------------------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7 | TMT OK | Read | 0 | Indicates transmission in progress | | | | | | (Transmit O.K) | | 1 | This bit is set automatically when transmission of all packets in the transmitter buffer is completed. In the single buffer mode, the next transmit data can be transferred from the host system. In the dual buffer mode, transmission of data from the second bank can be started (Bit 7 (TMST) of the BMR10 is set). The dual buffer mode permits transfer of the next transmit data from the host system to one buffer, while the other buffer is transmitting packets. | | | | | | | Write | 0 | Not affected | | | | | | | | 1 | This bit is cleared. | | | | | 6 | NET BSY<br>(Net Busy) | Read | 0 | Indicates network empty (no carrier detected) | | | | | | | | 1 | Indicates network in use (carrier detected) | | | | | | | Write | _ | Not affected | | | | | 5 | TMT REC<br>(Transmit<br>Packet Receive) | Read | 0 | Indicates packets transmitted by this register not received normally. This bit is cleared automatically at the start of transmission of each packet. | | | | | | | | 1 | Indicates packets transmitted by this register received normally. This bit must not be used in normal operation. | | | | | | | Write | _ | Not affected | | | | | 4 | SRT PKT<br>(Short Packet) | Read | 0 | No short packet error. This bit is cleared automatically at the start of transmission of each packet. | | | | | | | | 1 | Indicates network carrier detect disappeared during packet transmission. This bit is usually set in the event of a packet collision or physical damage to the cable. | | | | | | | Write | | Not affected | | | | | Bit no. | Bit name | Operation | Value | Function | |---------|-------------------------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | JABBER | Read | 0 | No jabber | | | | | 1 | Indicates transmission suspension with continuous transmission over specified time detected by internal watchdog timer | | | | Write | 0 | Not affected | | | | | 1 | This bit is cleared. | | 2 | | Read | 0 | No collision error | | | (Collision Error) | | 1 | Indicates occurrence of packet collision on network during packet transmission. The data link controller performs retransmission automatically until 16 collisions occur. The count of collision can be checked by reading bits 7 to 4 of the collision counter register DLCR4. | | | | Write | 0 | Not affected | | | | | 1 | This bit is cleared. | | 1 | 16COL | Read | 0 | No 16 collision error | | | (16 Collision<br>Error) | | 1 | Indicates collisions occurred 16 times continuously during packet transmission. The operation after 16 collision errors can be set using bits 2 and 1 of the 16 collision control register BMPR11. | | | | Write | 0 | Not affected | | | | | 1 | This bit is cleared. | | 0 | BUS WR ERR | Read | 0 | No bus write error | | | (Bus Write<br>Error) | | 1 | Indicates LSI failed to assert RDY signal within 2.15 $\mu$ s at writing transmit data from system to transmitter buffer. In other words, transmit data could not be written because the transmitter buffer is full. This bit is never set at transmitting based on the normal operation flow. | | | | Write | 0 | Not affected | | | | | 1 | This bit is cleared. | # (2) DLCR1: Receive Status Register DLCR1 indicates the receive status of the data link controller. The external interrupt INT is asserted by setting the bits of DLCR3 corresponding to the status bits, bit 7 to 0. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|---------------|------------|---------|---------------|---------|---------|---------| | Read | PKT RDY | BUS RD<br>ERR | DMA<br>EOP | RMT RST | RX SRT<br>PKT | ALG ERR | CRC ERR | OVRFLO | | Write | BIT CLR | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | |---------|-------------------------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--|--|--| | 7 | PKT RDY | Read | 0 | No received packet is in the receiver | r buffer. | | | | | | (Packet Ready) | | 1 | Indicates packets from self office rec<br>transferred completely to receiver bu<br>In other words, at least one packet of<br>receiver buffer. | uffer. | | | | | | | Write | 0 | Not affected | | | | | | | | | 1 | This bit is cleared. If there are still received packets in the receiver buffer even after the host system has read one packet of receive data from the receiver buffer, this bit is automatically reset. | | | | | | 6 | 6 BUS RD ERR<br>(Bus Read<br>Error) | Read | 0 | No bus read error | | | | | | | | | 1 | Indicates LSI failed to assert RDY signal within 2.15 $\mu$ s at reading data in receiver buffer from host system. In other words, the host system attempted to read data from the receiver buffer, although the buffer has no data to read. | | | | | | | | Write | 0 | Not affected | | | | | | | | | 1 | This bit is cleared. | | | | | | 5 | 5 DMA EOP | | 0 | Indicates DMA transfer not yet completed during DMA transfer. This bit is cleared when both the DMA RENA and DMA TENA bits of the BMPR12 are cleared. | | | | | | | | | 1 | Indicates DMA transfer completed and EOP signal asserted by external DMA controller | * : This bit is invalid in the PC card mode. | | | | | | | Write 0 | 0 | Not affected | | | | | | | | | 1 | This bit is cleared. This clearing should be done by clearing both the DMA RENA and DMA TENA bits of the BMPR12. | | | | | | Bit no. | Bit name | Operation | Value | Function | | | | | | |---------|-----------------------------------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 4 | RMT RST | Read | 0 | The received packet is not a remote reset packet. | | | | | | | | (Remote Reset) | | 1 | Indicates value of data length field in received packet is 0900 <sub>H</sub> . This bit is set only when the ENA RMT RST bit of DLCR5 is set and a physical address match occurs; it is not set for the multicast address and broadcast address. It is also not set when the ENA SRT PKT bit of DLCR5 is set. | | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. It is also cleared automatically at the start of receiving the next packet. | | | | | | | 3 | | Read* | 0 | No short packet error | | | | | | | | (Short Packet) | | 1 | Indicates data length (address + data length + data) of received packet not more than minimum data length (60 bytes). This bit is set for not more than 6 bytes when the ENA SRT PKT bit of DLCR5 is set. It is not set when a collision occurs at the self-TXPKT. | | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 2 | 2 ALG ERR<br>(Alignment<br>Error) | Read* | 0 | No alignment error | | | | | | | | | | 1 | Indicates CRC of received packet incorrect and bit count of received data not multiple of 8 | | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 1 | CRC ERR | Read* | 0 | No CRC error | | | | | | | | (CRC Error) | | 1 | Indicates CRC of received packet incorrect. This bit is not set when a collision occurs at the self-TXPKT. | | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 0 | OVRFLO | Read* | 0 | No overflow error | | | | | | | | (Overflow Error) | Lifety | | Indicates that data erased because data length of received packet larger than free capacity of receiver buffer memory. Even when this bit is set, data is received normally when the data length of the next packet is smaller than the free capacity of the receiver buffer memory. This bit is set to indicate that the receiver buffer memory is almost full; transfer data immediately from the buffer to the host system. This bit is not set in the loopback mode. | | | | | | | | | Write | | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | $<sup>\</sup>ensuremath{^*}$ : The bit 3 to bit 0 are cleared when the new packet is received. # (3) DLCR2: Transmit Interrupt Enable Register The DLCR2 register enables a transmit interrupt. When the bit corresponding to the status bit of DLCR0 is set to 1, the external interrupt $\overline{\text{INT}}$ is asserted when the status bit is set. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------------|-------|-------|-------|---------------|---------|--------------|-------------------| | Read/Write | ENA<br>TMT OK | 0 | 0 | 0 | ENA<br>JABBER | ENA COL | ENA<br>16COL | ENA BUS<br>WR ERR | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|------------|------------|-------|---------------------------------------------------------------| | 7 | ENA TMT OK | Read/Write | 0 | Disables TMT OK interrupt | | | | | 1 | Enables TMT OK interrupt | | 6 to 4 | Not used | Read/Write | _ | The read value is always 0. Write 0 to these bits at writing. | | 3 | ENA JABBER | Read/Write | 0 | Disables JABBER interrupt | | | | | 1 | Enables JABBER interrupt | | 2 | ENA COL | Read/Write | 0 | Disables COL interrupt | | | | | 1 | Enables COL interrupt | | 1 | ENA 16COL | Read/Write | 0 | Disables 16COL interrupt | | | | | 1 | Enables 16COL interrupt | | 0 | ENA BUS RD | Read/Write | 0 | Disables BUS RD ERR interrupt | | | ERR | | 1 | Enables BUS RD ERR interrupt | # (4) DLCR3: Receive Interrupt Enable Register The DLCR3 register enables a receive interrupt. When the bit corresponding to the status bit of DLCR1 is set to 1, the external interrupt $\overline{\text{INT}}$ is asserted when the status bit is set. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|----------------|-------------------|----------------|----------------|-------------------|----------------|----------------|---------------| | Read/Write | ENA PKT<br>RDY | ENA BUS<br>RD ERR | ENA DMA<br>EOP | ENA<br>RMT RST | ENA RX<br>SRT PKT | ENA ALG<br>ERR | ENA<br>CRC ERR | ENA<br>OVRFLO | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | | |---------|-------------|------------------------|---------------------------|-------------------------------|-------------------------------|--|--|--|--| | 7 | ENA PKT RDY | Read/Write | 0 | Disables PKT RDY interrupt | | | | | | | | | | 1 | Enables TMT OK interrupt | | | | | | | 6 | ENA BUS RD | Read/Write | 0 | Disables BUS RD ERR interrupt | | | | | | | | ERR | | 1 | Enables BUS RD ERR interrupt | | | | | | | 5 | ENA DMA EOP | ENA DMA EOP Read/Write | 0 | Disables DMA EOP interrupt | *: This bit is invalid in the | | | | | | | | | 1 | Enables DMA EOP interrupt | PC card mode. | | | | | | 4 | ENA RMT RST | Read/Write | 0 | Disables RMT RST interrupt | | | | | | | | | 1 | Enables RMT RST interrupt | | | | | | | | 3 | ENA RX SRT | Read/Write | 0 | Disables RX SRT ERR interrupt | | | | | | | | ERR | | 1 | Enables RX SRT ERR interrupt | | | | | | | 2 | ENA ALG ERR | Read/Write | 0 | Disables ALG ERR interrupt | | | | | | | | | | 1 | Enables ALG ERR interrupt | | | | | | | 1 | ENA CRC ERR | Read/Write | 0 | Disables CRC ERR interrupt | | | | | | | | | | 1 | Enables CRC ERR interrupt | | | | | | | 0 | ENA OVRFLO | Read/Write | 0 | Disables OVRFLO interrupt | | | | | | | | | | 1 | Enables OVRFLO interrupt | | | | | | # (5) DLCR4: Transmit Mode Register DLCR4 sets the transmitter operation modes, and displays the count of collision occurrence. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|---------|-------|-------| | Read | COL3 | COL2 | COL1 | COL0 | TST1 | CNTRL | LBC | DSC | | Write | _ | _ | | _ | 0 | CIVITAL | LDC | DSC | | Initial Value | 0* | 0* | 0* | 0* | 0 | 1 | 1 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | |---------|--------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--|--| | 7 to 4 | COL3 to COL0<br>(Collision<br>Count) | Read | _ | Displays count of collision until transmission completed. These bits are cleared at the completion of transmission. | | | | | 3 | TST1<br>(Chip Test 1) | Read/Write | _ | This is a chip test bit. Always write 0 to this bit at writing to DLCR4. 1 cannot be written to this bit during normal operation. | | | | | 2 | CNTRL<br>(DREQ Control) | Read/Write | 0 | The DREQ signal is negated in the last cycle of DMA transfer. | * : This bit is invalid in the | | | | | | | 1 | The DREQ signal is negated two cycles before the last cycle of DMA transfer. | PC card mode | | | | 1 | 1 LBC<br>(Loopback<br>Control) | | 0 | Forced to enter loopback mode. The loopback is not canceled even when a collision is detected. Transmit data is not output from the TPOP*/TPON* pin. | | | | | 1 | | 1 | Enters standard loopback mode specified in 10BASE-T standard. The loopback function works only at data transmission. The transmit data is loopbacked to the receiver by the encoder/decoder. If the MB86967 is in the link fail and jabber states when a collision is detected, the loopback mode is canceled and signals are accepted from the twisted-pair board. | | | | | | 0 | DSC<br>(Disable<br>Carrier Detec) | Read/Write | _ | When this bit is set to 1, the MB869 transmission. In this case, data can irrespective of the state of the receiv loopback operation. | be transmitted · | | | <sup>\*:</sup> These bits are undefined until the first packet is completely transmitted after power-on. # (6) DLCR5: Receive Mode Register DLCR5 sets the receiver operation mode, and displays the status of the receiver buffer memory. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|---------|---------|-------|---------|---------|-------|-------| | Read | TST2 | BUF EMP | ACPT | ADD | ENA SRT | ENA | AM1 | AM0 | | Write | 0 | _ | BAD PKT | SIZE | PKT | RMT RST | AIVII | AIVIU | | Initial Value | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit no. | Bit name | Operation | Value | Function | |-----------------|-----------------------------------------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TST2<br>(Chip Test 2) | Read/Write | _ | This is a chip test bit. Always write 0 to this bit at writing to DLCR5. Writing 1 to this bit is prohibited during normal operation. | | 6 | BUF EMP | Read | 0 | Indicates valid data remaining in receiver buffer memory | | | (Buffer Empty) | | 1 | Indicates no valid data in receiver buffer memory | | | | Write | _ | Not affected | | 5 | ACPT BAD PKT<br>(Bad Packet<br>Receive) | Read/Write | 0 | If the received packet has short packet, alignment, and CRC errors, it is discarded and is not transferred to the receiver buffer. | | , | | | 1 | A packet with short packet, alignment, and CRC errors is transferred to the receiver buffer like a normally-received packet. | | 4 | 4 ADD SIZE (Address Size) | Read/Write | 0 | Compares destination addresses of receive packet and ID addresses of node for match at all 6 bytes (48 bits) | | | | | 1 | Compares destination addresses of received packet and ID addresses of node for match only at upper byte and 5 bytes (40 bits) | | 3 | ENA SRT PKT<br>(Enable Short | Read/Write | 0 | A packet of more than 60 bytes and less than 2 Kbytes can be received. | | Packet Receive) | | | 1 | A packet of more than 6 bytes and less than 2 Kbytes can be received. The value of this bit is ignored when bit 5 (ACPT BAD PKT) is set. | | 2 | ENA RMT RST | Read/Write | 0 | The remote reset packet is not detected. | | | (Enable Remote Reset) | | 1 | Checks whether value of data length field in receive packet is 0900н | | 1 and 0 | AM1, AM0<br>(Address<br>Match Mode) | Read/Write | | Selects node ID address match detect mode at packet receiving (Tables 3 and 4) | **Table 3 Receiving Packets from Other Nodes** | AM1 | AM0 | LBC | SELF RX | Physica | I Packet | Broadcast | Multicast Packet | | | |----------------|----------------|----------------|-----------------|-------------|----------------|-----------|---------------------|---------------------|--| | DLCR5<br>Bit 1 | DLCR5<br>Bit 0 | DLCR4<br>Bit 1 | BMPR14<br>Bit 0 | ID<br>Match | ID<br>Mismatch | Packet | Lower ID<br>Match*1 | Address<br>Filter*2 | | | 0 | 0 | × | × | Discarded | Discarded | Discarded | Discarded | Discarded | | | 0 | 1 | 0 | × | Discarded | Discarded | Discarded | Discarded | Discarded | | | 0 | 1 | 1 | × | Received | Discarded | Received | Received | Discarded | | | 1 | 0 | 0 | × | Discarded | Discarded | Discarded | Discarded | Discarded | | | 1 | 0 | 1 | × | Received | Discarded | Received | Discarded | Discarded | | | 1 | 1 | 0 | × | Discarded | Discarded | Discarded | Discarded | Discarded | | | 1 | 1 | 1 | × | Received | Received | Received | Received | Received | | # **Table 4 Receiving Packets Transmitted from Self Office** | AM1 | AM0 | LBC | SELF RX | Physica | I Packet | Broadcast | Multicas | t Packet | |----------------|----------------|----------------|-----------------|-------------|----------------|-----------|-----------|---------------------| | DLCR5<br>Bit 1 | DLCR5<br>Bit 0 | DLCR4<br>Bit 1 | BMPR14<br>Bit 0 | ID<br>Match | ID<br>Mismatch | ID Packet | | Address<br>Filter*2 | | 0 | 0 | × | × | Discarded | Discarded | Discarded | Discarded | Discarded | | 0 | 1 | 0 | × | Received | Discarded | Received | Received | Discarded | | 0 | 1 | 1 | × | Received | Discarded | Discarded | Discarded | Discarded | | 1 | 0 | 0 | × | Received | Discarded | Received | Discarded | Received | | 1 | 0 | 1 | × | Received | Discarded | Discarded | Discarded | Discarded | | 1 | 1 | 0 | × | Received | Received | Received | Received | Received | | 1 | 1 | 1 | 0 | Received | Received | Received | Received | Received | | 1 | 1 | 1 | 1 | Discarded | Discarded | Discarded | Discarded | Discarded | <sup>\*1:</sup> Lower ID Match: Receive the packets because a match occurs at the 24 lower bits of the node ID and bit 0 of the node ID register is 1. <sup>\*2:</sup> Address Filter: Receive the packets because bit 0 of the node ID register is 1 and the CRC value of the node ID register is selected by the multicast address register. # (7) DLCR6: Control Register 1 DLCR6 sets the MB86966 operation modes. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|-----------------|-------|-------|------------------|------------------|---------------|---------------| | Read/Write | ENA DLC | 100NS/<br>150NS | SB/SW | BB/BW | TX BUF<br>SIZE 1 | TX BUF<br>SIZE 0 | BUF<br>SIZE 1 | BUF<br>SIZE 0 | | Initial Value | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | | The part of | Bit no. | Bit name | Operation | Value | Function | | | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------|------------|-----------------|--------------|-------|--| | are initialized and both the transmitter and receiver buffers are also initialized. 8 | 7 | (Enable Data | Read/Write | 0 | tran | smitting a | and receiv | ving. When | this bit is 0, | the node II | | | | Sets cycle time of external SRAM to 100 ns. In this case, use SRAM with an access time of 80 ns or less. SB/SW (System Bus Width Select) | | | | 1 | are i | initialized | and both | | | | | | | Time Select) Selects width of system data bus | 6 | | Read/Write | 0 | Sets cycle time of external SRAM to 150 ns | | | | | | | | | SB/SW System Data Bus 0 16 bit 1 8 1 8 bit 1 1 1 1 1 1 1 1 1 | | | | 1 | In this case, use SRAM with an access time of 80 ns of | | | | | | less. | | | Width Select) PC Card Mode | 5 | | Read/Write | | Sele | cts width | of syster | m data bus | | | | | | PC Card Mode When 1 is written to bit 5 (IOIS8) of the CCR1, the SB/-SW bit is set to 1, placing the system data bus in the byte transfer mode. When 0 is written, the SB/-SW bit is set to 0, placing the system data bus in the word transfer mode. In the PC card mode, writing to the SB/-SW bit is performed by CCR1. Writing from DLCR6 does not affect bit 5. General-purpose Bus Mode The reversed value of the SB/SW bit is output to the external pin SB/SW. A BB/BW (Buffer Memory Bus Width) Write Write Not affected | | (System Bus<br>Width Select) | | | | | SB/SV | <b>√</b> ; | System Data | Bus | | | | PC Card Mode When 1 is written to bit 5 (IOIS8) of the CCR1, the SB/-SW bit is set to 1, placing the system data bus in the byte transfer mode. When 0 is written, the SB/-SW bit is set to 0, placing the system data bus in the word transfer mode. In the PC card mode, writing to the SB/-SW bit is performed by CCR1. Writing from DLCR6 does not affect bit 5. General-purpose Bus Mode The reversed value of the SB/SW bit is output to the external pin SB/SW. Write Write Write The width of the buffer memory data bus is fixed to 8 bits. The read value of this bit is always 1. Write Not affected TX BUF SIZE 1 TX BUF SIZE 1 TX BUF SIZE 0 TX BUF SIZE 0 TX BUF SIZE Bank Bank Capacity Count | | Tridiii Golooti | | | | | 0 | | 16 bit | | | | | When 1 is written to bit 5 (IOIS8) of the CCR1, the SB/-SW bit is set to 1, placing the system data bus in the byte transfer mode. When 0 is written, the SB/-SW bit is set to 0, placing the system data bus in the word transfer mode. In the PC card mode, writing to the SB/-SW bit is performed by CCR1. Writing from DLCR6 does not affect bit 5. 4 BB/BW (Buffer Memory Bus Width) Read The width of the buffer memory data bus is fixed to 8 bits. The read value of this bit is always 1. Write Not affected TX BUF SIZE 1 TX BUF SIZE 1 TX BUF SIZE 0 (Transmitter Buffer Size) Read/Write TX BUF SIZE 0 (Tansmitter Buffer Size) Not affected Bank Capacity Count Capacity O 0 2 Kbyte 1 2 Kbyte O 1 2 Kbyte O 1 4 Kbyte 2 8 Kbyte | | | | | | | 1 | | 8 bit | | | | | Buffer Memory Bus Width) Write Not affected | | | | | When 1 is written to bit 5 (IOIS8) of the CCR1, the S bit is set to 1, placing the system data bus in the byte transfer mode. When 0 is written, the SB/-SW bit is splacing the system data bus in the word transfer moder in the PC card mode, writing to the SB/-SW bit is per by CCR1. Writing from DLCR6 does not affect bit 5. General-purpose Bus Mode The reversed value of the SB/SW bit is output to the | | | | | | to 0, | | | 3 and 2 TX BUF SIZE 1 TX BUF SIZE 0 (Transmitter Buffer Size) | 4 | (Buffer Memory | Read | 1 | | | | | ata bus is fixe | ed to 8 bits | . The | | | TX BUF SIZE 0 (Transmitter Buffer Size) TX BUF SIZE 1 0 Capacity Capacity D 1 2 Kbyte 1 0 4 Kbyte Ruffer Capacity A Kbyte | | Bus Width) | Write | | Not | affected | | | | | | | | (Transmitter Buffer Size) TX BUF Size Bank Capacity Bank Count Capacity | 3 and 2 | | Read/Write | _ | Sets | size of t | ransmitte | r buffer. | | | | | | 0 0 2 Kbyte 1 2 Kbyte 0 1 2 Kbyte 2 4 Kbyte 1 0 4 Kbyte 2 8 Kbyte | | | | | | TX BU | IF SIZE | | | | | | | 0 1 2 Kbyte 2 4 Kbyte<br>1 0 4 Kbyte 2 8 Kbyte | | | | | 1 0 Capacity Count Capacit | | | | | | | | | 1 0 4 Kbyte 2 8 Kbyte | | | | | | | | 2 Kbyte | | 2 Kbyte | | | | | | | | | | | - | • | | • | | | | 1 1 8 Kbyte 2 16 Kbyte | | | | | | | | • | | | | | | | | | | | | 1 | 2 | 16 Kbyte | Э | | | | <sup>\*:</sup> This register is accessible only for the device initialization. # (Continued) | Bit no. | Bit name | Operation | Value | | Fun | ction | | | | | |---------|------------|------------|-------|-------------------------------------------|---------------------------------------|--------------------------|--------|--|--|--| | 1 | BUF SIZE 1 | Read/Write | _ | | of external buffer me<br>buffer size) | mory (transmitter buffer | size + | | | | | | | | | BUF SIZE 1 Buffer Size | | | | | | | | | | | | 0 8 Kbyte | | | | | | | | | | | | 1 32 Kbyte | | | | | | | | 0 | BUF SIZE 0 | Read | 0 | The read value of this bit is fixed at 0. | | | | | | | | | | Write | _ | Not affec | ted | | | | | | # (8) DLCR7: Control Register 2 DLCR7 sets the MB86967 operation modes. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|---------|-------|--------|-------|-------|---------|-------| | Read | IDENT1 | IDENT0 | STBY | RDYPOL | RBS1 | RBS0 | EOP/EOP | BYTE | | Write | IDLINIT | IDLINIO | 3101 | _ | NDO I | ND30 | LOF/LOF | SWAP | | Initial Value | 1 | 0 | 1 | × | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|------------------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 and 6 | IDENT1<br>IDENT0 | Read | _ | Reading the initial values of these bits permits checking the type of controller used in software. Read values 10: MB86967 Read values 11: MB86965A Read values 01: MB86964 Read values 00: MB86960A Writing to these bits is invalid. | | 5 | STBY | Read/Write | 0 | The LAN controller is placed in the standby mode. In the standby mode, the clock stops, reducing current consumption to about 10%. When 1 is prewritten to bit 4 of BMPR14, the MB86967 enters the shutdown mode. In this mode, the crystal oscillator stops, reducing the current consumption to about 1%. In the PC card mode, when the PwrDwn bit of CCR1 is set to 1, this bit is set to 0. Writing from DLCR7 to this bit is prohibited. | | | | | 1 | Operating state (not standby state). In the PC card mode, when the PwrDwn bit of CCR1 is set to 0, this bit is set to 1. Writing from DLCR7 to this bit is prohibited. Return from the shutdown mode by resetting. | | 4 | RDYPOL | Read | _ | The value of the external pin RDYPOL can be read. In the PC card mode, the read value is always 1. In the ISA bus mode, the read value of this bit is always 0. | | | | Write | _ | Not affected | #### (Continued) | Bit no. | Bit name | Operation | Value | | | Function | | | | |---------|--------------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------|--------------------------------|--|--| | 3 and 2 | RBS1<br>RBS0 | Read/Write | _ | The MB86967 has three internal register sets. Bank switching by these bits allows the system to access each register set. DLCR0 to DLCR7 can always be accessed irrespective of the conditions of register banks. | | | | | | | | | | | RBS1 | RBS2 | Address 00 <sub>H</sub> to 07 | 'н Address 08н to 0Fн | | | | | | | | 0 | 0 | DLCR0 to DLCR7 | DLCR8 to DLCR15 | | | | | | | | 0 | 1 | DLCR0 to DLCR7 | MAR8 to MAR15 | | | | | | | | 1 | 0 | DLCR0 to DLCR7 | BMPR8 to BMPR15 | | | | | | | | 1 | 1 | DLCR0 to DLCR7 | Reserved | | | | 1 | EOP/EOP | Read/Write | 0 | Sets DM. | | gnal (EOP) input | * : This bit is invalid in the | | | | | | | 1 | Sets DM.<br>pin Active | | gnal (EOP) input | PCMCIA mode. | | | | 0 | BYTE SWAP | Read/Write | 0 | When the mode, by performe The bus | rte swap<br>d for acc | *: Writing 1 to this bit is prohibited in the PC | | | | | | | | 1 | When the mode, by for acces between bus is a ! | card mode. Always write 0 to this bit. | | | | | #### (9) DLCR8 to DLCR13: Node ID Registers | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | DLCR8 | ID7 | ID6 | ID5 | ID4 | ID3 | ID2 | ID1 | ID0 | | DLCR9 | ID15 | ID14 | ID13 | ID12 | ID11 | ID10 | ID9 | ID8 | | DLCR10 | ID23 | ID22 | ID21 | ID20 | ID19 | ID18 | ID17 | ID16 | | DLCR11 | ID31 | ID30 | ID29 | ID28 | ID27 | ID26 | ID25 | ID24 | | DLCR12 | ID39 | ID38 | ID37 | ID36 | ID35 | ID34 | ID33 | ID32 | | DLCR13 | ID47 | ID46 | ID45 | ID44 | ID43 | ID42 | ID41 | ID40 | DLCR8 to DLCR13 store the node ID of the self office. After comparing the destination addresses in the receive packet with the values of the node ID registers, the matching packets are received according to the setting conditions of the Address Match Mode bits of DLCR5. Usually, set bit 0 (ID 0) of DLCR8 to 0 (When bit 0 of the destination address is 1, the received data serve as the multicast address and the packet is received according to the setting conditions of the Address Match Mode bits of DLCR5, irrespective of their values). The initial values of the node ID registers are undefined. Reading and writing are possible only when bit 7 (ENA DLC) of DLCR6 is 1. #### (10) DLCR14 and DLCR15: TDR Registers | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | DLCR14 | TDR7 | TDR6 | TDR5 | TDR4 | TDR3 | TDR2 | TDR1 | TDR0 | | DLCR15 | 0 | 0 | TDR13 | TDR12 | TDR11 | TDR10 | TDR9 | TDR8 | DLCR14 and DLCR15 are 14-bit counters that are reset at the start of transmission to count the transmit bits until a collision occurs or the carrier is dropped. They are read-only registers. The read values of bits 7 and 6 of DLCR15 is always 0. #### 2.2 Multicast Address Registers | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------|-------|-------|-------|-------|-------|-------|-------|-------| | MAR8 | MID7 | MID6 | MID5 | MID4 | MID3 | MID2 | MID1 | MID0 | | MAR9 | MID15 | MID14 | MID13 | MID12 | MID11 | MID10 | MID9 | MID8 | | MAR10 | MID23 | MID22 | MID21 | MID20 | MID19 | MID18 | MID17 | MID16 | | MAR11 | MID31 | MID30 | MID29 | MID28 | MID27 | MID26 | MID25 | MID24 | | MAR12 | MID39 | MID38 | MID37 | MID36 | MID35 | MID34 | MID33 | MID32 | | MAR13 | MID47 | MID46 | MID45 | MID44 | MID43 | MID42 | MID41 | MID40 | | MAR14 | MID55 | MID54 | MID53 | MID52 | MID51 | MID50 | MID49 | MID48 | | MAR15 | MID63 | MID62 | MID61 | MID60 | MID59 | MID58 | MID57 | MID56 | The multicast address registers select the multicast address packet to receive when the Address Match Mode bits of DLCR5 are set to 1 and 0, respectively. Multicast addresses are input to a 32-bit CRC circuit and grouped into 64 by the six rightmost bits of the calculated CRC. Packets with multicast addresses of groups in which set the bits corresponding to the multicast address registers are received. The initial values of the multicast address registers are undefined. Reading and writing are possible only when bit 7 (ENA DLC) of DLCR6 is 1. #### 2.3 Buffer Memory Port Registers #### (1) BMPR8: Buffer Memory Port | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |----------|-------|-------|-------|-------|-------|-------|-------|-------| | BMPR8 | BMP7 | BMP6 | BMP5 | BMP4 | BMP3 | BMP2 | BMP1 | BMP0 | | DIVIFICO | BMP15 | BMP14 | BMP13 | BMP12 | BMP11 | BMP10 | BMP9 | BMP8 | BMPR8 is a data port for transferring transmit and receive data between the host system and buffer memory. When the system interface is in the byte mode, BMPR8 serves as an 8-bit I/O port. When the system interface is in the 16-bit bus mode, BMPR8 serves as a 16-bit I/O port. In the 16-bit bus mode, other registers can be accessed in both bytes and words, but this register can be accessed only in words. In the 16-bit bus mode, setting bit 0 (BYTE SWAP) of DLCR7 permits order swapping between MSB and LSB, allowing this register to work with both Intel and Motorola processors. # (2) BMPR10: Transmit Packet Count Register BMPR10 sets the transmit start bit and transmit packet count. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|--------|--------|--------|--------|--------|--------|--------| | Read | 0 | TX PKT | Write | TMST | CNT 6 | CNT 5 | CNT 4 | CNT 3 | CNT 2 | CNT 1 | CNT 0 | | Initial Value | 0 | × | × | × | × | × | × | × | | Bit no. | Bit name | Operation | Value | Function | |---------|----------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TMST | Read | 0 | The read value of this bit is always 0. | | | | Write | 0 | Not affected | | | | | 1 | Starts transmitting packet. When the transmitter buffer is in the single buffer mode, set this bit after transferring the transmit packet from the host to the transmit buffer. When the transmitter buffer is in the dual buffer mode, set this bit after transferring the transmit packet to the transmitter buffer and completing transmission of the packet to the second bank (after the TMT OK bit of DLCR0 is set). | | 6 to 0 | TX PKT CNT<br>6 to 0 | Read | _ | These bits are decremented each time transmission of one packet is completed, and display the count of packets that have not been transmitted yet. They are set to 00H after all packets have been transmitted. | | | | Write | _ | The MB86967 can start transmitting more than one packet using one transmit command. Set the TMST bit and write the transmit packet count (the count of packet transferred to buffer memory). | # (3) BMPR11: 16 Collision Control Register BMPR11 controls operation of the data link controller after a 16 collisions occur. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|-----------------|-----------------|-----------------| | Read/Write | 0 | 0 | 0 | 0 | 0 | 16COL<br>CNTL 2 | 16COL<br>CNTL 1 | 16COL<br>CNTL 0 | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | |---------|----------------------|----------------|-------|----------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 7 to 3 | Not used | Read | 0 | The re | ead v | alues | of these bits is always 0. | | | | | Write | 0 | Writing 1 is prohibi | | | nibited. Always write 0 at writing. | | | 2 to 0 | 16COL CNTL<br>2 to 0 | Read/<br>Write | _ | 16C | OL C | NTL | Operation after 16COLs Occur | | | | | | | 2 | 1 | 0 | operation after 100013 000ar | | | | | | | 1 | 1 | 0 | Similar to ordinary collisions, the transmit packet causing 16COLs is retransmitted automatically (Auto Mode). | | | | | | | 1 | 1 | 1 | The next packet is transmitted automatically after skipping the transmit packet causing the 16COLs (Auto Mode). | | | | | | | 0 | 1 | × | When 16COLs occur, stop the transmitted data link controller temporarily. To resume transmission, write the values listed in the table below to this register. These values are valid only when written. Write them to this register each time transmission stops after 16COLs occur (Manual Mode). | | | | | | | 16C | OL C | NTL | Operation when Resuming | | | | | | | 2 | 1 | 0 | Transmission in Manual Mode | | | | | | | 0 | 1 | 0 | Similar to ordinary collisions, the transmit packet causing 16COLs is retransmitted. | | | | | | | 0 | 1 | 1 | The next packet is transmitted after skipping the transmit packet causing the 16COLs. | | #### (4) BMPR12: DAM Enable Register The BMPR12 controls DMA transfer between the host system and the MB86967. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |------------------|-------|-------|-------|-------|---------|-------|-------|-------| | Read | × | × | × | × | LONGPKT | 0 | DMA | DMA | | Write | 0 | 0 | 0 | 0 | RCV DIS | U | RENA | TENA | | Initial<br>Value | × | × | × | × | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | |---------|-------------------|------------|--------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--|--| | 7 to 4 | Not used | Read | _ | The read values of these bits are all | ways undefined. | | | | | | Write | 0 | Writing 1 is prohibited. Always write 0 at writing. | | | | | 3 | LONGPKTRCV<br>DIS | Read/Write | 0 | The receive long packet removal function is enabled. Packets with a length of 1792 bytes or more are not received. | | | | | | | | 1 | The receive long packet removal function is disabled. Packets with a length of up to 2047 bytes cannot be received normally. | | | | | 2 | Not used | Read/Write | _ | The read value of this bit is always 0. Writing 1 is prohibited. Always write 0 at writing. | | | | | 1 | DMA RENA | Read/Write | 0 (*1) | DMA read operation is disabled. | | | | | | | | 1 (*2) | DMA read operation (reading from receiver buffer) is enabled. | * : Writing 1 to this bit is prohibited in the PC | | | | 0 | DMA TENA | Read/Write | 0 (*1) | The DMA write operation is disabled. The DMA write operation is card mode. Alw write 0 to this because of the card mode. | | | | | | | | 1 (*2) | The DMA write operation (writing to receiver buffer) is enabled. | | | | <sup>\*1:</sup> The DLCR1 DMAEOP bit is cleared if the DMA RENA bit and DMA TENA bit are set to "00". <sup>\*2:</sup> Writing "11" to both DMA RENA bit and DMA TENA bit is prohibited. # (5) BMPR13: DMA Burst/Transceiver Mode Control Register The BMPR13 sets the DMA transfer cycle count between the host system and MB86967 and the operation modes of the 10BASE-T transceiver. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|--------------------|-------|---------------------|-------|-------|-------|---------------|---------------| | Read | I/O BASE<br>UNLOCK | • | LINK<br>TEST<br>ENA | 0 | 0 | 0 | DMA<br>BRST 1 | DMA<br>BRST 0 | | Write | | 0 | | | | | | | | Initial Value | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | | |---------|---------------------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--|--|--| | 7 | I/O BASE<br>UNLOCK | Read/Write | 0 | The I/O ba | | ss is not changed even after an I/O-read<br>s X12H. | | | | | | | | 1 | An I/O-read operation to address X12H increments the values of the I/O base address select signals (IOSEL0 to IOSEL2), causing a change in the I/O base address (This is valid only in the jumperless ISA bus mode). | | | | | | | 6 | Not used | Read/Write | _ | | The read value of this bit is always 0. Writing 1 is prohibited. Always write 0 to this bit at writing. | | | | | | 5 | LINK TEST | Read/Write | 0 | The link test on the 10BASE-T transceiver is enabled. | | | | | | | | ENA | | 1 | The link test on the 10BASE-T transceiver is disabled. | | | | | | | 4 to 2 | Not used | Read/Write | _ | | | hese bits is always 0.<br>ed. Always write 0 to these bits at writing. | | | | | 1 and 0 | DMA BRST<br>1 and 0 | Read/Write | _ | | | ycle count is set by one bus request lid in the PC card mode). | | | | | | | | | BRST1 | BRST0 | DAM Transfer Cycle Count (Max.) | | | | | | | | | 0 | 0 | 1 (single DMA) | | | | | | | | | 0 | 1 | 4 | | | | | | | | | 1 | 0 | 18 | | | | | | | | | 1 | 1 | 12 | | | | # (6) BMPR14: Receiver Control/Transceiver Interrupt Enable/Shutdown Register BMPR14 controls interrupts from the receiver buffer pointer and 10BASE-T transceiver. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|----------------|-------|---------------------|-------|---------|----------------|---------------| | Read | 0 | ENA LKF<br>INT | _ | SHUT<br>DWN<br>MODE | TST3 | SKIP RX | ENA<br>SQE INT | ENA<br>FILTER | | Write | 0 | | 0 | | 0 | PKT | | | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|--------------------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Not used | Read/Write | _ | The read value of this bit is always 0. Always write 0 to this bit at writing. | | 6 | ENA LKF INT | Read/Write | 0 | The link fail interrupt is disabled. | | | | | 1 | The link fail interrupt is enabled. | | 5 | Not used | Read/Write | _ | The read value of this bit is always 0. Always write 0 to this bit at writing. | | 4 | SHUT DWN<br>MODE | Read/Write | 0 | When bit 5 (STBY) of DLCR7 is set, the MB86967 enters the standby state (oscillation continues). | | | | | 1 | When bit 5 (STBY) of DLCR7 is set, the MB86967 enters the shutdown state (oscillation stops). | | 3 | TST3 (Chip Test 3) | Read/Write | _ | This a chip test bit. Always write 0 to this bit at writing to the BMPR14. Writing 1 to this bit during normal operation is prohibited. | | 2 | SKIP RX PKT | Read/Write | 0 | Skipping the receiver buffer pointer is completed. | | | | | 1 | The receiver buffer pointer is being skipped (updated), indicating the transient state from when 1 is written to this bit until skipping the pointer is completed (about 200 ns). | | | | | 0 | Not affected.<br>The receiver buffer pointer is not skipped. | | | | | 1 | When 1 is written to this bit, the receiver buffer pointer is skipped up to the beginning of the next packet. This bit is cleared automatically when skipping is completed. If the packet to be skipped is the last one in the receiver buffer, the BUF EMP bit of DLCR5 is set after the receiver buffer pointer is skipped. This function works only after reading the receive packet header (4 bytes). And, it is prohibited to write "1" when the remainder of the packet becomes 8-byte. | | 1 | ENA SQE INT | Read/Write | 0 | The signal quality error interrupt is disabled. | | | | | 1 | The signal quality error interrupt is enabled. | | 0 | FILTER SELF<br>RX | Read/Write | 0 | When the Address Match Mode bits AM1 and AM0 are 11, the packet transmitted from the self office is also received. | | | | | 1 | When the Address Match Mode bits AM1 and AM0 are 11, the packet transmitted from the self office is not received. | # (7) BMPR15: Transceiver Status Control Register BMPR15 indicates the status of the 10BASE-T transceiver. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|---------|-------|-------|---------|-------|---------|-------| | Read | 0 | LKF | 0 | 0 | POL REV | 0 | SQE | 0 | | Write | | BIT CLR | | | BIT CLR | | BIT CLR | | | Initial Value | 0 | × | 0 | 0 | × | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | | |---------|----------|------------|-------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|--| | 7 | Not used | Read/Write | _ | The read value of this bit is always 0. Writing 1 is prohibited. Always write 0 to this bit at writing. | | | | | | | 6 | LKF | Read | 0 | No link fail is detected. | | | | | | | | | | 1 | A link fail is detected. | | | | | | | | | | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 5 and 4 | Not used | Read/Write | _ | The read value of this bit is always 0. Writing 1 is prohibited. Always write 0 to this bit at writing. | | | | | | | 3 | POL REV | Read | 0 | Polarity reversal is not detected. | | | | | | | | | | 1 | Polarity reversal is detected. | | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 2 | Not used | Read/Write | _ | The read value of this bit is always (Writing 1 is prohibited. Always write | | | | | | | 1 | SQE | Read | 0 | An SQE error is not detected. | *: The read value of this | | | | | | | | | 1 | An SQE error is detected. | bit is always 0 when bit<br>0 of DLCR4(DSC:<br>Disable Carrier<br>Detect) is enabled (1). | | | | | | | | Write | 0 | Not affected | | | | | | | | | | 1 | This bit is cleared. | | | | | | | 0 | Not used | Read/Write | _ | The read value of this bit is always 0. Writing 1 is prohibited. Always write 0 to this bit at writing. | | | | | | #### **■ EXPLANATION OF ISA BUS MODE** #### 1. Jumperless ISA Mode In this mode, the LAN controller reads the I/O addresses and interrupt outputs from initialization data in external $E^2PROM$ after the hardware reset at power-on, and initializes them. It takes about 50 $\mu s$ until initialization is completed. This eliminates the need for on-board DIP switches for address decode selection. The initialization data can be changed because the E<sup>2</sup>PROM can be read and written. Utilities for changing initialization data allow an inexperienced user to retrieve contentions between I/O addresses and mount a LAN interface card in any personal computer. Only one byte is used for the initialization data in the E<sup>2</sup>PROM. Second and later bytes should be used to store node ID. Data (node ID) at the second and later bytes should be read bit-by-bit, converted to parallel data, and then written to the node ID registers (DLCR8 to DLCR15). #### 1.1 Setting at E<sup>2</sup>PROM The initial values should be prewritten to the first byte in the E<sup>2</sup>PROM as shown in Figure 8; the node ID should be prewritten to the second and later bytes. After a hardware reset, the LAN controller reads the initialization data at the first one byte in E<sup>2</sup>PROM automatically, and sets it at the BMPR19 internal register. Figure 8 Configuration of Bits at First One Byte in E<sup>2</sup>PROM #### 1.2 Setting I/O Base Addresses After completing jumperless initialization, read 8 bytes (DLCR0 to DLCR7) of the registers in the LAN controller using the system software and check that the initial values in these registers have been read correctly. If they are not read correctly, the I/O addresses are assumed to overlap other I/O addresses, and must be changed. To make a change, read BMPR18 (the read value is meaningless). Each time BMPR18 is read, the values of IOSEL2 to IOSEL0 are incremented from 000 to 111 and the updated values become valid in BMPR19. When the I/O addresses are updated until the values of DLCR0 to DLCR7 can be read properly, the LAN controller is located at the correct I/O addresses. After the I/O addresses have been defined, to prevent them being updated in error when BMPR18 is read, clear bit 7 (I/O BASE UNLOCK) of BMPR13. When the I/O address values found by the above operation are prewritten to E<sup>2</sup>PROM, the above operation is not needed at the next system startup, which reduces the system startup overhead. Consequently, the above retrieval of I/O addresses is required only when the LAN interface board is first installed in a personal computer. #### 1.3 Setting Interrupt Signals The LAN controller has four interrupt output pins. The interrupt output pin from which interrupt signals should be output can be specified by initialization data in E²PROM. If contention occurs between the interrupt signals and other I/O devices, the address decoder cannot be updated like the I/O addresses. Write another address decode value to E²PROM and then restart the system. Repeat the above process until interrupt signals are allocated to the correct address area. #### 1.4 Restarting System To restart the system, perform a hardware reset or a write operation to the reset registers RESET0 to RESET7 (any data can be written to any of RESET0 to RESET7). The write operation provides the same condition as the hardware reset except that BMPR16 and BMPR17 are not initialized. Initialization takes about $50 \mu s$ after canceling a hardware reset, or completing a write operation at the reset registers. #### 2. Jumper + E<sup>2</sup>PROM ISA Mode This mode is the jumperless ISA mode without automatic initialization function. The I/O addresses are set by external pins. The interrupt output pin is fixed at IRQ0. The E<sup>2</sup>PROM interface functions only to store node ID. Read and write operations from and to E<sup>2</sup>PROM are performed by the system software. After converting read serial data to parallel data, write the data to the node ID registers (DLCR8 to DLCR15). #### 3. Performance Comparison between Jumperless ISA Mode and Jumper + E<sup>2</sup>PROM ISA Mode | | Jumperless ISA Mode | Jumper + E <sup>2</sup> PROM ISA<br>Mode | |-------------------------------|---------------------|------------------------------------------| | Automatic initialization | 0 | × | | E <sup>2</sup> PROM interface | (Required) | ○ (Option) | | Interrupt output selection | 0 | × | # 4. Register Arrangement Registers accessible only in the ISA mode are listed below. | Degister Name | Symbol | | Sys | stem Add | ress | | Regist | er Bank | |-----------------------------|--------|-----|-----|----------|------|-----|--------|---------| | Register Name | Symbol | SA4 | SA3 | SA2 | SA1 | SA0 | RBS1 | RBS0 | | E <sup>2</sup> PROM control | BMPR16 | 1 | 0 | 0 | 0 | 0 | × | × | | E <sup>2</sup> PROM data | BMPR17 | 1 | 0 | 0 | 0 | 1 | × | × | | I/O base address | BMPR18 | 1 | 0 | 0 | 1 | 0 | × | × | | Jumperless setting | BMPR19 | 1 | 0 | 0 | 1 | 1 | × | × | | Reserved | _ | 1 | 0 | 1 | 0 | 0 | × | × | | Reserved | _ | 1 | 0 | 1 | 0 | 1 | × | × | | Reserved | _ | 1 | 0 | 1 | 1 | 0 | × | × | | Reserved | _ | 1 | 0 | 1 | 1 | 1 | × | × | | Reset 0 | RES0 | 1 | 1 | 0 | 0 | 0 | × | × | | Reset 1 | RES1 | 1 | 1 | 0 | 0 | 1 | × | × | | Reset 2 | RES2 | 1 | 1 | 0 | 1 | 0 | × | × | | Reset 3 | RES3 | 1 | 1 | 0 | 1 | 1 | × | × | | Reset 4 | RES4 | 1 | 1 | 1 | 0 | 0 | × | × | | Reset 5 | RES5 | 1 | 1 | 1 | 0 | 1 | × | × | | Reset 6 | RES6 | 1 | 1 | 1 | 1 | 0 | × | × | | Reset 7 | RES7 | 1 | 1 | 1 | 1 | 1 | × | × | # 5. BMPR16: E<sup>2</sup>PROM Control Register BMPR16 controls external E<sup>2</sup>PROM. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | Read | × | × | × | × | × | × | × | × | | Write | 0 | ESK | ECS | 0 | 0 | 0 | 0 | 0 | | Initial Value | × | 0 | 0 | × | × | × | × | × | | Bit no. | Bit name | Operation | Value | Function | |---------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Not used | Read | _ | The read value of this bit is undefined. | | | | Write | 0 | Always write 0 to this bit at writing. | | 6 | ESK | Read | | The read value of this bit is undefined. | | | | Write | _ | Shift clocks to E <sup>2</sup> PROM are generated by repeatedly writing 1 or 0 to this bit. | | 5 | ECS | Read | | The read value of this bit is undefined. | | | | Write | _ | When 1 is written to this bit, the E²PROM chip select signal is asserted. When 0 is written to this bit, the E²PROM chip select signal is negated. | | 4 to 0 | Not used | Read | _ | The read values of these bits are undefined. | | | | Write | 0 | Always write 0s to these bits at writing. | # 6. BMPR17: E<sup>2</sup>PROM Data Register BMPR17 is an external E<sup>2</sup>PROM data port. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | Read | EDIO | × | × | × | × | × | × | × | | Write | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Initial Value | 0 | × | × | × | × | × | × | × | | Bit no. | Bit name | Operation | Value | Function | |---------|----------|-----------|-------|-------------------------------------------------------| | 7 | EDIO | Read | _ | Port for reading output data from E <sup>2</sup> PROM | | | | Write | _ | Port for writing input data to E <sup>2</sup> PROM | | 6 to 0 | Not used | Read | _ | The read values of these bits are undefined. | | | | Write | 0 | Always write 0s to these bits at writing. | # 7. BMPR18: I/O Base Address Register BMPR18 updates and displays the I/O base addresses (valid only in jumperless mode). | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | Read | IOBA7 | IOBA6 | IOBA5 | IOBA4 | IOBA3 | IOBA2 | IOBA1 | IOBA0 | | Write | _ | _ | _ | _ | _ | _ | _ | | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|----------------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 to 0 | IOBA7 to IOBA0 | Read | _ | Each time this register is read, the I/O base address select signals (IOSEL2 to IOSEL0) are incremented to update the I/O base addresses. The updated values can be read from bits 2 to 0 of BMPR19. The read values of this register have no meaning. | #### 8. BMPR19: Jumperless Setting Register BMPR19 displays the initialization value in the jumperless mode (valid only in jumperless mode). | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|---------|-------|-------|-------|--------|--------|--------| | Read | INTSEL1 | INTSEL1 | × | × | × | IOSEL2 | IOSEL1 | IOSEL0 | | Write | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |---------------|------------------|-----------|-------|---------------------------------|----------------------------------------------|--------------|--------------|-------------------------|------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|---|---|--------------| | 7 to 6 | INTSEL1 | Read | _ | Display the interrupt channels. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | INTSEL0 | | | | INTSEL | 1 INTS | EL0 | Interrupt Channel (Pin) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 0 | | IRQ0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 1 | | IRQ1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 0 | | IRQ2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 1 | | IRQ3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 5 to 3 | Not used | Read | _ | The | The read values of these bits are undefined. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2 to 0 IOSEL2 | Read | _ | Dis | play the I | boot ROM | l address | ses. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | IOSEL1<br>IOSEL0 | | | | Ī | OSEL2 | IOSEL1 | IOSELO | I/O Base Address | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 100220 | | | | 0 | 0 | 0 | 260н to 27Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 0 | 1 | 280н to 29Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 1 | 0 | 2A0н to 2BFн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 1 | 1 | 240н to 25Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 0 | 0 | 340н to 35Fн | | | | | 1 0 1 | | | 320н to 33Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 1 | 0 | 380н to 39Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | 1 | 1 | 300н to 31Fн | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 9. RES0 to RES7: Reset Registers These 8-byte reset registers are valid only in the ISA bus mode. Writing to these registers (any data can be written to any of RES0 to RES7) allows initialization of the buffer manager, data link controller, Manchester encoder/decoder, and 10BASE-T transceiver. This writing also allows the internal registers to be initialized by a reset, but prohibits initialization of BMPR18 and BMPR19. #### **■ EXPLANATION OF PC CARD MODE** #### 1. E<sup>2</sup>PROM/FLASH Interface - \*1: Changed depending on size of E<sup>2</sup>PROM or flash ROM [Example] - PA0 to PA16 for 128-KB flash ROM - \*2: To I/O-read the ID number, connect the ROMAD pin to the most significant bit of ROM. If I/O-read is not required, leave the ROMAD pin open to set the ID number in the CIS. #### 2. Use of E<sup>2</sup>PROM and Flash ROM #### 2.1 Setting ID Number in CIS | ROM Size | CIS<br>Space | Common<br>Memory Space | CCR<br>Location | Address Pin from<br>System to ROM | Address Pin from<br>System to MB86966 | |-----------------------------|--------------|------------------------|-----------------|-----------------------------------|---------------------------------------| | 128-Kbyte flash<br>ROM | 2 Kbytes | 126 Kbytes | 7F0н to 7F6н | A0 to A16 | A0 to A10 | | 2-Kbyte E <sup>2</sup> PROM | 2 Kbytes | _ | 7F0н to 7F6н | A0 to A10 | | # 2.2 I/O-reading ID Number | ROM Size | CIS<br>Space | Common<br>Memory<br>Space | I/O<br>Space | CCR<br>Location | Address Pin<br>from System<br>to ROM | Address Pin<br>from System<br>to MB86966 | Address Pin<br>from MB86966<br>to ROM | |--------------------------------|--------------|---------------------------|--------------|-----------------|--------------------------------------|------------------------------------------|---------------------------------------| | 128-Kbyte<br>flash ROM | 2 Kbytes | 62 Kbytes | 62 Kbytes | 7F0н to 7F6н | A0 to A10 | A0 to A10 | Connect<br>ROMAD pin to<br>A16. | | 4-Kbyte<br>E <sup>2</sup> PROM | 2 Kbytes | _ | 2 Kbytes | 7F0н to 7F6н | A0 to A10 | A0 to A10 | Connect<br>ROMAD pin to<br>A11. | #### 3. Address Space The configuration of the LAN PC card in the MB86967 (in PC card mode) has up to three address spaces (for common memory, I/O memory, and attribute memory). Table 5 gives the common memory space, I/O memory space, and attribute memory space of the MB86967. **Table 5 Memory Map for PC Card** | Common Memory Space*1 | I/O Memory Space | Attribute Memory Space | |--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | (E <sup>2</sup> PROM or FLASH) | <ul> <li>Control registers in LAN controller<br/>(Core of LAN controller)</li> <li>LAN card control register<br/>(PC card interface)</li> <li>ID number<br/>(E<sup>2</sup>PROM or FLASH)*<sup>2</sup></li> </ul> | <ul> <li>Card attribute data register (CIS) (E<sup>2</sup>PROM or FLASH)</li> <li>LAN card configuration register (CCR) (PC card interface)</li> </ul> | Note: Parts in parentheses are the blocks where each item is located. <sup>\*1:</sup> Common memory space cannot allocated if the E2PROM or flash ROM to be selected is less than 2 Kbytes. <sup>\*2:</sup> Connecting P97 (ROMAD) to the most significant address bit of ROM allows I/O-reading of the ID number. To write to this space, both the IOWR and WE pins must be enabled. #### 4. Common Memory Space Common memory space can be used if the capacity of E<sup>2</sup>PROM or flash ROM to be selected is large. The address space is located higher than the CIS (card attribute data register) of attribute memory space (See examples of E<sup>2</sup>PROM and flash ROM in 2). Only even addresses are used in the CIS, but both common memory space even and odd addresses can be used in common memory space. Only byte access (8 bits) is available. Writing to common memory space is possible. Efficient writing is performed by data-polling the selected E<sup>2</sup>PROM or flash ROM. However, in this case, the PwrDwn bit of CCR1 must be not set for the power-down state without ending writing. Batch erase should not be selected for flash ROM. When erasing common memory in blocks, take care not to erase attribute memory space. #### (1) Read from Common Memory | Mode | REG | CE2 | CE1 | ŌĒ | WE | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|----|----|-----|----------------|---------------|------|-------|-------| | Byte access | 1 | 1 | 0 | 0 | 1 | 0 | Invalid | Even byte | L | L | L | | (8 bits) | ' | ' | U | U | ' | 1 | Invalid | Odd byte | L | L | L | | Word access (16 bits) | 1 | 0 | 0 | 0 | 1 | × | Invalid | Invalid | Н | Н | L | | High byte only | 1 | 0 | 1 | 0 | 1 | × | Invalid | Invalid | Н | Н | L | #### (2) Write to Common Memory | Mode | REG | CE2 | CE1 | ŌĒ | WE | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |--------------------------|-----|-----|-----|----|----|-----|----------------|---------------|------|-------|-------| | Byte access | 1 | 1 | 0 | 0 | 1 | 0 | Don't care | Even byte | L | Н | L | | (8 bits) | ' | ' | U | U | ' | 1 | Don't care | Odd byte | L | Н | L | | Word access<br>(16 bits) | 1 | 0 | 0 | 0 | 1 | × | Don't care | Don't care | Н | Н | L | | High byte only | 1 | 0 | 1 | 0 | 1 | × | Don't care | Don't care | Н | Н | L | #### 5. Attribute Memory Space Attribute memory space has the card attribute data register (CIS) and card configuration register (CCR). It can be accessed in 8 bits from even addresses; odd addresses are invalid. The MB86967 can have access to both 8-bit and 16-bit data. When attribute memory space is accessed in the 16-bit mode, only the data signals D0 to D7 are valid, and D8 to D15 are invalid. CIS is located at 000H to 7EEH, starting with address 0. CCR has four registers, located at 7F0H, 7F2H, 7F4H, and 7F6H. | Address | Symbol | Register | |--------------|--------|------------------------------------| | 7F0н | CCR0 | Card configuration option register | | 7F2н | CCR1 | Card configuration status register | | 7F4н | CCR2 | Pin replacement register | | <b>7</b> F6н | CCR3 | Socket/copy register | #### [Reference] CIS: In E2PROM or flash ROM CCR: In MB86967 #### (1) Read from CIS | Mode | REG | CE2 | CE1 | ŌĒ | IORD | WE | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|----|------|----|-----|----------------|---------------|------|-------|-------| | Byte access | 0 | 1 | 0 | 0 | 1 | 1 | 0 | Invalid | Even byte | L | L | L | | (8 bits) | | ' | | | ' | ' | 1 | Invalid | Invalid | Н | Н | L | | Word access (16 bits) | 0 | 0 | 0 | 0 | 1 | 1 | × | Invalid | Even byte | L | L | L | #### (2) Write to CIS | Mode | REG | CE2 | CE1 | OE | IOWR | WE | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|----|------|----|-----|----------------|---------------|------|-------|-------| | Byte access | 0 | 1 | 0 | 1 | 1 | 0 | 0 | Don't care | Even byte | L | Н | L | | (8 bits) | U | ' | 0 | ' | ' | U | 1 | Don't care | Don't care | Н | Н | L | | Word access (16 bits) | 0 | 0 | 0 | 1 | 1 | 0 | × | Don't care | Even byte | L | Н | L | #### (3) Read from CCR | Mode | Address | REG | CE2 | CE1 | ΟE | IORD | WE | PA0 | PD8<br>to<br>PD15 | PD0<br>to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----------------|-----|-----|-----|----|------|----|-----|-------------------|------------------|------|-------|-------| | Byte access (8 bits) | 750 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | Invalid | Even<br>byte | Н | Н | L | | (O Dita) | 7F0н to<br>7F6н | | | | | | | 1 | Invalid | Invalid | Н | Н | L | | Word access (16 bits) | | 0 | 0 | 0 | 0 | 1 | 1 | × | Invalid | Even<br>byte | Н | Н | L | # (4) Write to CCR | Mode | Address | REG | CE2 | CE1 | ŌĒ | IOWR | WE | PA0 | PD8<br>to<br>PD15 | PD0<br>to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----------------|-----|-----|-----|----|------|----|-----|-------------------|------------------|------|-------|-------| | Byte access | | 0 | 1 | 0 | 1 | 1 | 0 | 0 | Don't care | Even<br>byte | Н | Н | L | | (8 bits) | 7F0н to<br>7F6н | | ' | 0 | ' | ' | U | 1 | Don't care | Don't care | Н | Н | L | | Word access (16 bits) | | 0 | 0 | 0 | 1 | 1 | 0 | × | Don't care | Even<br>byte | Н | Н | L | # 6. LAN Card Configuration Register # (1) CCR0: Card Configuration Option Register (00007F0H) The card configuration option register (CCR0) sets a software reset, interrupt signal, and configuration index. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|--------|---------|-------|-------|-----------|------------|-------|-------| | Read | SRESET | LevIREQ | | | Configuro | tion inday | | | | Write | SKESET | _ | | | Cornigura | tion index | | | | Initial Value | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|-----------------------------------------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SRESET<br>(Software Reset) | Read/Write | 0 | When 0 is written to this bit, the MB86967 enters the hardware reset state or the same state as that after hardware reset. | | | | | 1 | Reset state; this is the same as the hardware reset state except that this bit is not cleared. When this bit is set, the pointers and registers in the LAN controller are also reset. | | 6 | LevIREQ<br>(Level Interrupt<br>Request) | Read | _ | Since the MB86967 is in the level interrupt request mode, 1 is always read in the I/O interface card mode. This bit is not affected by writing. | | 5 to 0 | CONF INDX<br>(Configuration<br>Index) | Read/Write | _ | These bits are used to select 32 configuration indexes provided for the card. | # (2) CCR1: Card Configuration Status Register (00007F2H) This register indicates the configuration status of the card. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|---------|-------|-------|-------|-------|---------|-------|-------| | Read | Changed | 0 | IOis8 | 0 | 0 | PwrDwn | 0 | 0 | | Write | _ | _ | 10150 | _ | _ | PWIDWII | _ | _ | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|---------------------------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | Changed<br>(State Change) | Read | _ | This bit is 1, indicating that the bit value (bit 5) of the pin replacement register is 1. The value of bit 5 of the pin replacement register, indicating that this bit becomes 0. This is a read-only bit and it is not affected by writing. | | 6 | Not used | Read | _ | The read value of this bit is always 0 and this bit is not affected by writing. | | 5 | IOIS8<br>(8-bit I/O) | Read/Write | 0 | The MB86967 enters the word transfer mode (PD0 to PD15). In this case, bit 5 (SB/SW) of the control register (DLCR6) in the LAN controller is set to 0. | | | | | 1 | The MB86967 enters the byte transfer mode (PD0 to PD7). In this case, SB/-SW (bit 5) of DLCR6 in the LAN controller is set to 1. The system must set CE2 Non-active. | | 4 and 3 | Not used | Read | _ | The read value is always 0. These bits are not affected by writing. | | 2 | PwrDwn | Read/Write | 0 | This bit clears the power-down mode. When this bit is cleared, bit 5 (STBY) of DLCR7 in the LAN controller is also cleared to 1. | | | | | 1 | The power-down mode is set. When this bit is set, bit 5 (STBY) of DLCR7 is set to 0, making it possible to place the LAN controller and 10BASE-T transceiver in the standby state. Presetting bit 4 of BMPR14 in the LAN controller causes the MB86967 to enter the shutdown mode (oscillation stopped). This bit should be set after initializing the LAN controller. Return from the shutdown mode should be made by reset. See 4. Operation Sequence in PC Card Mode. | | 1 and 0 | Not used | Read | _ | The read values of these bits is always 0. These bits are not affected by writing. | # (3) CCR2: Pin Replacement Register (00007F4H) This register indicates the card ready or busy state. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|----------|-------|-------|-------|----------|-------| | Read | 0 | 0 | CRdy/Bsy | 0 | 1 | 1 | RRdy/Bsy | 0 | | Write | _ | _ | CRuy/bsy | _ | _ | _ | KKuy/bsy | _ | | Initial Value | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|------------------------------------------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 and 6 | Not used | Read | _ | The read values of these bits is always 0. These bits are not affected by writing. | | 5 | CRdy/Bsy<br>(Ready/Busy<br>State Change) | Read/Write | 0 | Indicates that Ready/Busy bit (bit 1) not changed (from 1 to 0 or from 0 to 1) 0 can be written to this bit only when this bit is 1 with bit 1 set to 1. | | | | | 1 | Indicates that Ready/Busy changed (from 1 to 0 or from 0 to 1) 0 can be written to this bit only when this bit is 1 with bit 1 set to 1. | | 4 | Not used | Read | _ | The read value of this bit is always 0. This bit is not affected by writing. | | 3 and 2 | Not used | Read | _ | The read values of these bits is always 1. These bits are not affected by writing. | | 1 | RRdy/Bsy | Read/Write | 0 | Indicates card in busy state | | | (Ready/Busy) | | 1 | Indicates card in ready state In the IC memory card interface mode, such as power-on and reset a High level is output (when a write operation to the CCR is not performed). | | 0 | Not used | Read | _ | The read value of this bit is always 0. This bit is not affected by writing. | # (4) CCR3: Socket/Copy Register (00007F6н) | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|-------|-------|-------|-------|-------|-------|-------|-------| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | _ | _ | _ | _ | _ | _ | _ | _ | | Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|----------|-----------|-------|------------------------------------------------------------------------------------| | 0 to 7 | Not used | Read | | The read values of these bits is always 0. These bits are not affected by writing. | #### 7. I/O Address Space I/O address space has control registers in the LAN controller and the LAN card control register; in some cases, it has ID numbers. The MB86967 supports both the independent I/O addressing mode, and overlapping I/O addressing mode. Index 0 of the 32 I/O indexes is used to address the independent I/O, and index 31 is used to address the overlapping I/O. One index has 32 bytes of address space. In the independent I/O addressing mode, the I/O address pins A4 to A0 are used. When using the overlapping I/O addressing mode in the ISA and EISA buses, I/O address space is allocated to any one of the 31 indexes. The system can select any I/O base address by writing different indexes to bits 0 to 5 of the card configuration option register. In this mode, all I/O address pins A0 to A10 are used. If 32 bytes of I/O address space are allocated to the control registers in the LAN controller, the LAN card control register, and ID numbers are as follows: | Base Address | Register | |---------------------------------|-------------------------------------------------------------------------------------------------------------| | +0 to F | Control registers in LAN controller | | +10 | LAN card control register | | +12, 14, 16, 18, 1A, 1C, 1E | For setting ID numbers (only read value valid) A read value that is not used as the ID number is undefined. | | +11, 13, 15, 17, 19, 1B, 1D, 1F | Reserved (The read value is undefined and writing is invalid.) | The configuration indexes and I/O base addresses to be assigned are as follows: | Index | CCR 7F0н<br>Bit 0 to 5 | I/O Address Space | Index | CCR 7F0 <sub>H</sub><br>Bit 0 to 5 | I/O Address Space | |-------|------------------------|----------------------------|-------|------------------------------------|-------------------| | | 000000 | I/O function in non-active | 16 | 110000 | 200H to 21Fн | | 0 | 100000 | Independent I/O addressing | 17 | 110001 | 220н to 23Fн | | 1 | 100001 | 020н to 03Fн | 18 | 110010 | 240н to 25Fн | | 2 | 100010 | 040н to 05Fн | 19 | 110011 | 260н to 27Fн | | 3 | 100011 | 060н to 07Fн | 20 | 110100 | 280н to 29Fн | | 4 | 100100 | 080н to 09Fн | 21 | 110101 | 2A0н to 2BFн | | 5 | 100101 | 0A0н to 0BFн | 22 | 110110 | 2C0н to 2DFн | | 6 | 100110 | 0С0н to 0DFн | 23 | 110111 | 2E0н to 2FFн | | 7 | 100111 | 0E0н to 0FFн | 24 | 111000 | 300н to 31Fн | | 8 | 101000 | 100н to 11Fн | 25 | 111001 | 320н to 33Fн | | 9 | 101001 | 120н to 13Fн | 26 | 111010 | 340н to 35Fн | | 10 | 101010 | 140н to 15Fн | 27 | 111011 | 360н to 37Fн | | 11 | 101011 | 160н to 17Fн | 28 | 111100 | 380н to 39Fн | | 12 | 101100 | 180н to 19Fн | 29 | 111101 | 3A0н to 3BFн | | 13 | 101101 | 1A0н to 1BFн | 30 | 111110 | 3B0н to 3DFн | | 14 | 101110 | 1С0н to 1DFн | 31 | 111111 | 3E0н to 3FFн | | 15 | 101111 | 1ЕОн to 1FFн | | | | # (1) I/O-read (+0 to +10) | Mode | REG | CE2 | CE1 | IORD | ŌΕ | IOWR | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|------|----|------|-----|----------------|---------------|------|-------|-------| | Byte access | 0 | 1 | 0 | 0 | 1 | 1 | 0 | Invalid | Even byte | Н | Н | L | | (8 bits) | U | ' | U | U | ' | ı | 1 | Invalid | Odd byte | Н | Н | L | | Word access (16 bits) | 0 | 0 | 0 | 0 | 1 | 1 | 0 | Odd byte | Even byte | Н | Н | L | | High byte only | 0 | 0 | 1 | 0 | 1 | 1 | × | Even byte | Invalid | Н | Н | L | # (2) I/O-read (+12, +14, +16, +18, 1A, 1C, 1E: ID number) | Mode | REG | CE2 | CE1 | IORD | OE | IOWR | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|------|----|------|-----|----------------|---------------|------|-------|-------| | Byte access (8 bits) | 0 | 1 | 0 | 0 | 1 | 1 | 0 | Invalid | Even byte | L | L | Н | | Word access (16 bits) | 0 | 0 | 0 | 0 | 1 | 1 | 0 | Odd byte | Even byte | L | L | Н | # (3) I/O-write (+0 to +10) | Mode | REG | CE2 | CE1 | IORD | IOWR | WE | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|------|------|----|-----|----------------|---------------|------|-------|-------| | Byte access | 0 | 1 | 0 | 1 | 0 | 1 | 0 | Don't care | Even byte | Н | Н | L | | (8 bits) | | 1 | U | 1 | U | ' | 1 | Don't care | Odd byte | Н | Н | L | | Word access (16 bits) | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Odd byte | Even byte | Н | Н | L | | High byte only | 0 | 0 | 1 | 1 | 0 | 1 | × | Even byte | Don't care | Н | Н | L | # (4) I/O-write (+12, +14, +16, +18, 1A, 1C, 1E: ID number) | Mode | REG | CE2 | CE1 | IORD | IOWR* | WE* | PA0 | PD8 to<br>PD15 | PD0 to<br>PD7 | ROMS | ROMRD | ROMAD | |-----------------------|-----|-----|-----|------|-------|-----|-----|----------------|---------------|------|-------|-------| | Byte access (8 bits) | 0 | 1 | 0 | 1 | 0 | 0 | 0 | Don't care | Even byte | L | Н | Н | | Word access (16 bits) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Odd byte | Even byte | L | Н | Н | <sup>\*:</sup> To write the ID number, both the IOWR and WE pins must be set Active. #### (5) CARDCR: LAN Card Control Register (Base address +10) This is an external ROM control register that can be accessed only in the PC card mode. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |------------------|--------|--------|------------------|-------|-------|-------|-------|-------| | Read | CIS WR | COMMON | ID | 0 | 0 | 0 | 0 | 0 | | Write | ENA | WR ENA | NUMBER<br>WR ENA | _ | | | | | | Initial<br>Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit no. | Bit name | Operation | Value | Function | |---------|------------------------------------|------------|-------|---------------------------------------------------------------------------------------------| | 7 | CIS WRITE<br>ENABLE | Read/Write | 0 | The system cannot write data to CIS in E <sup>2</sup> PROM or flash ROM. | | | (CIS Write Enable) | | 1 | The system can write data to CIS in E <sup>2</sup> PROM or flash ROM. | | 6 | COMMON WR<br>ENABLE | Read/Write | 0 | The system cannot write data to common memory in E <sup>2</sup> PROM or flash ROM. | | | (Common<br>Memory Write<br>Enable) | | 1 | The system can write data to common memory in E²PROM or flash ROM. | | 5 | ID NUMBER<br>WR ENABLE | Read/Write | 0 | The system cannot write data to I/O space (for ID number) in E²PROM or flash ROM. | | | (ID Number<br>Write Enable) | | 1 | The system can write data to I/O space (for ID number) in E <sup>2</sup> PROM or flash ROM. | | 0 to 4 | Not used | Read | _ | The read values of these bits are always 0s. These bits are not affected by writing. | #### 8. Initializing Card (Using MB86967 in PC Card) Immediately after the card is installed in the system, the IC memory card interface (memory card) is selected. The following instructions describe how to switch to the I/O card interface: - a. The system reads card attribute data (CIS) for setting operating environments. - b. The data is written to the card configuration register (CCR). At this time, the LAN controller is set to the 8-bit interface or 16-bit interface by setting the bit 5 (IOIS8) of CCR1. - c. The Ethernet ID numbers read from CIS or I/O space are written. Note: Switch from the I/O card interface to IC memory card interface by setting the external RESET pin or the SRESET bit of CCR0. # ■ RESET, STANDBY, AND SHUTDOWN MODES # 1. PC Card Mode | Interface | LA | N Controller | Operation | |---------------------------------------------|----------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Input of 1 to<br>external<br>reset register | | | <ul> <li>The CCR is initialized.</li> <li>The I/O card interface is switched to the IC memory interface.</li> <li>The LAN controller and 10BASE-T transceiver are also initialized.</li> </ul> | | CCR0 Bit 7<br>SRESET = 1 | | | <ul> <li>Same as above, except this bit not cleared</li> <li>The CCR is initialized.</li> <li>The I/O card interface is switched to the IC memory interface.</li> <li>The LAN controller and 10BASE-T transceiver are also initialized.</li> </ul> | | | DLCR6 Bit 7<br>ENA DLC = 1 | | <ul> <li>The LAN controller is initialized. The previous values of the control registers (DLCR, MAR, and BMPR) in the LAN controller are retained. </li> <li>The TP or AUI transceiver is in the power-down mode.</li> </ul> | | CCR1 Bit 2<br>PwrDwn = 1 | | BMPR14 Bit 4<br>SHUT DWN MODE = 0 | Standby mode The clock stops and current consumption is reduced to about 10%. | | | | BMPR14 Bit 4<br>SHUT DWN MODE = 1 | Shutdown mode Crystal oscillation stops and current consumption is reduced to about 1%. | <sup>\*:</sup> The STBY bit of the DLCR7 is set automatically. # 2. ISA Bus Mode | | | Operation | |---------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Input of 1 to external reset register | | The LAN controller and 10BASE-T transceiver are initialized. | | Write to reset (any values) | registers: RES0 to RES7 | The LAN controller and 10BASE-T transceiver are initialized but<br>BMPR16 and BMPR17 are not. | | DLCR6 Bit 7<br>ENA DLC = 1 | | <ul> <li>The LAN controller is initialized. The previous values of the control registers (DLCR, MAR, and BMPR) in the LAN controller are retained. </li> <li>The TP transceiver is in the power-down mode.</li> </ul> | | DLCR7 Bit 5<br>STBY = 0 | BMPR14 Bit 4<br>SHUT DWN MODE = 0 | Standby mode The clock stops and current consumption is reduced to about 10%. | | | BMPR14 Bit 4<br>SHUT DWN MODE = 1 | Shutdown mode Crystal oscillation stops and current consumption is reduced to about 1%. | # 3. General-purpose Bus Mode | | | Operation | |---------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Input of 1 to external reset register | | The LAN controller and 10BASE-T transceiver are initialized. | | DLCR6 Bit 7<br>ENA DLC = 1 | | <ul> <li>The LAN controller is initialized. The previous values of the control registers (DLCR, MAR, and BMPR) in the LAN controller are retained. </li> <li>The TP transceiver is in the power-down mode.</li> </ul> | | DLCR7 Bit 5<br>STBY = 0 | BMPR14 Bit 4<br>SHUT DWN MODE = 0 | Standby mode The clock stops and current consumption is reduced to about 10%. | | | BMPR14 Bit 4<br>SHUT DWN MODE = 1 | Shutdown mode Crystal oscillation stops and current consumption is reduced to about 1%. | ### 4. Operation Sequence in PC Card Mode - \*1: The time for setting the DLCR, MAR, and BMPR registers may be included in the waiting time of 200 μs. - \*2: The STBY bit of DLCR7 is automatically set to 0. - \*3: The STBY bit of DLCR7 is automatically set to 1. In the PC card mode, the STBY bit of DLCR7 is set from the PwrDwn bit of CCR1 to as shown in \*2 and \*3. Direct change (from 0 to 1 or from 1 to 0) is not allowed. - Standby state: The clock to each circuit stops but crystal oscillation does not. - Shutdown state: Crystal oscillation stops. ### 5. Operation Sequence in ISA Bus Mode - $^{*}$ : The time for setting the DLCR, MAR, and BMPR registers may be included in the waiting time of 200 $\mu$ s. - Standby state: The clock to each circuit stops but crystal oscillation does not. - Shutdown state: Crystal oscillation stops. - $^{\star}$ : The time for setting the DLCR, MAR, and BMPR registers may be included in the waiting time of 200 $\mu$ s. - Standby state: The clock to each circuit stops but crystal oscillation does not. - Shutdown state: Crystal oscillation stops. #### ■ SOFTWARE SUPPORT FOR POPULAR NETWORK OPERATING SYSTEMS #### 1. LAN Node Drivers The so-called driver is the hardware-dependent portion of the software complement for a network node. It's purpose is to marry a specific hardware configuration to a more-or-less generic interface provided by the networking software. Network software suppliers provide such generic interfaces for drivers to encourage universal support from a variety of hardware products. By partitioning or layering the software into a stack of components with standardized interfaces between the layers, the job of integrating various hardware and software offerings with a particular network operating system becomes easier. More drivers will become available, and everyone benefits. As seen in Figure 9, which depicts a model of LAN node components, the driver sits between the generic network software and the hardware, and acts as a bridge between the system and the node hardware. The interface of the driver to the network software and its applications is a generic interface and virtually the same for all drivers running on a given operating system. But the driver comprehends the configuration and nuances of the hardware, and optimizes it's performance in the system. A good, well-written driver is a positive advantage to the system, allowing it to achieve its performance potential; whereas a poor driver will limit the performance and reliability of the system. The best drivers have a certain intimacy with the hardware, which allows them to take full advantage of its features. High data throughput, data integrity, and reliable operation are the key goals for which every node-driver writer should strive. In addition, the final driver should be efficient, by requiring minimum host execution time. These are all things the end user will and should take for granted; if they are not supplied with the design, there will be no customer satisfaction. Most network software suppliers offer technical support for third-party driver development. This often comes in the form of a developer's kit that includes a manual and software examples. Some suppliers also offer test suites and certification testing to verify the driver product, because they know that good drivers benefit both users and suppliers. Figure 9 Model of LAN Node #### 2. What's in a Driver? Typical node drivers manage the movement of packet data between system memory and the network, and vice versa, as well as providing diagnostic testing, error processing, and error statistics on-demand for the system. The first thing a driver does when the system is powered up is system check-out, which may include buffer memory testing, and loopback testing of the transmit and receive circuits. If the network supports it, as does Ethernet, for example, the testing may include sending and receiving test packets on the network to verify the ability to communicate. As shown in Figure 10, the driver provides control of the initialization, interrupt and branch control processes, supporting both the transmit and the receive functions. Figure 11 shows an example in flow chart form of a check-out routine written for the Fujitsu MB86967 Controller. The driver first initializes the control and status registers in the controller for memory and loopback testing. Loopback and memory testing are conducted simultaneously by transmitting memory test patterns from the transmit buffer area of memory to the receive buffer area using loopback. This test sequence simultaneously exercises and tests the transmitter, the receiver and the buffer memory. The loopback/memory startup test is performed by first loading a test pattern in the form of several packets into the controller chip's transmit buffer, then transmitting the packets in loopback mode. The loopback transmission path through the chip exercises the data link controller as well as the encoder and decoder circuitry, but does not affect the network. The MB86967 controller has a unique buffer memory architecture which pipelines packets through the system in both directions, optimizing data through-put. MB86967's buffer controller provides all the pointer management for accessing the buffer automatically, greatly reducing the complexity of the driver and minimizing the software overhead. Receive packets with errors are automatically purged by MB86967. When a collision occurs, MB86967 automatically re-transmits without host interaction. These features provide high data throughput while minimizing the host and memory overhead. At the successful conclusion of the tests, the driver starts up the MB86967 chip for regular service on the network. #### 3. Operating on the Network Driver code for operating on the network might be partitioned into three main modules as shown in the example for the MB86967 controller in this section. The modules, shown in Figures 12, 13, and 14 are Transmit Packet Write, in which packets to be transmitted are moved from host memory to the point marked TX PKT WRITE. Transmission takes place in two steps. First, packets to be transmitted are loaded into the transmit buffer. Secondly, when the transmitter is not busy, it will be started to transmit the stored packets. Each of these steps may have to wait for resources. The packets cannot be loaded unless there is buffer space available. MB86967 provides the option of a single or two independent transmit buffers. With two buffers there is usually no waiting. The transmitter cannot transmit but one buffer full of packets at a time. To manage these resources, two software flags are used, TBUF STAT and TX STAT, the status of the transmit buffer and the transmitter respectively. TBUF STAT refers to the current buffer which might be available to the driver for loading. Its status can be Busy if no buffer is available, Loading when in the process of being loaded, in Standby if ready to transmit, but not full, ready and Full or Empty. The transmitter status can be either Busy or Idle. Packet length is checked during the loading process to assure that the ISO/ANSI/IEEE 8802-3 length requirements are met. Packets ready to be loaded can be loaded into an Empty or Standby buffer, the latter being a buffer with packets waiting for the transmitter to become idle. If a standby buffer has more room for packets, additional packets can be loaded until it is full. The Empty buffer is available for loading and has no packets. The driver takes ownership of an Empty or Standby buffer by changing its status to Loading. After the packets are loaded, the transmit status flag is checked for an idle transmitter. If idle, it can be immediately started to transmit the contents of either a Full or Standby buffer. When the transmitter of the MB86967 chip is started, buffer status also changes. In single buffer mode, starting the transmitter makes the single buffer unavailable to the system. In dual buffer mode, starting the transmitter re-allocates its previously-transmitted buffer as an empty buffer, available for loading. If the transmitter is busy, the routine will suspend execution at that point pending an idle transmitter. Two key interrupts used in this example are the receive packet interrupt (RX PKT), indicating that one or more packets has been received since the interrupt was last enabled, and the transmitter done interrupt (TX DONE), indicating that the transmitter has finished transmitting the contents of its current buffer. The interrupt service routine for network operation, illustrated in Figure 13, is short and sweet. If the receive packet interrupt has occurred, it calls or queues the routine for reading packets (RX PKT READ). Further receive interrupts are masked until the driver has emptied the receive buffer. This prevents redundant interrupts which would otherwise occur if packets come in during the read sequence. If the transmitter done interrupt has occurred, the status flags are updated, and appropriate action is taken to satisfy pending activity, if any, with the newly available buffer and/or transmitter resource. The driver is structured to read all receive packets in the buffer whenever one or more packets arrive. A status bit in MB86967 (BUF EMPTY) indicates whether the receive buffer is empty or not (indicating whole packets only). The packet read routine, shown in Figure 14, starts by masking further receive interrupts until it has emptied the buffer and suspended execution. This prevents redundant interrupts which would otherwise occur if packets come in during the read sequence. As each packet is read, it can be read in parts. If after reading the first part the packet is not of interest, the rest can be discarded without being moved to host memory using MB86967's Skip Packet feature. Reading will continue until the buffer is empty, as indicated by RBUF EMPTY bit. The Transmit Packet Write Routine, shown in Figure 12, and the Receive Packet Read Routine, shown in Figure 14, together comprise the driver core, which can be called by the network software or from the Network Interrupt Service Routine, shown in Figure 13. Once called, this core routine transfers both transmit and receive packets until there are no more to be transferred, then exits or returns. If packets are transferring, this core routine avoids locking out either the transmitter or the receiver while the other is very busy, by alternating between the two after a fixed number of packets, set by TX MAX and RX MAX. While in operation, the core routine polls key status bits. Interrupts are disabled to prevent unnecessary interrupts while the core is executing. A driver such as the one illustrated in this section might typically occupy 4 to 6 kilobytes on its distribution diskette. The host-resident portion, when loaded for network operation, might use typically 2 to 3 kilobytes of host memory. A set of quality software drivers bundled with the hardware is well worth providing to LAN equipment customers. By providing better performance and reliability, good drivers will enhance both customer satisfaction and sales, while reducing customer service calls. Table 6 represents typical control and status parameter used in MB86967 Network Drivers. ### **Table 6 Control and Status Parameters** | Symbol | Туре | Name | | Description | | | | |---------------|-------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | DLC EN | Register<br>Bit | DATA LINK<br>CONTROL<br>ENABLE | transmitter an | esets all buffer memory pointers and disables both the d the receiver circuits. When low, enables buffer smitter and receiver. | | | | | <u>LBC</u> | Register<br>Bit | LOOPBACK<br>CONTROL | When set low, | , places MB86967 in internal loopback mode. | | | | | RBUF<br>EMPTY | Register<br>Bit | RECEIVE<br>BUFFER<br>EMPTY | stored in the r | dicates that there is at least one complete packet receive buffer, ready to read. When low, indicates there is ready to read in the receive buffer. | | | | | RPKT<br>LEFT | Software<br>Value | RECEIVE<br>PACKET<br>LENGTH LEFT | The number of bytes remaining in the receive packet being read from the buffer. Calculated by the driver from the original length given by MB86967 in the 3rd and 4th bytes of the receive packet header, less the number of bytes already read out. | | | | | | RX CNT | Software<br>Value | RECEIVE<br>TRANSFER<br>COUNT | A running count of the number of packets transferred from the receive buffer to system memory since entering the Receive Packet Read Routine. This parameter can share the same memory location with TX CNT, because both are not used concurrently in the same subroutine. | | | | | | RX MAX | Software<br>Value | MAXIMUM<br>VALUE FOR RX<br>CNT | The maximum number of packets that may be processed in the Receive Packet Read Routine.before passing control to the Transmit Packet Write Routine. This parameter can be fixed or allowed to vary according to need. Typical range for this parameter is 15 - 32. | | | | | | TBUF<br>FREE | Software<br>Value | TRANSMIT<br>BUFFER FREE<br>SPACE | | of available bytes remaining in the transmit buffer being ackets by the driver. Calculated by driver. | | | | | TBUF<br>MODE | Register<br>Bits | TRANSMIT<br>BUFFER MODE | The configura DUAL buffers. | tion of the transmit buffer space, SINGLE buffer or | | | | | TBUF SIZE | Software<br>Value | TRANSMIT<br>BUFFER SIZE | | tes of each transmit buffer, which depends on initial parameters for the buffer memory. | | | | | TBUF STAT | Software<br>Value | TRANSMIT<br>BUFFER<br>STATUS | Current status<br>Maintained by | s of the transmit buffer available for loading packets. the driver. | | | | | | | | TBUF STAT | Value Description | | | | | | | | Empty | Current transmit buffer available to system bus is completely empty. | | | | | | | | Busy | No buffer is currently available to the system bus because a) MB86967 is in single-buffer mode and b) the transmitter is using the buffer. | | | | | | | | Standby The buffer currently available to the system bus has one or more packets in it, but may still have room for additional packet(s). | | | | | | | | | Full | The buffer currently available to the system bus has one or more packets in it, and does not have room for the next packet presented to the driver from the transmit queue. | | | | | Symbol | Туре | Name | | Description | | | | |----------|-------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | TPKT CNT | Software<br>Value | TRANSMIT<br>PACKET<br>COUNT | driver. Value is | of packets loaded into the current transmit buffer by the s counted by driver. This value is written into MB86967 R10<6:0> at the time transmitter is started. | | | | | TX CNT | Software<br>Value | TRANSMIT<br>TRANSFER<br>COUNT | A running count of the number of packets transferred from system memory to the transmit buffer since entering the Transmit Packet Write Routine. This parameter can share the same memory location with RX CNT, because both are not used concurrently in the same subroutine. | | | | | | TX DONE | Register<br>Bit | TRANSMITTER<br>DONE | When transmitter finishes transmitting, MB86967 sets this bit high. Normally cleared by driver prior to starting transmitter. Hardware reset or DLC EN being set high also clears this bit. | | | | | | TX MAX | Software<br>Value | MAXIMUM<br>VALUE FOR TX<br>CNT | The maximum number of packets that may be processed in the Transmit Packet Write Routine before passing control to Receive Packet Read Routine. This parameter can be fixed or allowed to vary according to need. Typical range for this parameter is 15-32. | | | | | | TX START | Register<br>Bit | START<br>TRANSMITTER | | n, activates transmitter to transmit all packets in the nit buffer. See also TPKT CNT. | | | | | TX STAT | Software<br>Value | TRANSMIT<br>BUFFER<br>STATUS | Current status | s of the transmitter, maintained by driver. | | | | | | | | TX STAT | Value Description | | | | | | | | Busy | Transmitter has not finished transmitting packets previously given to it to transmit. | | | | | | | | Idle | Transmitter has finished transmitting all packets in its buffer. | | | | #### **■ ABSOLUTE MAXIMUM RATINGS** (GND = 0 V) | Baramatar | Cumb al | Rat | l lmi4 | | |-----------------------|----------|-----------|-----------------------|------| | Parameter | Symbol | Min. | Max. | Unit | | Power supply voltage | $V_{DD}$ | Vss - 0.5 | +6.0 | V | | Input voltage | Vı | Vss - 0.5 | V <sub>DD</sub> + 0.5 | V | | Output voltage | Vo | Vss - 0.5 | V <sub>DD</sub> + 0.5 | V | | Storage temperature | Tstg | -55 | +125 | °C | | Operating temperature | Тор | -40 | +85 | °C | | Output current | lo | -40 | +40 | mA | <sup>\*:</sup> Duration of voltage applied is within 1 sec per terminal. WARNING: Semiconductor devices can be permanently damaged by application of stress (voltage, current, temperature, etc.) in excess of absolute maximum ratings. Do not exceed these ratings. #### ■ RECOMMENDED OPERATING CONDITIONS | Donomotor. | Symbol | | l lm:4 | | | |------------------------------|-----------------|------|---------------------------|------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | Power supply voltage | V <sub>DD</sub> | 4.75 | 5.00 | 5.25 | V | | Operating temperature | Та | 0 | _ | +70 | °C | | | | _ | -2.0 | _ | mA | | TTL "H" level output current | Іон | _ | -4.0* <sup>1</sup> | _ | mA | | | | _ | <b>-8.0*</b> <sup>3</sup> | _ | mA | | | | _ | 3.2 | _ | mA | | TTL "L" level output current | loL | _ | 12.0*2 | _ | mA | | | | _ | 24.0*3 | _ | mA | | Crystal oscillator frequency | <b>f</b> Xtal | 20 | 0.000 ± 0.005 | % | MHz | <sup>\*1:</sup> Applies to P92 (IREQ, IREQ0, INT) WARNING: The recommended operating conditions are required in order to ensure the normal operation of the semiconductor device. All of the device's electrical characteristics are warranted when the device is operated within these ranges. Always use semiconductor devices within their recommended operating condition ranges. Operation outside these ranges may adversely affect reliability and could result in device failure. No warranty is made with respect to uses, operating conditions, or combinations not represented on the data sheet. Users considering application outside the listed conditions are advised to contact their FUJITSU representatives beforehand. <sup>\*2:</sup> Applies to LED terminal (open-drain output) and P92 (IREQ, IREQ0, INT) <sup>\*3:</sup> Applies to P3 (WAIT, IOCHRDY, READY) and P84 (IOIS16) ### **■ ELECTRICAL CHARACTERISTICS** #### 1. DC Characteristics $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Devenuetes | Complete | Conditions | | Value | | Unit | |----------------------------------|----------|---------------------------------|------|-------|-----------------|------| | Parameter | Symbol | Conditions | Min. | Тур. | Max. | Unit | | | IDD | Operation state*1 | _ | 70 | 100 | mA | | Power supply current | IDDP | Power down*2 | _ | 10 | 15 | mA | | | IDDS | Shut down*3 | _ | 0.1 | 0.5 | mA | | TTL "H" level output voltage | Vон | Іон = -2 mA, -4 mA, -8 mA | 4.0 | _ | V <sub>DD</sub> | V | | TTL "I " level output voltage | V | lo <sub>L</sub> = 3.2 mA, 12 mA | Vss | | 0.4 | V | | TTL "L" level output voltage | Vol | IoL = 24 mA | Vss | | 0.5 | V | | TTL "Ll" lovel input veltage | V | TTL standard cell | 2.2 | | V <sub>DD</sub> | V | | TTL "H" level input voltage | ViH | TTL schmitt trigger cell | 2.4 | | $V_{DD}$ | V | | TTL "I " level input velte ge | VIL | TTL standard cell | Vss | | 0.8 | V | | TTL "L" level input voltage | VIL | TTL schmitt trigger cell | Vss | | 0.6 | V | | TTL input leak current | lu | \\ | -10 | | 10 | μΑ | | TTL HI-Z leak current*4 | lız | $V_I = 0$ to $V_{DD}$ | -10 | _ | 10 | μΑ | | Input pull-up/pull-down resistor | RPUPD | VI = 0 V to VDD | 100 | _ | _ | kΩ | <sup>\*1:</sup> For TP in operation. <sup>\*2:</sup> With the use of register settings, enable power saving mode, including RESET=Low, TP input/input with pull-up resistor = OPEN, other input terminal = Low or High, All output terminals = OPEN <sup>\*3:</sup> With the use of register settings, enable shut-down mode, including RESET=Low, TP input/input with pull-up resistor = OPEN, other input terminal = Low or High, All output terminals = OPEN <sup>\*4:</sup> Leak current when the TTL I/O terminal is in a high-impedance state. ## 2. TP Interface DC Characteristics $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Dovometer | Complete | Conditions | | l lmi4 | | | |------------------------------------------------------|-------------|--------------|-----------------------|--------|-----------------|------| | Parameter | Symbol | Conditions | Min. | Тур. | Max. | Unit | | TPO "H" level output voltage | Vтон | Ітон = 24 mA | V <sub>DD</sub> - 0.5 | _ | V <sub>DD</sub> | V | | TPO "L" level output voltage | VTOL | ITOL = 24 mA | Vss | _ | 0.4 | V | | TPO "H" level output current | Ітон | _ | _ | 24.0 | _ | mA | | TPO "L" level output current | Ітоь | _ | _ | 24.0 | _ | mA | | TPO output impedance | <b>Z</b> TO | _ | _ | 10.0 | _ | Ω | | TPI input impedance | Zτι | _ | _ | 10.0 | _ | kΩ | | TPI input bias voltage | V⊤ıBIAS | _ | _ | 3.3 | _ | V | | TPI differential input voltage | VτιD | _ | ±0.58 | _ | ±3.1 | V | | TPI differential input squelch threshold voltage | V⊤ıDSH | _ | _ | -420 | _ | mV | | TPI differential input non-squelch threshold voltage | V⊤ıDNSH | _ | -80 | 0 | +80 | mV | ### 3. AC Characteristics (1) Bus Timing (PC card mode, CCR read cycle) (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Doromotor | Cumbal | Va | I In:i4 | | |----------------------------------------------------------|----------------|------------|---------|------| | Parameter | Symbol | Min. 5 5 — | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to OE assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2, REG after OE negate | <b>t</b> 2 | 5 | _ | ns | | Output delay time for read data | <b>t</b> 3 | _ | 40 | ns | | Output hold time for read data | t <sub>4</sub> | 5 | _ | ns | ## (2) Bus Timing (PC card mode, CCR write cycle) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Doromotor | Sumbol | Va | lue | l lmi4 | |----------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------|------|--------| | Parameter | Symbol | Value Min. Max. 5 — 5 — 10 — 5 — | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to WE assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2, REG after WE negate | <b>t</b> 2 | 5 | _ | ns | | Setup time for write data input | <b>t</b> 3 | 10 | _ | ns | | Hold time for write data input | t <sub>4</sub> | 5 | _ | ns | ## (3) Bus Timing (PC card mode, CIS read) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Cumbal | Va | l lni4 | | |----------------------------------------------------------|----------------|------|--------|------| | Parameter | Symbol | Min. | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to OE assert | <b>t</b> 1 | 5 | _ | ns | | Hold time for address, CE1, CE2, REG after OE negate | <b>t</b> 2 | 5 | _ | ns | | ROMS assert output delay after OE assert | <b>t</b> 3 | _ | 30 | ns | | ROMS negate output delay after OE negate | t <sub>4</sub> | _ | 30 | ns | | ROMRD assert output delay after OE assert | <b>t</b> 5 | _ | 30 | ns | | ROMRD negate output delay after OE negate | <b>t</b> 6 | _ | 30 | ns | ## (4) Bus Timing (PC card mode, CIS write) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Doromotor | Cumbal | Va | l lmi4 | | |----------------------------------------------------------|----------------|-------------------|--------|------| | Parameter | Symbol | Value Min. 5 5 — | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to WE assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2, REG after WE negate | <b>t</b> 2 | 5 | | ns | | ROMS assert output delay after WE assert | <b>t</b> 3 | _ | 30 | ns | | ROMS negate output delay after WE negate | t <sub>4</sub> | _ | 30 | ns | ### (5) Bus Timing (PC card mode, common memory read) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Dovementor | Comple of | Va | 11:4 | | |------------------------------------------------|----------------|------|-----------------|------| | Parameter | Symbol | Min. | Max. — 30 30 30 | Unit | | Setup time for address, CE1 prior to OE assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1 after OE negate | <b>t</b> 2 | 5 | _ | ns | | ROMS assert output delay after OE assert | <b>t</b> 3 | | 30 | ns | | ROMS negate output delay after OE negate | t <sub>4</sub> | | 30 | ns | | ROMRD assert output delay after OE assert | <b>t</b> 5 | _ | 30 | ns | | ROMRD negate output delay after OE negate | t <sub>6</sub> | | 30 | ns | (6) Bus Timing (PC card mode, common memory write) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Comb al | Va | lue | 11:4 | |------------------------------------------------|----------------|------|------|------| | | Symbol | Min. | Max. | Unit | | Setup time for address, CE1 prior to WE assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1 after WE negate | <b>t</b> 2 | 5 | _ | ns | | ROMS assert output delay after WE assert | t <sub>3</sub> | _ | 30 | ns | | ROMS negate output delay after WE negate | t <sub>4</sub> | _ | 30 | ns | ### (7) Bus Timing (PC card mode, I/O read cycle) | Doromotor | Cumbal | Va | Unit | | |------------------------------------------------------------|----------------|------|-------|------| | Parameter | Symbol | Min. | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to IORD assert | <b>t</b> 1 | 5 | _ | ns | | Hold time for address, CE1, CE2 after IORD negate | <b>t</b> 2 | 5 | _ | ns | | Hold time for REG after TORD negate | <b>t</b> 3 | 0 | _ | ns | | Output delay for read data after IORD assert | <b>t</b> 4 | _ | 44 | ns | | Output hold for read data after TORD negate | <b>t</b> 5 | 10 | _ | ns | | Read pulse width | <b>t</b> 6 | 30 | _ | ns | | Output delay for INPACK assert after IORD assert | <b>t</b> 7 | _ | 45 | ns | | Output delay for INPACK negate after IORD negate | t <sub>8</sub> | _ | 45 | ns | | Output delay time of WAIT assert from IORD assert | <b>t</b> 9 | 5*¹ | 35*1 | ns | | Output delay time of WAIT negate from IORD assert | <b>t</b> 10 | _ | 175*2 | ns | <sup>\*1:</sup> WAIT is asserted only when the write access conflicts with that of the network on reading the buffer memory This value will be 2.15 µs when the bus write error occurs on reading the buffer memory port. port (BMPR8). \*2: WAIT is asserted only when the write access conflicts with that of the network on reading the buffer memory port (BMPR8). (8) Bus Timing (PC card mode, I/O write cycle) | Devementer | Cumb al | Va | l lee it | | |------------------------------------------------------------|----------------|------|----------|------| | Parameter | Symbol | Min. | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to IOWR assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2 after IOWR negate | <b>t</b> 2 | 5 | _ | ns | | Hold time for REG after IOWR negate | <b>t</b> 3 | 0 | _ | ns | | Setup time for write data input | t <sub>4</sub> | 10 | _ | ns | | Hold time for write data input | <b>t</b> 5 | 5 | _ | ns | | Write pulse width | <b>t</b> 6 | 36 | _ | ns | | Output delay time for IOIS16 assert from address | <b>t</b> 7 | _ | 35 | ns | | Output delay time for IOIS16 negate from address | t <sub>8</sub> | _ | 35 | ns | | Output delay time for WAIT assert from IOWR assert | <b>t</b> 9 | 5*¹ | 35*1 | ns | | Output delay time for WAIT negate from IOWR assert | <b>t</b> 10 | _ | 175*2 | ns | <sup>\*1:</sup> WAIT is asserted only when the write access conflicts with that of the network on writing the buffer memory This value will be 2.15 µs when the bus write error occurs on writing the buffer memory port. port (BMPR8). \*2: WAIT is asserted only when the write access conflicts with that of the network on writing the buffer memory port (BMPR8). (9) Bus Timing (PC card mode, ID number read from EEPROM: I/O access) (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Desembles | Cumbal | Va | l lmit | | |------------------------------------------------------------|-----------------------|----|--------|------| | Parameter | Symbol | | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to IORD assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2 after IORD negate | <b>t</b> 2 | 5 | _ | ns | | Hold time for REG after IORD negate | <b>t</b> 3 | 0 | _ | ns | | Output delay for INPACK assert after IORD assert | <b>t</b> 4 | _ | 45 | ns | | Output delay for INPACK negate after IORD negate | <b>t</b> 5 | _ | 45 | ns | | Output delay for ROMS assert after IORD assert | <b>t</b> 6 | _ | 35 | ns | | Output delay for ROMS negate after IORD negate | <b>t</b> <sub>7</sub> | _ | 35 | ns | | Output delay for ROMRD assert after IORD assert | t <sub>8</sub> | _ | 30 | ns | | Output delay for ROMRD negate after IORD negate | <b>t</b> 9 | _ | 30 | ns | | Output delay for ROMAD assert after TORD assert | <b>t</b> 10 | _ | 30 | ns | | Output delay for ROMAD negate after IORD negate | <b>t</b> 11 | _ | 30 | ns | (10)Bus Timing (PC card mode, ID number write from EEPROM: I/O access) $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Symbol | Va | Unit | | |------------------------------------------------------------|----------------|------|------|------| | Parameter | Symbol | Min. | Max. | Unit | | Setup time for address, CE1, CE2, REG prior to IOWR assert | t <sub>1</sub> | 5 | _ | ns | | Hold time for address, CE1, CE2 after IOWR negate | <b>t</b> 2 | 5 | | ns | | Hold time for REG after IOWR negate | <b>t</b> 3 | 0 | | ns | | Output delay for ROMS assert after IOWR assert | t <sub>4</sub> | _ | 35 | ns | | Output delay for ROMS negate after IOWR negate | <b>t</b> 5 | _ | 35 | ns | | Output delay for ROMAD assert after IOWR assert | <b>t</b> 6 | _ | 30 | ns | | Output delay for ROMAD negate after TOWR negate | <b>t</b> 7 | _ | 30 | ns | ### (11)ISA Bus Mode Read Cycle $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | | | 11114 | | | |------------------------------------------------------------------------------------------------------------|----------------|------|-------|------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | From the rising edge of SA19 to SA14, SA9 to SA0, and ALE or establishment of AEN or SBHE until IOR assert | t <sub>1</sub> | 15 | _ | _ | ns | | Hold time of SA19 to SA14, SA9 to SA0, AEN, SBHE from IOR negate | <b>t</b> 2 | 21 | _ | _ | ns | | IOR pulse width | <b>t</b> 3 | 50 | | | ns | | From TOR negate to IOCHRDY negate | <b>t</b> 4 | | | 20 | ns | | IOCHRDY pulse width (on conflict at the time of BMPR8 access) | <b>t</b> 5 | _ | _ | 175 | ns | | From IOCHRDY assert to SD15 to 0 enabled | <b>t</b> 6 | _ | _ | 30 | ns | | From IOCHRDY assert to IOR hold time | t <sub>7</sub> | 20 | _ | _ | ns | | From IOR assert to SD15 to 0 enabled (no conflict on bus access) | <b>t</b> 8 | _ | _ | 38 | ns | | From TOR negate to SD15 to SD0 high impedance | <b>t</b> 9 | _ | _ | 38 | ns | | From SA19 to SA14, SA9 to SA0, ALE rising edge, AEN or SBHE rising edge up to IOCS16 assert | <b>t</b> 10 | _ | _ | 28 | ns | | From SA19 to SA14, SA9 to SA0, ALE rising edge, AEN or SBHE rising edge up to IOCS16 negate | <b>t</b> 11 | _ | _ | 71 | ns | | From IOR assert to ENHB, or ENLB assert | <b>t</b> 12 | _ | _ | 46 | ns | | From IOR negate to ENHB or ENLB negate | <b>t</b> 13 | _ | _ | 24 | ns | | ALE pulse width | <b>t</b> 14 | 30 | _ | _ | ns | (12)ISA Bus Mode Write Cycle $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | | ` | | <u>'</u> | , | , | |------------------------------------------------------------------------------------------------------------|----------------|-------|----------|------|--------| | Parameter | Symbol | Value | | | l lmi4 | | Parameter | Symbol | Min. | Тур. | Max. | Unit | | From the rising edge of SA19 to SA14, SA9 to SA0, and ALE or establishment of AEN or SBHE until IOW assert | t <sub>1</sub> | 15 | _ | _ | ns | | Hold time of SA19 to SA14, SA9 to SA0, AEN, SBHE from IOW negate | <b>t</b> 2 | 21 | _ | _ | ns | | IOW pulse width | <b>t</b> 3 | 50 | _ | _ | ns | | From IOW negate to IOCHRDY negate | t <sub>4</sub> | _ | _ | 20 | ns | | IOCHRDY pulse width (on conflict at the time of BMPR8 access) | <b>t</b> 5 | _ | _ | 175 | ns | | From IOCHRDY assert to IOW hold time | <b>t</b> 6 | 20 | _ | _ | ns | | TOW to SD15 to 0 setup time | t <sub>7</sub> | 5 | _ | _ | ns | | TOW to SD15 to SD0 hold time | t <sub>8</sub> | 33 | _ | _ | ns | | From SA19 to SA14, SA9 to SA0, ALE rising edge, AEN or SBHE rising edge up to IOCS16 assert | <b>t</b> 9 | _ | _ | 38 | ns | | From SA19 to SA14, SA9 to SA0, ALE rising edge, AEN or SBHE rising edge up to IOCS16 negate | <b>t</b> 10 | _ | _ | 71 | ns | | From IOW assert to ENHB, or ENLB assert | <b>t</b> 11 | _ | _ | 46 | ns | | From TOW negate to ENHB or ENLB negate | <b>t</b> 12 | | | 24 | ns | | ALE pulse width | <b>t</b> 13 | 30 | | _ | ns | #### (13)General-purpose Bus Mode Read Cycle $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Power and an | Comple al | | Value | Value | | | |-----------------------------------------------------|----------------|------|-------|----------|------|--| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | | Address setup time (from IOR assert) | t <sub>1</sub> | 3 | _ | _ | ns | | | Address hold time (from TOR negate) | <b>t</b> 2 | 3 | _ | | ns | | | TOR pulse width | <b>t</b> 3 | 30 | _ | _ | ns | | | Output delay time for READY negate | t <sub>4</sub> | 7*2 | _ | 26*2 | ns | | | Output delay time for READY assert | <b>t</b> 5 | _ | _ | 175*1 | ns | | | Output delay time for READY assert | <b>t</b> 6 | _ | _ | 28/175*3 | ns | | | Output delay time for READY negate | t <sub>7</sub> | _ | _ | 28 | ns | | | Output delay time for read data (from IOR assert) | <b>t</b> 8 | _ | _ | 44 | ns | | | Output delay time for read data (from READY assert) | <b>t</b> 9 | _ | _ | 8 | ns | | | Output delay time for read data (from READY assert) | <b>t</b> 10 | _ | _ | 18 | ns | | | Output hold time for read data | <b>t</b> 11 | 10 | | 80 | ns | | <sup>\*1:</sup> READY is negated only when the read access is conflicted with that of the network on reading the buffer memory port (BMR8). This value would be 2.15 µs when the bus read error occurs on reading the buffer memory port. This value would be 2.15 µs when the bus read error occurs on reading the buffer memory port. <sup>\*2:</sup> READY is negated only when the read access is conflicted with that of the network on reading the buffer memory port (BMR8). <sup>\*3:</sup> Max time is 28 ns for normal read. Max time is 175 ns only when the read access is conflicted with that of the network on reading the buffer memory port (BMR8). \*: The IOCHRDY output terminal allows the RDYPNSEL terminal to toggle between READY (active high) and READY (active low). #### (14)General-purpose Bus Mode Write Cycle | $(VDD = +5 V \pm 5\%,$ | GND = 0 V | ' Ta = 0°C to | +70°C) | |------------------------|-----------|---------------|--------| | ( V DD — 10 V ± 0 /0, | O(10-0) | , ia – 0 0 io | 11001 | | Parameter | Control of | Value | | | 11:4 | |--------------------------------------|----------------|-------|------|-------------------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | Address setup time (from IOW assert) | t <sub>1</sub> | 3 | _ | _ | ns | | Address hold time (from TOW negate) | t <sub>2</sub> | 3 | _ | _ | ns | | TOW pulse width | t <sub>3</sub> | 36 | _ | _ | ns | | Delay time for READY negate output | t <sub>4</sub> | 7*2 | _ | 26*2 | ns | | Delay time for READY assert output | <b>t</b> 5 | _ | _ | 175* <sup>1</sup> | ns | | Delay time for READY assert output | <b>t</b> 6 | _ | _ | 28/175*3 | ns | | Delay time for READY negate output | t <sub>7</sub> | _ | _ | 28 | ns | | Setup time for write data input | t <sub>8</sub> | 5 | _ | _ | ns | | Hold time for write data input | <b>t</b> 9 | 6 | _ | _ | ns | - \*1: READY is negated only when the write access is conflicted with that of the network on writing the buffer memory port (BMR8). - This value would be 2.15 µs when the bus write error occurs on writing the buffer memory port. - \*2: READY is negated only when the write access is conflicted with that of the network on writing the buffer memory port (BMR8). - \*3: Max time is 28 ns for normal write. Max time is 175 ns only when the write access is conflicted with that of the network on writing the buffer memory port (BMR8). This value would be 2.15 μs when the bus write error occurs on writing the buffer memory port. \*: The IOCHRDY output terminal allows the RDYPNSEL terminal to toggle between READY (active high) and READY (active low). (15)General-purpose Bus Mode Write Input Inhibit Period $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Symbol | Value | | | 11:4:4 | |---------------------------------------|----------------|-------|------|------|--------| | | | Min. | Тур. | Max. | Unit | | Input inhibit period for IOR and IOW. | t <sub>1</sub> | 50 | _ | _ | ns | ### (16) Single DMA Access Timing (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | Value | | | 11:4 | |-------------------------------------------------------|----------------|-------|------|------|------| | | | Min. | Тур. | Max. | Unit | | Delay time for DREQ negate output (from DMACK assert) | t <sub>1</sub> | _ | _ | 21 | ns | | Delay time for DREQ assert output (from DMACK negate) | t <sub>2</sub> | _ | _ | 19 | ns | | EOP pulse width | <b>t</b> 3 | 10 | _ | _ | ns | | Delay time for EOP assert input | t <sub>4</sub> | 3 | _ | _ | ns | | Setup time for EOP negate | <b>t</b> 5 | 3 | _ | _ | ns | | Setup time for DMACK | <b>t</b> 6 | 0 | _ | _ | ns | | Hold time for DMACK input | t <sub>7</sub> | 3 | _ | _ | ns | <sup>\*:</sup> EOP input allows the values of EOP/EOP register values for bit 1 of DLCR7 to toggle between EOP (active high) and EOP (active low). Note: IOCHRDY signal timing is identical as that of bus timing. ### (17)Burst DMA Access Timing | Parameter | Symbol | Value | | | l lm:4 | |--------------------------------------------------|----------------|-------|------|------|--------| | | | Min. | Тур. | Max. | Unit | | Hold time for DREQ output | t <sub>1</sub> | _ | _ | 32 | ns | | Hold time for DMACK input (from IOR, IOW negate) | <b>t</b> 2 | 3 | _ | _ | ns | | Hold time for DREQ output | <b>t</b> 3 | 4 | _ | 28 | ns | | Hold time for DMACK input (from EOP/EOP negate) | t <sub>4</sub> | 3 | _ | _ | ns | | Setup time for DMACK input | <b>t</b> 5 | 0 | _ | _ | ns | - \*1: This transition goes low at a single cycle before the last DMA when DLCR4 bit 2 is 1. - \*2: This transition goes low at the last cycle of DMA when DLCR4 bit 2 is 0. \*: EOP input allows the values of EOP/EOP register values for bit 1 of DLCR7 to toggle between EOP (active high) and EOP (active low). Note: IOCHRDY signal timing is identical as that of bus timing. ### (18)Buffer Memory Read Timing ### • 100 ns cycle access (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | | l lnit | | | |-------------------------------------------|----------------|------|--------|------|------| | | | Min. | Тур. | Max. | Unit | | Read cycle time (100 ns cycle mode) | t <sub>1</sub> | _ | 100 | _ | ns | | Address access time | <b>t</b> 2 | _ | _ | 81 | ns | | Address setup time (from BCS Low) | <b>t</b> 3 | 0 | _ | 8 | ns | | Address hold time (from BCS High) | t <sub>4</sub> | 0 | _ | _ | ns | | Setup time for BOE output (from BCS High) | <b>t</b> 5 | _ | _ | 5 | ns | | Access time for chip select | <b>t</b> 6 | _ | _ | 81 | ns | | Access time for output enable | t <sub>7</sub> | _ | _ | 49 | ns | | Setup time for data | t <sub>8</sub> | 15 | _ | _ | ns | | Hold time for data | <b>t</b> 9 | 0 | _ | _ | ns | ### • 150 ns cycle access (VDD = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Comple of | | 11 | | | |-------------------------------------------|----------------|------|------|------|------| | | Symbol | Min. | Тур. | Max. | Unit | | Read cycle time (150 ns cycle mode) | t <sub>1</sub> | _ | 150 | _ | ns | | Address access time | t <sub>2</sub> | _ | _ | 81 | ns | | Address setup time (from BCS Low) | t <sub>3</sub> | 0 | _ | 8 | ns | | Address hold time (from BCS High) | t <sub>4</sub> | 0 | _ | _ | ns | | Setup time for BOE output (from BCS High) | <b>t</b> 5 | _ | _ | 5 | ns | | Access time for chip select | <b>t</b> 6 | _ | _ | 81 | ns | | Access time for output enable | t <sub>7</sub> | _ | _ | 49 | ns | | Setup time for data | t <sub>8</sub> | 15 | _ | _ | ns | | Hold time for data | <b>t</b> 9 | 0 | _ | _ | ns | (19)Buffer Memory Write Timing ### • 100 ns cycle access (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Cymbol | | Unit | | | |------------------------------------------|----------------|------|------|------|------| | | Symbol | Min. | Тур. | Max. | Unit | | Write cycle time (100 ns cycle mode) | <b>t</b> 1 | _ | 100 | _ | ns | | Setup time for data | <b>t</b> 2 | 40 | _ | _ | ns | | Hold time for data | <b>t</b> 3 | 10 | _ | _ | ns | | Address hold time (from WE High) | <b>t</b> 4 | 12 | _ | _ | ns | | WE pulse width | <b>t</b> 5 | 60 | _ | _ | ns | | Address setup time (from BCS Low) | <b>t</b> 6 | 2 | _ | 8 | ns | | Address hold time (from BCS High) | t <sub>7</sub> | 0 | _ | _ | ns | | Delay time for WE output (from BCS Low) | t <sub>8</sub> | 0 | _ | _ | ns | | Setup time for WE output (from BCS High) | <b>t</b> 9 | 0 | _ | _ | ns | | Address determination time | <b>t</b> 10 | 71 | _ | _ | ns | | Chip select determination time | <b>t</b> 11 | 62 | _ | _ | ns | ### • 150 ns cycle access (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | | | Unit | | |------------------------------------------|----------------|------|------|------|------| | | Symbol | Min. | Тур. | Max. | Unit | | Write cycle time (150 ns cycle mode) | <b>t</b> 1 | _ | 150 | _ | ns | | Setup time for data | <b>t</b> 2 | 40 | _ | _ | ns | | Hold time for data | <b>t</b> 3 | 10 | _ | _ | ns | | Address hold time (from WE High) | <b>t</b> 4 | 12 | _ | _ | ns | | WE pulse width | <b>t</b> 5 | 100 | _ | _ | ns | | Address setup time (from BCS Low) | <b>t</b> 6 | 2 | _ | 8 | ns | | Address hold time (from BCS High) | t <sub>7</sub> | 0 | _ | _ | ns | | Delay time for WE output (from BCS Low) | t <sub>8</sub> | 0 | _ | _ | ns | | Setup time for WE output (from BCS High) | <b>t</b> 9 | 0 | _ | _ | ns | | Address determination time | <b>t</b> 10 | 110 | _ | _ | ns | | Chip select determination time | <b>t</b> 11 | 100 | _ | _ | ns | #### (20)Reset Timing (V<sub>DD</sub> = +5 V $$\pm$$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | | I In: | | | |---------------------------------------------|----------------|------|-------|------|------| | | | Min. | Тур. | Max. | Unit | | Reset pulse width | t <sub>1</sub> | 200 | _ | _ | ns | | Register access enable start time | <b>t</b> 2 | 300 | _ | _ | ns | | Start time for transmit & receive operation | t <sub>3</sub> | 200 | _ | _ | μs | #### (21)Skip Packet Timing (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | Value | | | Unit | |---------------|----------------|-------|------|------|------| | | | Min. | Тур. | Max. | Unit | | Skip end time | t <sub>1</sub> | 300 | _ | _ | ns | ### (22)Interrupt Output Timing $$(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$$ | Parameter | Symbol | | l lmi4 | | | |---------------------------------------|----------------|------|--------|------|------| | | | Min. | Тур. | Max. | Unit | | Delay time for interrupt output clear | t <sub>1</sub> | 5 | _ | 40 | ns | ### (23) Jabber Timing (V<sub>DD</sub> = +5 V $$\pm$$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter Symbo | Councile of | Condition | | 11:0:4 | | | |-------------------|-------------|-----------|------|--------|------|------| | | Symbol | | Min. | Тур. | Max. | Unit | | Max transmit time | _ | _ | 64 | 96 | 128 | ns | | Jabber stop timer | _ | _ | 480 | 512 | 544 | ns | ### (24)Link Test Timing $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Symbol | | 1110:4 | | | |---------------------------------------|----------------|------|--------|------|------| | | | Min. | Тур. | Max. | Unit | | Link pulse width for TPOPA | t <sub>1</sub> | _ | 100 | _ | ns | | Link pulse width for TPOPB and TPONB | <b>t</b> 2 | _ | 50 | _ | ns | | Link pulse transmit interval | <b>t</b> 3 | 15 | 16 | 17 | ms | | Effective link pulse receive interval | t <sub>4</sub> | 4.0 | _ | 65 | ms | (25) Timing for reading the EEPROM default setting information (jumperless ISA mode) | Parameter | Combal | | l lmi4 | | | |-----------------------------|----------------|------|--------|------|------| | | Symbol | Min. | Тур. | Max. | Unit | | Shift clock "H" pulse width | t <sub>1</sub> | _ | 600 | _ | ns | | Shift clock "L" pulse width | t <sub>2</sub> | _ | 600 | _ | ns | | Chip select setup time | t <sub>3</sub> | _ | 400 | _ | ns | | Chip select hold time | t <sub>4</sub> | _ | 200 | _ | ns | | DI data setup time | <b>t</b> 5 | _ | 200 | _ | ns | | DI data hold time | <b>t</b> 6 | _ | 200 | _ | ns | | DO data setup time | t <sub>7</sub> | 100 | _ | _ | ns | | DO data hold time | t <sub>8</sub> | 100 | _ | _ | ns | Notes: Use the NMC93C06 or NMC93C46 for EEPROM by National Semiconductor or its equivalent. • Control signal or data for EEPROM requires control through software when writing data or reading the node ID data. It is to be controlled so that it meets the AC timing requirements for EEPROM. #### (26)SQE Test Timing (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | Symbol | | 11::4 | | | |---------------------|--------|------|-------|------|------| | | | Min. | Тур. | Max. | Unit | | SQE test wait timer | _ | 800 | 1000 | 1200 | ns | | SQE test timer | _ | 800 | 1000 | 1200 | ns | #### (27)LED Turn-on Time $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Parameter | Symbol | | l lmi4 | | | |---------------------------|--------|------|--------|------|------| | | | Min. | Тур. | Max. | Unit | | Receive LED turn-on time | _ | _ | 128 | _ | ms | | Transmit LED turn-on time | _ | _ | 128 | _ | ms | | Collision turn-on time | _ | _ | 128 | _ | ms | #### (28)Loopback Test $(V_{DD} = +5 \text{ V} \pm 5\%, \text{ GND} = 0 \text{ V}, \text{ Ta} = 0^{\circ}\text{C to } +70^{\circ}\text{C})$ | Doromotor | Symbol | Value | | | Unit | |-----------------------------------------------------------------------------|--------|-------|------|------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | Setup time for loopback signal (DLCR4, bit 1) prior to starting to transmit | _ | 100 | _ | _ | ns | | Hold time for loopback signal (DLCR4, bit1) after transmit. | _ | 100 | _ | _ | ns | #### (29) Timing for transmitting TP (V<sub>DD</sub> = +5 V $\pm$ 5%, GND = 0 V, Ta = 0°C to +70°C) | Parameter | | Value | | | Unit | |------------------------------------------------------------|----------------|-------|------|------|------| | | | Min. | Тур. | Max. | Unit | | Data width for transmitting TP (1, 0, 1, 0) | t <sub>1</sub> | _ | 100 | _ | ns | | Data with for transmitting TP (1, 1, 1, 1, or 0, 0, 0, 0,) | <b>t</b> 2 | | 50 | _ | ns | | Data width for end of packet (the last data: "0") | tз | | 250 | _ | ns | | Data width for end of packet (the last data: "1") | t <sub>4</sub> | | 300 | _ | ns | | Delay time from TPOPA to TPOPB or from TPONA to TPONB. | <b>t</b> 5 | | 50 | _ | ns | #### **■ SYSTEM CONFIGURATION EXAMPLE** ### **■ 10 BASE-T INTERFACE CIRCUIT** #### • Recommended pulse transformer Recommended transformer for the MB86967 is as follows: Model: S556-9004-09 Manufacturer: Bel Fuse Ltd. Model: TLA-3M103 Manufacturer · Distributor: TDK Co. Model: 851C2N-0005 Manufacturer · Distributor: Toko Co. ### **■** FEATURES OF MB86965B, MB86964-R, MB86967 | | | MB86965B | MB86964-R | MB86967 | Notes | |-------------------------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------| | Package | | QFP160 | SQFP100 | SQFP100 | | | Supply voltage | | 5 V ± 5% | 5 V ± 5% | 5 V ± 5% | | | Operation mode | | Jumperless +ISA I/F<br>Jumper+E <sup>2</sup> PROM+ISA I/F<br>Jumper+PROM+ISA I/F<br>General-purpose I/F | General-purpose bus I/F | PC card I/F<br>General-purpose bus I/F<br>Jumperless +ISA I/F<br>Jumper + E²PROM + ISA I/F | | | Network interface | | TP/AUI | TP/AUI | ТР | | | Max buffer memory si: | size | 64 Kbytes | 32 Kbytes | 32 Kbytes | | | Buffer memory bus width | idth | 8/16 bits | 8 bits | 8 bits | | | ROM interface for boot program | ot program | Internal | No | No | | | ROM type for boot program | ogram | PROM or Flash ROM | | | Writable by selecting Flash ROM | | LED for monitoring<br>network status | ISA bus mode | Test for transmit, receive, collision, link | | Test for transmit, receive, collision, link | | | | PC card mode | | | Test for transmit, receive, collision, link | | | | General-purpose<br>bus mode | Test for transmit, receive, collision, link | Test for transmit, receive, collision, link | Test for transmit, receive, collision, link | | | Device ID | | 1,1 | 0, 1 | 1, 0 | DLCR7 bit 6, 7 | | Internal register | ISA bus mode | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 19, IDRB 0<br>to 7 | | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 19, (IDRB 0<br>to 7)* | *: Change name to RES0 to 7 | | | PC card mode | | | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 15,<br>CARDCR, (ID), CCR 0 to 3 | | | | General-purpose<br>bus mode | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 15 | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 15 | DLCR 0 to 15, MAR 8 to 15,<br>BMPR 8, 10 to 15 | | | Full duplex operation | | Yes | No | Yes | DLCR4 bit 0 | | Jumperless mode default setting | ault setting | External reset or writing IDRB0 to 7 | | External reset or writing IDRB 0-7 | | | Shutdown mode | | No | No | Yes (crystal oscillation stop) | BMPR14 bit 4 × DLCR7 bit 5 | | TP transceiver filter | | Internal | Internal | External | | | Winding ratio for TP transmit pulse transformer | ransmit pulse | 1: /2 | 1: /2 | 1:1 | | | Remote signalling | | Yes | Yes | No | BMPR14 bit 5, 7<br>BMPR15 bit 4, 5, 7 | | 100 $\Omega$ /150 $\Omega$ termination resistor | ion resistor | Selectable | Selectable | 100 Ω | BMPR13 bit 2 | | Deleting receive long packet | packet | No | No | Yes | BMPR12 bit 3 | | Lower Squelch | | Yes | Yes | No | BMPR13 bit 6 | #### **■ ERRATA SHEET** Category Power supply OFF sequence in PC card mode,. Summary Whin the CIS area is prepared with an EEPROM device, MB86967 mulfunctions with mis- writing occasionally for the CIS area (This error depends on the type of PC.) Recommendation Please insert the OR-gate between MB86967 and EEPROM. As a result. even if Pin 95 is driven to Low, it does not influence EEPROM. ### **■** ORDERING INFORMATION | Part number | Package | Remarks | |-------------|----------------------------------------|---------| | MB86967PFV | 100-pin Plastic LQFP<br>(FPT-100P-M05) | | #### **■ PACKAGE DIMENSION** ### **FUJITSU LIMITED** For further information please contact: #### Japan FUJITSU LIMITED Corporate Global Business Support Division Electronic Devices KAWASAKI PLANT, 4-1-1, Kamikodanaka Nakahara-ku, Kawasaki-shi Kanagawa 211-8588, Japan Tel: 81(44) 754-3763 Fax: 81(44) 754-3329 http://www.fujitsu.co.jp/ #### North and South America FUJITSU MICROELECTRONICS, INC. Semiconductor Division 3545 North First Street San Jose, CA 95134-1804, USA Tel: (408) 922-9000 Fax: (408) 922-9179 Customer Response Center Mon. - Fri.: 7 am - 5 pm (PST) Tel: (800) 866-8608 Fax: (408) 922-9179 http://www.fujitsumicro.com/ #### **Europe** FUJITSU MIKROELEKTRONIK GmbH Am Siebenstein 6-10 D-63303 Dreieich-Buchschlag Germany Tel: (06103) 690-0 Fax: (06103) 690-122 http://www.fujitsu-ede.com/ #### **Asia Pacific** FUJITSU MICROELECTRONICS ASIA PTE LTD #05-08, 151 Lorong Chuan New Tech Park Singapore 556741 Tel: (65) 281-0770 Fax: (65) 281-0220 http://www.fmap.com.sg/ F9811 © FUJITSU LIMITED Printed in Japan All Rights Reserved. The contents of this document are subject to change without notice. Customers are advised to consult with FUJITSU sales representatives before ordering. The information and circuit diagrams in this document are presented as examples of semiconductor device applications, and are not intended to be incorporated in devices for actual use. Also, FUJITSU is unable to assume responsibility for infringement of any patent rights or other rights of third parties arising from the use of this information or circuit diagrams. FUJITSU semiconductor devices are intended for use in standard applications (computers, office automation and other office equipment, industrial, communications, and measurement equipment, personal or household devices, etc.). CAUTION: Customers considering the use of our products in special applications where failure or abnormal operation may directly affect human lives or cause physical injury or property damage, or where extremely high levels of reliability are demanded (such as aerospace systems, atomic energy controls, sea floor repeaters, vehicle operating controls, medical devices for life support, etc.) are requested to consult with FUJITSU sales representatives before such use. The company will not be responsible for damages arising from such use without prior approval. Any semiconductor devices have an inherent chance of failure. You must protect against injury, damage or loss from such failures by incorporating safety design measures into your facility and equipment such as redundancy, fire protection, and prevention of over-current levels and other abnormal operating conditions. If any products described in this document represent goods or technologies subject to certain restrictions on export under the Foreign Exchange and Foreign Trade Law of Japan, the prior authorization by Japanese government will be required for export of those products from Japan.