

### Features

- USB Specification 1.1 Compliant
- Single 5V Operation
- Low Power
- On-Chip Voltage Regulator
- Single Serial Port
  - Supports up to 920 Kbps Serial Data Rate
  - Supports 5, 6, 7, & 8-bit Data Widths
  - Supports 1, 1.5, & 2 Stop Bits
  - Supports Even, Odd, Mark, Space and None parities
- Single Printer Port Interface
- Internal Power-On Reset
- 2KV In-Circuit ESD protection for lower cost of external components
- Available in 48-Pin QFP Package

#### Applications

- Monitoring Equipment
- High-Speed Modems
  - Printer Server
  - Serial Networking
  - Printer Interface

### **Application Note**

• AN-7715

### **Evaluation Board**

MCS7715-EVB

## **General Description**

The MCS7715 controller provides bridging between the Universal Serial Bus (USB) port, an enhanced UART, and a Parallel Printer port. This device contains all the necessary logic to communicate with the host computer via the USB bus. It supports Printers with hardware accelerated SPP mode.

The MCS7715 contains a 3.3V regulator, operates in Bus-Powered mode, and has a reduced frequency (6 MHz) crystal oscillator.

This combination of features allows significant cost savings in system design along with straightforward implementation of Serial Port and Parallel Port functionality into PC peripherals using the host's USB port.

| Ordering Information              |
|-----------------------------------|
| Commercial Grade (0° C to +70° C) |

MCS7715CQ-GR 48-LQFP RoHS











## **Pin Assignments**

| Pin Name | Pin | Туре | Description                                                                                                                                                                                                                                                                                                  |  |  |  |
|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| XTAL1    | 3   | I    | Crystal Oscillator input, or External Clock input pin (6 MHz).<br>This signal input is used in conjunction with XTAL2 to form a<br>feedback circuit for the internal timing. Two (10 pF) external<br>capacitors connected from each side of the crystal to GND are<br>required to form a Crystal Oscillator. |  |  |  |
| XTAL2    | 4   | 0    | Crystal Oscillator output. See XTAL1 description.                                                                                                                                                                                                                                                            |  |  |  |
| TSTPLL   | 6   | I    | Test Mode (active low, internal pull-up).<br>When this pin is tied to GND, the internal PLL is bypassed and an<br>external 48 MHz clock is used as the reference clock.                                                                                                                                      |  |  |  |
| TSTMODE  | 7   | I    | Internal Test Mode (active low, internal pull-up).<br>When this pin is tied to GND, the Internal Test Mode is enabled.                                                                                                                                                                                       |  |  |  |
| DM       | 9   | I/O  | Upstream USB port differential Data Minus (D-), analog.                                                                                                                                                                                                                                                      |  |  |  |
| DP       | 10  | I/O  | Upstream USB port differential Data Plus (D+), analog.                                                                                                                                                                                                                                                       |  |  |  |
| RESET    | 12  | Ι    | System Reset (active high).<br>Resets all internal registers, sequencers, and signals to a consistent<br>state. Connect to GND to use the internal Power-On-Reset circuit.                                                                                                                                   |  |  |  |
| nCD      | 15  | I    | Carrier-Detect signal.<br>When low, this indicates that the modem or data set has detected<br>the Data Carrier. nCD has no effect on the transmitter.                                                                                                                                                        |  |  |  |
| nDSR     | 18  | I    | Data-Set-Ready signal.<br>When low, this indicates that the modem or data set is ready<br>to establish a communication link. nDSR has no effect on the<br>transmitter or receiver.                                                                                                                           |  |  |  |
| RX       | 19  | I    | UART Serial Data Input.                                                                                                                                                                                                                                                                                      |  |  |  |
| nRTS     | 20  | 0    | Request-To-Send signal.<br>It is set high (inactive) after a hardware reset or during internal loop-<br>back mode. When low, this indicates that the UART is ready to<br>exchange data.                                                                                                                      |  |  |  |
| SLCT     | 22  | I    | Peripheral/Printer Selected (internal pull-up).<br>This pin is set high by the peripheral/printer when it is selected.                                                                                                                                                                                       |  |  |  |
| PE       | 23  | I    | Paper Empty (internal pull-up).<br>This pin is set high by the peripheral/printer when printer paper is<br>empty.                                                                                                                                                                                            |  |  |  |
| BUSY     | 24  | Ι    | Peripheral/Printer Busy (internal pull-up).<br>This pin is set high by the peripheral/printer when the printer or<br>peripheral is not ready to accept data.                                                                                                                                                 |  |  |  |
| nACK     | 25  | I    | Peripheral/Printer data Acknowledge (internal pull-up).<br>This pin is set low by the peripheral/printer to indicate a successful data transfer has taken place.                                                                                                                                             |  |  |  |
| PD7      | 26  | I/O  | Parallel printer port Data bit 7.                                                                                                                                                                                                                                                                            |  |  |  |



| Pin Name | Pin                                   | Туре | Description                                                                                                                                                                                                                                                                                        |  |  |
|----------|---------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PD6      | 27                                    | I/O  | Parallel printer port Data bit 6.                                                                                                                                                                                                                                                                  |  |  |
| ТХ       | 28                                    | 0    | UART Serial Data Output.                                                                                                                                                                                                                                                                           |  |  |
| PD5      | 29                                    | I/O  | Parallel printer port Data bit 5.                                                                                                                                                                                                                                                                  |  |  |
| PD4      | 32                                    | I/O  | Parallel printer port Data bit 4.                                                                                                                                                                                                                                                                  |  |  |
| PD3      | 33                                    | I/O  | Parallel printer port Data bit 3.                                                                                                                                                                                                                                                                  |  |  |
| nSLCTIN  | 34                                    | I/O  | Peripheral/Printer Select (open-drain).<br>Selects the peripheral/printer when it is set low.                                                                                                                                                                                                      |  |  |
| PD2      | 35                                    | I/O  | Parallel printer port Data bit 2.                                                                                                                                                                                                                                                                  |  |  |
| nINIT    | 36                                    | I/O  | Initialize the peripheral/printer (open drain).<br>When set low, the peripheral/printer starts its initialization routine.                                                                                                                                                                         |  |  |
| PD1      | 37                                    | I/O  | Parallel printer port Data bit 1.                                                                                                                                                                                                                                                                  |  |  |
| nFAULT   | 38                                    | I    | Peripheral/Printer data error (internal pull-up).<br>This pin is set low by the peripheral/printer during an error condition.                                                                                                                                                                      |  |  |
| PD0      | 40                                    | I/O  | Parallel printer port Data bit 0.                                                                                                                                                                                                                                                                  |  |  |
| nAUTOFDX | 41                                    | I/O  | Peripheral/Printer Auto Feed (open-drain).<br>Continuous autofed paper is selected when this pin is set low.                                                                                                                                                                                       |  |  |
| nSTROBE  | 42                                    | I/O  | Peripheral/Printer data Strobe (open drain).<br>Data is latched into the peripheral/printer when the nSTROBE is low.                                                                                                                                                                               |  |  |
| nCTS     | 44                                    | I    | Clear-To-Send signal.<br>When low, this indicates that the modem or data set is ready to<br>exchange data. nCTS has no effect on the transmitter.                                                                                                                                                  |  |  |
| nDTR     | 45                                    | 0    | Data-Terminal-Ready signal.<br>It is set high (inactive) after a hardware reset or during internal loop-<br>back mode. When low, this output indicates to the modem or data<br>set that the UART is ready to establish a communication link. nDTR<br>has no effect on the transmitter or receiver. |  |  |
| nRI      | 46                                    | I    | Ring-In detect signal.                                                                                                                                                                                                                                                                             |  |  |
| VOUT     | 48                                    | PWR  | +3.3V Voltage Regulator output.                                                                                                                                                                                                                                                                    |  |  |
| GND      | 5, 8, 13,<br>14, 17,21,<br>30, 39, 47 | PWR  | Power and Signal Ground.                                                                                                                                                                                                                                                                           |  |  |
| 3.3V     | 2, 11, 16,<br>31, 43                  | PWR  | Device Supply Inputs.<br>All should be connected to the VOUT pin.<br>VOUT voltage is gated by RESET.                                                                                                                                                                                               |  |  |
| 5V       | 1                                     | PWR  | Main Power Input.<br>Connect to USB VBUS or local VDD.                                                                                                                                                                                                                                             |  |  |

Note: All names with "n" prefix are active low.



## **USB** Description

### Analog Transceivers

The on-chip transceivers are connected directly to USB cables through external series resistors. They transmit and receive serial data at both full-speed (12Mbit/s) and low-speed (1.5Mbit/s) data rates. Slew rates are automatically adjusted according to the speed of the device connected and lie within the range defined in the USB Specification Rev. 1.1.

### Serial Interface Engine

This engine implements the complete USB protocol layer including: parallel /serial conversion, synchronization pattern recognition, CRC checking/generation, bit (de)stuffing, packet identifier (PID) verification/generation, address recognition and handshake evaluation/generation.

### **Bit Clock Recovery**

The bit clock recovery circuit recovers the clock from the incoming USB data stream using 4x over sampling. It is able to track in the presence of jitter and frequency drift as specified by the USB Specification Rev. 1.1.

### 3.3V Source

A 5V to 3.3V DC-DC regulator is integral to the chip relieving the need for a +3.3V source. It supplies the analog transceivers and internal logic and can be used to supply the  $1.5k\Omega$  pull-up resistor on the DP line of the upstream connection.

### PLL Clock Multiplier

An integral Phase-Locked Loop (PLL) performs 6 to 48MHz clock multiplication and requires no external components except the crystal. This allows for the use of low-cost 6MHz crystals which reduce high frequency radiated Electro-Magnetic Interference (EMI).



### **Host Requests**

All standard USB requests from the host are handled via Control Endpoint-0. The Control Endpoint can handle a maximum of 8 Bytes per transfer.

This table shows the supported standard USB requests.

**Note:** the USB data transmission order is Least Significant Bit (LSB) first. In the following tables Multi-Byte variables are displayed least significant Byte first.

#### **Standard USB Requests**

|                                            | bmRequestType      | bRequest | wValue    | wIndex     | wLength   |                                                       |  |
|--------------------------------------------|--------------------|----------|-----------|------------|-----------|-------------------------------------------------------|--|
| RequestName                                | Byte 0 [7:0] (bin) | Byte 1   | Byte 2, 3 | Byte 4, 5  | Byte 6, 7 | Data                                                  |  |
|                                            |                    | (hex)    | (hex)     | (hex)      | (hex)     |                                                       |  |
| Address                                    |                    |          |           |            |           |                                                       |  |
| Set Address                                | X000 0000          | 05       | address** | 00,00      | 00,00     | none                                                  |  |
| Configuration                              |                    |          |           |            |           |                                                       |  |
| Get Configuration                          | 1000 0000          | 08       | 00,00     | 00,00      | 01,00     | Configuration Value = 0x01                            |  |
| Set Configuration-0                        | X000 0000          | 09       | 00,00     | 00,00      | 00,00     | none                                                  |  |
| Set Configuration-1                        | X000 0000          | 09       | 01,00     | 00,00      | 00,00     | none                                                  |  |
| Descriptor                                 |                    |          |           |            |           |                                                       |  |
| Get Configuration Descriptor               | 1000 0000          | 06       | 00,02     | 00,00      | length*** | Configuration, Interface, and<br>Endpoint Descriptors |  |
| Get Device Descriptor                      | 1000 0000          | 06       | 00,01     | 00,00      | length*** | Device Descriptor                                     |  |
| Feature                                    |                    |          |           |            |           |                                                       |  |
| Clear Feature<br>(REMOTE_WAKEUP)           | X000 0000          | 01       | 01,00     | 00,00      | 00,00     | none                                                  |  |
| Clear Endpoint (1) Feature<br>(HALT/STALL) | X000 0010          | 01       | 00,00     | 81,00      | 00,00     | none                                                  |  |
| Status                                     |                    |          |           |            |           |                                                       |  |
| Get Device Status                          | 1000 0000          | 00       | 00,00     | 00,00      | 02,00     | Device Status                                         |  |
| Get Interface Status                       | 1000 0001          | 00       | 00,00     | 00,00      | 02,00     | zero                                                  |  |
| Get Endpoint (0) Status                    | 1000 0010          | 00       | 00,00     | 00/80, 00* | 02,00     | Endpoint-0 Status                                     |  |
| Get Endpoint (1) Status                    | 1000 0010          | 00       | 00,00     | 81,00      | 02,00     | Endpoint-1 Status                                     |  |

\* The MSB specifies endpoint direction: 0 = OUT, 1 = IN. Either value is accepted.

\*\* Device Address: 0 to 127

\*\*\* Returned Value (in Bytes)

### **Standard USB Descriptors**

These are the supported Standard USB Descriptors:

- Device
- Configuration
- Interface
- Endpoint



|                   | Device Descriptors                 |   |                |                              |  |  |  |  |
|-------------------|------------------------------------|---|----------------|------------------------------|--|--|--|--|
| Offset<br>(Bytes) | ) Field Name Size Va<br>(Bytes) (h |   | Value<br>(hex) | Comments                     |  |  |  |  |
| 0                 | bLength                            | 1 | 12             | Descriptor Length = 18 Bytes |  |  |  |  |
| 1                 | bDescriptorType                    | 1 | 01             | Type = DEVICE                |  |  |  |  |
| 2                 | bcdUSB                             | 2 | 10,01          | USB Specification Rev-1.1    |  |  |  |  |
| 4                 | bDeviceClass                       | 1 | FF             | Vendor Class                 |  |  |  |  |
| 5                 | bDeviceSubClass                    | 1 | 00             | n/a                          |  |  |  |  |
| 6                 | bDeviceProtocol                    | 1 | FF             | Vendor Class                 |  |  |  |  |
| 7                 | bMaxPacketSize0                    | 1 | 08             | Packet Size = 8 Bytes        |  |  |  |  |
| 8                 | idVendor                           | 2 | 10,97          | the Vendor-ID (9710)         |  |  |  |  |
| 10                | idProduct                          | 2 | 15,77          | the MCS7715 Product-ID       |  |  |  |  |
| 12                | bcdDevice                          | 2 | 00,01          | the silicon revision (1.0)   |  |  |  |  |
| 14                | iManufacturer                      | 1 | 00             | no manufacturer string       |  |  |  |  |
| 15                | iProduct                           | 1 | 00             | no product string            |  |  |  |  |
| 16                | iSerialNumber                      | 1 | 00             | no serial number string      |  |  |  |  |
| 17                | bNumConfigurations                 | 1 | 01             | one configuration            |  |  |  |  |

### **Configuration Descriptors**

| Offset<br>(Bytes) | Field Name      | Size<br>(Bytes) | Value<br>(hex) | Comments                                                                                   |
|-------------------|-----------------|-----------------|----------------|--------------------------------------------------------------------------------------------|
| 0                 | bLength         | 1               | 09             | Descriptor Length = 9 Bytes                                                                |
| 1                 | bDescriptorType | 1               | 02             | Type = CONFIGURATION                                                                       |
| 2                 | wTotalLength    | 2               | 35,00          | Combined Length of Configuration,<br>+ Interface, + all Endpoint Descriptors<br>(53 Bytes) |
| 4                 | bNumInterfaces  | 1               | 01             | one Interface                                                                              |
| 5                 | bConfiguration  | 1               | 01             | Configuration Value = 1                                                                    |
| 6                 | iConfiguration  | 1               | 00             | no configuration string                                                                    |
| 7                 | bmAttributes    | 1               | A0             | Bus-Powered with remote wake-up                                                            |
| 8                 | MaxPower        | 1               | 32             | 100mA default                                                                              |

#### **Interface Descriptors**

| Offset<br>(Bytes) | Field Name         | Size<br>(Bytes) | Value<br>(hex) | Comments                    |
|-------------------|--------------------|-----------------|----------------|-----------------------------|
| 0                 | bLength            | 1               | 09             | Descriptor Length = 9 Bytes |
| 1                 | bDescriptorType    | 1               | 04             | Type = INTERFACE            |
| 2                 | bInterfaceNumber   | 1               | 00             | n/a                         |
| 3                 | bAlternateSetting  | 1               | 00             | no alternate setting        |
| 4                 | bNumEndpoints      | 1               | 05             | five Endpoints              |
| 5                 | bInterfaceClass    | 1               | FF             | Vendor Class                |
| 6                 | bInterfaceSubClass | 1               | 00             | n/a                         |
| 7                 | bInterfaceProtocol | 1               | FF             | Vendor Class                |
| 8                 | bInterface         | 1               | 00             | no interface string         |



## **Endpoint Descriptions**

There are five end points apart from the Control Endpoint

044-44

| Endpoint | Туре                                   | Function              | Size     |
|----------|----------------------------------------|-----------------------|----------|
| 0        | Control Endpoint Default Functionality |                       |          |
| 1        | Bulk-In Parallel Printer Port          |                       | 32Bytes  |
| 2        | Bulk-Out                               | Parallel Printer Port | 32 Bytes |
| 3        | Bulk-In                                | Serial Port           | 64 Bytes |
| 4        | Bulk-Out                               | Serial Port           | 32 Bytes |
| 5        | Interrupt                              | Status Endpoint       | 4 Bytes  |

| Endpoint        |
|-----------------|
| Descriptor #1   |
| Bulk-In         |
| (Parallel Port) |

Endpoint Descriptor #2 Bulk-Out (Parallel Port)

| (Bytes) | Field Name       | (Bytes) | (hex) | Comments                    |
|---------|------------------|---------|-------|-----------------------------|
| 0       | bLength          | 1       | 07    | Descriptor Length = 7 Bytes |
| 1       | bDescriptorType  | 1       | 05    | Type = ENDPOINT             |
| 2       | bEndpointAddress | 1       | 81    | Endpoint-1, direction: IN   |
| 3       | bmAddress        | 1       | 02    | Bulk Endpoint               |
| 4       | wMaxPacketSize   | 2       | 20,00 | Packet Size = 32 Bytes      |
| 6       | bInterval        | 1       | FF    | Polling Interval (255mS)    |

Value

0:

| Offset<br>(Bytes) | Field Name       | Size<br>(Bytes) | Value<br>(hex) | Comments                    |
|-------------------|------------------|-----------------|----------------|-----------------------------|
| 0                 | bLength          | 1               | 07             | Descriptor Length = 7 Bytes |
| 1                 | bDescriptorType  | 1               | 05             | Type = ENDPOINT             |
| 2                 | bEndpointAddress | 1               | 02             | Endpoint-2, direction: OUT  |
| 3                 | bmAddress        | 1               | 02             | Bulk Endpoint               |
| 4                 | wMaxPacketSize   | 2               | 20,00          | Packet Size = 32 Bytes      |
| 6                 | bInterval        | 1               | FF             |                             |



Endpoint Descriptor #3 Bulk-In (Serial Port)

| Offset<br>(Bytes) | Field Name       | Size<br>(Bytes) | Value<br>(hex) | Comments                    |
|-------------------|------------------|-----------------|----------------|-----------------------------|
| 0                 | bLength          | 1               | 07             | Descriptor Length = 7 Bytes |
| 1                 | bDescriptorType  | 1               | 05             | Type = ENDPOINT             |
| 2                 | bEndpointAddress | 1               | 83             | Endpoint-3, direction: IN   |
| 3                 | bmAddress        | 1               | 02             | Bulk Endpoint               |
| 4                 | wMaxPacketSize   | 2               | 40,00          | Packet Size = 64 Bytes      |
| 6                 | bInterval        | 1               | 01             | Polling Interval (1mS)      |

Endpoint Descriptor #4 Bulk-Out (Serial Port)

| Offset<br>(Bytes) | Field Name       | Size<br>(Bytes) | Value<br>(hex) | Comments                    |
|-------------------|------------------|-----------------|----------------|-----------------------------|
| 0                 | bLength          | 1               | 07             | Descriptor Length = 7 Bytes |
| 1                 | bDescriptorType  | 1               | 05             | Type = ENDPOINT             |
| 2                 | bEndpointAddress | 1               | 04             | Endpoint-4, direction: OUT  |
| 3                 | bmAddress        | 1               | 02             | Bulk Endpoint               |
| 4                 | wMaxPacketSize   | 2               | 20,00          | Packet Size = 32 Bytes      |
| 6                 | bInterval        | 1               | FF             |                             |



|                 | Offset<br>(Bytes) | Field Name       | Size<br>(Bytes) | Value<br>(hex) | Comments                    |
|-----------------|-------------------|------------------|-----------------|----------------|-----------------------------|
|                 | 0                 | bLength          | 1               | 07             | Descriptor Length = 7 Bytes |
| Endpoint        | 1                 | bDescriptorType  | 1               | 05             | Type = ENDPOINT             |
| Descriptor #5   | 2                 | bEndpointAddress | 1               | 87             | Endpoint-7, direction: IN   |
| Status Endpoint | 3                 | bmAddress        | 1               | 03             | Interrupt Endpoint          |
|                 | 4                 | wMaxPacketSize   | 2               | 04,00          | Packet Size = 4 Bytes       |
|                 | 6                 | bInterval        | 1               | 01             | Polling Interval (1mS)      |

### **Status Endpoint:**

The Status Endpoint returns 4 Bytes every 1 millisecond. These four Bytes are status information of the Parallel Printer port and the Serial port.

- Byte-1: Interrupt Identification Register of the Serial port (IIR)
- Byte-2: Reserved (Unused)
- Byte-3: Device Status Register of the Parallel Printer port (DSR)
- Byte-4: FIFO status of both the Parallel Printer port and the Serial port.

#### Description for Byte-4 of Status Endpoint.

| Bit[7]   | Bit[6]   | Bit[5]              | Bit[4]               | Bit[3]              | Bit[2]             | Bit[1]             | Bit[0]            |
|----------|----------|---------------------|----------------------|---------------------|--------------------|--------------------|-------------------|
| Reserved | Reserved | SerInFifo<br>Status | SerOutFifo<br>Status | ParOutFifo<br>Empty | ParOutFifo<br>Full | ParInFifo<br>Empty | ParInFifo<br>Full |

| Bit               | Description                                           |                         |
|-------------------|-------------------------------------------------------|-------------------------|
| ParInFifo Full    | 1 Indicates the Bulk-In FIFO is full.                 | (Parallel Printer Port) |
| ParInFifo Empty   | 1 Indicates the Bulk-In FIFO is empty.                | (Parallel Printer Port) |
| ParOutFifo Full   | 1 Indicates the Bulk-Out FIFO is full.                | (Parallel Printer Port) |
| ParOutFifo Empty  | 1 Indicates the Bulk-Out FIFO is empty.               | (Parallel Printer Port) |
| SorOutEifo Status | 1 Indicates the Bulk-Out FIFO is empty.               | (Sorial Port)           |
| SerOulFilo Status | 0 indicates the Bulk-Out FIFO is filled with Tx Data. | (Senai Polit)           |
| Sorla Fife Status | 1 indicates the Bulk-In FIFO is filled with Rx Data.  | (Carial Dart)           |
| Sennriio Status   | 0 indicates the Bulk-In FIFO is empty.                | (Senai Port)            |



### **USB Vendor Specific Commands:**

The purpose of the vendor commands is to configure the Serial and Parallel Printer ports. The following tables provide information for the Vendor Specific Commands.

|                         | BmrequestType     | Brequest | Wvalue         | Windex | Wlength | Register Name  |
|-------------------------|-------------------|----------|----------------|--------|---------|----------------|
| PARALLEL PRINTER PORT   | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0000 | 0x0001  | PP_DPR         |
|                         | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0001 | 0x0001  | PP_DSR         |
|                         | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0002 | 0x0001  | PP_DCR         |
| Get Application         | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0008 | 0x0001  | PP_C_FIFO      |
| Vendor Specific Command | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0008 | 0x0001  | PP_CONF_A      |
| (Parallel Printer Port) | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x0009 | 0x0001  | PP_CONF_B      |
|                         | 0xC0              | 0x0D     | 0x01 <u>xx</u> | 0x000A | 0x0001  | PP_ECR         |
|                         | Proguesting       | Proquest | Wyoluo         | Windox | Wlongth | Pogiotor Namo  |
|                         | Ov40              |          |                |        |         |                |
|                         | 0x40              |          | 0x01xx         | 0x0000 | 0x0000  |                |
| Set Application         | 0x40              |          | 0x01xx         | 0x0001 | 0x0000  | PP_DSR         |
| Vendor Specific Command | 0x40              |          | 0x01xx         | 0x0002 | 0x0000  |                |
| (Parallel Printer Port) | 0x40              |          | 0x01xx         | 0x0008 | 0x0000  |                |
|                         | 0x40              |          | 0x01xx         | 0x0008 | 0x0000  | PP_CONF_A      |
|                         | 0x40              |          |                | 0x0009 | 0x0000  |                |
|                         | 0X40              | UXUE     | 0X01 <u>XX</u> | UXUUUA | 00000   | PP_ECK         |
|                         | Duran and a trans | Dramast  | 14/1-1-1-1-1   |        |         | De sieter News |
|                         | BmrequestType     | Brequest | wvalue         | windex | wiength | Register Name  |
| SERIAL PORT             | 0xC0              | 0x0D     | 0x02 <u>xx</u> | 0x0000 | 0x0001  |                |
| <u>OEMAET ONT</u>       | 0xC0              |          | 0x02 <u>xx</u> | 0X0001 | 0X0001  | SP_IER         |
|                         | 0xC0              | 0x0D     | 0x02xx         | 0X0002 | 0X0001  |                |
|                         | 0xC0              |          | 0x02 <u>xx</u> | 0X0003 | 0X0001  | SP_LCR         |
| Cot Application         | 0xC0              |          | 0x02xx         | 0X0004 | 0x0001  |                |
| Vender Specific Command | 0xC0              | 0x0D     | 0x02xx         | 0X0005 | 0X0001  | SP_LSR         |
|                         | 0xC0              |          | 0x02 <u>xx</u> | 0X0006 | 0X0001  | SP_MSR         |
| (Senai Port)            | 0xC0              |          | 0x02 <u>xx</u> | 0x0007 | 0x0001  | SP_SPR         |
|                         | 0xC0              |          | 0x02 <u>xx</u> | 00000  | 0x0001  | SP_DLL         |
|                         | UXCU              | UXUD     | 0X02 <u>XX</u> | 00001  | 0x0001  | SP_DLM         |
|                         | Duran and a trans | Deserves | Maria          |        |         | Desister News  |
|                         | Diffequest type   | Drequest | wvalue         | windex |         |                |
|                         | 0x40              | 0x0E     | 0x02 <u>xx</u> | 00000  | 0x0000  | SP_IHR         |
|                         | 0x40              |          | 0x02xx         | 000001 | 0x0000  | SP_IER         |
| Set Application         | 0x40              |          | 0x02xx         | 0x0002 | 0x0000  | SP_FCR         |
| Vender Specific Command | 0x40              |          | 0x02xx         | 0x0003 | 0x0000  | SP_LCR         |
| (Sorial Port)           | 0x40              |          | 0x02xx         | 0X0004 | 0x0000  | SP_MCR         |
|                         | 0x40              |          |                | 0x0005 | 00000   |                |
|                         | 0x40              |          | 0x02xx         | UXUUU6 | 00000   | SP_IVISK       |
|                         | 0x40              |          |                | 0x0007 | 0x0000  | SF_SPK         |
|                         | 0x40              |          | 0x02xx         | UXUUUU | 00000   | SP_DLL         |
|                         | 0x40              | UXUE     | 0x02 <u>xx</u> | UXUUU1 | 000000  | SP_DLM         |



### **Vendor Specific Command Parameters**

<u>Brequest</u>: specifies whether to Read or Write 0x0E = write to the application register. 0x0D = read from the application register.

Wvalue: Specifies the Application Number.

0x0100 is the application number for the Parallel Printer port

0x0200 is the application number for the Serial port

0x0000 is the application number provided for accessing the other control registers to control the Parallel Printer port and Serial port (i.e. Enabling the Higher Baud Rates, enabling the Auto hardware Flow Control, Setting the clock frequency, etc.)

xx specifies the Byte value to be written into the register.

Windex: Is the offset of the register to Read/Write.

<u>Wlength</u>: Is the length of the data we are going to read or write.



## UART Register Set:

The UART has 10 registers. Mapping is dependent on the Line Control Register (LCR).

| Name                                                                                                                                     | Offset                                           | R/W                                                                          | Bit[7]                                                                                | Bit[6]                                            | Bit[5]                                                                       | Bit[4]                                                           | Bit[3]                                                             | Bit[2]                        | Bit[1]    | Bit[0]   |
|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------|-----------|----------|
| THR                                                                                                                                      | 0                                                | W                                                                            |                                                                                       | Dat                                               | ta to be tran                                                                | smitted (Tra                                                     | ansmitting                                                         | Holding R                     | egister)  |          |
| RHR                                                                                                                                      | 0                                                | R                                                                            |                                                                                       |                                                   | Data to be I                                                                 | eceived (Re                                                      | eceiver Hol                                                        | aing Regi                     | Ster)     | DyDdy    |
|                                                                                                                                          | 1                                                |                                                                              |                                                                                       | Decer                                             | a d                                                                          | Sleep                                                            | Interrupt                                                          | RX Stat                       |           | RXRUY    |
| IER                                                                                                                                      | 1                                                | R/VV                                                                         |                                                                                       | Reserv                                            | ea                                                                           | Mode                                                             | Interrupt                                                          | Interrupt                     | Interrupt | Interrup |
|                                                                                                                                          |                                                  |                                                                              | R                                                                                     | HR                                                |                                                                              |                                                                  | IVIdSK                                                             | Flush                         | Flush     |          |
| FCR                                                                                                                                      | 2                                                | W                                                                            | Trigge                                                                                |                                                   | Rese                                                                         | erved                                                            | Reserved                                                           |                               |           | Enable   |
|                                                                                                                                          |                                                  |                                                                              | FIF                                                                                   |                                                   |                                                                              |                                                                  |                                                                    |                               |           | Interrup |
| ISR                                                                                                                                      | 2                                                | R                                                                            | Ena                                                                                   | bled                                              | Rese                                                                         | erved                                                            | Inte                                                               | rrupt Prior                   | rity      | Pending  |
| 1.00                                                                                                                                     | -                                                | 5                                                                            |                                                                                       | Tx                                                | Force                                                                        | Odd/Even                                                         | Parity                                                             | Stop                          |           | 1 onanış |
| LCR                                                                                                                                      | 3                                                | R/W                                                                          | DLE                                                                                   | Break                                             | Parity                                                                       | Parity                                                           | Enable                                                             | Bits                          | Data L    | ength    |
|                                                                                                                                          |                                                  |                                                                              |                                                                                       |                                                   | RTS/CTS                                                                      |                                                                  |                                                                    |                               |           |          |
| MCR                                                                                                                                      | 4                                                | R/W                                                                          | Res                                                                                   | erved                                             | Flow                                                                         | Loop                                                             | Unu                                                                | sed                           | RTS       | DTR      |
|                                                                                                                                          |                                                  |                                                                              |                                                                                       |                                                   | Control                                                                      |                                                                  |                                                                    |                               |           |          |
|                                                                                                                                          | F                                                | Р                                                                            | Data                                                                                  | Тx                                                | THR                                                                          | Rx                                                               | Framing                                                            | Parity                        | 0.000000  | יירטיים  |
| LOK                                                                                                                                      | 5                                                | к                                                                            | Error                                                                                 | Empty                                             | Empty                                                                        | Break                                                            | Error                                                              | Error                         | Overrun   | клкиу    |
| MCD                                                                                                                                      | 6                                                | D                                                                            |                                                                                       | DI                                                | DSD                                                                          | CT S                                                             | Delta                                                              | TEDI                          | Delta     | Delta    |
| IVISK                                                                                                                                    | 0                                                | К                                                                            | DCD                                                                                   | КI                                                | DSK                                                                          | 015                                                              | DCD                                                                | IERI                          | DSR       | CTS      |
| SPR                                                                                                                                      | 7                                                | R/W                                                                          |                                                                                       |                                                   |                                                                              | Scratch P                                                        | ad Registe                                                         | r                             |           |          |
| DLL<br>DLM                                                                                                                               | 0                                                | R/W<br>R/W                                                                   |                                                                                       |                                                   |                                                                              | Divisor La<br>Divisor La                                         | atch bits[7:0<br>tch bits[15:                                      | )]<br>8]                      |           |          |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:                                                                                           | 0                                                | R/W<br>R/W<br>TH<br>Dat                                                      | R<br>ta to be                                                                         | transm                                            | itted                                                                        | Divisor La<br>Divisor La                                         | atch bits[7:0<br>tch bits[15:                                      | )]<br>8]                      |           |          |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>ermissions                                                                             | 0<br>1                                           | R/W<br>R/W<br>TH<br>Dat<br>000<br>Wri                                        | R<br>ta to be<br>)<br>ite<br>R[7] =0                                                  | transm                                            | itted                                                                        | Divisor La<br>Divisor La                                         | atch bits[7:0<br>tch bits[15:                                      | )]<br>8]                      |           |          |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>ermissions<br>cess Cond                                                                | 0<br>1<br>:<br>dition:                           | R/W<br>R/W<br>Dat<br>000<br>Wri<br>LC                                        | R<br>ta to be<br>)<br>ite<br>R[7] =0<br>Bit[6]                                        | transm<br>, only w                                | itted                                                                        | Divisor La<br>Divisor La                                         | atch bits[7:0<br>tch bits[15:<br>cess this re                      | egister                       | Bit[1]    | Bitf(    |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>fset:<br>cess Conc                                                                     | 0<br>1<br>dition:<br>Bit[7]                      | R/W<br>R/W<br>Dat<br>000<br>Wri<br>LC                                        | R<br>ta to be<br>ite<br>R[7] =0<br>Bit[6]                                             | transm<br>, only w<br>Bit                         | itted<br>rite condit<br>5] Bir<br>Data                                       | Divisor La<br>Divisor La<br>on can acc<br>[4] B<br>to be trans   | atch bits[7:0<br>tch bits[15:<br>cess this re<br>it[3] I<br>mitted | )]<br>8]<br>egister<br>Bit[2] | Bit[1]    | Bit[(    |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>ermissions<br>cess Conc<br>egister:<br>escription:<br>fset:<br>ermissions              | 0<br>1<br>dition:<br>Bit[7]                      | R/W<br>R/W<br>TH<br>Dat<br>000<br>Wri<br>LC<br>RH<br>Dat<br>000<br>Rei       | R<br>ta to be<br>ite<br>R[7] =0<br>Bit[6]<br>R<br>ta to be<br>ad                      | transm<br>, only w<br>Bit]                        | itted<br>rite condit<br>5] Bir<br>Data                                       | Divisor La<br>Divisor La<br>ion can acc<br>t[4] B<br>to be trans | atch bits[7:0<br>tch bits[15:<br>cess this re<br>it[3] I<br>mitted | )]<br>8]<br>egister<br>Bit[2] | Bit[1]    | Bit[(    |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>ermissions<br>cess Cond<br>egister:<br>escription:<br>fset:<br>ermissions<br>cess Cond | 0<br>1<br>dition:<br>Bit[7]                      | R/W<br>R/W<br>TH<br>Dat<br>000<br>Wri<br>LC<br>RH<br>Dat<br>000<br>Rea<br>LC | R<br>ta to be<br>ite<br>R[7] =0<br>Bit[6]<br>R<br>ta to be<br>ad<br>R[7] =0           | transm<br>, only w<br>Bit<br>receive<br>, only re | iitted<br>rite conditi<br>5] Bin<br>Data                                     | Divisor La<br>Divisor La<br>ion can acc<br>t[4] B<br>to be trans | ess this re                                                        | egister<br>Bit[2]             | Bit[1]    | Bit[     |
| DLL<br>DLM<br>egister:<br>escription:<br>fset:<br>ermissions<br>cess Cond<br>scription:<br>fset:<br>ermissions<br>cess Cond              | 0<br>1<br>sition:<br>Bit[7]<br>dition:<br>Bit[7] | R/W<br>R/W<br>TH<br>Dat<br>000<br>Wri<br>LC<br>Rea<br>LC                     | R<br>ta to be<br>ite<br>R[7] =0<br>Bit[6]<br>R<br>ta to be<br>ad<br>R[7] =0<br>Bit[6] | transm<br>, only w<br>Bit<br>receive<br>, only re | itted<br>rite conditi<br>5] Bir<br>Data<br>ed<br>ed<br>ead conditi<br>5] Bir | Divisor La<br>Divisor La<br>ion can acc<br>[4] B<br>to be trans  | ess this re                                                        | •gister<br>Bit[2]             | Bit[1]    | Bit[     |

Copyright © 2002-2011 ASIX Electronics Corporation. All rights reserved.



## Interrupt Enable Register:

Serial channel interrupts are enabled using the Interrupt Enable Register (IER).

| Register:<br>Description<br>Offset:<br>Permission | ::<br>s: | IER<br>Interrupt Ena<br>001<br>Read/Write | able Regist | ter    |                   |                   |                   |                   |
|---------------------------------------------------|----------|-------------------------------------------|-------------|--------|-------------------|-------------------|-------------------|-------------------|
|                                                   | Bit[7]   | Bit[6]                                    | Bit[5]      | Bit[4] | Bit[3]            | Bit[2]            | Bit[1]            | Bit[0]            |
|                                                   |          |                                           |             | Sloop  | Modem             | Rx Stat           | THRE              | RxRdy             |
|                                                   |          | Reserved                                  |             | Mode   | Interrupt<br>Mask | Interrupt<br>Mask | Interrupt<br>Mask | Interrupt<br>Mask |

| Bit | Name                   | Description                                                                                                                   |
|-----|------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0   | RxRdy Interrupt Mask   | Logic 0 = Disable the Receiver Ready Interrupt<br>Logic 1 = Enable the Receiver Ready Interrupt                               |
| 1   | THRE Interrupt Mask    | Logic 0 = Disable the Transmitter Ready Interrupt<br>Logic 1 = Enable the Transmitter Ready Interrupt                         |
| 2   | Rx Stat Interrupt Mask | Logic 0 = Disable the Receiver Status Interrupt (Normal Mode)<br>Logic 1 = Enable the Receiver Status Interrupt (Normal Mode) |
| 3   | Modem Interrupt Mask   | Logic 0 = Disable the Modem Status Interrupt<br>Logic 1 = Enable the Modem Status Interrupt                                   |
| 4   | Sleep Mode             | Logic 0 = Disable Sleep-Mode<br>Logic 1 = Enable Sleep-Mode<br>(the internal clock of the channel is switched off)            |
| 5   | Reserved               | Reserved                                                                                                                      |
| 6   | Reserved               | Reserved                                                                                                                      |
| 7   | Reserved               | Reserved                                                                                                                      |



## **FIFO Control Register:**

The FCR controls the UART behavior in various modes.

| Register:<br>Description<br>Offset:<br>Permission | :<br>s: | FCR<br>FIFO Contro<br>010<br>Write | ol Register |        |          |        |        |        |
|---------------------------------------------------|---------|------------------------------------|-------------|--------|----------|--------|--------|--------|
|                                                   | Bit[7]  | Bit[6]                             | Bit[5]      | Bit[4] | Bit[3]   | Bit[2] | Bit[1] | Bit[0] |
|                                                   | R       | HR                                 | Deee        | much   | Deserved | Flush  | Flush  | Enable |
|                                                   | Triage  | er Level                           | Rese        | erved  | Reserved | THR    | RHR    | FIFO   |

| Bit  | Name                 | Description                                                                                                                                                                                                                                           |
|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Enable<br>FIFO Mode  | Logic 0 = Byte Mode<br>Logic 1 = FIFO Mode                                                                                                                                                                                                            |
| 1    | Flush<br>RHR         | Logic 0 = No change<br>Logic 1 = Flushes the contents of RHR. This is operative only in FIFO<br>Mode. The RHR is automatically flushed whenever changing<br>between Byte Mode and FIFO Mode. The bit will return to zero<br>after clearing the FIFOs. |
| 2    | Flush<br>THR         | Logic 0 = No change<br>Logic 1 = Flushes the content of the THR, in the same manner as FCR[1]<br>does the RHR                                                                                                                                         |
| 3    | Reserved             | Reserved                                                                                                                                                                                                                                              |
| 5, 4 | Reserved             | Reserved                                                                                                                                                                                                                                              |
| 7, 6 | RHR<br>Trigger Level | See the table below.                                                                                                                                                                                                                                  |

## FCR[7:6] RHR Trigger Level:

In 550 mode, the receiver FIFO trigger levels are defined using FCR[7:6]. The interrupt trigger level & flow control trigger level where appropriate are defined by L2 in the table below. L1 defines lower flow control trigger levels that introduce a hysteresis element in hardware RTS/CTS flow control.

In Byte Mode (450 Mode) the trigger levels are all set to 1.

| FCR[7:6] | 550 Mode<br>(FIFO = 16) |    |  |
|----------|-------------------------|----|--|
|          | <u>L1</u>               | L2 |  |
| 2'b00    | 1                       | 1  |  |
| 2'b01    | 1                       | 4  |  |
| 2'b10    | 1                       | 8  |  |
| 2'b11    | 1                       | 14 |  |



## Interrupt Status Register:

The source of the highest priority interrupt pending is indicated by the contents of the Interrupt Status Register (ISR). There are five sources of interrupts, and four levels of priority (1 is the highest) as tabulated below.

| Level | Interrupt Source                      | ISR[5:0]  |  |
|-------|---------------------------------------|-----------|--|
| -     | No interrupt pending                  | 6'b000001 |  |
| 1     | Receiver Status Error                 | 6'b000110 |  |
| 1     | or address bit detected in 9-bit mode | 0110000   |  |
| 2a    | Receiver Data Available               | 6'b000100 |  |
| 2b    | Receiver Time Out                     | 6'b001100 |  |
| 3     | Transmitter THR Empty                 | 6'b000010 |  |
| 4     | Modem Status Change                   | 6'b000000 |  |

Note: ISR[0] indicates whether any interrupt is pending

| Register:   |             | ISR    |        |  |  |  |  |  |
|-------------|-------------|--------|--------|--|--|--|--|--|
| Description | atus Regist | er     |        |  |  |  |  |  |
| Offset:     |             | 010    |        |  |  |  |  |  |
| Permission  | s:          | Read   |        |  |  |  |  |  |
|             | Bit[7]      | Bit[6] | Bit[5] |  |  |  |  |  |

| Bit[7] | Bit[6] | Bit[5]   | Bit[4]     | Bit[3] | Bit[2]    | Bit[1]  | Bit[0] |
|--------|--------|----------|------------|--------|-----------|---------|--------|
| FIF    | Os     | Interrup | t Priority | In     | Interrupt |         |        |
| Enal   | bled   | (Enhance | ed Mode)   |        |           | Pending |        |

### Interrupt Descriptions:

## Level1: Receiver Status Error

Normal Mode: This interrupt is active whenever any of the LSR[1], LSR[2], LSR[3] or LSR[4] are set. These flags are cleared following a read of the LSR. The interrupt is masked with IER[2].

### Level 2a: Receiver Data Available

The interrupt is active whenever the receiver FIFO level is above the interrupt trigger level.

### Level 2b: Receiver Time-Out

A receiver time out event, (which may cause an interrupt) will occur when all of the following conditions are true:

- The UART is in the FIFO Mode.
- There is data in the RHR
- There has been no read of the RHR for a period of time greater than the timeout period. The timeout period of time is greater than the time out period. The time out period is four times the character period (including start & stop bits) measured from the centre of the first stop bit of the first data item received.

Reading the first data item in RHR clears this interrupt.

#### Level 3: Transmitter Empty

This interrupt is set when the transmit FIFO level falls below the trigger level. It is cleared on the ISR read to Level-3 interrupt or by writing more data to the THR so that the trigger level is exceeded.

#### Level 4: Modem Change

This interrupt is set by the modem change flag (MSR[0], MSR[1], MSR[2] or MSR[3]) becoming active due to changes in the input modem lines. This interrupt is cleared following the read of the MSR register.



## Line Control Register:

The LCR specifies the data format that is common to both transmitter and receiver.

| Register:LCRDescription:Line Control RegisterOffset:011Permissions:Read/WriteAccess Condition:LCR[7] =0                                                                                                                                                                                                                                                                             |                                                                         |                                                                                                                             |                                |                                                      |        |                |                                                                              |        |        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------------------|--------|----------------|------------------------------------------------------------------------------|--------|--------|
|                                                                                                                                                                                                                                                                                                                                                                                     | Bit[7]                                                                  | Bit[6]                                                                                                                      | Bit[5]                         | Bit[4]                                               | Bit[3] | Bit[2          | 2] Bi                                                                        | t[1]   | Bit[0] |
|                                                                                                                                                                                                                                                                                                                                                                                     |                                                                         | Tx                                                                                                                          | Force                          | Odd/Even                                             | Parity | Numbe          | er of                                                                        | Dat    | a      |
|                                                                                                                                                                                                                                                                                                                                                                                     | DLE                                                                     | Break                                                                                                                       | Parity                         | Parity                                               | Enable | e Stop E       | Bits                                                                         | Leng   | th     |
| LCR[1:0]:                                                                                                                                                                                                                                                                                                                                                                           | Determines t                                                            | he data lengt                                                                                                               | h of serial                    | _                                                    |        |                |                                                                              |        |        |
|                                                                                                                                                                                                                                                                                                                                                                                     | characters.                                                             |                                                                                                                             |                                | _                                                    | LC     | R[1:0]         | Da                                                                           | ata Le | ngth   |
|                                                                                                                                                                                                                                                                                                                                                                                     |                                                                         |                                                                                                                             |                                |                                                      |        | 2'b00<br>2'b01 |                                                                              | 5 bits | S      |
| LCR[2]: D                                                                                                                                                                                                                                                                                                                                                                           | efines the nu                                                           | mber of stop                                                                                                                | bits per serial                |                                                      |        | 2'b10          |                                                                              | 7 bit  | s      |
|                                                                                                                                                                                                                                                                                                                                                                                     | character.                                                              |                                                                                                                             |                                |                                                      |        | 2'b11          |                                                                              | 8 bit  | S      |
| <ul> <li>LCR[5:3]: The selected parity type will be generated during transmission and checked by the receiver, which may produce a parity error as a result. In 9-bit mode parity is disabled and LCR[5:3] are ignored.</li> <li>LCR[2] Data Length Stop Bits         <ul> <li>0</li> <li>5,6,7,8</li> <li>1</li> <li>5</li> <li>1</li> <li>6,7,8</li> <li>2</li> </ul> </li> </ul> |                                                                         |                                                                                                                             |                                |                                                      |        |                |                                                                              | its    |        |
|                                                                                                                                                                                                                                                                                                                                                                                     | (SOU<br>comm<br>respo<br>to ens<br>longe<br>it to be<br>break           | T) low to alert<br>nunications ch<br>nsibility of the<br>sure that the b<br>r than the cha<br>e recognized<br>rather than d | ne<br>ver<br>for               | LCR[5:3]<br>3'bxx0<br>3'b001<br>3'b011<br>3'b101 Par |        |                | Parity Type<br>No parity<br>Odd parity<br>Even parity<br>ity bit forced to 1 |        |        |
| LCR[7]: D<br>L                                                                                                                                                                                                                                                                                                                                                                      | vivisor Latch E<br>ogic 0: Access<br>disabl<br>ogic 1: Access<br>enable | nable<br>ses to DLL ar<br>ed<br>ses to DLL ar<br>ed                                                                         | nd DLM regist<br>nd DLM regist | ers<br>ers                                           |        | I              | <u>ר מוונץ טונ ונ</u>                                                        |        |        |



## Line Status Register:

This register provides the status of the data transfer to the CPU.

| Register:<br>Description<br>Offset:<br>Permission<br>Access Col | n:<br>Is:<br>ndition: | LSR<br>Line Stat<br>101<br>Read<br>LCR[7] = | us Register<br>0, ACR[6] = 0 |        |         |        |         |        |
|-----------------------------------------------------------------|-----------------------|---------------------------------------------|------------------------------|--------|---------|--------|---------|--------|
|                                                                 | Bit[7]                | Bit[6]                                      | Bit[5]                       | Bit[4] | Bit[3]  | Bit[2] | Bit[1]  | Bit[0] |
|                                                                 | Data                  | Tx                                          | THR                          | Rx     | Framing | Parity | Overrup | DyDdy  |
|                                                                 | Error                 | Empty                                       | Empty                        | Break  | Error   | Error  | Ovenun  | RXRUY  |

| Bit | Name              | Description                                                               |
|-----|-------------------|---------------------------------------------------------------------------|
| 0   | RHR               | Logic 0 = RHR is empty                                                    |
| 0   | Data Available    | Logic 1 = RHR is not empty, data is available to be read                  |
|     |                   | Logic 0 = No overrun error                                                |
| 1   | RHR               | Logic 1 = Data was received when the RHR was full, An overrun             |
| '   | Overrun           | has occurred. The error is flagged when the data would                    |
|     |                   | normally have been transferred to the RHR.                                |
|     | Received Data     | Logic 0 = No parity error in received data, or 9th bit is "0" in 9-bit    |
| 2   | Dority Error      | mode.                                                                     |
|     | Failty Elloi      | Logic 1 = Data has been received that did not have correct parity         |
| 3   | Received Data     | Logic 0 = No framing error                                                |
| 5   | Framing Error     | Logic 1 = data has been received with an invalid stop bit.                |
| 4   | Received Break    | Logic 0 = No receiver break error                                         |
| -   | Error             | Logic 1 = the receiver received a break error                             |
| 5   | THR               | Logic 0 = Transmitter FIFO is not empty                                   |
| 0   | Empty             | Logic 1 = Transmitter FIFO is empty                                       |
|     | Transmitter & THR | Logic 0 = The transmitter is not idle                                     |
| 6   | Empty             | Logic 1 = THR is empty & the transmitter has completed the character      |
|     | Empty             | in the shift register and is in the idle mode                             |
|     |                   | Logic 0 = Either there are no receiver data errors in the FIFO, or it     |
| 7   | Receiver Data     | was cleared by earlier read of LSR                                        |
| 1   | Error             | Logic 1 = At least one parity error, framing error or break indication in |
|     |                   | the FIFO.                                                                 |

**Note :** A break condition occurs when the SIN line goes low and stays low through out the start, data, parity & first stop bits. One zero character associated with break flag set will be transferred to the RHR and the receiver will then wait until the SIN line returns high. The LSR[4] flag break flag is set when this data item gets to the top of the RHR and it is cleared following the read to the LSR.



| Modem Cor                                         | ntrol Reg             | jister:                     |                    |                                                                                                 |                                  |                                                 |                    |         |        |  |  |  |
|---------------------------------------------------|-----------------------|-----------------------------|--------------------|-------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------------------|--------------------|---------|--------|--|--|--|
| Register:<br>Description<br>Offset:<br>Permission | s:                    | MCR<br>Mode<br>100<br>Read/ | m Contı<br>Write   | ol Regi                                                                                         | ister                            |                                                 |                    |         |        |  |  |  |
|                                                   | Bit[7]                | Bit[6]                      | Bit                | [5]                                                                                             | Bit[4]                           | Bit[3]                                          | Bit[2]             | Bit[1]  | Bit[0] |  |  |  |
|                                                   |                       |                             |                    |                                                                                                 | 550                              | Mode                                            |                    |         |        |  |  |  |
|                                                   | Unused CTS/<br>Flow C |                             | RTS<br>ontrol      | Internal<br>Loop Back<br>Enable                                                                 | Out2<br>(Interrupt Enable)       | Out1                                            | RTS                | DTR     |        |  |  |  |
|                                                   |                       |                             |                    |                                                                                                 |                                  |                                                 |                    |         |        |  |  |  |
|                                                   | Bit Name              |                             |                    |                                                                                                 | Description                      |                                                 |                    |         |        |  |  |  |
|                                                   | 0                     | DT                          | R                  | Logic 0 = Forces DTR# output to inactive (high)<br>Logic 1 = Forces DTR# output to active (low) |                                  |                                                 |                    |         |        |  |  |  |
|                                                   | 1                     | RT                          | S                  | Logic 0 = Forces RTS# output to inactive (high)<br>Logic 1 = Forces RTS# output to active (low) |                                  |                                                 |                    |         |        |  |  |  |
|                                                   | 2                     | Ou                          | t1                 | Unuse                                                                                           | d                                |                                                 |                    |         |        |  |  |  |
|                                                   | 3                     | Ou                          | t2                 | Unuse                                                                                           | d                                |                                                 |                    |         |        |  |  |  |
|                                                   | 4                     | Inter<br>Loop<br>Ena        | nal<br>Back<br>ble | Logic (<br>Logic 1                                                                              | ) = Normal ope<br>I = Enable Loc | erating mode<br>al Loop-Back Mode               |                    |         |        |  |  |  |
|                                                   | 5                     | CTS/<br>flow co             | RTS<br>ontrol      | Logic (<br>Logic 1                                                                              | ) = CTS/RTS fl<br>I = CTS/RTS fl | ow control Disabled in<br>ow control Enabled in | 550-Mod<br>550-Mod | le<br>e |        |  |  |  |
|                                                   | 6                     | Unu                         | sed                | Unuse                                                                                           | d                                |                                                 |                    |         |        |  |  |  |
|                                                   | 7                     | Unu                         | sed                | Unuse                                                                                           | d                                |                                                 |                    |         |        |  |  |  |



## Modem Status Register:

This register provides the status of the modem control lines to CPU.

| Register:<br>Description<br>Offset:<br>Permission | ı:<br>s: | MSR<br>Modem Status Register<br>110<br>Read |        |        |           |                     |           |           |  |  |
|---------------------------------------------------|----------|---------------------------------------------|--------|--------|-----------|---------------------|-----------|-----------|--|--|
|                                                   | Bit[7]   | Bit[6]                                      | Bit[5] | Bit[4] | Bit[3]    | Bit[2]              | Bit[1]    | Bit[0]    |  |  |
|                                                   | DCD      | RI                                          | DSR    | CTS    | Delta DCD | Trailing<br>Edge RI | Delta DSR | Delta CTS |  |  |

| Bit | Name          | Description                                                                  |
|-----|---------------|------------------------------------------------------------------------------|
|     |               | Logic 0 = no change in the CTS signal                                        |
| 0   | Delta CTS     | Logic 1 = indicates that the CTS input has changed since the last time the   |
|     |               | MSR was read                                                                 |
|     |               | Logic 0 = no change in the DSR signal                                        |
| 1   | Delta DSR     | Logic 1 = indicates that the DSR input has changed since the last time the   |
|     |               | MSR was read                                                                 |
|     | Trailing Edge | Logic 0 = no change in the RI signal                                         |
| 2   | 2 RI          | Logic 1 = indicates that the RI input has changed from low to high since the |
|     |               | last time the MSR was read                                                   |
|     |               | Logic 0 = no change in the DCD signal                                        |
| 3   | Delta DCD     | Logic 1 = indicates that the DCD input has changed since the last time the   |
|     |               | MSR was read                                                                 |
| 4   | CTS           | Logic 0 = CTS# line is 1                                                     |
| -   | 010           | Logic 1 = CTS# line is 0                                                     |
| 5   | DSB           | Logic 0 = DSR# line is 1                                                     |
| 5   | DOR           | Logic 1 = DSR# line is 0                                                     |
| 6   | DI            | Logic 0 = RI# line is 1                                                      |
| 0   |               | Logic 1 = RI# line is 0                                                      |
| 7   |               | Logic 0 = DCD# line is 1                                                     |
|     | 000           | Logic 1 = DCD# line is 0                                                     |

### Scratch Pad Register:

The scratch pad register does not effect operation of the rest of the UART in any way and can be used for the temporary data storage.

| Register:<br>Description<br>Offset:<br>Permissior | n:<br>15: | SPR<br>Scratch Pac<br>111<br>Read/Write | l Register |            |             |        |        |        |
|---------------------------------------------------|-----------|-----------------------------------------|------------|------------|-------------|--------|--------|--------|
|                                                   | Bit[7]    | Bit[6]                                  | Bit[5]     | Bit[4]     | Bit[3]      | Bit[2] | Bit[1] | Bit[0] |
|                                                   |           |                                         |            | Scratch Pa | ad Register |        |        |        |
|                                                   |           |                                         |            |            |             |        |        |        |
|                                                   |           |                                         |            |            |             |        |        |        |



### **Divisor Latch Registers:**

The divisor latch registers (DLL & DLM) are used to program the baud rate divisor. This is a value between 1 and 65535 by which the input clock is divided in order to generate serial Baud Rates. After a hardware Reset, the Baud Rate used by the transmitter & receiver is given by:

Baud Rate = Input Clock / 16 \* Divisor

where divisor is given by: (256 \* DLM ) + DLL

**Note:** More flexible Baud Rate generation options are also available. These require the use of Advanced Features in other registers however.

| Register:<br>Description<br>Offset:<br>Permission<br>Access Con | s:<br>ndition:                          | DLL<br>Divisor Late<br>000<br>Read/Write<br>LCR[7] =1, 4        | ch Register<br>Address = 0 | 00     |        |        |        |        |  |  |
|-----------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------|----------------------------|--------|--------|--------|--------|--------|--|--|
|                                                                 | Bit[7]                                  | Bit[6]                                                          | Bit[5]                     | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |  |  |
|                                                                 |                                         | Least significant Byte for divisor latch                        |                            |        |        |        |        |        |  |  |
| Register:<br>Description<br>Offset:<br>Permission<br>Access Cor | :<br>s:<br>ndition:                     | DLM<br>Divisor Lato<br>001<br>Read/Write<br>LCR[7] =1, <i>J</i> | ch Register<br>Address = 0 | 01     |        |        |        |        |  |  |
|                                                                 | Bit[7]                                  | Bit[6]                                                          | Bit[5]                     | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |  |  |
|                                                                 | Most significant Byte for divisor latch |                                                                 |                            |        |        |        |        |        |  |  |
|                                                                 |                                         |                                                                 |                            |        |        |        |        |        |  |  |

|                     | Baud Rate | DLM<br>(Hex) | DLL<br>(Hex) |
|---------------------|-----------|--------------|--------------|
|                     | 115.2K    | 00           | 01           |
|                     | 57.6K     | 00           | 02           |
|                     | 38.4K     | 00           | 03           |
| Paud Pata Constator | 19.2K     | 00           | 06           |
| Programming Table   | 9600      | 00           | 0C           |
|                     | 2400      | 00           | 30           |
|                     | 1200      | 00           | 60           |
|                     | 600       | 00           | C0           |
|                     | 300       | 01           | 80           |
|                     | 150       | 03           | 00           |
|                     | 50        | 09           | 00           |



### **Master Reset Values**

| Register | BIT-7 | BIT-6 | BIT-5 | BIT-4 | BIT-3 | BIT-2 | BIT-1 | BIT-0 |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| RHR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| THR      | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |
| IER      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| FCR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| IIR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |
| LCR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| MCR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| LSR      | 0     | 1     | 1     | 0     | 0     | 0     | 0     | 0     |
| MSR      | Х     | Х     | Х     | Х     | 0     | 0     | 0     | 0     |
| SPR      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



### **Parallel Printer Port Register Descriptions**

#### **Data Register**

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 ports. During a read operation PD7-PD0 ports are buffered and output to the host CPU.

| Register:                    |                                                                                   | PP DPR                      |              |            |             |        |        |        |  |  |
|------------------------------|-----------------------------------------------------------------------------------|-----------------------------|--------------|------------|-------------|--------|--------|--------|--|--|
| Description                  | n:                                                                                | Parallel Prir               | nter Data Re | egister    |             |        |        |        |  |  |
| Offset:                      |                                                                                   | 000                         |              | -          |             |        |        |        |  |  |
| Permission                   | IS:                                                                               | <b>Read/Write</b>           |              |            |             |        |        |        |  |  |
| Access Condition:            |                                                                                   | Application Number = 0x0100 |              |            |             |        |        |        |  |  |
|                              | Bit[7]                                                                            | Bit[6]                      | Bit[5]       | Bit[4]     | Bit[3]      | Bit[2] | Bit[1] | Bit[0] |  |  |
|                              |                                                                                   |                             |              | Parallel P | rinter Data |        |        |        |  |  |
| Device Stat<br>The bits of t | Device Status Register<br>The bits of the status register are defined as follows: |                             |              |            |             |        |        |        |  |  |
| Register:                    | <b>.</b> .                                                                        | DSR<br>Device Stat          | us Register  |            |             |        |        |        |  |  |

| Description                                   | ):     | <b>Device Stat</b> | us Register | •      |        |        |        |        |  |
|-----------------------------------------------|--------|--------------------|-------------|--------|--------|--------|--------|--------|--|
| Offset:                                       |        | 001                |             |        |        |        |        |        |  |
| Permissions:                                  |        | Read               |             |        |        |        |        |        |  |
| Access Condition: Application Number = 0x0100 |        |                    |             |        |        |        |        |        |  |
|                                               | Bit[7] | Bit[6]             | Bit[5]      | Bit[4] | Bit[3] | Bit[2] | Bit[1] | Bit[0] |  |
|                                               | nBUSY  | nACK               | PE          | SLCT   | nFAULT | Unused | Unused | Unused |  |

| Dit | Nama   | Description                                                                                                                 |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------|
| BIt | Name   | Description                                                                                                                 |
| 0   | Unused | Not used, set to 0                                                                                                          |
| 1   | Unused | Not used, set to 0                                                                                                          |
| 2   | Unused | Not used, set to 0                                                                                                          |
| 3   | nFAULT | Logic 0 = Printer reports an error condition exists.<br>Logic 1 = Normal operation.                                         |
| 4   | SLCT   | Logic 0 = Printer is off line.<br>Logic 1 = Printer is on line.                                                             |
| 5   | PE     | Logic 0 = Normal operation<br>Logic 1 = Paper end/empty is detected                                                         |
| 6   | nACK   | Logic 0 = State of the nACK pin (nACK = Low).<br>Logic 1 = State of the nACK pin (nACK = High).                             |
| 7*  | nBUSY  | Logic 0 = BUSY pin is high, printer is not ready to take data.<br>Logic 1 = BUSY pin is low, printer is ready to take data. |

**Note:** Bit-7 (nBUSY) in 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.



nINIT

SLCTIN

Unused

DIR

Unused

Unused

2

3\*

4

5

6

7

## MCS7715 USB 1.1 to Single Serial and Single Parallel Controller

| Device Con                                                                             | Device Control Register |       |       |                                                                      |                                                                                                                                                                            |              |        |        |        |        |
|----------------------------------------------------------------------------------------|-------------------------|-------|-------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|--------|--------|--------|
| Register:DCRDescription:DeviceOffset:002Permissions:Read/VAccess Condition:Application |                         |       |       | Con <sup>-</sup><br>/rite<br>tion                                    | trol Registe<br>Number = (                                                                                                                                                 | er<br>0x0100 |        |        |        |        |
|                                                                                        | B                       | it[7] | Bit[6 |                                                                      | Bit[5]                                                                                                                                                                     | Bit[4]       | Bit[3] | Bit[2] | Bit[1] | Bit[0] |
|                                                                                        | Ur                      | nused | Unuse | ed                                                                   | DIR                                                                                                                                                                        | Unused       | SLCTIN | nINIT  | AUTOFD | STROBE |
|                                                                                        |                         |       |       |                                                                      |                                                                                                                                                                            |              |        |        |        |        |
|                                                                                        | Bit                     | Na    | ame   |                                                                      | Description                                                                                                                                                                |              |        |        |        |        |
|                                                                                        |                         |       |       | Logic 0 = Sets the nSTROBE pin to high.                              |                                                                                                                                                                            |              |        |        |        |        |
|                                                                                        | 0*                      | STF   | ROBE  | Logic 1 = Sets the nSTROBE pin to low. PD7-PD0 data are latched into |                                                                                                                                                                            |              |        |        |        |        |
|                                                                                        |                         |       |       |                                                                      | printer                                                                                                                                                                    |              |        |        |        |        |
|                                                                                        | 1*                      | AUT   | OFD   | Log                                                                  | Logic 0 = Sets the nAUTOFDX pin to high. No auto feed function.<br>Logic 1 = Sets the nAUTOFDX pin to low. Printer generates auto line feed<br>after each line is printed. |              |        |        |        |        |

Logic 1 = Normal Operation.

Not uset set to 0

Not used, set to 0.

Not used, set to 0.

| 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, this bit must be set LOW.

Logic 0 = Peripheral/printer starts its initialization routine.

Logic 0 = Sets the nSLCTIN pin to high. Printer is not selected.

Logic 1 = Sets the nSLCTIN pin to low. Selects the printer.

Logic 0 = PD7-PD0 pins are configured for output mode.

Logic 1 = PD7-PD0 pins are configured for input mode.



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

This register controls the Parallel Port mode selection operation.

| Register:<br>Description<br>Offset:<br>Permission<br>Access Con | i: F<br>S: F<br>ndition: 7 | PP_ECR<br>Parallel Prin<br>)x0A<br>Read/Write<br>Application | nter Port Ex | ttended Con | trol Registe | er     |
|-----------------------------------------------------------------|----------------------------|--------------------------------------------------------------|--------------|-------------|--------------|--------|
|                                                                 | Bit[7]                     | Bit[6]                                                       | Bit[5]       | Bit[4]      | Bit[3]       | Bit[2] |
|                                                                 | Para                       | allel Port Mo                                                | ode          | Reserved    | Reserved     | Reserv |
|                                                                 |                            |                                                              |              |             |              |        |

| Bit[7]             | Bit[6] | Bit[5]   | Bit[4]   | Bit[3]   | Bit[2]   | Bit[1]   | Bit[0] |
|--------------------|--------|----------|----------|----------|----------|----------|--------|
| Parallel Port Mode |        | Reserved | Reserved | Reserved | Reserved | Reserved |        |

| Bit-7 | Bit-6 | Bit-5 | Operating Mode |
|-------|-------|-------|----------------|
| 0     | 0     | 0     | SPP            |
| 0     | 0     | 1     | Nibble         |
| 0     | 1     | 0     | CB-FIFO mode   |
| 0     | 1     | 1     | Not Used       |
| 1     | 0     | 0     | Not Used       |
| 1     | 0     | 1     | Not used       |
| 1     | 1     | 0     | Not Used       |
| 1     | 1     | 1     | Not Used       |



## **Mode Changes**

After a hardware reset Nibble Mode is selected as the default mode. It is required to select mode 000 or 001 before any other mode configuration.

#### Mode "000"

### SPP/Centronics/Compatible Mode

Forward direction only. The direction bit is forced to "0" and PD7-PD0 are set to the output direction. The Parallel Port is under software control. This mode defines the protocol used by most PCs to transfer data to a printer. It is commonly called the "Centronics" mode and is the method utilized with the Standard Parallel Printer port. Data is placed on the PD7-PD0 ports, 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. This operating cycle continues when the printer/peripheral issues the data acknowledge signal (pulses the ACK and nBUSY pins).

## Mode "001"

## Nibble Mode

The Nibble Mode is the most common way to get reverse channel data from the printer or peripheral. This mode is usually combined with the SPP Mode or a proprietary forward channel mode to create a Bi-Directional channel. In this mode printer status bits are used as Nibble bits.

| 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 Order for Nibble Mode** 

## Mode "010"

#### **FIFO Output Mode**

In this mode, Bytes written to the FIFO are transmitted automatically using the SPP/Centronics standard protocol.



## Vendor Specific Command Registers:

There are three vendor specific registers which are used to tune the behavior and performance of the UART and Parallel Port. They are as follows

- SP\_REG
- PP\_REG
- SP\_CONTROL\_REG

## SP\_REGISTER:

This register is used for internal debugging of UDC controller & bridge circuitry. This enables the designer to pin point the problem in the design. This register also enables the hardware flow control. This register has bits which clear the Bulk-In & Bulk-Out FIFOs. There is a bit which resets the UART. There are bits which control the input clock fed to the UART, providing options for higher Baud Rates.

|              | D:4[7]  | D:4[0]               | DHEL   | D:4141   | D:     |  |  |
|--------------|---------|----------------------|--------|----------|--------|--|--|
| Access Con   | dition: | Applicati            | on Nun | nber = 0 | )x0000 |  |  |
| Permissions  | S:      | Read/Write           |        |          |        |  |  |
| Offset:      |         | 0x01                 |        |          |        |  |  |
| Description: |         | Serial Port Register |        |          |        |  |  |
| Register:    |         | SP_REG               |        |          |        |  |  |
|              |         |                      |        |          |        |  |  |

| Bit[7]     | Bit[6] | Bit[5] | Bit[4] | Bit[3]      | Bit[2]      | Bit[1]              | Bit[0]   |
|------------|--------|--------|--------|-------------|-------------|---------------------|----------|
| UART_Reset | Clk_L  | JART_S | Select | Sp_bi_clear | Sp_bo_clear | Ser_line_err_ctl_en | Udc_loop |

| Bit                 | Description                                                                |
|---------------------|----------------------------------------------------------------------------|
| Udc_loop            | When enabled, loops the data from the Bulk-Out FIFO to the Bulk-In FIFO.   |
| Ser_line_err_ctl_en | When enabled, will not allow the data from the UART to be written into the |
|                     | Bulk-In FIFO if there are any errors in the received data.                 |
| Sp_bo_clear         | Reset the Bulk-Out FIFO                                                    |
| Sp_bi_clear         | Reset the Bulk-In FIFO                                                     |
| Clk_UART_Select     | Changes the clock fed to UART as shown in the table below                  |
| UART_Reset          | Resets the UART                                                            |

Clk\_UART\_Select: Changes the clock fed to the Serial Port as shown in the table below.

| Option | Input Clock Frequency |
|--------|-----------------------|
| 3'b000 | 12 MHz                |
| 3'b001 | 6 MHz                 |
| 3'b010 | 3 MHz                 |
| 3'b011 | 1.5 MHz               |
| 3'b100 | 0.75 MHz              |



## **PP\_REGISTER:**

This register is used for internal debugging of UDC controller & bridge circuitry. There is a bit which resets the Parallel Printer port. There are bits which control the input clock fed to the Parallel Printer port.

| Register:<br>Description<br>Offset:<br>Permission<br>Access Cor | :<br>s:<br>ndition: | PP_REG<br>Parallel Prir<br>0x04<br>Read/Write<br>Application | nter Port R<br>Number =                        | egister |        |        |        |          |
|-----------------------------------------------------------------|---------------------|--------------------------------------------------------------|------------------------------------------------|---------|--------|--------|--------|----------|
|                                                                 | D:4[7]              | Diffel                                                       | D:4[5]                                         | D:4[4]  | D:4[0] | D:4/01 | D:4[4] | D:4[0]   |
|                                                                 | BIt[/]              | BIT[0]                                                       | BIT[2]                                         | Bit[4]  | BIT[3] | BIT[2] | BIT[1] | BIT[U]   |
|                                                                 | pp_reset            | clk                                                          | clk_freq_selectpp_bi_clear pp_bo_clear Reserve |         |        |        |        | udc_loop |

| Bit             | Description                                                              |
|-----------------|--------------------------------------------------------------------------|
| udc_loop        | When enabled, loops the data from the Bulk-Out FIFO to the Bulk-In FIFO. |
| Reserved        | Reserved                                                                 |
| pp_bo_clear     | Reset the Bulk-Out FIFO                                                  |
| pp_bi_clear     | Reset the Bulk-In FIFO                                                   |
| clk_freq_select | Changes the clock fed to the Parallel Printer port.                      |
| pp_reset        | Resets the Parallel Printer port                                         |

**pp reset:** This bit will reset the Parallel Printer port. When this bit is a 1 the Parallel Printer port is under the Reset process. Whenever the frequency is to be changed, first set the Reset bit, change the clk\_ frequency, and finally clear the Reset bit to 0. **clk\_freq\_select:** Changes the clock fed to the Parallel Printer port as shown in the table below.

| Option Input Clock Frequency |          |  |  |
|------------------------------|----------|--|--|
| 3'b000                       | 12 MHz   |  |  |
| 3'b001                       | 6 MHz    |  |  |
| 3'b010                       | 3 MHz    |  |  |
| 3'b011                       | 1.5 MHz  |  |  |
| 3'b100                       | 0.75 MHz |  |  |



## SP\_CONTROL\_REGISTER:

ľ

The Control register is used for controlling the Auto RTS/CTS flow control of the Serial Port.

| <b>Register:</b> |          | SP_CONTROL_REG                   |           |             |        |   |  |
|------------------|----------|----------------------------------|-----------|-------------|--------|---|--|
| Description      | n:       | Control Register for Serial Port |           |             |        |   |  |
| Offset:          |          | 0x08                             |           |             |        |   |  |
| Permissio        | าร:      | Read/Write                       |           |             |        |   |  |
| Access Co        | ndition: | Applicat                         | ion Numbe | er = 0x0000 | )      |   |  |
|                  | D:4[7]   | D:4[6]                           | D:4[6]    | D:4[4]      | D:4[2] | D |  |

| Bit[7]   | Bit[6]   | Bit[5]   | Bit[4]   | Bit[3]   | Bit[2]   | Bit[1]   | Bit[0]              |
|----------|----------|----------|----------|----------|----------|----------|---------------------|
| Reserved | sp_autoflow_ctrl_en |

| Bit                 | Description                                                                  |
|---------------------|------------------------------------------------------------------------------|
| sp_autoflow_ctrl_en | This bit is used for enabling the hardware flow control for the Serial port. |
| Reserved            | Reserved                                                                     |



### **Electrical Characteristics**

#### **Absolute Maximum Ratings**

Supply Voltage Input Voltage (I/O) Storage Temperature 6 Volts -0.3 to V<sub>cc</sub> +0.3 -60° C to +150° C

4.5 to 5.5 Volts

0° C to +115° C

0 to 5.5 Volts 0° C to +70° C

### **Recommended Operating Conditions**

Supply Voltage Input Voltage (I/O) Ambient Operating Temperature (free air) Junction Operating Temperature

### Static Characteristics (Supply Pins)

 $V_{cc}$  = 4.5V to 5.5V; GND = 0V; Temp = 0 to +70° C; unless otherwise specified

| Symbol                  | Parameter                | Conditions | Min | Typical | Мах | Unit |
|-------------------------|--------------------------|------------|-----|---------|-----|------|
| V <sub>reg</sub> (3.3V) | Regulated Supply Voltage |            | 3.0 | 3.3     | 3.6 | V    |
| I <sub>cc</sub>         | Operating Supply Current |            | -   | 18      | -   | mA   |

#### Static Characteristics

 $V_{cc}$  = 4.5V to 5.5V; GND = 0V; Temp = 0 to +70° C; unless otherwise specified

| Symbol               | Parameter                        | Conditions | Min     | Typical | Мах     | Unit |
|----------------------|----------------------------------|------------|---------|---------|---------|------|
| V <sub>IL</sub>      | LOW Level Input Voltage          |            | -       | -       | 0.3*Vcc | V    |
| V <sub>IH</sub>      | HIGH Level Input Voltage         |            | 0.7*Vcc | -       | -       | V    |
| V <sub>th</sub> (LH) | Positive going Threshold Voltage |            | -       | 3.22    | -       | V    |
| V <sub>th</sub> (HL) | Negative going Threshold Voltage |            | -       | 1.84    | -       | V    |
| I <sub>LI</sub>      | Input Leakage Current            |            | -       | -       | ±1      | μA   |
| I <sub>oz</sub>      | Tri-State Leakage Current        |            | -       | -       | ±10     | μA   |
| V <sub>ol</sub>      | Output Voltage (Low)             |            | -       | -       | 0.4     | V    |
| V <sub>OH</sub>      | Output Voltage (High)            |            | 3.5     | -       | -       | V    |

## Dynamic Characteristics - Analog I/O Pins (DP, DM); Full-Speed Mode

 $V_{cc} = 4.5V$  to 5.5V; GND = 0V; Temp = 0 to +70° C; unless otherwise specified

| Symbol          | Parameter | Condition                                                                 | Min | Typical | Мах | Unit |
|-----------------|-----------|---------------------------------------------------------------------------|-----|---------|-----|------|
| T <sub>FR</sub> | Rise Time | С <sub>L</sub> = 50pF<br>10% to 90% of  V <sub>он</sub> - V <sub>оL</sub> | 4   | -       | 20  | nS   |
| T <sub>FF</sub> | Fall Time | С <sub>L</sub> = 50pF<br>10% to 90% of  V <sub>OH</sub> - V <sub>OL</sub> | 4   | -       | 20  | nS   |
|                 |           |                                                                           |     |         |     |      |





Copyright © 2002-2011 ASIX Electronics Corporation. All rights reserved.



## IMPORTANT NOTICE

Copyright © 2002-2011 ASIX Electronics Corporation. All rights reserved.

### DISCLAIMER

No part of this document may be reproduced or transmitted in any form or by any means, electronic or mechanical, including photocopying and recording, for any purpose, without the express written permission of ASIX. ASIX may make changes to the product specifications and descriptions in this document at any time, without notice.

ASIX provides this document "as is" without warranty of any kind, either expressed or implied, including without limitation warranties of merchantability, fitness for a particular purpose, and non-infringement.

Designers must not rely on the absence or characteristics of any features or registers marked "reserved", "undefined" or "NC". ASIX reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. Always contact ASIX to get the latest document before starting a design of ASIX products.

### TRADEMARKS

ASIX, the ASIX logo are registered trademarks of ASIX Electronics Corporation. All other trademarks are the property of their respective owners.



|          | Revision History |                                                                                                                                                                                                                                                   |  |  |  |
|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Revision | Date             | Comment                                                                                                                                                                                                                                           |  |  |  |
| 1.0      | 6-Nov-2002       | Preliminary Release                                                                                                                                                                                                                               |  |  |  |
| 1.1      | 7-Feb-2005       | Datasheet updated for Serial and Printer port related details                                                                                                                                                                                     |  |  |  |
| 1.2      | 25-Oct-2005      | Revised Data Sheet                                                                                                                                                                                                                                |  |  |  |
| 1.3      | 17-Nov-2005      | Minor Layout Changes                                                                                                                                                                                                                              |  |  |  |
| 1.4      | 28-Nov-2005      | Changes to Serial and Parallel Port Descriptors                                                                                                                                                                                                   |  |  |  |
| 1.5      | 30-Nov-2005      | Corrected Polling Intervals                                                                                                                                                                                                                       |  |  |  |
| 1.6      | 6-Jan-2006       | Corrected Electrical Characteristics and Pin Descriptions                                                                                                                                                                                         |  |  |  |
| 2.00     | 2011/08/05       | <ol> <li>Changed to ASIX Electronics Corp. logo, strings and contact<br/>information.</li> <li>Added ASIX copyright legal header information.</li> <li>Modified the Revision History table format.</li> <li>Updated the block diagram.</li> </ol> |  |  |  |
| 2.01     | 2011/11/01       | 1. Updated the ordering information.                                                                                                                                                                                                              |  |  |  |

# \_ .. \_\_.



