## Infineon Technologies - <u>CY7C63231A-SXCT Datasheet</u>



Welcome to E-XFL.COM

Embedded - Microcontrollers - Application Specific: Tailored Solutions for Precision and Performance

### Embedded - Microcontrollers - Application Specific

represents a category of microcontrollers designed with unique features and capabilities tailored to specific application needs. Unlike general-purpose microcontrollers, application-specific microcontrollers are optimized for particular tasks, offering enhanced performance, efficiency, and functionality to meet the demands of specialized applications.

#### What Are <u>Embedded - Microcontrollers -</u> <u>Application Specific</u>?

Application enacific microcontrollars are analyzared to

#### Details

-XE

| Details                 |                                                                            |
|-------------------------|----------------------------------------------------------------------------|
| Product Status          | Obsolete                                                                   |
| Applications            | USB Microcontroller                                                        |
| Core Processor          | M8B                                                                        |
| Program Memory Type     | OTP (3kB)                                                                  |
| Controller Series       | CY7C632xx                                                                  |
| RAM Size                | 96 × 8                                                                     |
| Interface               | USB                                                                        |
| Number of I/O           | 10                                                                         |
| Voltage - Supply        | 3.5V ~ 5.5V                                                                |
| Operating Temperature   | 0°C ~ 70°C                                                                 |
| Mounting Type           | Surface Mount                                                              |
| Package / Case          | 18-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package | 18-SOIC                                                                    |
| Purchase URL            | https://www.e-xfl.com/product-detail/infineon-technologies/cy7c63231a-sxct |
|                         |                                                                            |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



# LIST OF FIGURES

\_\_\_\_\_

| Figure 8-1. P  | rogram Memory Space with Interrupt Vector Table              | 11 |
|----------------|--------------------------------------------------------------|----|
| Figure 9-1. C  | lock Oscillator On-chip Circuit                              | 14 |
| Figure 9-2. C  | lock Configuration Register (Address 0xF8)                   | 14 |
| Figure 10-1.   | Watchdog Reset (WDR, Address 0x26)                           | 17 |
|                | Block Diagram of GPIO Port (one pin shown)                   |    |
| Figure 12-2. I | Port 0 Data (Address 0x00)                                   | 19 |
| Figure 12-3. I | Port 1 Data (Address 0x01)                                   | 20 |
| Figure 12-4.   | GPIO Port 0 Mode0 Register (Address 0x0A)                    | 20 |
|                | GPIO Port 0 Mode1 Register (Address 0x0B)                    |    |
|                | GPIO Port 1 Mode0 Register (Address 0x0C)                    |    |
|                | GPIO Port 1 Mode1 Register (Address 0x0D)                    |    |
|                | Port 2 Data Register (Address 0x02)                          |    |
|                | USB Status and Control Register (Address 0x1F)               |    |
| Figure 14-1.   | USB Device Address Register (Address 0x10)                   | 25 |
|                | Endpoint 0 Mode Register (Address 0x12)                      |    |
|                | USB Endpoint EP1 Mode Registers (Address 0x14)               |    |
| Figure 14-4. I | Endpoint 0 and 1 Counter Registers (Addresses 0x11 and 0x13) | 27 |
|                | Diagram of USB - PS/2 System Connections                     |    |
|                | Timer LSB Register (Address 0x24)                            |    |
|                | Timer MSB Register (Address 0x25)                            |    |
|                | Timer Block Diagram                                          |    |
|                | Processor Status and Control Register (Address 0xFF)         |    |
|                | Global Interrupt Enable Register (Address 0x20)              |    |
| Figure 19-2. I | Endpoint Interrupt Enable Register (Address 0x21)            | 33 |
| Figure 19-3. I | Interrupt Controller Logic Block Diagram                     | 34 |
|                | Port 0 Interrupt Enable Register (Address 0x04)              |    |
|                | Port 1 Interrupt Enable Register (Address 0x05)              |    |
| Figure 19-6. I | Port 0 Interrupt Polarity Register (Address 0x06)            | 35 |
| Figure 19-7. I | Port 1 Interrupt Polarity Register (Address 0x07)            | 35 |
| Figure 19-8.   | GPIO Interrupt Diagram                                       | 35 |
| Figure 24-1.   | Clock Timing                                                 | 45 |
| Figure 24-2.   | USB Data Signal Timing                                       | 45 |
|                | Receiver Jitter Tolerance                                    |    |
| Figure 24-4. I | Differential to EOP Transition Skew and EOP Width            | 46 |
| Figure 24-5. I | Differential Data Jitter                                     | 46 |

## LIST OF TABLES

| Table 8-1. I/O Register Summary                                                              | 13 |
|----------------------------------------------------------------------------------------------|----|
| Table 11-1. Wake-up Timer Adjust Settings                                                    |    |
| Table 12-1. Ports 0 and 1 Output Control Truth Table                                         | 21 |
| Table 13-1. Control Modes to Force D+/D– Outputs                                             | 24 |
| Table 19-1. Interrupt Vector Assignments                                                     | 31 |
| Table 20-1. USB Register Mode Encoding for Control and Non-Control Endpoint                  |    |
| Table 20-2. Decode table for Table 20-3: "Details of Modes for Differing Traffic Conditions" |    |
| Table 20-3. Details of Modes for Differing Traffic Conditions                                |    |
| Table 26-1. CY7C63221A-XC Probe Pad Coordinates in microns ((0,0) to bond pad centers) .     |    |



## 1.0 Features

- enCoRe<sup>™</sup> USB enhanced Component Reduction
  - -Internal oscillator eliminates the need for an external crystal or resonator
  - Interface can auto-configure to operate as PS/2 or USB without the need for external components to switch between
    modes (no GPIO pins needed to manage dual mode capability)
  - Internal 3.3V regulator for USB pull-up resistor
  - Configurable GPIO for real-world interface without external components
- Flexible, cost-effective solution for applications that combine PS/2 and low-speed USB, such as mice, gamepads, joysticks, and many others
- USB Specification Compliance
  - Conforms to USB Specification, Version 2.0
  - Conforms to USB HID Specification, Version 1.1
  - Supports 1 low-speed USB device address
  - -Supports 1 control endpoint and 1 data endpoint
  - -Integrated USB transceiver
  - 3.3V regulated output for USB pull-up resistor
- 8-bit RISC microcontroller
  - -Harvard architecture
  - 6-MHz external ceramic resonator or internal clock mode
  - 12-MHz internal CPU clock
  - -Internal memory
  - -96 bytes of RAM
  - 3 Kbytes of EPROM
  - Interface can auto-configure to operate as PS/2 or USB
  - -No external components for switching between PS/2 and USB modes
- I/O ports
  - Up to 10 versatile General Purpose I/O (GPIO) pins, individually configurable
  - High current drive on any GPIO pin: 50 mA/pin current sink
  - Each GPIO pin supports high-impedance inputs, internal pull-ups, open drain outputs, or traditional CMOS outputs
  - Maskable interrupts on all I/O pins
  - XTALIN, XTALOUT and VREG can be configured as additional input pins
- Internal low-power wake-up timer during suspend mode
- Periodic wake-up with no external components
- Optional 6-MHz internal oscillator mode

   Allows fast start-up from suspend mode
- Watchdog timer (WDT)
- Low-voltage Reset at 3.75V
- · Internal brown-out reset for suspend mode
- · Improved output drivers to reduce EMI
- Operating voltage from 4.0V to 5.5VDC
- Operating temperature from 0 to 70 degrees Celsius
- available in DIE form or 16-pin PDIP
- available in 18-pin SOIC, 18-pin PDIP
- Industry-standard programmer support



## 2.0 Functional Overview

## 2.1 *enCoRe* USB - The New USB Standard

Cypress has reinvented its leadership position in the low-speed USB market with a new family of innovative microcontrollers. Introducing...*enCoRe*<sup>™</sup> USB—"enhanced Component Reduction." Cypress has leveraged its design expertise in USB solutions to create a new family of low-speed USB microcontrollers that enables peripheral developers to design new products with a minimum number of components. At the heart of the Cypress *enCoRe* USB technology is the breakthrough design of a crystalless oscillator. By integrating the oscillator into the chip, an external crystal or resonator is no longer needed. We have also integrated other external components commonly found in low-speed USB applications such as pull-up resistors, wake-up circuitry, and a 3.3V regulator. All of this adds up to a lower system cost.

The family is comprised of 8-bit RISC One Time Programmable (OTP) microcontrollers. The instruction set has been optimized specifically for USB and PS/2 operations, although the microcontrollers can be used for a variety of other embedded applications.

The features up to 10 general-purpose I/O (GPIO) pins to support USB, PS/2 and other applications. The I/O pins are grouped into two ports (Port 0 to 1) where each pin can be individually configured as inputs with internal pull-ups, open drain outputs, or traditional CMOS outputs with programmable drive strength of up to 50 mA output drive. Additionally, each I/O pin can be used to generate a GPIO interrupt to the microcontroller.

The microcontrollers feature an internal oscillator. With the presence of USB traffic, the internal oscillator can be set to precisely tune to USB timing requirements (6 MHz ±1.5%). This clock generator has been optimized to reduce clock-related noise emissions (EMI), and provides the 6-MHz and 12-MHz clocks that remain internal to the microcontroller. When using the internal oscillator, XTALIN and XTALOUT can be configured as additional input pins that can be read on port 2. Optionally, an external 6-MHz ceramic resonator can be used to provide a higher precision reference if needed.

The is offered with 3 Kbytes of EPROM to minimize cost, and has 96 bytes of data RAM for stack space, user variables, and USB endpoint FIFOs.

The family includes low-voltage reset logic, a watchdog timer, a vectored interrupt controller, and a 12-bit free-running timer. The low-voltage reset (LVR) logic detects when power is applied to the device, resets the logic to a known state, and begins executing instructions at EPROM address 0x0000. LVR will also reset the part when  $V_{CC}$  drops below the operating voltage range. The watchdog timer can be used to ensure the firmware never gets stalled for more than approximately 8 ms.

The microcontroller supports 7 maskable interrupts in the vectored interrupt controller. Interrupt sources include the USB Bus-Reset, the 128- $\mu$ s and 1.024-ms outputs from the free-running timer, two USB endpoints, an internal wake-up timer and the GPIO port. The timers bits cause periodic interrupts when enabled. The USB endpoints interrupt after USB transactions complete on the bus. The GPIO port has a level of masking to select which GPIO inputs can cause a GPIO interrupt. For additional flexibility, the input transition polarity that causes an interrupt is programmable for each GPIO pin. The interrupt polarity can be either rising or falling edge.

The free-running 12-bit timer clocked at 1 MHz provides two interrupt sources as noted above (128  $\mu$ s and 1.024 ms). The timer can be used to measure the duration of an event under firmware control by reading the timer at the start and end of an event, and subtracting the two values.

The CY7C63221/31A includes an integrated USB serial interface engine (SIE). The hardware supports one USB device address with two endpoints. The SIE allows the USB host to communicate with the function integrated into the microcontroller. A 3.3V regulated output pin provides a pull-up source for the external USB resistor on the D– pin. When using an external voltage regulator VREG can be configured as an input pin that can be read on port 2 (P2.0).

The USB D+ and D– USB pins can alternately be used as PS/2 SCLK and SDATA signals, so that products can be designed to respond to either USB or PS/2 modes of operation. PS/2 operation is supported with internal pull-up resistors on SCLK and SDATA, the ability to disable the regulator output pin, and an interrupt to signal the start of PS/2 activity. No external components are necessary for dual USB and PS/2 systems, and no GPIO pins need to be dedicated to switching between modes. Slow edge rates operate in both modes to reduce EMI.



## 5.0 Pin Assignments (continued)

|                 |     |        | CY7C63231A/<br>CY7C63221A-XC |                                                                                                           |
|-----------------|-----|--------|------------------------------|-----------------------------------------------------------------------------------------------------------|
| Name            | I/O | 16-Pin | 18-Pin/Pad                   | Description                                                                                               |
| XTALIN/P2.1     | IN  | 8      | 9                            | 6-MHz ceramic resonator or external clock input, or P2.1 input                                            |
| XTALOUT/P2.2    | IN  | 9      | 10                           | 6-MHz ceramic resonator return pin or internal oscillator output, or P2.2 input                           |
| V <sub>PP</sub> |     | 6      | 7                            | Programming voltage supply, ground for normal operation                                                   |
| V <sub>CC</sub> |     | 10     | 11                           | Voltage supply                                                                                            |
| VREG/P2.0       |     | 7      | 8                            | Voltage supply for $1.3 \text{-} k\Omega$ USB pull-up resistor (3.3V nominal). Also serves as P2.0 input. |
| V <sub>SS</sub> |     | 5      | 6                            | Ground                                                                                                    |

## 6.0 **Programming Model**

Refer to the CYASM Assembler User's Guide for more details on firmware operation with the microcontrollers.

## 6.1 **Program Counter (PC)**

The 14-bit program counter (PC) allows access for 3 Kbytes of EPROM using the architecture. The program counter is cleared during reset, such that the first instruction executed after a reset is at address 0x0000. This is typically a jump instruction to a reset handler that initializes the application.

The lower 8 bits of the program counter are incremented as instructions are loaded and executed. The upper 6 bits of the program counter are incremented by executing an XPAGE instruction. As a result, the last instruction executed within a 256-byte "page" of sequential code should be an XPAGE instruction. The assembler directive "XPAGEON" will cause the assembler to insert XPAGE instructions automatically. As instructions can be either one or two bytes long, the assembler may occasionally need to insert a NOP followed by an XPAGE for correct execution.

The program counter of the next instruction to be executed, carry flag, and zero flag are saved as two bytes on the program stack during an interrupt acknowledge or a CALL instruction. The program counter, carry flag, and zero flag are restored from the program stack only during a RETI instruction.

Please note the program counter cannot be accessed directly by the firmware. The program stack can be examined by reading SRAM from location 0x00 and up.

Note that there are restrictions in using the JMP, CALL, and INDEX instructions across the 4-KB boundary of the program memory. Refer to the *CYASM Assembler User's Guide* for a detailed description.

### 6.2 8-bit Accumulator (A)

The accumulator is the general-purpose, do-everything register in the architecture where results are usually calculated.

### 6.3 8-bit Index Register (X)

The index register "X" is available to the firmware as an auxiliary accumulator. The X register also allows the processor to perform indexed operations by loading an index value into X.

### 6.4 8-bit Program Stack Pointer (PSP)

During a reset, the program stack pointer (PSP) is set to zero. This means the program "stack" starts at RAM address 0x00 and "grows" upward from there. Note that the program stack pointer is directly addressable under firmware control, using the MOV PSP,A instruction. The PSP supports interrupt service under hardware control and CALL, RET, and RETI instructions under firmware control.

During an interrupt acknowledge, interrupts are disabled and the program counter, carry flag, and zero flag are written as two bytes of data memory. The first byte is stored in the memory addressed by the program stack pointer, then the PSP is incremented. The second byte is stored in memory addressed by the program stack pointer and the PSP is incremented again. The net effect is to store the program counter and flags on the program "stack" and increment the program stack pointer by two.

The return from interrupt (RETI) instruction decrements the program stack pointer, then restores the second byte from memory addressed by the PSP. The program stack pointer is decremented again and the first byte is restored from memory addressed by the PSP. After the program counter and flags have been restored from stack, the interrupts are enabled. The effect is to restore the program counter and flags from the program stack, decrement the program stack pointer by two, and re-enable interrupts.



# 8.0 Memory Organization

## 8.1 **Program Memory Organization**

| After reset | Address |                                                       |
|-------------|---------|-------------------------------------------------------|
| 14-bit PC   | 0x0000  | Program execution begins here after a reset.          |
|             | 0x0002  | USB Bus Reset interrupt vector                        |
|             | 0x0004  | 128-µs timer interrupt vector                         |
|             | 0x0006  | 1.024-ms timer interrupt vector                       |
|             | 0x0008  | USB endpoint 0 interrupt vector                       |
|             | 0x000A  | USB endpoint 1 interrupt vector                       |
|             | 0x000C  | Reserved                                              |
|             | 0x000E  | Reserved                                              |
|             | 0x0010  | Reserved                                              |
|             | 0x0012  | Reserved                                              |
|             | 0x0014  | GPIO interrupt vector                                 |
|             | 0x0016  | Wake-up interrupt vector                              |
|             | 0x0018  | Program Memory begins here                            |
|             |         |                                                       |
|             |         |                                                       |
|             |         |                                                       |
|             |         |                                                       |
|             | 0x0BDF  | 3 KB PROM ends here (3K - 32 bytes). See Note 1 below |

Figure 8-1. Program Memory Space with Interrupt Vector Table

### Note:

1. The upper 32 bytes of the 3K PROM are reserved. Therefore, user's program must not over-write this space.



## 8.2 Data Memory Organization

The microcontroller provides 96 bytes of data RAM. In normal usage, the SRAM is partitioned into four areas: program stack, data stack, user variables and USB endpoint FIFOs as shown below:





## 8.3 I/O Register Summary

I/O registers are accessed via the I/O Read (IORD) and I/O Write (IOWR, IOWX) instructions. IORD reads the selected port into the accumulator. IOWR writes data from the accumulator to the selected port. Indexed I/O Write (IOWX) adds the contents of X to the address in the instruction to form the port address and writes data from the accumulator to the specified port. Note that specifying address 0 with IOWX (e.g., IOWX 0h) means the I/O port is selected solely by the contents of X.

**Note: All bits of all registers are cleared to all zeros on reset,** except the Processor Status and Control Register (*Figure 18-1*). *All registers not listed are reserved, and should never be written by firmware. All bits marked as reserved should always be written as 0 and be treated as undefined by reads.* 

| Register Name              | I/O Address | Read/Write | Function                                                   | Fig. |
|----------------------------|-------------|------------|------------------------------------------------------------|------|
| Port 0 Data                | 0x00        | R/W        | GPIO Port 0                                                | 12-2 |
| Port 1 Data                | 0x01        | R/W        | GPIO Port 1                                                | 12-3 |
| Port 2 Data                | 0x02        | R          | Auxiliary input register for D+, D–, VREG, XTALIN, XTALOUT | 12-8 |
| Port 0 Interrupt Enable    | 0x04        | W          | Interrupt enable for pins in Port 0                        | 19-4 |
| Port 1 Interrupt Enable    | 0x05        | W          | Interrupt enable for pins in Port 1                        | 19-5 |
| Port 0 Interrupt Polarity  | 0x06        | W          | Interrupt polarity for pins in Port 0                      | 19-6 |
| Port 1 Interrupt Polarity  | 0x07        | W          | Interrupt polarity for pins in Port 1                      | 19-7 |
| Port 0 Mode0               | 0x0A        | W          | Controls output configuration for Port 0                   | 12-4 |
| Port 0 Mode1               | 0x0B        | W          |                                                            | 12-5 |
| Port 1 Mode0               | 0x0C        | W          | Controls output configuration for Port 1                   | 12-6 |
| Port 1 Mode1               | 0x0D        | W          |                                                            | 12-7 |
| USB Device Address         | 0x10        | R/W        | USB Device Address register                                | 14-1 |
| EP0 Counter Register       | 0x11        | R/W        | USB Endpoint 0 counter register                            | 14-4 |
| EP0 Mode Register          | 0x12        | R/W        | USB Endpoint 0 configuration register                      | 14-2 |
| EP1 Counter Register       | 0x13        | R/W        | USB Endpoint 1 counter register                            | 14-4 |
| EP1 Mode Register          | 0x14        | R/W        | USB Endpoint 1 configuration register                      | 14-3 |
| USB Status & Control       | 0x1F        | R/W        | USB status and control register                            | 13-1 |
| Global Interrupt Enable    | 0x20        | R/W        | Global interrupt enable register                           | 19-1 |
| Endpoint Interrupt Enable  | 0x21        | R/W        | USB endpoint interrupt enables                             | 19-2 |
| Timer (LSB)                | 0x24        | R          | Lower 8 bits of free-running timer (1 MHz)                 | 17-1 |
| Timer (MSB)                | 0x25        | R          | Upper 4 bits of free-running timer                         | 17-2 |
| WDR Clear                  | 0x26        | W          | Watch Dog Reset clear                                      | -    |
| Clock Configuration        | 0xF8        | R/W        | Internal / External Clock configuration register           | 9-2  |
| Processor Status & Control | 0xFF        | R/W        | Processor status and control                               | 18-1 |

#### Table 8-1. I/O Register Summary



Internal Clock saves the external oscillator start-up time and keeps that oscillator off for additional power savings. The external oscillator mode can be activated when desired, similar to operation at power-up.

The sequence of events for these modes is as follows:

#### Wake in Internal Clock Mode:

- 1. Before entering suspend, clear bit 0 of the Clock Configuration Register. This selects Internal clock mode after suspend.
- 2. Enter suspend mode by setting the suspend bit of the Processor Status and Control Register.
- 3. After a wake-up event, the internal clock starts immediately (within 2  $\mu$ s).
- 4. A time-out period of 8  $\mu$ s passes, and then firmware execution begins.
- 5. At some later point, to activate External Clock mode, set bit 0 of the Clock Configuration Register. This halts the internal clocks while the external clock becomes stable. After an additional time-out (128 μs or 4 ms, see Section 9.0), firmware execution resumes.

#### Wake in External Clock Mode:

- 1. Before entering suspend, the external clock must be selected by setting bit 0 of the Clock Configuration Register. Make sure this bit is still set when suspend mode is entered. This selects External clock mode after suspend.
- 2. Enter suspend mode by setting the suspend bit of the Processor Status and Control Register.
- 3. After a wake-up event, the external oscillator is started. The clock is monitored for stability (this takes approximately 50–100  $\mu$ s with a ceramic resonator).
- 4. After an additional time-out period (128 µs or 4 ms, see Section 9.0), firmware execution resumes.

#### 11.2 Wake-up Timer

The wake-up timer runs whenever the wake-up interrupt is enabled, and is turned off whenever that interrupt is disabled. Operation is independent of whether the device is in suspend mode or if the global interrupt bit is enabled. Only the Wake-up Timer Interrupt Enable bit (*Figure 19-1*) controls the wake-up timer.

Once this timer is activated, it will give interrupts after its time-out period (see below). These interrupts continue periodically until the interrupt is disabled. Whenever the interrupt is disabled, the wake-up timer is reset, so that a subsequent enable always results in a full wake-up time.

The wake-up timer can be adjusted by the user through the Wake-up Timer Adjust bits in the Clock Configuration Register (*Figure 9-2*). These bits clear on reset. In addition to allowing the user to select a range for the wake-up time, a firmware algorithm can be used to tune out initial process and operating condition variations in this wake-up time. This can be done by timing the wake-up interrupt time with the accurate 1.024-ms timer interrupt, and adjusting the Timer Adjust bits accordingly to approximate the desired wake-up time.

| Adjust Bits [2:0]<br>(Bits [6:4] in <i>Figure</i> 9-2) | Wake-up Time            |  |  |  |
|--------------------------------------------------------|-------------------------|--|--|--|
| 000 (reset state)                                      | 1 * t <sub>WAKE</sub>   |  |  |  |
| 001                                                    | 2 * t <sub>WAKE</sub>   |  |  |  |
| 010                                                    | 4 * t <sub>WAKE</sub>   |  |  |  |
| 011                                                    | 8 * t <sub>WAKE</sub>   |  |  |  |
| 100                                                    | 16 * t <sub>WAKE</sub>  |  |  |  |
| 101                                                    | 32 * t <sub>WAKE</sub>  |  |  |  |
| 110                                                    | 64 * t <sub>WAKE</sub>  |  |  |  |
| 111                                                    | 128 * t <sub>WAKE</sub> |  |  |  |
| See Section 24.0 for the value of t <sub>WAKE</sub>    |                         |  |  |  |

#### Table 11-1. Wake-up Timer Adjust Settings



## 12.0 General Purpose I/O Ports

Ports 0 and 1 provide up to 10 versatile GPIO pins that can be read or written (the number of pins depends on package type).



Figure 12-1. Block Diagram of GPIO Port (one pin shown)

Port 0 is an 8-bit port; Port 1 contains 2 bits, P1.1–P1.0 in the and CY7C63221A-XC parts. Each bit can also be selected as an interrupt source for the microcontroller.

The data for each GPIO pin is accessible through the Port Data Register. Writes to the Port Data Register store outgoing data state for the port pins, while reads from the Port Data Register return the actual logic value on the port pins, not the Port Data Register contents.

Each GPIO pin is configured independently. The driving state of each GPIO pin is determined by the value written to the pin's Data Register and by two associated pin's Mode0 and Mode1 bits.

The Port 0 Data Register is shown in *Figure 12-2*, and the Port 1 Data Register is shown in *Figure 12-3*. The Mode0 and Mode1 bits for the two GPIO ports are given in *Figure 12-4* through *Figure 12-7*.

| Bit #      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit Name   | PO  |     |     |     |     |     |     |     |
| Read/Write | R/W |
| Reset      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Figure 12-2. Port 0 Data (Address 0x00)

#### Bit [7:0]: P0[7:0]

1 = Port Pin is logic HIGH

0 = Port Pin is logic LOW



| Bit #      | 7 | 6       | 5     | 4 | 3 | 2 | 1 | 0 |
|------------|---|---------|-------|---|---|---|---|---|
| Bit Name   |   | P1[1:0] | Mode1 |   |   |   |   |   |
| Read/Write | - | -       | -     | - | - | - | W | W |
| Reset      | 0 | 0       | 0     | 0 | 0 | 0 | 0 | 0 |

Figure 12-7. GPIO Port 1 Mode1 Register (Address 0x0D)

Bit [7:2]: Reserved

#### Bit [1:0]: P1[1:0] Mode 1

1 = Port Pin Mode 1 is logic HIGH

0 = Port Pin Mode 1 is logic LOW

Each pin can be independently configured as high-impedance inputs, inputs with internal pull-ups, open drain outputs, or traditional CMOS outputs with selectable drive strengths.

The driving state of each GPIO pin is determined by the value written to the pin's Data Register and by its associated Mode0 and Mode1 bits. *Table 12-1* lists the configuration states based on these bits. The GPIO ports default on reset to all Data and Mode Registers cleared, so the pins are all in a high-impedance state. The available GPIO output drive strength are:

• Hi-Z Mode (Mode1 = 0 and Mode0 = 0)

Q1, Q2, and Q3 (*Figure 12-1*) are OFF. The GPIO pin is not driven internally. Performing a read from the Port Data Register return the actual logic value on the port pins.

- Low Sink Mode (Mode1 = 1, Mode0 = 0, and the pin's Data Register = 0) Q1 and Q3 are OFF. Q2 is ON. The GPIO pin is capable of sinking 2 mA of current.
- Medium Sink Mode (Mode1 = 0, Mode0 = 1, and the pin's Data Register = 0) Q1 and Q3 are OFF. Q2 is ON. The GPIO pin is capable of sinking 8 mA of current.
- **High Sink Mode** (Mode1 = 1, Mode0 = 1, and the pin's Data Register = 0) Q1 and Q3 are OFF. Q2 is ON. The GPIO pin is capable of sinking 50 mA of current.
- **High Drive Mode** (Mode1 = 0 or 1, Mode0 = 1, and the pin's Data Register = 1) Q1 and Q2 are OFF. Q3 is ON. The GPIO pin is capable of sourcing 2 mA of current.
- **Resistive Mode** (Mode1 = 1, Mode0 = 0, and the pin's Data Register = 1)

Q2 and Q3 are OFF. Q1 is ON. The GPIO pin is pulled up with an internal 14-k $\Omega$  resistor.

Note that open drain mode can be achieved by fixing the Data and Mode1 Registers LOW, and switching the Mode0 register.

Input thresholds are CMOS, or TTL as shown in the table (See Section 23.0 for the input threshold voltage in TTL or CMOS modes). Both input modes include hysteresis to minimize noise sensitivity. In suspend mode, if a pin is used for a wake-up interrupt using an external R-C circuit, CMOS mode is preferred for lowest power.

| Data Register | Mode1 | Mode0 | Output Drive Strength | Input Threshold |
|---------------|-------|-------|-----------------------|-----------------|
| 0             |       |       | Hi-Z                  | CMOS            |
| 1             | 0     | 0     | Hi-Z                  | TTL             |
| 0             |       |       | Medium (8 mA) Sink    | CMOS            |
| 1             | 0     | 1     | High Drive            | CMOS            |
| 0             |       | _     | Low (2 mA) Sink       | CMOS            |
| 1             | 1     | 0     | Resistive             | CMOS            |
| 0             |       |       | High (50 mA) Sink     | CMOS            |
| 1             | 1     | 1     | High Drive            | CMOS            |

Table 12-1. Ports 0 and 1 Output Control Truth Table

### 12.1 Auxiliary Input Port

Port 2 serves as an auxiliary input port as shown in Figure 12-8. The Port 2 inputs all have TTL input thresholds.



#### Bit 3: USB Bus Activity

The Bus Activity bit is a "sticky" bit that detects any non-idle USB event has occurred on the USB bus. Once set to HIGH by the SIE to indicate the bus activity, this bit retains its logical HIGH value until firmware clears it. Writing a '0' to this bit clears it; writing a '1' preserves its value. The user firmware should check and clear this bit periodically to detect any loss of bus activity. Firmware can clear the Bus Activity bit, but only the SIE can set it. The 1.024-ms timer interrupt service routine is normally used to check and clear the Bus Activity bit.

1 = There has been bus activity since the last time this bit was cleared. This bit is set by the SIE.

0 = No bus activity since last time this bit was cleared (by firmware).

#### Bit [2:0]: D+/D– Forcing Bit [2:0]

Forcing bits allow firmware to directly drive the D+ and D– pins, as shown in *Table 13-1*. Outputs are driven with controlled edge rates in these modes for low EMI. For forcing the D+ and D– pins in USB mode, D+/D– Forcing Bit 2 should be 0. Setting D+/D– Forcing Bit 2 to '1' puts both pins in an open-drain mode, preferred for applications such as PS/2 or LED driving.

| Table 13-1. | Control | Modes to | Force | D+/D- | Outputs |
|-------------|---------|----------|-------|-------|---------|
|-------------|---------|----------|-------|-------|---------|

| D+/D- Forcing Bit [2:0] | Control Action                    | Application              |
|-------------------------|-----------------------------------|--------------------------|
| 000                     | Not forcing (SIE controls driver) | Any Mode                 |
| 001                     | Force K (D+ HIGH, D– LOW)         | USB Mode                 |
| 010                     | Force J (D+ LOW, D– HIGH)         |                          |
| 011                     | Force SE0 (D– LOW, D+ LOW)        |                          |
| 100                     | Force D– LOW, D+ LOW              | PS/2 Mode <sup>[2]</sup> |
| 101                     | Force D– LOW, D+ HiZ              |                          |
| 110                     | Force D– HiZ, D+ LOW              |                          |
| 111                     | Force D– HiZ, D+ HiZ              |                          |

Note:

2. For PS/2 operation, the D+/D- Forcing Bit [2:0] = 111b mode must be set initially (one time only) before using the other PS/2 force modes.



While this bit is set to '1', the CPU cannot write to the EP0 FIFO. This prevents firmware from overwriting an incoming SETUP transaction before firmware has a chance to read the SETUP data.

0 = No SETUP received. This bit is cleared by any non-locked writes to the register.

#### Bit 6: IN Received

1 = A valid IN packet has been received. This bit is updated to '1' after the last received packet in an IN transaction. This bit is cleared by any non-locked writes to the register.

0 = No IN received. This bit is cleared by any non-locked writes to the register.

#### Bit 5: OUT Received

1 = A valid OUT packet has been received. This bit is updated to '1' after the last received packet in an OUT transaction. This bit is cleared by any non-locked writes to the register.

0 = No OUT received. This bit is cleared by any non-locked writes to the register.

#### **Bit 4: ACKed Transaction**

The ACKed Transaction bit is set whenever the SIE engages in a transaction to the register's endpoint that completes with an ACK packet.

- 1 = The transaction completes with an ACK
- 0 = The transaction does not complete with an ACK

#### Bit [3:0]: Mode Bit[3:0]

The endpoint modes determine how the SIE responds to USB traffic that the host sends to the endpoint. For example, if the endpoint Mode Bits [3:0] are set to 0001 which is NAK IN/OUT mode as shown in *Table 20-1*, the SIE will send NAK hand-shakes in response to any IN or OUT token sent to this endpoint. In this NAK IN/OUT mode, the SIE will send an ACK handshake when the host sends a SETUP token to this endpoint. The mode encoding is shown in *Table 20-1*. Additional information on the mode bits can be found in *Table 20-2* and *Table 20-3*. These modes give the firmware total control on how to respond to different tokens sent to the endpoints from the host.

In addition, the Mode Bits are automatically changed by the SIE in response to many USB transactions. For example, if the Mode Bit [3:0] are set to 1011 which is ACK OUT-NAK IN mode as shown in *Table 20-1*, the SIE will change the endpoint Mode Bit [3:0] to NAK IN/OUT (0001) mode after issuing an ACK handshake in response to an OUT token. Firmware needs to update the mode for the SIE to respond appropriately.

#### 14.3 USB Non-Control Endpoints

The feature one non-control endpoint, endpoint 1 (EP1). The EP1 Mode Register does not have the locking mechanism of the EP0 Mode Register. The EP1 Mode Register uses the format shown in *Figure 14-3*. EP1 uses an 8-byte FIFO at SRAM locations 0xF0–0xF7 as shown in Section 8.2.

| Bit #      | 7     | 6     | 5     | 4                    | 3               | 2 | 1 | 0 |  |  |
|------------|-------|-------|-------|----------------------|-----------------|---|---|---|--|--|
| Bit Name   | STALL | Rese  | erved | ACKed<br>Transaction | Mode Bit        |   |   |   |  |  |
| Read/Write | R/W   | -     |       |                      | R/W R/W R/W R/V |   |   |   |  |  |
| Reset      | 0     | 0 0 0 |       | 0                    | 0               | 0 | 0 | 0 |  |  |

Figure 14-3. USB Endpoint EP1 Mode Registers (Address 0x14)

## Bit 7: STALL

1 = The SIE will stall an OUT packet if the Mode Bits are set to ACK-OUT, and the SIE will stall an IN packet if the mode bits are set to ACK-IN. See Section 20.0 for the available modes.

0 = This bit must be set to LOW for all other modes.

Bit [6:5]: Reserved. Must be written to zero during register writes.

### **Bit 4: ACKed Transaction**

The ACKed transaction bit is set whenever the SIE engages in a transaction to the register's endpoint that completes with an ACK packet.

1 = The transaction completes with an ACK.

0 = The transaction does not complete with an ACK.



## 19.2 Interrupt Latency

Interrupt latency can be calculated from the following equation:

Interrupt Latency = (Number of clock cycles remaining in the current instruction) + (10 clock cycles for the CALL instruction) + (5 clock cycles for the JMP instruction)

For example, if a 5-clock-cycle instruction such as JC is being executed when an interrupt occurs, the first instruction of the Interrupt Service Routine will execute a minimum of 16 clocks (1+10+5) or a maximum of 20 clocks (5+10+5) after the interrupt is issued. With a 6 MHz external resonator, internal CPU clock speed is 12 MHz, so 20 clocks take 20/12 MHz = 1.67  $\mu$ s.

### 19.3 Interrupt Sources

The following sections provide details on the different types of interrupt sources.

| Bit #      | 7                              | 6                           | 5 | 4        | 3 | 2                               | 1                             | 0                                                   |
|------------|--------------------------------|-----------------------------|---|----------|---|---------------------------------|-------------------------------|-----------------------------------------------------|
| Bit Name   | Wake-up<br>Interrupt<br>Enable | GPIO<br>Interrupt<br>Enable |   | Reserved |   | 1.024-ms<br>Interrupt<br>Enable | 128-μs<br>Interrupt<br>Enable | USB Bus<br>Reset /<br>PS/2 Activity<br>Intr. Enable |
| Read/Write | R/W                            | R/W                         | - | -        | - | R/W                             | R/W                           | R/W                                                 |
| Reset      | 0                              | 0                           | 0 | 0        | 0 | 0                               | 0                             | 0                                                   |

Figure 19-1. Global Interrupt Enable Register (Address 0x20)

#### Bit 7: Wake-up Interrupt Enable

The internal wake-up timer is normally used to wake the part from suspend mode, but it can also provide an interrupt when the part is awake. The wake-up timer is cleared whenever the Wake-up Interrupt Enable bit is written to a 0, and runs whenever that bit is written to a 1. When the interrupt is enabled, the wake-up timer provides periodic interrupts at multiples of period, as described in Section 11.2.

- 1 = Enable wake-up timer for periodic wake-up.
- 0 = Disable and power-off wake-up timer.

#### **Bit 6: GPIO Interrupt Enable**

Each GPIO pin can serve as an interrupt input. During a reset, GPIO interrupts are disabled by clearing all GPIO interrupt enable registers. Writing a '1' to a GPIO Interrupt Enable bit enables GPIO interrupts from the corresponding input pin. These registers are shown in *Figure 19-4* for Port 0 and *Figure 19-5* for Port 1. In addition to enabling the desired individual pins for interrupt, the main GPIO interrupt must be enabled, as explained in Section 19.0.

The polarity that triggers an interrupt is controlled independently for each GPIO pin by the GPIO Interrupt Polarity Registers. Setting a Polarity bit to '0' allows an interrupt on a falling GPIO edge, while setting a Polarity bit to '1' allows an interrupt on a rising GPIO edge. The Polarity Registers reset to 0 and are shown in *Figure 19-6* for Port 0 and *Figure 19-7* for Port 1.

All of the GPIO pins share a single interrupt vector, which means the firmware will need to read the GPIO ports with enabled interrupts to determine which pin or pins caused an interrupt. The GPIO interrupt structure is illustrated in *Figure 19-8*.

Note that if one port pin triggered an interrupt, no other port pins can cause a GPIO interrupt until that port pin has returned to its inactive (non-trigger) state or its corresponding port interrupt enable bit is cleared. The CY7C63221/31A does not assign interrupt priority to different port pins and the Port Interrupt Enable Registers are not affected by the interrupt acknowledge process.

1 = Enable

0 = Disable

#### Bit [5:3]: Reserved

#### Bit 2: 1.024-ms Interrupt Enable

The 1.024-ms interrupts are periodic timer interrupts from the free-running timer (based on the 6-MHz clock). The user should disable this interrupt before going into the suspend mode to avoid possible conflicts between servicing the timer interrupts (128-µs interrupt and 1.024-ms interrupt) first or the suspend request first when waking up.

1 = Enable. Periodic interrupts will be generated approximately every 1.024 ms.

0 = Disable.



The polarity that triggers an interrupt is controlled independently for each GPIO pin by the GPIO Interrupt Polarity Registers. *Figure 19-6* and *Figure 19-7* control the interrupt polarity of each GPIO pin.

| Bit #      | 7 | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
|------------|---|-----------------------|---|---|---|---|---|---|--|--|--|--|
| Bit Name   |   | P0 Interrupt Polarity |   |   |   |   |   |   |  |  |  |  |
| Read/Write | W | W                     | W | W | W | W | W | W |  |  |  |  |
| Reset      | 0 | 0                     | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |

Figure 19-6. Port 0 Interrupt Polarity Register (Address 0x06)

### Bit [7:0]: P0[7:0] Interrupt Polarity

1 = Rising GPIO edge

0 = Falling GPIO edge

| Bit #      | 7 | 6 | 5 | 4                          | 3 | 2 | 1 | 0 |
|------------|---|---|---|----------------------------|---|---|---|---|
| Bit Name   |   |   |   | P1[1:0] Interrupt Polarity |   |   |   |   |
| Read/Write | - | - | - | -                          | - | - | W | W |
| Reset      | 0 | 0 | 0 | 0                          | 0 | 0 | 0 | 0 |

Figure 19-7. Port 1 Interrupt Polarity Register (Address 0x07)

#### Bit [7:0]: P1[7:0] Interrupt Polarity

1 = Rising GPIO edge

0 = Falling GPIO edge



Figure 19-8. GPIO Interrupt Diagram



## 20.0 USB Mode Tables

The following tables give details on mode setting for the USB Serial Interface Engine (SIE) for both the control endpoint (EP0) and non-control endpoint (EP1).

| Mode                                                                                    | Encoding     | SETUP            | IN                | OUT              | Comments                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------|--------------|------------------|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Disable                                                                                 | 0000         | Ignore           | Ignore            | Ignore           | Ignore all USB traffic to this endpoint                                                                                                                                                                                                                       |
| NAK IN/OUT                                                                              | 0001         | Accept           | NAK               | NAK              | On Control endpoint, after successfully sending an ACK handshake to a SETUP packet, the SIE forces the endpoint mode (from modes other than 0000) to 0001. The mode is also changed by the SIE to 0001 from mode 1011 on issuance of ACK handshake to an OUT. |
| Status OUT Only                                                                         | 0010         | Accept           | STALL             | Check            | For Control endpoints                                                                                                                                                                                                                                         |
| STALL IN/OUT                                                                            | 0011         | Accept           | STALL             | STALL            | For Control endpoints                                                                                                                                                                                                                                         |
| Ignore IN/OUT                                                                           | 0100         | Accept           | Ignore            | Ignore           | For Control endpoints                                                                                                                                                                                                                                         |
| Reserved                                                                                | 0101         | Ignore           | Ignore            | Always           | Reserved                                                                                                                                                                                                                                                      |
| Status IN Only                                                                          | 0110         | Accept           | TX 0 Byte         | STALL            | For Control Endpoints                                                                                                                                                                                                                                         |
| Reserved                                                                                | 0111         | Ignore           | TX Count          | Ignore           | Reserved                                                                                                                                                                                                                                                      |
| NAK OUT                                                                                 | 1000         | Ignore           | Ignore            | NAK              | In mode 1001, after sending an ACK handshake to an OUT, the SIE changes the mode to 1000                                                                                                                                                                      |
| $\begin{array}{l} ACK \ OUT(STALL^{[3]} = 0) \\ ACK \ OUT(STALL^{[3]} = 1) \end{array}$ | 1001<br>1001 | lgnore<br>Ignore | Ignore<br>Ignore  | ACK<br>STALL     | This mode is changed by the SIE to mode 1000 on issuance of ACK handshake to an OUT                                                                                                                                                                           |
| NAK OUT - Status IN                                                                     | 1010         | Accept           | TX 0 Byte         | NAK              |                                                                                                                                                                                                                                                               |
| ACK OUT - NAK IN                                                                        | 1011         | Accept           | NAK               | ACK              | This mode is changed by the SIE to mode 0001 on issuance of ACK handshake to an OUT                                                                                                                                                                           |
| NAK IN                                                                                  | 1100         | Ignore           | NAK               | Ignore           | An ACK from mode 1101 changes the mode to 1100                                                                                                                                                                                                                |
| ACK IN(STALL <sup>[3]</sup> =0)<br>ACK IN(STALL <sup>[3]</sup> =1)                      | 1101<br>1101 | lgnore<br>Ignore | TX Count<br>STALL | lgnore<br>Ignore | This mode is changed by the SIE to mode 1100 on issuance of ACK handshake to an IN                                                                                                                                                                            |
| NAK IN - Status OUT                                                                     | 1110         | Accept           | NAK               | Check            | An ACK from mode 1111 changes the mode to 1110                                                                                                                                                                                                                |
| ACK IN - Status OUT                                                                     | 1111         | Accept           | TX Count          | Check            | This mode is changed by the SIE to mode 1110 on issuance of ACK handshake to an IN                                                                                                                                                                            |

Table 20-1. USB Register Mode Encoding for Control and Non-Control Endpoint

Note:

3. STALL bit is the bit 7 of the USB Non-Control Device Endpoint Mode registers. Refer to Section 14.3 for more explanation.

#### Mode Column:

The 'Mode' column contains the mnemonic names given to the modes of the endpoint. The mode of the endpoint is determined by the 4 bit binaries in the 'Encoding' column as discussed below. The Status IN and Status OUT modes represent the status IN or OUT stage of the control transfer.

#### **Encoding Column:**

The contents of the 'Encoding' column represent the Mode Bits [3:0] of the Endpoint Mode Registers (*Figure 14-2* and *Figure 14-3*). The endpoint modes determine how the SIE responds to different tokens that the host sends to the endpoints. For example, if the Mode Bits [3:0] of the Endpoint 0 Mode Register (*Figure 14-2*) are set to '0001', which is NAK IN/OUT mode as shown in Table 20-1 above, the SIE of the part will send an ACK handshake in response to SETUP tokens and NAK any IN or OUT tokens. For more information on the functionality of the Serial Interface Engine (SIE), see Section 13.0.

#### SETUP, IN, and OUT Columns:

Depending on the mode specified in the 'Encoding' column, the 'SETUP', 'IN', and 'OUT' columns contain the device SIE's responses when the endpoint receives SETUP, IN, and OUT tokens respectively.

A 'Check' in the Out column means that upon receiving an OUT token the SIE checks to see whether the OUT is of zero length and has a Data Toggle (Data1/0) of 1. If these conditions are true, the SIE responds with an ACK. If any of the above conditions is not met, the SIE will respond with either a STALL or Ignore. Table 20-3 gives detailed analysis of all possible cases.

A 'TX Count' entry in the IN column means that the SIE will transmit the number of bytes specified in the Byte Count Bit [3:0] of the Endpoint Count Register (*Figure 14-4*) in response to any IN token.



### Table 20-2. Decode table for Table 20-3: "Details of Modes for Differing Traffic Conditions"



The response of the SIE can be summarized as follows:

- 1. The SIE will only respond to valid transactions, and will ignore non-valid ones.
- 2. The SIE will generate an interrupt when a valid transaction is completed or when the FIFO is corrupted. FIFO corruption occurs during an OUT or SETUP transaction to a valid internal address, that ends with a non-valid CRC.
- 3. An incoming Data packet is valid if the count is < Endpoint Size + 2 (includes CRC) and passes all error checking;
- 4. An IN will be ignored by an OUT configured endpoint and visa versa.
- 5. The IN and OUT PID status is updated at the end of a transaction.
- 6. The SETUP PID status is updated at the beginning of the Data packet phase.
- 7. The entire Endpoint 0 mode register and the Count register are locked to CPU writes at the end of any transaction to that endpoint in which an ACK is transferred. These registers are only unlocked by a CPU read of these registers, and only if that read happens after the transaction completes. This represents about a 1-μs window in which the CPU is locked from register writes to these USB registers. Normally the firmware should perform a register read at the beginning of the Endpoint ISRs to unlock and get the mode register information. The interlock on the Mode and Count registers ensures that the firmware recognizes the changes that the SIE might have made during the previous transaction.



## Table 20-3. Details of Modes for Differing Traffic Conditions(continued)

| IUN |                 |      |      |           | mouo             | 5 101 011 | ioning in |         | lancionio | oomanae | u)    |    |     |     |     |       |            |                  |
|-----|-----------------|------|------|-----------|------------------|-----------|-----------|---------|-----------|---------|-------|----|-----|-----|-----|-------|------------|------------------|
| 3   | 2               | 1    | 0    | token     | count            | buffer    | dval      | DTOG    | DVAL      | COUNT   | SETUP | IN | OUT | ACK | 3 2 | 2 1 0 | response   | int              |
| 1   | 1               | 1    | 0    | OUT       | х                | UC        | invalid   | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 1               | 1    | 0    | IN        | x                | UC        | х         | UC      | UC        | UC      | UC    | 1  | UC  | UC  | NoC | hange | NAK        | yes              |
| Sta | Status OUT Only |      |      |           |                  |           |           |         |           |         |       |    |     |     |     |       |            |                  |
| 0   | 0               | 1    | 0    | OUT       | 2                | UC        | valid     | 1       | 1         | updates | UC    | UC | 1   | 1   | NoC | hange | ACK        | yes              |
| 0   | 0               | 1    | 0    | OUT       | 2                | UC        | valid     | 0       | 1         | updates | UC    | UC | 1   | UC  | 0 0 | 1 1   | STALL      | yes              |
| 0   | 0               | 1    | 0    | OUT       | !=2              | UC        | valid     | updates | 1         | updates | UC    | UC | 1   | UC  | 0 0 | 1 1   | STALL      | yes              |
| 0   | 0               | 1    | 0    | OUT       | > 10             | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 0   | 0               | 1    | 0    | OUT       | х                | UC        | invalid   | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 0   | 0               | 1    | 0    | IN        | x                | UC        | х         | UC      | UC        | UC      | UC    | 1  | UC  | UC  | 0 0 | 1 1   | STALL      | yes              |
| οι  | JT E            | End  | poi  | int       |                  |           |           |         |           |         |       |    |     |     |     |       |            |                  |
| AC  | к               | רטכ  | ī, S | TALL Bi   | t = 0 ( <i>F</i> | igure 14  | -3)       |         |           |         |       |    |     |     |     |       |            |                  |
| 1   | 0               | 0    | 1    | OUT       | <= 10            | data      | valid     | updates | 1         | updates | UC    | UC | 1   | 1   | 1 0 | 0 0   | ACK        | yes              |
| 1   | 0               | 0    | 1    | OUT       | > 10             | junk      | x         | updates | updates   | updates | UC    | UC | 1   | UC  | NoC | hange | Ignore     | yes              |
| 1   | 0               | 0    | 1    | OUT       | х                | junk      | invalid   | updates | 0         | updates | UC    | UC | 1   | UC  | NoC | hange | Ignore     | yes              |
| 1   | 0               | 0    | 1    | IN        | х                | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| AC  | к               | רטכ  | , S  | TALL Bi   | t = 1 ( <i>F</i> | igure 14  | -3)       | •       | •         | •       | •     |    |     | •   |     |       | •          |                  |
| 1   | 0               | 0    | 1    | OUT       | <= 10            | UC        | valid     | UC      | UC        | UC      | UC    | UC | 1   | UC  | NoC | hange | STALL      | yes              |
| 1   | 0               | 0    | 1    | OUT       | > 10             | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 0               | 0    | 1    | OUT       | х                | UC        | invalid   | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 0               | 0    | 1    | IN        | x                | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| NA  | NK (            | רטכ  |      |           |                  |           |           |         |           |         |       |    |     |     |     |       |            |                  |
| 1   | 0               | 0    | 0    | OUT       | <= 10            | UC        | valid     | UC      | UC        | UC      | UC    | UC | 1   | UC  | NoC | hange | NAK        | yes              |
| 1   | 0               | 0    | 0    | OUT       | > 10             | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 0               | 0    | 0    | OUT       | х                | UC        | invalid   | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 0               | 0    | 0    | IN        | х                | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| Re  | ser             | ved  |      |           |                  |           |           |         |           |         |       |    |     |     |     |       |            |                  |
| 0   | 1               | 0    | 1    | OUT       | х                | updates   | updates   | updates | updates   | updates | UC    | UC | 1   | 1   | NoC | hange | RX         | yes              |
| 0   | 1               | 0    | 1    | IN        | х                | UC        | х         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| IN  | End             | dpo  | int  |           |                  |           |           |         |           |         |       |    |     |     |     |       |            |                  |
| AC  | K I             | N, S | ST/  | ALL Bit = | • 0 (Fig         | ure 14-3  | )         |         |           |         |       |    |     |     |     |       |            |                  |
| 1   | 1               | 0    | 1    | OUT       | x                | UC        | x         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 1               | 0    | 1    | IN        | х                | UC        | x         | UC      | UC        | UC      | UC    | 1  | UC  | 1   | 1 1 | 0 0   | ACK (back) | yes              |
| AC  | K I             | N, S | ST/  | ALL Bit = | 1 (Fig           | ure 14-3  | )         |         | •         |         |       | •  | 1   |     |     |       |            | •                |
| 1   | 1               | 0    | 1    | OUT       | x                | UC        | x         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 1               | 0    | 1    | IN        | х                | UC        | x         | UC      | UC        | UC      | UC    | 1  | UC  | UC  | NoC | hange | STALL      | yes              |
|     | NK I            |      |      |           |                  | I         | L         | 1       | 1         | I       | 1     |    | 1   | 1   |     |       | 1          |                  |
| 1   | 1               | 0    | 0    | OUT       | х                | UC        | x         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 1   | 1               | 0    | 0    | IN        | x                | UC        | x         | UC      | UC        | UC      | UC    | 1  | UC  | UC  |     | hange | NAK        | yes              |
| Re  | ser             |      |      |           | 1                | 1         | I         | 1       | 1         | 1       | 1     | 1  | 1   | 1   | 1   |       | 1          | <u> </u>         |
| 0   | 1               | 1    | 1    | Out       | x                | UC        | x         | UC      | UC        | UC      | UC    | UC | UC  | UC  | NoC | hange | Ignore     | no               |
| 0   | 1               | 1    | 1    | IN        | x                | UC        | x         | UC      | UC        | UC      | UC    | 1  | UC  | UC  |     | hange | TX         | yes              |
| -   |                 |      |      |           | 1                |           |           |         |           |         |       | 1  |     |     |     | - 35  | 1          | , . <del>.</del> |



# 21.0 Register Summary

|                                      | Address       | Register Name             | Bit 7                                                                                                                                                                                | Bit 6                       | Bit 5                                               | Bit 4                | Bit 3                          | Bit 2                                                                                               | Bit 1                         | Bit 0                                             | Read/Write)/<br>Both(B) | Default/<br>Reset      |
|--------------------------------------|---------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------------------------|----------------------|--------------------------------|-----------------------------------------------------------------------------------------------------|-------------------------------|---------------------------------------------------|-------------------------|------------------------|
|                                      | 0x00          | Port 0 Data               | PO                                                                                                                                                                                   |                             |                                                     |                      |                                |                                                                                                     |                               |                                                   |                         | 00000000               |
| 4D 2                                 | 0x01          | Port 1 Data               | Reserved P1[1:0]                                                                                                                                                                     |                             |                                                     |                      |                                |                                                                                                     |                               |                                                   |                         | 00000000               |
| GPIO CONFIGURATION PORTS 0, 1, AND 2 | 0x02          | Port 2 Data               | Reserved         D+(SCLK)<br>State         D-(SDATA)<br>State         Reserved         P2.2(Int Clk<br>Mode only)         P2.1 (Int Clk<br>Mode only)         P2.0 Vreg<br>Pin State |                             |                                                     |                      |                                |                                                                                                     |                               | RR-RRR                                            | 00000000                |                        |
| TS (                                 | 0x0A          | GPIO Port 0 Mode 0        |                                                                                                                                                                                      |                             |                                                     | P0[7:0]              | Mode0                          |                                                                                                     |                               |                                                   | www.www.ww              | 00000000               |
| POR                                  | 0x0B          | GPIO Port 0 Mode 1        |                                                                                                                                                                                      |                             |                                                     | P0[7:0]              | Mode1                          |                                                                                                     |                               |                                                   | www.www.ww              | 00000000               |
| NO                                   | 0x0C          | GPIO Port 1 Mode 0        |                                                                                                                                                                                      |                             | Rese                                                | erved                |                                |                                                                                                     | P1[1:0]                       | Mode0                                             | WW                      | 00000000               |
| RATI                                 | 0x0D          | GPIO Port 1 Mode 1        |                                                                                                                                                                                      |                             | Rese                                                | erved                |                                |                                                                                                     | P1[1:0]                       | Mode1                                             | WW                      | 00000000               |
| IGUF                                 | 0x04          | Port 0 Interrupt Enable   |                                                                                                                                                                                      |                             |                                                     | P0[7:0] Inte         | rrupt Enable                   |                                                                                                     |                               |                                                   | www.www                 | 00000000               |
| ONF                                  | 0x05          | Port 1 Interrupt Enable   |                                                                                                                                                                                      |                             | Rese                                                | erved                |                                |                                                                                                     | P1[1:0] Inte                  | rrupt Enable                                      | WW                      | 00000000               |
| Ŭ<br>O                               | 0x06          | Port 0 Interrupt Polarity |                                                                                                                                                                                      |                             |                                                     | P0[7:0] Inte         | rrupt Polarity                 |                                                                                                     |                               |                                                   | www.www.ww              | 00000000               |
| GPI                                  | 0x07          | Port 1 Interrupt Polarity |                                                                                                                                                                                      |                             | Rese                                                | erved                |                                |                                                                                                     | P1[1:0] Inter                 | rrupt Polarity                                    | WW                      | 00000000               |
| Clock<br>Config.                     | 0xF8          | Clock Configuration       | Ext. Clock<br>Resume<br>Delay                                                                                                                                                        | Wake-u                      | p Timer Adjust                                      | Bit [2:0]            | LowVoltage<br>Reset<br>Disable | Precision<br>USB<br>Clocking<br>Enable<br>USB<br>Output<br>Disable<br>Clock<br>Oscillator<br>Enable |                               |                                                   | BBBBBBBB                | 0000000                |
| ENDPOINT 0, I AND 2<br>CONFIGURATION | 0x10          | USB Device Address        | Device<br>Address<br>Enable                                                                                                                                                          |                             |                                                     | I                    | Device Addres                  | S                                                                                                   |                               | 1                                                 | BBBBBBBB                | 00000000               |
| NT 0, I<br>IFIGUR                    | 0x12          | EP0 Mode                  | SETUP<br>Received                                                                                                                                                                    | IN<br>Received              | OUT<br>Received                                     | ACKed<br>Transaction |                                | Mod                                                                                                 | le Bit                        |                                                   | BBBBBBBB                | 00000000               |
|                                      | 0x14          | EP1 Mode Register         | STALL                                                                                                                                                                                | Rese                        | erved                                               | ACKed<br>Transaction |                                | Mod                                                                                                 | le Bit                        |                                                   | BBBBBB                  | 00000000               |
| Ľ                                    | 0x11,<br>0x13 | EP0 and 1Counter          | Data 0/1<br>Toggle                                                                                                                                                                   | Data Valid                  | Rese                                                | erved                |                                | Byte                                                                                                | Count                         |                                                   | BBBBBB                  | 00000000               |
| USB-<br>SC                           | 0x1F          | USB Status and Control    | PS/2 Pull-<br>up<br>Enable                                                                                                                                                           | VREG<br>Enable              | USB Reset-<br>PS/2<br>Activity<br>Interrupt<br>Mode | Reserved             | USB Bus<br>Activity            | C                                                                                                   | )+/D- Forcing E               | Bit                                               | BBB-BBBB                | 0000000                |
| RUPT                                 | 0x20          | Global Interrupt Enable   | Wake-up<br>Interrupt<br>Enable                                                                                                                                                       | GPIO<br>Interrupt<br>Enable |                                                     | Reserved             |                                | 1.024 ms<br>Interrupt<br>Enable                                                                     | 128 μs<br>Interrupt<br>Enable | USB Bus<br>Reset-PS/2<br>Activity Intr.<br>Enable | BBBBB                   | 00000000               |
| INTERRUPT                            | 0x21          | Endpoint Interrupt Enable |                                                                                                                                                                                      |                             | Rese                                                | erved                |                                |                                                                                                     | ВВ                            | 0000000                                           |                         |                        |
| æ                                    | 0x24          | Timer LSB                 |                                                                                                                                                                                      |                             |                                                     | Timer                | Bit [7:0]                      |                                                                                                     |                               | 1                                                 | RRRRRRR                 | 00000000               |
| TIMER                                | 0x25          | Timer (MSB)               |                                                                                                                                                                                      | Rese                        | erved                                               |                      |                                | Timer E                                                                                             | Bit [11:8]                    |                                                   | RRRR                    | 00000000               |
| PROC<br>SC.                          | 0xFF          | Process Status & Control  | IRQ<br>Pending                                                                                                                                                                       | Watch Dog<br>Reset          | Bus<br>Interrupt<br>Event                           | LVR/BOR<br>Reset     | Suspend                        | Interrupt<br>Enable<br>Sense                                                                        | Reserved                      | Run                                               | RBBBBR-B                | See<br>Section<br>18.0 |



#### 18-Lead (300-Mil) Molded SOIC S1





*Table 26-1* below shows the die pad coordinates for the CY7C63221A-XC. The center location of each bond pad is relative to the center of the die which has coordinate (0,0) as shown above.

| Pad Number | Pin Name | X<br>(microns) | Y<br>(microns) |  |  |
|------------|----------|----------------|----------------|--|--|
| 1          | P0.0     | -351.75        | 995.00         |  |  |
| 2          | P0.1     | -543.20        | 995.00         |  |  |
| 3          | P0.2     | -734.65        | 995.00         |  |  |
| 4          | P0.3     | -861.05        | 779.25         |  |  |
| 5          | P1.0     | -861.05        | 587.80         |  |  |
| 6          | Vss      | -861.05        | -949.65        |  |  |
| 7          | Vpp      | -468.20        | -968.10        |  |  |
| 8          | VREG     | -300.40        | -968.10        |  |  |
| 9          | XTALIN   | 63.30          | -968.10        |  |  |
| 10         | XTALOUT  | 207.50         | -968.10        |  |  |
| 11         | Vcc      | 594.60         | -968.10        |  |  |
| 12         | D-       | 771.35         | -968.10        |  |  |
| 13         | D+       | 844.05         | -863.10        |  |  |
| 14         | P1.1     | 861.05         | 581.95         |  |  |
| 15         | P0.7     | 861.05         | 773.95         |  |  |
| 16         | P0.6     | 720.15         | 995.00         |  |  |
| 17         | P0.5     | 528.70         | 995.00         |  |  |
| 18         | P0.4     | 337.25         | 995.00         |  |  |

#### Table 26-1. CY7C63221A-XC Probe Pad Coordinates in microns ((0,0) to bond pad centers)

enCoRe is a trademark of Cypress Semiconductor Corporation. All product and company names mentioned in this document may be the trademarks of their respective holders.

© Cypress Semiconductor Corporation, 2002. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress Semiconductor product. Nor does it convey or imply any license under patent or other rights. Cypress Semiconductor does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress Semiconductor products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress Semiconductor against all charges.