

PCI to Single Printer Port

#### Features

- 5V Operation
- Low Power
- PCI Compatible Printer Port
- Multi-Mode Compatible Controller (SPP, PS2, EPP, ECP)
- Fast Data Rates up to 1.5 MBps (Parallel Port)
- 16-Byte FIFO (Parallel Port)
- Re-Map function for Legacy Ports
- 128-pin "Lead Free" QFP Package

#### Applications

- Printer Server
- Portable Backup Units
- Printer Interface
- Add-On I/O Cards

#### **Application Notes**

• AN-9805-1P-PCI5V

#### **Evaluation Board**

• MCS9805-EVB

#### **General Description**

The MCS9805 is a printer port controller with PCI Bus Interface. MCS9805 fully supports the existing Centronics printer interface as well as PS/2, EPP, and ECP modes.

The MCS9805 is ideally suited for PC applications, such as high speed parallel ports. The MCS9805 is available in a 128-pin QFP package. It is fabricated using an advanced submicron CMOS process to achieve low drain power and high-speed requirements.

The MCS9805 is a pin-compatible replacement for the previous Nm9805. The Nm9805 is no longer offered. It was only warranted for use with a 5V power supply, and was only intended to operate in 5V PCI signaling environments. The MCS9805's new RoHS "Lead Free" package and 5V operation make it a much more flexible device that is better suited for new designs.

| Ordering Information              |  |  |  |  |  |
|-----------------------------------|--|--|--|--|--|
| Commercial Grade (0 °C to +70 °C) |  |  |  |  |  |
| MCS9805CV 128-QFP RoHS            |  |  |  |  |  |









PCI to Single Printer Port



#### **Pin Assignments** Pin Name Туре Description CLK 122 L 33 MHz PCI System Clock Input. PCI System Reset (active low). nRESET 121 L Resets all internal registers, sequencers, and signals to a consistent state. During the reset condition AD31-0 & nSER are tri-stated. Multiplexed PCI address/data bus. A bus transaction consists of an address phase followed by one or more data phases. During the address phase, AD31-0 contain a physical AD31-29 126-128 I/O address. Write data is stable and valid when nIRDY and nTRDY are asserted (active). AD28-24 2-6 I/O See AD31-29 description. AD23-16 11-18 I/O See AD31-29 description. AD15-11 34-38 I/O See AD31-29 description. AD10-8 40-42 I/O See AD31-29 description. AD7-0 46-53 I/O See AD31-29 description. nFRAME is driven by the current Bus Master to indicate the beginning and nFRAME 23 duration of an access. nFRAME is asserted to indicate a Bus transaction L is beginning. While nFRAME is active, data transfer continues. Initiator Ready. During a write, nIRDY asserted indicates that the initiator is driving valid L nIRDY 24 data onto the data bus. During a read, nIRDY asserted indicates that the initiator is ready to accept data from the target. Target Ready (tri-state). nTRDY 25 Ο This line is asserted when the target is ready to complete the current data phase. nSTOP is asserted to indicate that the target wishes the initiator to stop 0 nSTOP 27 the transaction in-process on the current data phase. nLOCK indicates an atomic operation that may require multiple nLOCK 28 Т transactions to complete. Initialization Device Select. IDSEL 9 It is used as a chip select during configuration read and write L transactions. Device Select (tri-state). 26 Ο nDEVSEL A target asserts nDEVSEL when it has decoded one of its addresses. Parity Error (tri-state). 29 Is used to report parity errors during all PCI transactions except a special nPERR Ο cycle. The minimum duration of nPERR is one clock cycle.



| Name   | Pin | Туре | Description                                                                                                                                                                                                                                                                                    |
|--------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| nSERR  | 30  | 0    | System Error (open drain).<br>This pin goes low when address parity errors are detected.                                                                                                                                                                                                       |
| PAR    | 31  | I/O  | Even Parity.<br>Parity is even parity across AD31-0 and nC/BE3-0. PAR is stable and<br>valid one clock after the address phase. For the data phase, PAR is<br>stable and valid one clock after either nIRDY is asserted on a write<br>transaction, or nTRDY is asserted on a read transaction. |
| nC/BE3 | 8   | I    | Bus Command and Byte Enable.<br>During the address phase of a transaction, nC/BE3-0 define the Bus<br>Command. During the data phase, nC/BE3-0 are used as Byte Enables.<br>nC/BE3 applies to Byte "3".                                                                                        |
| nC/BE2 | 22  | I    | Bus Command and Byte Enable.<br>During the address phase of a transaction, nC/BE3-0 define the Bus<br>Command. During the data phase, nC/BE3-0 are used as Byte Enables.<br>nC/BE3 applies to Byte "2".                                                                                        |
| nC/BE1 | 32  | I    | Bus Command and Byte Enable.<br>During the address phase of a transaction, nC/BE3-0 define the Bus<br>Command. During the data phase, nC/BE3-0 are used as Byte Enables.<br>nC/BE3 applies to Byte "1".                                                                                        |
| nC/BE0 | 43  | I    | Bus Command and Byte Enable.<br>During the address phase of a transaction, nC/BE3-0 define the Bus<br>Command. During the data phase, nC/BE3-0 are used as Byte Enables.<br>nC/BE3 applies to Byte "0".                                                                                        |
| nINTA  | 120 | 0    | PCI active low Interrupt Output (open-drain).<br>This signal goes low (active) when an interrupt condition occurs.                                                                                                                                                                             |
| EE-CS  | 115 | 0    | External EEPROM chip select (active high).<br>After Power-On Reset, The EEPROM is read and the read-only<br>configuration registers are loaded sequentially from the first 64 Bytes<br>in the EEPROM.                                                                                          |
| EE-CLK | 116 | 0    | External EEPROM Clock.                                                                                                                                                                                                                                                                         |
| EE-DI  | 118 | I    | External EEPROM Data Input.                                                                                                                                                                                                                                                                    |
| EE-DO  | 117 | 0    | External EEPROM Data Output.                                                                                                                                                                                                                                                                   |
| EE-EN  | 123 | I    | Enable external EEPROM (active high, internal pull-up).<br>The external EEPROM can be disabled when this pin is tied to GND<br>or pulled low. When disabled, default values for the PCI configuration<br>registers will be used.                                                               |
| SLCT   | 84  | I    | Peripheral/printer Selected (internal pull-up).<br>This pin is set high by the peripheral/printer when it is selected.                                                                                                                                                                         |



| Name     | Pin                                                        | Туре | Description                                                                                                                                                                                                                                                         |
|----------|------------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PE       | 87                                                         | I    | Paper Empty (internal pull-up).<br>This pin is set high by the peripheral/printer when printer paper is<br>empty.                                                                                                                                                   |
| BUSY     | 85                                                         | I    | Peripheral/printer Busy (internal pull-up).<br>This pin is set high by the peripheral/printer when it is not ready to accept data.                                                                                                                                  |
| nACK     | 86                                                         | I    | Peripheral/printer Data Acknowledge (internal pull-up).<br>This pin is set low by the peripheral/printer to indicate a successful<br>data transfer has taken place. During SPP mode when interrupts are<br>enabled, the nINTA pin follows the nACK input pin state. |
| nFAULT   | 83                                                         | I    | Peripheral/printer Data Error (internal pull-up).<br>This pin is set low by the peripheral/printer during an error condition.                                                                                                                                       |
| nSTROBE  | 81                                                         | I/O  | Peripheral/printer Data Strobe (open drain, active low).<br>Informs the printer there is valid data on the Bus.                                                                                                                                                     |
| nAUTOFDX | 80                                                         | I/O  | Peripheral/printer Auto Feed (open-drain, active low).<br>Continuous autofed paper is selected when this pin is set low.                                                                                                                                            |
| nINIT    | 79                                                         | I/O  | Initialize the Peripheral/printer (open drain, active low).<br>When set low, the peripheral/printer starts it's initialization routine.                                                                                                                             |
| nSLCTIN  | 78                                                         | I/O  | Peripheral/printer Select (open-drain, active low).<br>Selects the peripheral/printer when it is set low.                                                                                                                                                           |
| PD7-PD4  | 98-95                                                      | I/O  | Peripheral/printer Data bits.                                                                                                                                                                                                                                       |
| PD3-PD0  | 93-90                                                      | I/O  | Peripheral/printer Data bits.                                                                                                                                                                                                                                       |
| GND      | 7,20,21,<br>33,44,45,<br>60,77,88,<br>94,99,108<br>119,125 | Pwr  | Power and Signal Ground.                                                                                                                                                                                                                                            |
| VCC      | 1,10,19,<br>39,54,66,<br>82,89,104<br>114                  | Pwr  | Supply. Voltage                                                                                                                                                                                                                                                     |



PCI to Single Printer Port

## **PCI Bus Operation:**

The execution of PCI Bus transactions take place in broadly five stages: address phase; transaction claiming; data phase(s); final data transfer; and transaction completion.

#### Address Phase:

Every PCI transaction starts with an address phase, one PCI clock period in duration. During the address phase the initiator (also known as the current Bus Master) identifies the target device (via the address) and type of transaction (via the command). The initiator drives the 32-bit address onto the Address/Data Bus, and a 4-bit command onto the Command/Byte-Enable Bus. The initiator also asserts the nFRAME signal during the same clock cycle to indicate the presence of valid address and transaction information on those buses. The initiator supplies the starting address and command type for one PCI clock cycle. The target generates the subsequent sequential addresses for burst transfers. The Address/Data Bus becomes the Data Bus, and the Command/Byte-Enable Bus becomes the Byte-Enable Bus for the remainder of the clock cycles in that transaction. The target latches the address and command type on the next rising edge of PCI clock, as do all other devices on that PCI bus. Each device then decodes the address and determines whether it is the intended target, and also decodes the command to determine the type of transaction.

## **Claiming The Transaction:**

When a device determines that it is the target of a transaction, it claims the transaction by asserting nDEVSEL.

## Data Phase(s):

The data phase of a transaction is the period during which a data object is transferred between the initiator and the target. The number of data Bytes to be transferred during a data phase is determined by the number of Command/Byte-Enable signals that are asserted by the initiator during the data phase. Each data phase is at least one PCI clock period in duration. Both initiator and target must indicate that they are ready to complete a data phase. If not, the data phase is extended by a wait state of one clock period in duration. The initiator and the target indicate this by asserting nIRDY and nTRDY respectively and the data transfer is completed at the rising edge of the next PCI clock.

## **Transaction Duration:**

The initiator, as stated earlier, gives only the starting address during the address phase. It does not tell the number of data transfers in a burst transfer transaction. The target will automatically generate the addresses for subsequent Data Phase transfers. The initiator indicates the completion of a transaction by asserting nIRDY and de-asserting nFRAME during the last data transfer phase. The transaction does not actually complete until the target has also asserted the nTRDY signal and the last data transfer takes place. At this point the nTRDY and nDEVSEL are de-asserted by the target.

## Transaction Completion:

When all of nIRDY, nTRDY, nDEVSEL, and nFRAME are in the inactive state (high state), the bus is in idle state. The bus is then ready to be claimed by another Bus Master.

PCI to Single Printer Port



## **PCI Resource Allocation**

PCI devices do not have "Hard-Wired" assignments for memory or I/O Ports like ISA devices do. PCI devices use "Plug & Play" to obtain the required resources each time the system boots up. Each PCI device can request up to six resource allocations. These can be blocks of memory (RAM) or blocks of I/O Registers. The size of each resource block requested can also be specified, allowing great flexibility. Each of these resource blocks is accessed by means of a Base-Address-Register (BAR). As the name suggests, this is a pointer to the start of the resource. Individual registers are then addressed using relative offsets from the Base-Address-Register contents. The important thing to note is: plugging the same PCI card into different machines will not necessarily result in the same addresses being assigned to it. For this reason, software (drivers, etc.) must always obtain the specific addresses for the device from the PCI System.

Each PCI device is assigned an entry in the PCI System's shared "Configuration Space". Every device is allocated 256 Bytes in the Configuration Space. The first 64 Bytes must follow the conventions of a standard PCI Configuration "Header". There are several pieces of information the device must present in specific fields within the header to allow the PCI System to properly identify it. These include the Vendor-ID, Device-ID and Class-Code. These three fields should provide enough information to allow the PCI System to associate the correct software driver with the hardware device. Other fields can be used to provide additional information to further refine the needs and capabilities of the device.

As part of the Enumeration process (discovery of which devices are present in the system) the Base-Address-Registers are configured for each device. The device tells the system how many registers (etc.) it requires, and the system maps that number into the system's resource space, reserving them for exclusive use by that particular device. No guarantees are made that any two requests for resources will have any predictable relationship to each other. Each PCI System is free to use its own allocation strategy when managing resources.

## **Multi-Function Devices**

MosChip uses the Subsystem-ID field to indicate how many Serial Ports and Parallel Ports are provided by the current implementation. By changing the data in the Subsystem-ID field, and stuffing only the appropriate number of external components, the same board could be used for products with either one or two Ports. The least significant Hexadecimal digit of the Subsystem-ID field indicates the number of Serial Ports that are currently being provided by the device. The next higher digit indicates the number of Parallel Ports being provided. The table below shows several different combinations and the types of Ports that would be enabled. Some MosChip devices provide Serial Ports, some provide Parallel Ports, and some provide both types of Ports. This field is used as an aid to the software Drivers, allowing them to easily determine how many of each Port type to configure.

| Subsystem-ID | Parallel Ports | Serial Ports |
|--------------|----------------|--------------|
| 0001         | 0              | 1            |
| 0010         | 1              | 0            |
| 0012         | 1              | 2            |

This use of the term "Multi-Function Device" should not be confused with the more generic use of that term by the PCI System. Each "Function" within a "Unit" (physical device) gets its own Configuration Space Header. MosChip's devices do not need this extra layer of complexity, the six Base Address Registers provided by one PCI "Function" are more than adequate to allocate all of the desired resources.

## External EEPROM

Data is read from the EEPROM immediately after a Hardware Reset, and the values obtained are used to update the Configuration before the PCI System first sees the device on the Bus. This allows a vendor to substitute their own ID codes in place of the MosChip codes for example. If no EEPROM is detected after a Hardware Reset, MosChip's default values for the configuration are provided by the chip itself.



PCI to Single Printer Port

## **PCI Configuration Space Header**

Default values for several key fields are shown in the table below.

| AD 31-23         | AD 22-16                                    | AD 15-8              | AD 7-0           | Offset (Hex) |  |  |  |
|------------------|---------------------------------------------|----------------------|------------------|--------------|--|--|--|
| Device ID        | (9805)                                      | Vendor II            | D (9710)         | 00           |  |  |  |
| Statu            | JS                                          | Comr                 | nand             | 04           |  |  |  |
| Cl               | ass Code (07800                             | 0)                   | Revision ID (01) | 08           |  |  |  |
| BIST             | Header Type                                 | Latency Timer        | Cache Size (08)  | 0C           |  |  |  |
| Base Addre       | ss Register (BAR                            | R) 0 – "Standard Reg | gisters" (Y)     | 10           |  |  |  |
| Base Addres      | ss Register (BAR                            | ) 1 – "Extended Reg  | jisters" (W)     | 14           |  |  |  |
|                  | 18                                          |                      |                  |              |  |  |  |
|                  | 1C                                          |                      |                  |              |  |  |  |
|                  | Reserved                                    |                      |                  |              |  |  |  |
|                  | Reserved                                    |                      |                  |              |  |  |  |
|                  | Reserved                                    |                      |                  |              |  |  |  |
| Subsystem        | Subsystem ID (0010) Subsystem Vendor ID (10 |                      |                  |              |  |  |  |
|                  | 30                                          |                      |                  |              |  |  |  |
|                  | 34                                          |                      |                  |              |  |  |  |
|                  | 38                                          |                      |                  |              |  |  |  |
| Max Latency (00) | Min Grant (00)                              | Interrupt Pin (01)   | Interrupt Line   | 3C           |  |  |  |

## Internal Address Select Configuration

The MCS9805 uses two Base Address Registers.

These essentially act as internal "Chip Select" logic.

Registers are addressed by using one of the Base Addresses plus an offset.

| BAR   | I/O Address Offset | Function                         |
|-------|--------------------|----------------------------------|
| 0 (Y) | 00-07              | Standard Parallel Port Registers |
| 1 (W) | 00                 | Configuration Register A         |
| 1 (W) | 01                 | Configuration Register B         |
| 1 (W) | 02                 | Extended Control Register (ECR)  |



| EEPROM<br>Address<br>Location | Hex Data<br>(Word) | Description of Content | EEPROM<br>Address<br>Location | Hex Data<br>(Word) | Description         |
|-------------------------------|--------------------|------------------------|-------------------------------|--------------------|---------------------|
| 0x00                          | 9805               | Device ID              | 0x20                          | 0000               |                     |
| 0x01                          | 0000               |                        | 0x21                          | 0000               |                     |
| 0x02                          | 9710               | Vendor ID              | 0x22                          | 0000               |                     |
| 0x03                          | 0000               |                        | 0x23                          | 0000               |                     |
| 0x04                          | 0000               |                        | 0x24                          | 0000               |                     |
| 0x05                          | 0000               |                        | 0x25                          | 0000               |                     |
| 0x06                          | 0000               |                        | 0x26                          | 0000               |                     |
| 0x07                          | 0000               |                        | 0x27                          | 0000               |                     |
| 0x08                          | 0780               | Class Code (23-8)      | 0x28                          | 0000               |                     |
| 0x09                          | 0000               |                        | 0x29                          | 0000               |                     |
| 0x0A                          | 0001               | Revision ID            | 0x2A                          | 0000               |                     |
| 0x0B                          | 0000               |                        | 0x2B                          | 0000               |                     |
| 0x0C                          | 0000               | Header                 | 0x2C                          | 0010               | Subsystem ID        |
| 0x0D                          | 0000               |                        | 0x2D                          | 0000               |                     |
| 0x0E                          | 0000               |                        | 0x2E                          | 1000               | Subsystem Vendor ID |
| 0x0F                          | 0000               |                        | 0x2F                          | 0000               |                     |
| 0x10                          | 0000               |                        | 0x30                          | 0000               |                     |
| 0x11                          | 0000               |                        | 0x31                          | 0000               |                     |
| 0x12                          | 0000               |                        | 0x32                          | 0000               |                     |
| 0x13                          | 0000               |                        | 0x33                          | 0000               |                     |
| 0x14                          | 0000               |                        | 0x34                          | 0000               |                     |
| 0x15                          | 0000               |                        | 0x35                          | 0000               |                     |
| 0x16                          | 0000               |                        | 0x36                          | 0000               |                     |
| 0x17                          | 0000               |                        | 0x37                          | 0000               |                     |
| 0x18                          | 0000               |                        | 0x38                          | 0000               |                     |
| 0x19                          | 0000               |                        | 0x39                          | 0000               |                     |
| 0x1A                          | 0000               |                        | 0x3A                          | 0000               |                     |
| 0x1B                          | 0000               |                        | 0x3B                          | 0000               |                     |
| 0x1C                          | 0000               |                        | 0x3C                          | 0000               |                     |
| 0x1D                          | 0000               |                        | 0x3D                          | 0000               |                     |
| 0x1E                          | 0000               |                        | 0x3E                          | 0100               | Interrupt Pin       |



PCI to Single Printer Port

## MCS9805CV EEPROM Key Locations

| Description          | EEPROM Address<br>Location | Word/Byte Data |
|----------------------|----------------------------|----------------|
| Device ID            | 0x00                       | 9805           |
| Vendor ID            | 0x02                       | 9710           |
| Class Code           | 0x08                       | 0780           |
| Class Code Interface | 0x0A (MS Byte)             | 00             |
| Revision ID          | 0x0A (LS Byte)             | 01             |
| Header Type          | 0x0C (LS Byte)             | 00             |
| Subsystem ID         | 0x2C                       | 0010           |
| Subsystem Vendor ID  | 0x2E                       | 1000           |
| Interrupt Pin        | 0x3E                       | 01             |

The MCS9805 EEPROM controller reads the least significant byte first and then the most significant byte in 16-bit format. Therefore, when writing to the EEPROM, the least significant byte is written first, followed by the most significant byte. For example, the value 9805 would be written as 05 98.

Changing the Device ID, Vendor ID, and Subsystem Vendor ID values requires corresponding changes in the device drivers to ensure proper functioning of the MCS9805CV. These fields can be customized to meet user requirements. The Subsystem Vendor ID value can be changed to arrive at a different product configuration using the EEPROM as shown below.

Product Type: Subsystem Vendor ID PCI to 1 Parallel (1P): 0010

Use default values for all other locations in the EEPROM.

PCI to Single Printer Port



## **Parallel Port Registers**

| CS | A2 | A1 | A0 | Register       | Bit-7  | Bit-6         | Bit-5  | Bit-4               | Bit-3         | Bit-2                | Bit-1        | Bit-0          |
|----|----|----|----|----------------|--------|---------------|--------|---------------------|---------------|----------------------|--------------|----------------|
| Y  | 0  | 0  | 0  | DPR            | PD7    | PD6           | PD5    | PD4                 | PD3           | PD2                  | PD1          | PD0            |
| Y  | 0  | 0  | 1  | DSR            | nBUSY  | nACK          | PE     | SLCT                | nFAULT        | INT<br>State         | "0"          | EPP<br>TIMEOUT |
| Y  | 0  | 1  | 0  | DCR            | "0"    | "0"           | DIR    | INTA                | SLCTIN        | nINIT                | AUTOFDX      | STROBE         |
| Y  | 0  | 1  | 1  | EPP<br>Address | ADD-7  | ADD-6         | ADD-5  | ADD-4               | ADD-3         | ADD-2                | ADD-1        | ADD-0          |
| Y  | 1  | 0  | 0  | EPP<br>Data    | DAT-7  | DAT-6         | DAT-5  | DAT-4               | DAT-3         | DAT-2                | DAT-1        | DAT-0          |
| Y  | 1  | 0  | 1  | Res            | Res    | Res           | Res    | Res                 | Res           | Res                  | Res          | Res            |
| Y  | 1  | 1  | 0  | Res            | Res    | Res           | Res    | Res                 | Res           | Res                  | Res          | Res            |
| Y  | 1  | 1  | 1  | Res            | Res    | Res           | Res    | Res                 | Res           | Res                  | Res          | Res            |
| W  | 0  | 0  | 0  | C-FIFO         | CDAT-7 | CDAT-6        | CDAT-5 | CDAT-4              | CDAT-3        | CDAT-2               | CDAT-1       | CDAT-0         |
| W  | 0  | 0  | 0  | CONF-A         | "1"    | "0"           | "0"    | "1"                 | "0"           | "1"                  | "0"          | "0"            |
| W  | 0  | 0  | 1  | CONF-B         | RLE    | RLE nINTA Pin |        | Interrupt Line      | Э             |                      | DMA Line     |                |
| W  | 0  | 1  | 0  | ECR            |        | Mode Select   |        | ErrIntrEn<br>Enable | DMA<br>Enable | Service<br>Interrupt | FIFO<br>Full | FIFO<br>Empty  |

Y: Standard Registers Chip Select W: Extended Registers Chip Select

## **Master Reset Conditions**

| Register | BIT-7 | BIT-6 | BIT-5 | BIT-4 | BIT-3 | BIT-2 | BIT-1 | BIT-0 |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| DPR      | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |
| DSR      | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 0     |
| DCR      | 0     | 0     | 0     | 0     | 1     | 1     | 0     | 0     |
| EPP      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| C-FIFO   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| CONF-A   | 1     | 0     | 0     | 1     | 0     | 1     | 0     | 0     |
| CONF-B   | 0     | Х     | 0     | 0     | 0     | 0     | 0     | 0     |
| ECR      | 0     | 0     | 1     | 1     | 0     | 1     | 0     | 1     |

## Data Register (DPR)

The Data register is cleared at initialization by RESET. During a write operation the contents of this register are buffered and output onto the PD7-PD0 pins. During a read operation PD7-PD0 pins are buffered and output to the host CPU.



PCI to Single Printer Port

## **Device Status Register**

**Note:** Bit-7 of this register is logically inverted from the state of the electrical signal appearing at the physical device pin. When the printer is BUSY, this bit will read back as a zero.

## DSR Bit-0: EPP Timeout

## 0 = Normal.

1 = 10µs timeout (EPP Mode only). Cleared by writing 1 into DSR register or consecutive reads (after the first read) always returns to "0".

## DSR Bit-1:

Not used, set to "0".

## DSR Bit-2: Interrupt State

- 0 = Interrupt Pending (nINTA follows the nACK pin when SPP mode is selected). Normal (no interrupt) when PS/2 mode is selected.
- 1 = Normal (no interrupt). This bit is set to "1" when the DSR is read.

## DSR Bit-3: nFAULT

- 0 = Printer reports error condition.
- 1 = Normal operation.

## DSR Bit-4: SLCT

- 0 = Printer is off-line.
- 1 = Printer is on-line.

## <u>DSR Bit-5: PE</u>

- 0 = Normal operation.
- 1 = Paper end/empty is detected.

## <u>DSR Bit-6: nACK</u>

- 0 = State of the nACK pin (nACK = low).
- 1 = State of the nACK pin (nACK = high).

## <u>DSR Bit-7: nBUSY</u>

- 0 = BUSY pin is high, printer is not ready to take data.
- 1 = BUSY pin is low, printer is ready to take data.

## **Device Control Register**

Note: Three bits (0, 1, & 3) of this register are logically inverted from the state of the electrical signals appearing at the physical device pins they control. The physical pins for these three bits are all Active-Low signals, so writing a "one" in this register will enable or activate the desired function. The physical pin associated with Bit-2 (nINIT) of this register is also an Active-Low electrical signal. This bit is not inverted however, so in order to start the Initialization process, that bit must be set LOW.

## DCR Bit-0: STROBE

- 0 = Sets the nSTROBE pin to high.
- 1 = Sets the nSTROBE pin to low. PD7-PD0 data are latched into printer.

## DCR Bit-1: AUTOFDX

- 0 = Sets the nAUTOFDX pin to high.
- Sets the nAUTOFDX pin to low. Printer generates auto line feed after each line is printed.

## DCR Bit-2: nINIT

- 0 = Sets the nINIT pin to low. Peripheral/printer starts its initialization routine.
- 1 = Sets the nINIT pin to high.

## DCR Bit-3: SLCTIN

- 0 =Sets the nSLCTIN pin to high.
- 1 = Sets the nSLCTIN pin to low. Selects the printer.

## <u>DCR Bit-4: INTA</u>

- 0 = Disables Printer interrupt function. nACK pin has no effect on the nINTA pin.
- 1 = Enables Printer interrupt function. The nINTA pin follows the nACK input pin during standard mode, latches high on the rising edge of the nACK when PS/2 mode is selected.

## DCR Bit-5: DIR

0 = PD7-PD0 pins are set to output mode. 1 = PD7-PD0 pins are set to input mode.

#### DCR Bits 7-6: Not used, set to "0".

PCI to Single Printer Port



## **EPP-Address Register**

Reading this register typically returns the address currently selected within the printer or external device.

Writing to this register typically selects a different address or function within the external device that will be the target for subsequent data transfers. A multifunction device might use different addresses for Printing, Scanning and Faxing operations.

All handshaking for the EPP Protocol is performed automatically by the hardware. Software does not need to manually toggle strobe bits, check for acknowledgement that the data was received, etc. The software only needs to read or write a single Byte to this location to perform the entire transaction. This allows significantly faster transfers when compared to SPP Mode transfers.

## **EPP-Data Register**

Reading this register returns the next Byte of data associated with the address currently selected within the printer or external device.

Writing to this register sends a Byte of data to the address currently selected within the printer or external device.

All handshaking for the EPP Protocol is performed automatically by the hardware. Software does not need to manually toggle strobe bits, check for acknowledgement that the data was received, etc. The software only needs to read or write a single Byte to this location to perform the entire transaction. This allows significantly faster transfers when compared to SPP Mode transfers.

## **C-FIFO Register**

This register is used in Mode "110" (FIFO Test).

The FIFO Test Mode allows writing data into, and reading data back out of the FIFO without actually transferring any data to the printer. All flags (FIFO Full, FIFO Empty, etc.) are active in this mode so all aspects of the FIFO operation can be observed.

This register is accessed using the BAR1 (W) Base Address Register.

## **Config-A Register**

This register is read only.

Reading this register always returns 10010100. The meaning of these bits are:

- Bit-7 = 1 Interrupts are Level-Triggered.
- Bit-6:4 = 001 The Port only accepts 8-bit words.
- Bit-3 = 0 Reserved
- Bit-2 = 1 The Byte currently in the transmitter pipeline affects the "FIFO Full" flag.
- Bit-1:0 = 00 In the case of an error, the unsent Byte is left in the FIFO.

This register is accessed using the BAR1 (W) Base Address Register.

This register can only be accessed when the Port is set to use Mode "111" (Config A/B Enable).



PCI to Single Printer Port

## **Config-B Register**

Returns information about the ECP capabilities.

<u>Bit 7: RLE</u> Set to "0". RLE is not supported.

## <u>Bit 6: nINTA Pin</u>

0 = The current nINTA state is low. 1 = The current nINTA state is high.

<u>Bit 5-3: Interrupt Line</u> Set to "000". The IRQ is set by the PCI System.

<u>Bit 2-0: DMA Line</u> Set to "000". DMA is not used.

This register is accessed using the BAR1 (W) Base Address Register.

This register can only be accessed when the Port is set to use Mode "111" (Config A/B Enable).

## **Extended Control Register (ECR)**

This register controls Mode Selection and returns Interrupt and FIFO Status. This register is accessed using the BAR1 (W) Base Address Register.

## ECR Bit-0: FIFO Empty

0 = One or more characters of data are in the FIFO. 1 = FIFO empty.

## ECR Bit-1: FIFO Full

0 = One or more locations in the FIFO are available. 1 = FIFO full.

## ECR Bit-2: Service Interrupt

- 1 = Disables the Service Interrupt. Writing a "1" to this bit will not cause an interrupt.
- 0 = Enables the Service Interrupt. A Service Interrupt occurs and this bit will be set to a "1" by the hardware when:
  - Port Direction = Output (DCR Bit-5 = 0) and there are write interrupt threshold (4 characters) or more Bytes free in the FIFO.
  - Port Direction = Input (DCR Bit-5 = 1) and there are read interrupt threshold (12 characters) or more Bytes to be read from the FIFO.

## ECR Bit-3: DMA Enable

The Parallel Port does not support DMA. Equivalent transfer speeds are obtained automatically by using PCI Bus Master "burst" transfers. This bit should always remain set to "0".

## ECR Bit-4: Error Interrupt Enable.

- 0 = Enable nFAULT interrupt. The nFAULT pin is used as a source of interrupts.
- 1 = Disable nFAULT interrupt.

## ECR Bit-7-5: Mode Select

The Parallel Port can operate in several different "Modes". These three bits are used to select the desired Mode.

| Bit-7 | Bit-6 | Bit-5 | Operating Mode    |
|-------|-------|-------|-------------------|
| 0     | 0     | 0     | SPP               |
| 0     | 0     | 1     | PS/2              |
| 0     | 1     | 0     | Not used          |
| 0     | 1     | 1     | ECP               |
| 1     | 0     | 0     | EPP               |
| 1     | 0     | 1     | Not used          |
| 1     | 1     | 0     | FIFO Test         |
| 1     | 1     | 1     | Config A/B Enable |

PCI to Single Printer Port



## Mode "000"

#### SPP/Centronics/Compatibility Mode

This mode operates in the forward direction only. The DIR bit is forced to "0" and PD7-PD0 are always set to the output direction. All control signals (nSTROBE etc.) are under software control. This mode defines the protocol used by most PCs to transfer data to a printer. Data is placed on the PD7-PD0 pins and the printer status is checked via the DSR register. If no error condition is flagged and the printer is not busy, software toggles the nSTROBE pin to latch the PD7-PD0 data into the printer. The printer/peripheral acknowledges receiving the data by pulsing the nACK and BUSY pins.

#### Nibble Mode

The Nibble mode is the most common way to get reverse channel data from a printer or peripheral. This mode is usually combined with the SPP/Centronics mode to create a bi-directional channel. Printer status bits are used as Nibble bits for the reverse channel data. The same Status bits are used for each Nibble, so special handshaking is required. When both Nibbles have been received, the PC must combine them to form the intended Byte of data.

| Pin    | Data Bit |
|--------|----------|
| BUSY   | Bit-7    |
| PE     | Bit-6    |
| SLCT   | Bit-5    |
| nFAULT | Bit-4    |
| BUSY   | Bit-3    |
| PE     | Bit-2    |
| SLCT   | Bit-1    |
| nFAULT | Bit-0    |

Bit usage for Nibble Mode

## Mode "001" PS/2, (Byte) Mode

The Byte Mode protocol is used to transfer bidirectional data via the PD7-PD0 pins. The FIFO is not used in this mode. The direction of the port is controlled with the DIR bit in the DCR register. PS/2 (Byte) Mode uses the same handshaking protocol as SPP Mode for data transfers.

## DCR Bit-5: DIR

 $\overline{0} = PD7 - PD0$  pins are set to output mode.

1 = PD7-PD0 pins are set to input mode.

#### Mode "011"

#### Extended Capability Port "ECP" Mode

ECP Mode is an advanced mode for communication with printers or peripherals. A 16-Byte FIFO provides a high performance bi-directional communication path. The following cycle types are provided in both the forward and reverse directions:

- Data cycle
- Command cycle
- Run-Length-Encoding (RLE)
- Channel Address

Run Length Encoding (RLE) provides data compression of up to 64:1. This is particularly useful for printers and peripherals that transfer raster images with long strings of identical data. In order for RLE to be enabled, both the host and peripheral must support it.

Channel addressing allows for multiple logical devices within a single physical unit, like Scanner/FAX/Printer in one physical package.



PCI to Single Printer Port

#### Mode "100"

#### Enhanced Parallel Port "EPP" Mode

In EPP Mode several control signals are used for different purposes than those described for the default SPP & PS/2 Modes. The nSLCTIN line is used as an "Address Strobe", and nAUTOFDX is used as the Data Strobe signal. The appropriate "Strobe" signal is automatically generated when data is read or written to one the EPP Specific registers. The nSTROBE signal is re-defined to indicate whether the current transfer is a write or read cycle. Separate I/O addresses are defined for "Data" and "Address" access, and when these locations are used handshaking is performed automatically by the chip.

## Mode "110"

#### FIFO Test Mode

In this mode the FIFO can be written and read, but no data will be transmitted to the printer. Whatever data is in the FIFO may be output on the PD7-PD0 pins, but no control signals will be generated to signal a transfer is to take place. All of the status Flags (FIFO Full, FIFO Empty, etc.) are operational in this mode, so the complete operation of the FIFO can be observed without actually affecting the external device.

## Mode "111"

## Config A/B Enable Mode

This mode must be selected whenever the Config-A or Config-B registers are accessed. The Config-A register uses the same I/O Address as the FIFO Register. Only allowing access to the Configuration Registers when this special Mode is selected prevents the two registers from interfering with each other.

## Mode Changes

After a hardware reset, PS/2 mode is selected as the default mode. When changing to a different mode, it is necessary to select mode 000 or 001 first, then any other desired mode configuration.

PCI to Single Printer Port



## **Electrical Characteristics**

| Absolute Maximum Ratings                     |                                    |
|----------------------------------------------|------------------------------------|
| Supply Voltage                               | 6 Volts                            |
| Voltage at any pin                           | GND - 0.3V to V $_{\rm cc}$ + 0.3V |
| Operating Temperature                        | 0 to +70 °C                        |
| Storage Temperature                          | -40 to +150 °C                     |
| ESD HBM (MIL-STD 883E Method 3015-7 Class 2) | 2000V                              |
| ESD MM (JEDEC EIA/JESD22 A115-A)             | 200V                               |
| CDM (JEDEC JESD22 C101-A)                    | 500V                               |
| Latch Up (JESD No. 78, March, 1997)          | 200 mA, 1.5 x VCC                  |
| Junction Temperature (Tj)                    | 150 °C                             |

## **Recommended Operating Conditions for PCI 5V Operation**

| Symbol | Parameter         | Min | Тур | Max | Unit | Condition |
|--------|-------------------|-----|-----|-----|------|-----------|
| Vcc    | Supply Voltage    | 4.5 | 5   | 5.5 | V    |           |
| Vin    | Input Voltage     | 0   |     | Vcc | V    |           |
| Icc    | Operating Current |     | 70  |     | mA   | No Load   |

## **General DC Characteristics**

| Symbol          | Parameter                         | Min | Тур | Max | Unit | Condition                  |
|-----------------|-----------------------------------|-----|-----|-----|------|----------------------------|
|                 | Package Dissipation               |     |     | 500 | mW   |                            |
| Ii <sub>L</sub> | Input Leakage Current             | -1  |     | 1   | μA   | No Pull-Up or<br>Pull-Down |
| Ioz             | Tri-State Leakage Current         | -10 |     | 10  | μA   |                            |
| Cin             | Input Capacitance                 |     | 3   |     | pF   |                            |
| Cout            | Output Capacitance                |     | 3   |     | pF   |                            |
| Cbid            | Bi-Directional Buffer Capacitance |     | 3   |     | pF   |                            |



PCI to Single Printer Port

## DC Electrical Characteristics (5.0V Operation)

Ambient Temp = 0 to +70 °C,  $V_{cc}$  = 4.75 to 5.25 V, Tj = 0 to +115 °C unless otherwise specified.

| Symbol          | Parameter                                           | Min          | Тур  | Мах          | Unit | Condition                                                     |
|-----------------|-----------------------------------------------------|--------------|------|--------------|------|---------------------------------------------------------------|
| Vi <sub>L</sub> | Input Voltage (Low)                                 |              |      | 0.3 *<br>Vcc | V    | CMOS                                                          |
| Vi <sub>H</sub> | Input Voltage (High)                                | 0.7 *<br>Vcc |      |              | V    | CMOS                                                          |
| Vi <sub>L</sub> | Input Voltage (Low)                                 |              |      | 0.8          | V    | TTL                                                           |
| Vi <sub>H</sub> | Input Voltage (High)                                | 2.0          |      |              | V    | TTL                                                           |
| Vt-             | Schmitt Trigger<br>Negative-Going Threshold Voltage |              | 1.84 |              | V    | CMOS                                                          |
| Vt+             | Schmitt Trigger<br>Positive-Going Threshold Voltage |              | 3.22 |              | V    | CMOS                                                          |
| Vt-             | Schmitt Trigger<br>Negative-Going Threshold Voltage |              | 1.10 |              | V    | TTL                                                           |
| Vt+             | Schmitt Trigger<br>Positive-Going Threshold Voltage |              | 1.87 |              | V    | TTL                                                           |
| Vo <sub>L</sub> | Output Voltage (Low)                                |              |      | 0.4          | V    | دان <mark>ا</mark> دی اور |
| Vo <sub>H</sub> | Output Voltage (High)                               | 3.5          |      |              | V    | IO <sub>H</sub> = 2 to 24<br>mA                               |
| Ri              | Input Pull-Up/Pull-Down Resistance                  |              | 50   |              | KΩ   | Vi <sub>L</sub> = 0V or<br>Vi <sub>H</sub> = Vcc              |







PCI to Single Printer Port

## **IMPORTANT NOTICE**

MosChip Semiconductor Technology, LTD products are not authorized for use as critical components in life support devices or systems. Life support devices are applications that may involve potential risks of death, personal injury or severe property or environmental damages. These critical components are semiconductor products whose failure to perform can be reasonably expected to cause the failure of the life support systems or device, or to adversely impact its effectiveness or safety. The use of MosChip Semiconductor Technology LTD's products in such devices or systems is done so fully at the customer risk and liability.

As in all designs and applications it is recommended that the customer apply sufficient safeguards and guard bands in both the design and operating parameters. MosChip Semiconductor Technology LTD assumes no liability for customer's applications assistance or for any customer's product design(s) that use MosChip Semiconductor Technology, LTD's products.

MosChip Semiconductor Technology, LTD warrants the performance of its products to the current specifications in effect at the time of sale per MosChip Semiconductor Technology, LTD standard limited warranty. MosChip Semiconductor Technology, LTD imposes testing and quality control processes that it deems necessary to support this warranty. The customer should be aware that not all parameters are 100% tested for each device. Sufficient testing is done to ensure product reliability in accordance with MosChip Semiconductor Technology LTD's warranty.

MosChip Semiconductor Technology, LTD believes the information in this document to be accurate and reliable but assumes no responsibility for any errors or omissions that may have occurred in its generation or printing. The information contained herein is subject to change without notice and no responsibility is assumed by MosChip Semiconductor Technology, LTD to update or keep current the information contained in this document, nor for its use or for infringement of patent or other rights of third parties. MosChip Semiconductor Technology, LTD to update or keep current the information contained in this document, nor for its use or for infringement of patent or other rights of third parties. MosChip Semiconductor Technology, LTD does not warrant or represent that any license, either expressed or implied, is granted to the user.



| Revision History |                                                                                                                                  |              |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------|--|
| Revision         | Changes                                                                                                                          | Date         |  |
| 1.0              | Initial Release.                                                                                                                 | Jul-2000     |  |
| 2.0              | Revised Data Sheet Format.                                                                                                       | 22-May-2006  |  |
| 2.1              | Switched to new Page-1 Layout.                                                                                                   | 30-May-2006  |  |
| 2.2              | Removed text about 5V tolerant serial and PCI interfaces.                                                                        | 25-July-2006 |  |
| 2.3              | Features list updated.<br>EEPROM contents added.<br>Electrical characteristics updated.<br>Package dimensions in inches removed. | 23-July-2007 |  |