# E·XFL



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 charific microcontrollars are analyzared to

#### Details

| Detalls                 |                                                                             |
|-------------------------|-----------------------------------------------------------------------------|
| Product Status          | Obsolete                                                                    |
| Applications            | USB Hub/Microcontroller                                                     |
| Core Processor          | M8                                                                          |
| Program Memory Type     | OTP (8kB)                                                                   |
| Controller Series       | USB Hub                                                                     |
| RAM Size                | 256 x 8                                                                     |
| Interface               | I <sup>2</sup> C, USB, HAPI                                                 |
| Number of I/O           | 31                                                                          |
| Voltage - Supply        | 4V ~ 5.25V                                                                  |
| Operating Temperature   | 0°C ~ 70°C                                                                  |
| Mounting Type           | Surface Mount                                                               |
| Package / Case          | 56-BSSOP (0.295", 7.50mm Width)                                             |
| Supplier Device Package | 56-SSOP                                                                     |
| Purchase URL            | https://www.e-xfl.com/product-detail/infineon-technologies/cy7c66113c-pvxct |
|                         |                                                                             |

Email: info@E-XFL.COM

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





#### Clock

The microcontroller uses an external 6 MHz crystal and an internal oscillator to provide a reference to an internal PLL based clock generator. This technology allows the customer application to use an inexpensive 6 MHz fundamental crystal that reduces the clock related noise emissions (EMI). A PLL clock generator provides the 6, 12, and 48 MHz clock signals for distribution within the microcontroller.

#### Memory

The CY7C66013C and CY7C66113C have 8 kB of PROM.

#### Power on Reset, Watchdog, and Free Running Timer

These parts include POR logic, a WDT, and a 12-bit free-running timer. The POR logic detects when power is applied to the device, resets the logic to a known state, and begins executing instructions at PROM address 0x0000. The WDT is used to ensure that the microcontroller recovers after a period of inactivity. The firmware may become inactive for a variety of reasons, including errors in the code or a hardware failure such as waiting for an interrupt that never occurs.

#### I<sup>2</sup>C and HAPI Interface

The microcontroller communicates with external electronics through the GPIO pins. An  $I^2C$  compatible interface accommodates a 100 kHz serial link with an external device. There is also a HAPI to transfer data to an external device.

#### Timer

The free-running 12-bit timer clocked at 1 MHz provides two interrupt sources, 128  $\mu$ s and 1.024 ms. The timer is used to measure the duration of an event under firmware control by reading the timer at the start of the event and after the event is complete. The difference between the two readings indicates the duration of the event in microseconds. The upper four bits of the timer are latched into an internal register when the firmware reads the lower eight bits. A read from the upper four bits actually reads data from the internal register, instead of the timer. This feature eliminates the need for firmware to try to compensate if the upper four bits increment immediately after the lower eight bits are read.

#### Interrupts

The microcontroller supports eleven maskable interrupts in the vectored interrupt controller. Interrupt sources include the 128 us (bit 6) and 1.024 ms (bit 9) outputs from the free-running timer, five USB endpoints, the USB hub, the DAC port, the GPIO ports, and the I<sup>2</sup>C compatible master mode interface. The timer bits cause an interrupt (if enabled) when the bit toggles from LOW '0' to HIGH '1.' The USB endpoints interrupt after the USB host has written data to the endpoint FIFO or after the USB controller sends a packet to the USB host. The DAC ports have an additional level of masking that allows the user to select which DAC inputs causes a DAC interrupt. The GPIO ports also have a level of masking to select which GPIO inputs causes a GPIO interrupt. For additional flexibility, the input transition polarity that causes an interrupt is programmable for each pin of the DAC port. Input transition polarity is programmed for each GPIO port as part of the port configuration. The interrupt polarity can be rising edge ('0' to '1') or falling edge ('1' to '0').

#### USB

The CY7C66013C and CY7C66113C include an integrated USB Serial Interface Engine (SIE) that supports the integrated peripherals and the hub controller function. The hardware supports up to two USB device addresses with one device address for the hub (two endpoints) and a device address for a compound device (three endpoints). The SIE allows the USB host to communicate with the hub and functions integrated into the microcontroller. The part includes a 1:4 hub repeater with one upstream port and four downstream ports. The USB Hub allows power management control of the downstream ports by using GPIO pins assigned by the user firmware. The user has the option of ganging the downstream ports together with a single pair of power management pins, or providing power management for each port with four pairs of power management pins.



## CY7C66013C/CY7C66113C

## Contents

| Pin Configurations                               | 5  |
|--------------------------------------------------|----|
| Product Summary Tables                           | 9  |
| Pin Assignments                                  | 9  |
| I/O Register Summary                             | 9  |
| Instruction Set Summary                          | 11 |
| Programming Model                                | 12 |
| 14-bit Program Counter (PC)                      | 12 |
| 8-bit Accumulator (A)                            |    |
| 8-bit Temporary Register (X)                     |    |
| 8-bit Program Stack Pointer (PSP)                | 13 |
| 8-bit Data Stack Pointer (DSP)                   | 13 |
| Address Modes                                    |    |
| Clocking                                         | 14 |
| Reset                                            | 15 |
| Power on Reset                                   | 15 |
| Watchdog Reset                                   | 15 |
| Suspend Mode                                     |    |
| General Purpose I/O (GPIO) Ports                 | 16 |
| GPIO Configuration Port                          | 18 |
| GPIO Interrupt Enable Ports                      | 19 |
| DAC Port                                         |    |
| DAC Isink Registers                              | 21 |
| DAC Port Interrupts                              | 21 |
| 12-bit Free-Running Timer                        | 22 |
| I <sup>2</sup> C and HAPI Configuration Register |    |
| I <sup>2</sup> C Compatible Controller           |    |
| Hardware Assisted Parallel Interface (HAPI)      |    |
| Processor Status and Control Register            | 27 |
| Interrupts                                       |    |
| Interrupt Vectors                                |    |
| Interrupt Latency                                |    |
| USB Bus Reset Interrupt                          |    |
| Timer Interrupt                                  |    |
| USB Endpoint Interrupts                          |    |
| USB Hub Interrupt                                |    |
| DAC Interrupt                                    |    |
| GPIO and HAPI Interrupt                          |    |
| I <sup>2</sup> C Interrupt                       | 32 |

| USB Overview                              | 32 |
|-------------------------------------------|----|
| USB Serial Interface Engine               | 32 |
| USB Enumeration                           | 32 |
| USB Hub                                   | 33 |
| Connecting and Disconnecting a USB Device | 33 |
| Enabling and Disabling a USB Device       | 34 |
| Hub Downstream Ports Status and Control   | 35 |
| Downstream Port Suspend and Resume        | 36 |
| USB Upstream Port Status and Control      | 38 |
| USB SIE Operation                         |    |
| USB Device Addresses                      | 39 |
| USB Device Endpoints                      |    |
| USB Control Endpoint Mode Registers       |    |
| USB Non Control Endpoint Mode Registers   | 41 |
| USB Endpoint Counter Registers            | 41 |
| Endpoint Mode and Count Registers Update  |    |
| and Locking Mechanism                     |    |
| USB Mode Tables                           |    |
| Register Summary                          |    |
| Sample Schematic                          |    |
| Absolute Maximum Ratings                  |    |
| Electrical Characteristics                | -  |
| Switching Characteristics                 |    |
| Ordering Information                      |    |
| Ordering Code Definitions                 |    |
| Package Diagrams                          | 56 |
| Quad Flat Package No Leads (QFN)          | _  |
| Package Design Notes                      |    |
| Acronyms                                  |    |
| Document Conventions                      |    |
| Units of Measure                          |    |
| Document History Page                     |    |
| Sales, Solutions, and Legal Information   |    |
| Worldwide Sales and Design Support        |    |
| Products                                  |    |
| PSoC® Solutions                           |    |
| Cypress Developer Community               |    |
| Technical Support                         | 61 |





## Instruction Set Summary

Refer to the CYASM Assembler User's Guide for more details.

### Table 4. Instruction Set Summary

| Mnemonic       | Operand | Opcode | Cycles |
|----------------|---------|--------|--------|
| HALT           |         | 00     | 7      |
| ADD A,expr     | data    | 01     | 4      |
| ADD A,[expr]   | direct  | 02     | 6      |
| ADD A,[X+expr] | index   | 03     | 7      |
| ADC A,expr     | data    | 04     | 4      |
| ADC A,[expr]   | direct  | 05     | 6      |
| ADC A,[X+expr] | index   | 06     | 7      |
| SUB A,expr     | data    | 07     | 4      |
| SUB A,[expr]   | direct  | 08     | 6      |
| SUB A,[X+expr] | index   | 09     | 7      |
| SBB A,expr     | data    | 0A     | 4      |
| SBB A,[expr]   | direct  | 0B     | 6      |
| SBB A,[X+expr] | index   | 0C     | 7      |
| OR A,expr      | data    | 0D     | 4      |
| OR A,[expr]    | direct  | 0E     | 6      |
| OR A,[X+expr]  | index   | 0F     | 7      |
| AND A,expr     | data    | 10     | 4      |
| AND A,[expr]   | direct  | 11     | 6      |
| AND A,[X+expr] | index   | 12     | 7      |
| XOR A,expr     | data    | 13     | 4      |
| XOR A,[expr]   | direct  | 14     | 6      |
| XOR A,[X+expr] | index   | 15     | 7      |
| CMP A,expr     | data    | 16     | 5      |
| CMP A,[expr]   | direct  | 17     | 7      |
| CMP A,[X+expr] | index   | 18     | 8      |
| MOV A,expr     | data    | 19     | 4      |
| MOV A,[expr]   | direct  | 1A     | 5      |
| MOV A,[X+expr] | index   | 1B     | 6      |
| MOV X,expr     | data    | 1C     | 4      |
| MOV X,[expr]   | direct  | 1D     | 5      |
| reserved       |         | 1E     |        |
| XPAGE          |         | 1F     | 4      |
| MOV A,X        |         | 40     | 4      |
| MOV X,A        |         | 41     | 4      |
| MOV PSP,A      |         | 60     | 4      |
| CALL           | addr    | 50-5F  | 10     |
| JMP            | addr    | 80-8F  | 5      |
| CALL           | addr    | 90-9F  | 10     |
| JZ             | addr    | A0-AF  | 5      |
| JNZ            | addr    | B0-BF  | 5      |

| Mnemonic       | Operand | Opcode | Cycles |
|----------------|---------|--------|--------|
| NOP            |         | 20     | 4      |
| INC A          | acc     | 21     | 4      |
| INC X          | х       | 22     | 4      |
| INC [expr]     | direct  | 23     | 7      |
| INC [X+expr]   | index   | 24     | 8      |
| DEC A          | acc     | 25     | 4      |
| DEC X          | Х       | 26     | 4      |
| DEC [expr]     | direct  | 27     | 7      |
| DEC [X+expr]   | index   | 28     | 8      |
| IORD expr      | address | 29     | 5      |
| IOWR expr      | address | 2A     | 5      |
| POP A          |         | 2B     | 4      |
| POP X          |         | 2C     | 4      |
| PUSH A         |         | 2D     | 5      |
| PUSH X         |         | 2E     | 5      |
| SWAP A,X       |         | 2F     | 5      |
| SWAP A,DSP     |         | 30     | 5      |
| MOV [expr],A   | direct  | 31     | 5      |
| MOV [X+expr],A | index   | 32     | 6      |
| OR [expr],A    | direct  | 33     | 7      |
| OR [X+expr],A  | index   | 34     | 8      |
| AND [expr],A   | direct  | 35     | 7      |
| AND [X+expr],A | index   | 36     | 8      |
| XOR [expr],A   | direct  | 37     | 7      |
| XOR [X+expr],A | index   | 38     | 8      |
| IOWX [X+expr]  | index   | 39     | 6      |
| CPL            |         | 3A     | 4      |
| ASL            |         | 3B     | 4      |
| ASR            |         | 3C     | 4      |
| RLC            |         | 3D     | 4      |
| RRC            |         | 3E     | 4      |
| RET            |         | 3F     | 8      |
| DI             |         | 70     | 4      |
| EI             |         | 72     | 4      |
| RETI           |         | 73     | 8      |
| JC             | addr    | C0-CF  | 5      |
| JNC            | addr    | D0-DF  | 5      |
| JACC           | addr    | E0-EF  | 7      |
| INDEX          | addr    | F0-FF  | 14     |



#### **Address Modes**

The CY7C66013C and CY7C66113C microcontrollers support three addressing modes for instructions that require data operands: data, direct, and indexed.

#### Data (Immediate)

"Data" address mode refers to a data operand that is actually a constant encoded in the instruction. As an example, consider the instruction that loads A with the constant 0xD8:

MOV A, 0D8h.

This instruction requires two bytes of code where the first byte identifies the "MOV A" instruction with a data operand as the second byte. The second byte of the instruction is the constant "0xD8". A constant may be referred to by name if a prior "EQU" statement assigns the constant value to the name. For example, the following code is equivalent to the example described earlier: DSPINIT: EQU 0D8h

MOV A, DSPINIT.

#### Direct

"Direct" address mode is used when the data operand is a variable stored in SRAM. In that case, the one byte address of the variable is encoded in the instruction. As an example, consider an instruction that loads A with the contents of memory address location 0x10:

MOV A, [10h].

Normally, variable names are assigned to variable addresses using "EQU" statements to improve the readability of the assembler source code. As an example, the following code is equivalent to the example described earlier:

buttons: EQU 10h MOV A, [buttons].

#### Indexed

"Indexed" address mode allows the firmware to manipulate arrays of data stored in SRAM. The address of the data operand is the sum of a constant encoded in the instruction and the contents of the "X" register. Normally, the constant is the "base" address of an array of data and the X register contains an index that indicates which element of the array is actually addressed: array: EQU 10h

MOV X, 3 MOV A, [X+array].

This has the effect of loading A with the fourth element of the SRAM "array" that begins at address 0x10. The fourth element would be at address 0x13.

### Clocking



The XTALIN and XTALOUT are the clock pins to the microcontroller. The user connects an external oscillator or a crystal to these pins. When using an external crystal, keep PCB traces between the chip leads and crystal as short as possible (less than 2 cm). A 6 MHz fundamental frequency parallel resonant crystal is connected to these pins to provide a reference frequency for the internal PLL. The two internal 30 pF load caps appear in series to the external crystal and would be equivalent to a 15 pF load. Therefore, the crystal must have a required load capacitance of about 15–18 pF. A ceramic resonator does not allow the microcontroller to meet the timing specifications of full speed USB and so a ceramic resonator is not recommended with these parts.

An external 6 MHz clock is applied to the XTALIN pin if the XTALOUT pin is left open. Grounding the XTALOUT pin when driving XTALIN with an oscillator does not work because the internal clock is effectively shorted to ground.



#### **GPIO Configuration Port**

Every GPIO port is programmed as inputs with internal pull ups, outputs LOW or HIGH, or Hi-Z (floating, the pin is not driven internally). In addition, the interrupt polarity for each port is programmed. The Port Configuration bits (Table 11) and the Interrupt Enable bit (Table 9 on page 17 through Table 16 on page 19) determine the interrupt polarity of the port pins.

| GPIO Configuration ADDRES |                        |                        |                        |                        |                        |                        |                        |                        |  |
|---------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|--|
| Bit #                     | 7                      | 6                      | 5                      | 4                      | 3                      | 2                      | 1                      | 0                      |  |
| Bit Name                  | Port 3<br>Config Bit 1 | Port 3<br>Config Bit 0 | Port 2<br>Config Bit 1 | Port 2<br>Config Bit 0 | Port 1<br>Config Bit 1 | Port 1<br>Config Bit 0 | Port 0<br>Config Bit 1 | Port 0<br>Config Bit 0 |  |
| Read/Write                | R/W                    |  |
| Reset                     | 0                      | 0                      | 0                      | 0                      | 0                      | 0                      | 0                      | 0                      |  |

#### Table 11. GPIO Configuration Register

As shown in Table 12, a positive polarity on an input pin represents a rising edge interrupt (LOW to HIGH), and a negative polarity on an input pin represents a falling edge interrupt (HIGH to LOW).

The GPIO interrupt is generated when all of the following conditions are met: the Interrupt Enable bit of the associated Port Interrupt Enable Register is enabled, the GPIO Interrupt Enable bit of the Global Interrupt Enable Register (Table 31 on page 28) is enabled, the Interrupt Enable Sense (bit 2,

Table 30 on page 27) is set, and the GPIO pin of the port sees an event matching the interrupt polarity.

The driving state of each GPIO pin is determined by the value written to the pin's Data Register (Table 7 on page 17 through Table 10 on page 17) and by its associated Port Configuration bits as shown in the GPIO Configuration Register (Table 9 on page 17). These ports are configured on a per port basis, so all pins in a given port are configured together. The possible port configurations are detailed in Table 12. As shown in this table, when a GPIO port is configured with CMOS outputs, interrupts from that port are disabled.

During reset, all the bits in the GPIO Configuration Register are written with '0' to select Hi-Z mode for all GPIO ports as the default configuration.

| Table 12. | GPIO Port Ou | put Control Truth | Table and Interrup | t Polarity |
|-----------|--------------|-------------------|--------------------|------------|
|-----------|--------------|-------------------|--------------------|------------|

| Port Config Bit 1 | Port Config Bit 0 | Data Register | Output Drive Strength | Interrupt Enable Bit | Interrupt Polarity |
|-------------------|-------------------|---------------|-----------------------|----------------------|--------------------|
| 1                 | 1                 | 0             | Output LOW            | 0                    | Disabled           |
|                   |                   | 1             | Resistive             | 1                    | – (Falling Edge)   |
| 1                 | 0                 | 0             | Output LOW            | 0                    | Disabled           |
|                   |                   | 1             | Output HIGH           | 1                    | Disabled           |
| 0                 | 1                 | 0             | Output LOW            | 0                    | Disabled           |
|                   |                   | 1             | Hi-Z                  | 1                    | – (Falling Edge)   |
| 0                 | 0                 | 0             | Output LOW            | 0                    | Disabled           |
|                   |                   | 1             | Hi-Z                  | 1                    | + (Rising Edge)    |

Q1, Q2, and Q3 discussed here are the transistors referenced in Figure 6 on page 16. The available GPIO drive strength are:

■ Output LOW Mode: The pin's Data Register is set to '0'

Writing '0' to the pin's Data Register puts the pin in output LOW mode, regardless of the contents of the Port Configuration Bits[1:0]. In this mode, Q1 and Q2 are OFF. Q3 is ON. The GPIO pin is driven LOW through Q3.

Output HIGH Mode: The pin's Data Register is set to 1 and the Port Configuration Bits[1:0] is set to '10'

In this mode, Q1 and Q3 are OFF. Q2 is ON. The GPIO is pulled up through Q2. The GPIO pin is capable of sourcing current.

■ Resistive Mode: The pin's Data Register is set to 1 and the Port Configuration Bits[1:0] is set to '11'

Q2 and Q3 are OFF. Q1 is ON. The GPIO pin is pulled up with an internal 14 k $\Omega$  resistor. In resistive mode, the pin may serve as an input. Reading the pin's Data Register returns a logic HIGH if the pin is not driven LOW by an external source.

■ Hi-Z Mode: The pin's Data Register is set to1 and Port Configuration Bits[1:0] is set either '00' or '01'

Q1, Q2, and Q3 are all OFF. The GPIO pin is not driven internally. In this mode, the pin may serve as an input. Reading the Port Data Register returns the actual logic value on the port pins.



#### **GPIO Interrupt Enable Ports**

Each GPIO pin is individually enabled or disabled as an interrupt source. The Port 0–3 Interrupt Enable registers provide this feature with an interrupt enable bit for each GPIO pin. When HAPI mode is enabled the GPIO interrupts are blocked, including ports not used by HAPI, so GPIO pins are not used as interrupt sources.

During a reset, GPIO interrupts are disabled by clearing all of the GPIO interrupt enable ports. Writing a '1' to a GPIO Interrupt Enable bit enables GPIO interrupts from the corresponding input pin. All GPIO pins share a common interrupt, as discussed in GPIO and HAPI Interrupt on page 31.

Table 13. Port 0 Interrupt Enable

#### Port 0 Interrunt Enable

| Port 0 Interrupt Enable |                     |                     |                     |                     |                     |                     |   |                     |
|-------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---|---------------------|
| Bit #                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1 | 0                   |
| Bit Name                | P0.7 Intr<br>Enable | P0.6 Intr<br>Enable | P0.5 Intr<br>Enable | P0.4 Intr<br>Enable | P0.3 Intr<br>Enable | P0.2 Intr<br>Enable |   | P0.0 Intr<br>Enable |
| Read/Write              | W                   | W                   | W                   | W                   | W                   | W                   | W | W                   |
| Reset                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0 | 0                   |

## Table 14. Port 1 Interrupt Enable

| Port 1 Interrupt Enable |                     |                     |                     |                     |                     |                     |                     |                     |  |
|-------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|
| Bit #                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |  |
| Bit Name                | P1.7 Intr<br>Enable | P1.6 Intr<br>Enable | P1.5 Intr<br>Enable | P1.4 Intr<br>Enable | P1.3 Intr<br>Enable | P1.2 Intr<br>Enable | P1.1 Intr<br>Enable | P1.0 Intr<br>Enable |  |
| Read/Write              | W                   | W                   | W                   | W                   | W                   | W                   | W                   | W                   |  |
| Reset                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |  |

#### Table 15. Port 2 Interrupt Enable

| Port 2 Interrupt Enable |                     |                     |                     |                     |                     |                     |                     |                     |  |
|-------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|
| Bit #                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |  |
| Bit Name                | P2.7 Intr<br>Enable | P2.6 Intr<br>Enable | P2.5 Intr<br>Enable | P2.4 Intr<br>Enable | P2.3 Intr<br>Enable | P2.2 Intr<br>Enable | P2.1 Intr<br>Enable | P2.0 Intr<br>Enable |  |
| Read/Write              | W                   | W                   | W                   | W                   | W                   | W                   | W                   | W                   |  |
| Reset                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |  |

#### Table 16. Port 3 Interrupt Enable

#### **Port 3 Interrupt Enable**

| Bit #      | 7        | 6                                         | 5      | 4                   | 3                   | 2                   | 1 | 0                   |
|------------|----------|-------------------------------------------|--------|---------------------|---------------------|---------------------|---|---------------------|
| Bit Name   | Reserved | P3.6 Intr<br>Enable<br>CY7C66113C<br>only | Enable | P3.4 Intr<br>Enable | P3.3 Intr<br>Enable | P3.2 Intr<br>Enable |   | P3.0 Intr<br>Enable |
| Read/Write | W        | W                                         | W      | W                   | W                   | W                   | W | W                   |
| Reset      | 0        | 0                                         | 0      | 0                   | 0                   | 0                   | 0 | 0                   |

#### 

| A | DD | RES | <b>S 0</b> 2 | x07 |
|---|----|-----|--------------|-----|



## **Processor Status and Control Register**

#### Table 30. Processor Status and Control Register

#### **Processor Status and Control**

| Processor 5ta | rocessor Status and Control ADDRESS 0XF |                   |                               |                   |         |                              |          |     |
|---------------|-----------------------------------------|-------------------|-------------------------------|-------------------|---------|------------------------------|----------|-----|
| Bit #         | 7                                       | 6                 | 5                             | 4                 | 3       | 2                            | 1        | 0   |
| Bit Name      | IRQ<br>Pending                          | Watchdog<br>Reset | USB Bus<br>Reset<br>Interrupt | Power On<br>Reset | Suspend | Interrupt<br>Enable<br>Sense | Reserved | Run |
| Read/Write    | R                                       | R/W               | R/W                           | R/W               | R/W     | R                            | R/W      | R/W |
| Reset         | 0                                       | 0                 | 0                             | 1                 | 0       | 0                            | 0        | 1   |

#### Bit 0: Run

This bit is manipulated by the HALT instruction. When Halt is executed, all the bits of the Processor Status and Control Register are cleared to 0. Since the run bit is cleared, the processor stops at the end of the current instruction. The processor remains halted until an appropriate reset occurs (power on or Watchdog). This bit should normally be written as a '1.'

#### Bit 1: Reserved

Bit 1 is reserved and must be written as a zero.

#### Bit 2: Interrupt Enable Sense

This bit indicates whether interrupts are enabled or disabled. Firmware has no direct control over this bit as writing a zero or one to this bit position has no effect on interrupts. A '0' indicates that interrupts are masked off and a '1' indicates that the interrupts are enabled. This bit is further gated with the bit settings of the Global Interrupt Enable Register (Table 31 on page 28) and USB End Point Interrupt Enable Register (Table 32 on page 28). Instructions DI, EI, and RETI manipulate the state of this bit.

#### Bit 3: Suspend

Writing a '1' to the Suspend bit halts the processor and cause the microcontroller to enter the suspend mode that significantly reduces power consumption. A pending, enabled interrupt or USB bus activity causes the device to come out of suspend. After coming out of suspend, the device resumes firmware execution at the instruction following the IOWR which put the part into suspend. An IOWR attempting to put the part into suspend is ignored if USB bus activity is present. See Suspend Mode on page 16 for more details on suspend mode operation.

#### **Bit 4: Power on Reset**

The POR is set to '1' during a power on reset. The firmware checks bits 4 and 6 in the reset handler to determine whether a reset was caused by a power on condition or a Watchdog timeout. A POR event may be followed by a WDR before firmware begins executing, as explained here.

#### Bit 5: USB Bus Reset Interrupt

The USB Bus Reset Interrupt bit is set when the USB Bus Reset is detected on receiving a USB Bus Reset signal on the upstream port. The USB Bus Reset signal is a single ended zero (SE0) that lasts from 12 to 16  $\mu$ s. An SE0 is defined as the condition in which both the D+ line and the D– line are LOW at the same time.

#### Bit 6: WDR

The WDR is set during a reset initiated by the WDT. This indicates the WDT went for more than  $t_{WATCH}$  (8 ms minimum) between Watchdog clears. This occurs with a POR event.

#### **Bit 7: IRQ Pending**

The IRQ pending, when set, indicates that one or more of the interrupts is recognized as active. An interrupt remains pending until its interrupt enable bit is set (Table 31 on page 28, Table 32 on page 28) and interrupts are globally enabled. At that point, the internal interrupt handling sequence clears this bit until another interrupt is detected as pending.

During power up, the Processor Status and Control Register is set to 00010001, which indicates a POR (bit 4 set) has occurred and no interrupts are pending (bit 7 clear). During the 96 ms suspend at start up (explained in Power on Reset on page 15), a WDR also occurs unless this suspend is aborted by an upstream SE0 before 8 ms. If a WDR occurs during the power up suspend interval, firmware reads 01010001 from the Status and Control Register after power up. Normally, the POR bit should be cleared so a subsequent WDR is clearly identified. If an upstream bus reset is received before firmware examines this register, the Bus Reset bit may also be set.

During a WDR, the Processor Status and Control Register is set to 01XX0001, which indicates a WDR (bit 6 set) has occurred and no interrupts are pending (bit 7 clear). The WDR does not effect the state of the POR and the Bus Reset Interrupt bits.



## Interrupts

Interrupts are generated by the GPIO and DAC pins, the internal timers,  $I^2C$  compatible or HAPI operation, the internal USB hub, or on various USB traffic conditions. All interrupts are maskable by the Global Interrupt Enable Register and the USB End Point Interrupt Enable Register. Writing a '1' to a bit position enables the interrupt associated with that bit position.

#### Table 31. Global Interrupt Enable Register

#### **Global Interrupt Enable Register**

#### ADDRESS 0X20

| Bit #      | 7        | 6                                    | 5                           | 4                          | 3                              | 2                               | 1                             | 0                                     |
|------------|----------|--------------------------------------|-----------------------------|----------------------------|--------------------------------|---------------------------------|-------------------------------|---------------------------------------|
| Bit Name   | Reserved | I <sup>2</sup> C Interrupt<br>Enable | GPIO<br>Interrupt<br>Enable | DAC<br>Interrupt<br>Enable | USB Hub<br>Interrupt<br>Enable | 1.024 ms<br>Interrupt<br>Enable | 128 μs<br>Interrupt<br>Enable | USB Bus<br>RST<br>Interrupt<br>Enable |
| Read/Write | -        | R/W                                  | R/W                         | R/W                        | R/W                            | R/W                             | R/W                           | R/W                                   |
| Reset      | -        | 0                                    | 0                           | 0                          | 0                              | 0                               | 0                             | 0                                     |

#### Bit 0: USB Bus RST Interrupt Enable

1 = Enable Interrupt on a USB Bus Reset;

0 = Disable interrupt on a USB Bus Reset

(Refer to USB Bus Reset Interrupt on page 30).

#### Bit 1: 128 µs Interrupt Enable

1 = Enable Timer interrupt every 128  $\mu$ s;

0 = Disable Timer Interrupt for every 128  $\mu$ s.

#### Bit 2: 1.024 ms Interrupt Enable

1= Enable Timer interrupt every 1.024 ms;

0 = Disable Timer Interrupt every 1.024 ms.

#### Bit 3: USB Hub Interrupt Enable

1 = Enable Interrupt on a Hub status change; 0 = Disable interrupt due to hub status change.

(Refer to USB Hub Interrupt on page 30.)

#### Bit 4: DAC Interrupt Enable

1 = Enable DAC Interrupt; 0 = Disable DAC interrupt.

#### Bit 5: GPIO Interrupt Enable

1 = Enable Interrupt on falling and rising edge on any GPIO; 0 = Disable Interrupt on falling and rising edge on any GPIO. (Refer to sections GPIO and HAPI Interrupt on page 31, GPIO Configuration Port on page 18, and GPIO Interrupt Enable Ports on page 19.)

#### Bit 6: I<sup>2</sup>C Interrupt Enable

1 = Enable Interrupt on I2C related activity; 0 = Disable I2C related activity interrupt.

(Refer to  $l^2C$  Interrupt on page 32.)

#### Bit 7: Reserved.

#### Table 32. USB Endpoint Interrupt Enable Register

#### **USB Endpoint Interrupt Enable**

| Bit #      | 7        | 6        | 5        | 4                           | 3                           | 2                           | 1                           | 0                           |
|------------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| Bit Name   | Reserved | Reserved | Reserved | EPB1<br>Interrupt<br>Enable | EPB0<br>Interrupt<br>Enable | EPA2<br>Interrupt<br>Enable | EPA1<br>Interrupt<br>Enable | EPA0<br>Interrupt<br>Enable |
| Read/Write | -        | -        | -        | R/W                         | R/W                         | R/W                         | R/W                         | R/W                         |
| Reset      | -        | -        | -        | 0                           | 0                           | 0                           | 0                           | 0                           |

#### **Bit 0: EPA0 Interrupt Enable**

1 = Enable Interrupt on data activity through endpoint A0; 0 = Disable Interrupt on data activity through endpoint A0.

#### Bit 1: EPA1 Interrupt Enable

1 = Enable Interrupt on data activity through endpoint A1;

0 = Disable Interrupt on data activity through endpoint A1.

#### Bit 2: EPA2 Interrupt Enable

1 = Enable Interrupt on data activity through endpoint A2;

0 = Disable Interrupt on data activity through endpoint A2.

#### Bit 3: EPB0 Interrupt Enable

1 = Enable Interrupt on data activity through endpoint B0;

0 = Disable Interrupt on data activity through endpoint B0.

#### Bit 4: EPB1 Interrupt Enable

1 = Enable Interrupt on data activity through endpoint B1;

#### 0 = Disable Interrupt on data activity through endpoint B1.

#### Bit [7..5]: Reserved

During a reset, the contents the Global Interrupt Enable Register and USB End Point Interrupt Enable Register are cleared, effectively, disabling all interrupts.

The interrupt controller contains a separate flip flop for each interrupt. See Figure 9 on page 29 for the logic block diagram of the interrupt controller. When an interrupt is generated, it is first registered as a pending interrupt. It stays pending until it is serviced or a reset occurs. A pending interrupt only generates an interrupt request if it is enabled by the corresponding bit in the interrupt enable registers. The highest priority interrupt request

### ADDRESS 0X21





is serviced following the completion of the currently executing instruction.

When servicing an interrupt, the hardware does the following:

- 1. Disables all interrupts by clearing the Global Interrupt Enable bit in the CPU (the state of this bit is read at Bit 2 of the Processor Status and Control Register, Table 30 on page 27).
- 2. Clears the flip flop of the current interrupt.
- 3. Generates an automatic CALL instruction to the ROM address associated with the interrupt being serviced (that is, the Interrupt Vector).

The instruction in the interrupt table is typically a JMP instruction to the address of the Interrupt Service Routine (ISR). The user re-enables interrupts in the interrupt service routine by executing an El instruction. Interrupts are nested to a level limited only by the available stack space.

The Program Counter value and the Carry and Zero flags (CF, ZF) are stored onto the Program Stack by the automatic CALL instruction generated as part of the interrupt acknowledge process. The user firmware is responsible for ensuring that the processor state is preserved and restored during an interrupt.

The PUSH A instruction should typically be used as the first command in the ISR to save the accumulator value and the POP A instruction should be used to restore the accumulator value just before the RETI instruction. The program counter CF and ZF are restored and interrupts are enabled when the RETI instruction is executed.

The DI and EI instructions are used to disable and enable interrupts, respectively. These instructions affect only the Global Interrupt Enable bit of the CPU. If desired, EI is used to re-enable interrupts while inside an ISR, instead of waiting for the RETI that exists the ISR. While the global interrupt enable bit is cleared, the presence of a pending interrupt is detected by examining the IRQ Sense bit (Bit 7 in the Processor Status and Control Register).

#### **Interrupt Vectors**

The Interrupt Vectors supported by the USB Controller are listed in Table 33 on page 30. The lowest numbered interrupt (USB Bus Reset interrupt) has the highest priority, and the highest numbered interrupt ( $I^2C$  interrupt) has the lowest priority.

#### Figure 9. Interrupt Controller Function Diagram





- 5. Firmware stores the new address in its USB Device Address Register (for example, as Address B) after the no data control sequence completes.
- 6. The host sends a request for the Device descriptor using the new USB address.
- 7. Firmware decodes the request and retrieves the Device descriptor from program memory tables.
- 8. The host performs a control read sequence and Firmware responds by sending its Device descriptor over the USB bus.
- 9. The host generates control reads from the device to request the Configuration and Report descriptors.
- 10. When the device receives a Set Configuration request, its functions may now be used.
- 11.Following enumeration as a hub, Firmware optionally indicates to the host that a compound device exists (for example, the keyboard in a keyboard/hub device).
- 12. The host carries out the enumeration process with this additional function as though it were attached downstream from the hub.
- 13. When the host assigns an address to this device, it is stored as the other USB address (for example, Address A).

## USB Hub

A USB hub is required to support:

- Connectivity behavior: service connect and disconnect detection
- Bus fault detection and recovery
- Full and low speed device support.

These features are mapped onto a hub repeater and a hub controller. The hub controller is supported by the processor integrated into the CY7C66013C and CY7C66113C microcontrollers. The hardware in the hub repeater detects whether a USB device is connected to a downstream port and the interface speed of the downstream device. The connection

to a downstream port is through a differential signal pair (D+ and D–). Each downstream port provided by the hub requires external  $R_{UDN}$  resistors from each signal line to ground, so that when a downstream port has no device connected, the hub reads a LOW (zero) on both D+ and D–. This condition is used to identify the "no connect" state.

The hub must have a resistor  $R_{UUP}$  connected between its upstream D+ line and  $V_{REG}$  to indicate it is a full speed USB device.

The hub generates an EOP at EOF1, in accordance with the USB 1.1 Specification, Section 11.2.2.

#### **Connecting and Disconnecting a USB Device**

A low speed (1.5 Mbps) USB device has a pull up resistor on the D– pin. At connect time, the bias resistors set the signal levels on the D+ and D– lines. When a low speed device is connected to a hub port, the hub sees a LOW on D+ and a HIGH on D–. This causes the hub repeater to set a connect bit in the Hub Ports Connect Status register for the downstream port. Then the hub repeater generates a Hub Interrupt to notify the microcontroller that there is a change in the Hub downstream status.

A full speed (12 Mbps) USB device has a pull up resistor from the D+ pin, so the hub sees a HIGH on D+ and a LOW on D–. In this case, the hub repeater sets a connect bit in the Hub Ports Connect Status register, clears a bit in the Hub Ports Speed register (for full speed), and generates a Hub Interrupt to notify the microcontroller of the change in Hub status. The firmware sets the speed of this port in the Hub Ports Speed Register (see Table 35 on page 34).

Connects are recorded by the time a non SE0 state lasts for more than 2.5  $\mu s$  on a downstream port.

When a USB device is disconnected from the Hub, the downstream signal pair eventually floats to a single ended zero state. The hub repeater recognizes a disconnect when the SE0 state on a downstream port lasts from 2.0 to 2.5  $\mu$ s. On a disconnect, the corresponding bit in the Hub Ports Connect Status register is cleared, and the Hub Interrupt is generated.

#### **Hub Ports Connect Status**

#### Table 34. Hub Ports Connect Status

| ADDRESS | 0x48 |
|---------|------|
|         |      |

| Bit #      | 7        | 6        | 5        | 4        | 3                           | 2                           | 1                           | 0                           |
|------------|----------|----------|----------|----------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| Bit Name   | Reserved | Reserved | Reserved | Reserved | Port 4<br>Connect<br>Status | Port 3<br>Connect<br>Status | Port 2<br>Connect<br>Status | Port 1<br>Connect<br>Status |
| Read/Write | R/W      | R/W      | R/W      | R/W      | R/W                         | R/W                         | R/W                         | R/W                         |
| Reset      | 0        | 0        | 0        | 0        | 0                           | 0                           | 0                           | 0                           |

#### Bit [0..3]: Port x Connect Status (where x = 1..4)

When set to 1, Port x is connected; When set to 0, Port x is disconnected.

#### Bit [7..4]: Reserved.

The Hub Ports Connect Status register is cleared to zero by reset or USB bus reset, then set to match the hardware configuration by the hub repeater hardware. The Reserved bits [7..4] should always read as '0' to indicate no connection.



#### Table 35. Hub Ports Speed

| Hub Ports Sp | Hub Ports Speed ADDRESS UX |          |          |          |              |              |              |              |
|--------------|----------------------------|----------|----------|----------|--------------|--------------|--------------|--------------|
| Bit #        | 7                          | 6        | 5        | 4        | 3            | 2            | 1            | 0            |
| Bit Name     | Reserved                   | Reserved | Reserved | Reserved | Port 4 Speed | Port 3 Speed | Port 2 Speed | Port 1 Speed |
| Read/Write   | R/W                        | R/W      | R/W      | R/W      | R/W          | R/W          | R/W          | R/W          |
| Reset        | 0                          | 0        | 0        | 0        | 0            | 0            | 0            | 0            |

#### **Hub Ports Speed**

#### Bit [0..3]: Port x Speed (where x = 1..4)

Set to 1 if the device plugged in to Port x is Low speed; Set to 0 if the device plugged in to Port x is Full speed.

#### Enabling and Disabling a USB Device

After a USB device connection is detected, firmware must update status change bits in the hub status change data structure that is polled periodically by the USB host. The host responds by sending a packet that instructs the hub to reset and enable the downstream port. Firmware then sets the bit in the Hub Ports Enable register, Table 36, for the downstream port. The hub repeater hardware responds to an enable bit in the Hub Ports Enable register by enabling the downstream port, so that USB traffic flows to and from that port.

If a port is marked enabled and is not suspended, it receives all USB traffic from the upstream port, and USB traffic from the downstream port is passed to the upstream port (unless babble

#### Bit [7..4]: Reserved.

The Hub Ports Speed register is cleared to zero by reset or bus reset. This must be set by the firmware on issuing a port reset. The Reserved bits [7..4] should always read as '0'.

is detected). Low speed ports do not receive full speed traffic from the upstream port.

When firmware writes to the Hub Ports Enable register to enable a port, the port is not enabled until the end of any packet currently being transmitted. If there is no USB traffic, the port is enabled immediately.

When a USB device disconnection is detected, firmware must update status bits in the hub change status data structure that is polled periodically by the USB host. In suspend, a connect or disconnect event generates an interrupt (if the hub interrupt is enabled) even if the port is disabled.

#### Table 36. Hub Ports Enable Register

ADDRESS 0x49 Hub Ports Enable Register 2 Bit # 4 3 6 5 1 0 Bit Name Reserved Port 4 Port 3 Port 2 Port 1 Reserved Reserved Reserved Enable Enable Enable Enable Read/Write R/W R/W R/W R/W R/W R/W R/W R/W Reset 0 0 0 0 0 0 n Ω

#### Bit [0..3]: Port x Enable (where x = 1..4)

Set to 1 if Port x is enabled; Set to 0 if Port x is disabled.

#### Bit [7..4]: Reserved.

The Hub Ports Enable register is cleared to zero by reset or bus reset to disable all downstream ports as the default condition. A port is also disabled by internal hub hardware (enable bit cleared) if babble is detected on that downstream port. Babble is defined as:

Any non idle downstream traffic on an enabled downstream port at EOF2

Any downstream port with upstream connectivity established at EOF2 (that is, no EOP received by EOF2).

#### Table 40. Hub Ports SE0 Status Register

| HUD PORS SE | ADDRESS VX4 |          |          |          |                      |                      |                      |                      |
|-------------|-------------|----------|----------|----------|----------------------|----------------------|----------------------|----------------------|
| Bit #       | 7           | 6        | 5        | 4        | 3                    | 2                    | 1                    | 0                    |
| Bit Name    | Reserved    | Reserved | Reserved | Reserved | Port 4<br>SE0 Status | Port 3<br>SE0 Status | Port 2<br>SE0 Status | Port 1<br>SE0 Status |
| Read/Write  | -           | -        | -        | -        | R                    | R                    | R                    | R                    |
| Reset       | 0           | 0        | 0        | 0        | 0                    | 0                    | 0                    | 0                    |

#### Bit [0..3]: Port x SE0 Status (where x = 1..4)

Set to 1 if a SE0 is output on the Port x bus; Set to 0 if a Non-SE0 is output on the Port x bus.

#### Table 41. Hub Ports Data Register

| HUD PORS Da | เส       |          |          |          |                      |                      | AD                   | DRE33 0X30           |
|-------------|----------|----------|----------|----------|----------------------|----------------------|----------------------|----------------------|
| Bit #       | 7        | 6        | 5        | 4        | 3                    | 2                    | 1                    | 0                    |
| Bit Name    | Reserved | Reserved | Reserved | Reserved | Port 4 Diff.<br>Data | Port 3 Diff.<br>Data | Port 2 Diff.<br>Data | Port 1 Diff.<br>Data |
| Read/Write  | -        | -        | -        | -        | R                    | R                    | R                    | R                    |
| Reset       | 0        | 0        | 0        | 0        | 0                    | 0                    | 0                    | 0                    |

#### Bit [0..3]: Port x Diff Data (where x = 1..4)

Set to 1 if D+ > D- (forced differential 1, if signal is differential, i.e. not a SE0 or SE1). Set to 0 if D- > D+ (forced differential 0, if signal is differential, i.e., not a SE0 or SE1);

#### **Downstream Port Suspend and Resume**

The Hub Ports Suspend Register (Table 42) and Hub Ports Resume Status Register (Table 49 on page 41) indicate the suspend and resume conditions on downstream ports. The suspend register must be set by firmware for any ports that are selectively suspended. Also, this register is only valid for ports that are selectively suspended.

If a port is marked as selectively suspended, normal USB traffic is not sent to that port. Resume traffic is also prevented from going to that port, unless the Resume comes from the selectively suspended port. If a resume condition is detected on the port, hardware reflects a Resume back to the port, sets the Resume bit in the Hub Ports Resume Register, and generates a hub interrupt. If a disconnect occurs on a port marked as selectively suspended, the suspend bit is cleared.

## Bit [7..4]: Reserved.

Bit [7..4]: Reserved.

The Device Remote Wakeup bit (bit 7) of the Hub Ports Suspend Register controls whether or not the resume signal is propagated by the hub after a connect or a disconnect event. If the Device Remote Wakeup bit is set, the hub automatically propagates the resume signal after a connect or a disconnect event. If the Device Remote Wakeup bit is cleared, the hub does not propagate the resume signal. The setting of the Device Remote Wakeup flag has no impact on the propagation of the resume signal after a downstream remote wakeup event. The hub automatically propagates the resume signal after a remote wakeup event, regardless of the state of the Device Remote of the hub interrupt. These registers are cleared on reset or USB bus reset.

#### Table 42. Hub Ports Suspend Register

ADDRESS 0x4D

| Bit #      | 7                          | 6        | 5        | 4        | 3                              | 2                              | 1                              | 0                              |
|------------|----------------------------|----------|----------|----------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| Bit Name   | Device<br>Remote<br>Wakeup | Reserved | Reserved | Reserved | Port 4<br>Selective<br>Suspend | Port 3<br>Selective<br>Suspend | Port 2<br>Selective<br>Suspend | Port 1<br>Selective<br>Suspend |
| Read/Write | R/W                        | R/W      | R/W      | R/W      | R/W                            | R/W                            | R/W                            | R/W                            |
| Reset      | 0                          | 0        | 0        | 0        | 0                              | 0                              | 0                              | 0                              |

#### Bit [0..3]: Port x Selective Suspend (where x = 1..4)

Set to 1 if Port x is Selectively Suspended; Set to 0 if Port x Do not suspend.

#### Bit 7: Device Remote Wakeup.

When set to 1, Enable hardware upstream resume signaling for connect and disconnect events during global resume.

When set to 0, Disable hardware upstream resume signaling for connect and disconnect events during global resume.

**Hub Ports Suspend** 



Hub Dorte SE0 Status

Lub Darte Date

ADDDECC AVEN



ADDD500 0.45

#### USB Upstream Port Status and Control

USB status and control is regulated by the USB Status and Control Register, as shown in Table 44. All bits in the register are cleared during reset.

#### USB Status and Control

#### Table 44. USB Status and Control Register

| USB Status a | nd Control       |                  |                |             |              |                            | ADI                        | JRESS (                    | UX1F |
|--------------|------------------|------------------|----------------|-------------|--------------|----------------------------|----------------------------|----------------------------|------|
| Bit #        | 7                | 6                | 5              | 4           | 3            | 2                          | 1                          | 0                          |      |
| Bit Name     | Endpoint<br>Size | Endpoint<br>Mode | D+<br>Upstream | D– Upstream | Bus Activity | Control<br>Action<br>Bit 2 | Control<br>Action<br>Bit 1 | Control<br>Action<br>Bit 0 |      |
| Read/Write   | R/W              | R/W              | R              | R           | R/W          | R/W                        | R/W                        | R/W                        |      |
| Reset        | 0                | 0                | 0              | 0           | 0            | 0                          | 0                          | 0                          |      |

#### Bits[2..0]: Control Action

Set to control action as per Table 45. The three control bits allow the upstream port to be driven manually by firmware. For normal USB operation, all of these bits must be cleared. Table 45 shows how the control bits affect the upstream port.

#### Table 45. Control Bit Definition for Upstream Port

| Control Bits | Control Action                    |
|--------------|-----------------------------------|
| 000          | Not Forcing (SIE Controls Driver) |
| 001          | Force D+[0] HIGH, D–[0] LOW       |
| 010          | Force D+[0] LOW, D–[0] HIGH       |
| 011          | Force SE0; D+[0] LOW, D–[0] LOW   |
| 100          | Force D+[0] LOW, D–[0] LOW        |
| 101          | Force D+[0] HiZ, D–[0] LOW        |
| 110          | Force D+[0] LOW, D–[0] HiZ        |
| 111          | Force D+[0] HiZ, D–[0] HiZ        |

#### **Bit 3: Bus Activity**

This is a "sticky" bit that indicates if any non idle USB event has occurred on the upstream USB port. Firmware should check and clear this bit periodically to detect any loss of bus activity. Writing a '0' to the Bus Activity bit clears it, while writing a '1' preserves the current value. In other words, the firmware clears the Bus Activity bit, but only the SIE can set it.

#### Bits 4 and 5: D– Upstream and D+ Upstream

These bits give the state of each upstream port pin individually: 1 = HIGH, 0 = LOW.

#### **Bit 6: Endpoint Mode**

This bit used to configure the number of USB endpoints. See USB Device Endpoints on page 39 for a detailed description.

#### Bit 7: Endpoint Size

This bit used to configure the number of USB endpoints. See USB Device Endpoints on page 39 for a detailed description.

The hub generates an EOP at EOF1 in accordance with the USB 1.1 Specification.



## **USB SIE Operation**

The CY7C66x13C SIE supports operation as a single device or a compound device. This section describes the two device addresses, the configurable endpoints, and the endpoint function.

#### **USB Device Addresses**

The USB Controller provides two USB Device Address Registers: A (addressed at 0x10)and B (addressed at 0x40). Upon reset and under default conditions, Device A has three endpoints and Device B has two endpoints. The USB Device Address Register contents are cleared during a reset, setting the USB device addresses to zero and disabling these addresses. Table 46 shows the format of the USB Address Registers.

#### Table 46. USB Device Address Registers

| USB Device A | JSB Device Address (Device A, B) ADDRESSES 0x10(A) and 0x40(B |                            |                            |                            |                            |                            |                            |                            |  |  |  |
|--------------|---------------------------------------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|--|--|--|
| Bit #        | 7                                                             | 6                          | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |  |  |  |
| Bit Name     | Device<br>Address<br>Enable                                   | Device<br>Address<br>Bit 6 | Device<br>Address<br>Bit 5 | Device<br>Address<br>Bit 4 | Device<br>Address<br>Bit 3 | Device<br>Address<br>Bit 2 | Device<br>Address<br>Bit 1 | Device<br>Address<br>Bit 0 |  |  |  |
| Read/Write   | R/W                                                           | R/W                        | R/W                        | R/W                        | R/W                        | R/W                        | R/W                        | R/W                        |  |  |  |
| Reset        | 0                                                             | 0                          | 0                          | 0                          | 0                          | 0                          | 0                          | 0                          |  |  |  |

#### Bits[6..0]: Device Address

Firmware writes this bits during the USB enumeration process to the non zero address assigned by the USB host.

#### **Bit 7: Device Address Enable**

Must be set by firmware before the SIE responds to USB traffic to the Device Address.

#### **USB Device Endpoints**

The CY7C66x13C controller supports up to two addresses and five endpoints for communication with the host. The configuration of these endpoints, and associated FIFOs, is controlled by bits [7,6] of the USB Status and Control Register (see Table 44 on page 38). Bit 7 controls the size of the endpoints and bit 6 controls the number of addresses. These configuration options are detailed in Table 47. Endpoint FIFOs are part of user RAM (as shown in Data Memory Organization on page 13).

#### Table 47. Memory Allocation for Endpoints

|       | USB Status And Control Register (0x1F) Bits [7, 6] |      |                                                            |                    |      |                                     |                    |      |                                     |                    |      |  |
|-------|----------------------------------------------------|------|------------------------------------------------------------|--------------------|------|-------------------------------------|--------------------|------|-------------------------------------|--------------------|------|--|
|       | [0,0]                                              |      |                                                            | [1,0]              |      |                                     | [0,1]              |      | [1,1]                               |                    |      |  |
|       | Addresses:<br>) & B (2 Endr                        |      | - Two USB Addresses: A (3 End-<br>points) &B (2 Endpoints) |                    |      | One USB Address:<br>A (5 Endpoints) |                    |      | One USB Address:<br>A (5 Endpoints) |                    |      |  |
| Label | Start Ad-<br>dress                                 | Size | Label                                                      | Start Ad-<br>dress | Size | Label                               | Start Ad-<br>dress | Size | Label                               | Start Ad-<br>dress | Size |  |
| EPB1  | 0xD8                                               | 8    | EPB0                                                       | 0xA8               | 8    | EPA4                                | 0xD8               | 8    | EPA3                                | 0xA8               | 8    |  |
| EPB0  | 0xE0                                               | 8    | EPB1                                                       | 0xB0               | 8    | EPA3                                | 0xE0               | 8    | EPA4                                | 0xB0               | 8    |  |
| EPA2  | 0xE8                                               | 8    | EPA0                                                       | 0xB8               | 8    | EPA2                                | 0xE8               | 8    | EPA0                                | 0xB8               | 8    |  |
| EPA1  | 0xF0                                               | 8    | EPA1                                                       | 0xC0               | 32   | EPA1                                | 0xF0               | 8    | EPA1                                | 0xC0               | 32   |  |
| EPA0  | 0xF8                                               | 8    | EPA2                                                       | 0xE0               | 32   | EPA0                                | 0xF8               | 8    | EPA2                                | 0xE0               | 32   |  |

When the SIE writes data to a FIFO, the internal data bus is driven by the SIE; not the CPU. This causes a short delay in the CPU operation. The delay is three clock cycles per byte. For example, an 8-byte data write by the SIE to the FIFO generates a delay of 2  $\mu$ s (3 cycles/byte \* 83.33 ns/cycle \* 8 bytes).

#### USB Control Endpoint Mode Registers

All USB devices are required to have a control endpoint 0 (EPA0 and EPB0) that is used to initialize and control each USB address. Endpoint 0 provides access to the device configuration information and allows generic USB status and control accesses. Endpoint 0 is bidirectional to both receive and transmit data. The other endpoints are unidirectional, but selectable by the user as IN or OUT endpoints.

The endpoint mode registers are cleared during reset. When USB Status And Control Register Bits [6,7] are set to [0,0] or [1,0], the endpoint 0 EPA0 and EPB0 mode registers use the format shown in Table 48 on page 40.



| Table 53. Details of Modes for Differing Traffic Conditions (see Table 52 on page 45 for the decode legend) (continued) |
|-------------------------------------------------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------------------------------------------------|

| Nal | k In/ | prei     | mat  | ure stati | us Out |         |         |         |         |         |        |       |       |        |          |      |      |                               |      |
|-----|-------|----------|------|-----------|--------|---------|---------|---------|---------|---------|--------|-------|-------|--------|----------|------|------|-------------------------------|------|
| 1   | 1     | 1        | 0    | Out       | 2      | UC      | valid   | 1       | 1       | updates | UC     | UC    | 1     | 1      | No       | Ch   | ange | ACK                           | yes  |
| 1   | 1     | 1        | 0    | Out       | 2      | UC      | valid   | 0       | 1       | updates | UC     | UC    | 1     | UC     | 0        | 0    | 1 1  | Stall                         | yes  |
| 1   | 1     | 1        | 0    | Out       | !=2    | UC      | valid   | updates | 1       | updates | UC     | UC    | 1     | UC     | 0        | 0    | 1 1  | Stall                         | yes  |
| 1   | 1     | 1        | 0    | Out       | > 10   | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| 1   | 1     | 1        | 0    | Out       | х      | UC      | invalid | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| 1   | 1     | 1        | 0    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | 1     | UC    | UC     | No       | Ch   | ange | NAK                           | yes  |
| Sta | tus ( | Out      | /ext | ra In     |        |         |         |         |         |         |        |       |       |        |          |      |      | •                             |      |
| 0   | 0     | 1        | 0    | Out       | 2      | UC      | valid   | 1       | 1       | updates | UC     | UC    | 1     | 1      | No       | Ch   | ange | 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     | No       | Ch   | ange | ignore                        | no   |
| 0   | 0     | 1        | 0    | Out       | х      | UC      | invalid | UC      | UC      | UC      | UC     | 1     | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| 0   | 0     | 1        | 0    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | 1     | UC    | UC     | 0        | 0    | 1 1  | Stall                         | yes  |
|     |       | <u> </u> |      | •         |        | •       |         |         | OUT EN  | DPOINT  | •      |       |       |        | <u> </u> |      |      |                               |      |
|     |       | Pro      | pei  | rties of  | Incomi | ng Pack | et      |         | Chang   | es made | by SIE | to In | terna | l Regi | ster     | 's a | nd N | lode Bits                     |      |
| N   | lode  | e Bi     | ts   | token     | count  | buffer  | dval    | DTOG    | DVAL    | COUNT   | Setup  | In    | Out   | ACK    | Mo       | ode  | Bits | Response                      | Intr |
| Noi | mal   | Ou       | t/er | roneous   | In     | •       |         |         | •       |         |        |       |       |        |          |      |      |                               |      |
| 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    | х       | updates | updates | updates | UC     | UC    | 1     | UC     |          |      | -    | ignore                        | yes  |
| 1   | 0     | 0        | 1    | Out       | х      | junk    | invalid | updates | 0       | updates | UC     | UC    | 1     | UC     | No       | Ch   | ange | ignore                        | yes  |
| 1   | 0     | 0        | 1    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
|     |       |          |      |           |        |         |         |         |         |         |        |       |       |        |          |      |      | (STALL <sup>[4]</sup> = 0)    |      |
| 1   | 0     | 0        | 1    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | Stall                         | no   |
|     |       |          |      |           |        |         |         |         |         |         |        |       |       |        |          |      |      | (STALL <sup>[4]</sup> =<br>1) |      |
| NA  | K Oi  | ut/e     | rron | ieous In  |        |         |         |         |         |         | 1      |       |       | 1      |          |      |      |                               |      |
| 1   | 0     | 0        | 0    | Out       | <= 10  | UC      | valid   | UC      | UC      | UC      | UC     | UC    | 1     | UC     | No       | Ch   | ange | NAK                           | yes  |
| 1   | 0     | 0        | 0    | Out       | > 10   | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| 1   | 0     | 0        | 0    | Out       | х      | UC      | invalid | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| 1   | 0     | 0        | 0    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| lso | chro  | nou      | is e | ndpoint   | (Out)  | •       | •       | •       | •       | •       | •      | •     | •     | •      | •        |      |      |                               | •    |
| 0   | 1     | 0        | 1    | Out       | х      | updates | updates | updates | updates | updates | UC     | UC    | 1     | 1      | No       | Ch   | ange | RX                            | yes  |
| 0   | 1     | 0        | 1    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
|     |       | •        | -    |           |        |         |         |         | IN END  |         |        | -     | -     |        |          |      |      |                               |      |
|     |       | Pro      | pei  |           |        | ng Pack | et      |         | -       |         | -      |       |       | -      |          |      |      | lode Bits                     |      |
|     | lode  |          |      |           |        | buffer  | dval    | DTOG    | DVAL    | COUNT   | Setup  | In    | Out   | ACK    | Mo       | ode  | Bits | Response                      | Intr |
| Noi | mal   | In/e     |      | neous C   | Dut    |         |         |         |         |         |        |       |       |        |          |      |      |                               |      |
| 1   | 1     | 0        | 1    | Out       | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
|     |       |          |      |           |        |         |         |         |         |         |        |       |       |        |          |      |      | (STALL <sup>[4]</sup> =<br>0) |      |
| 1   | 1     | 0        | 1    | Out       | х      | UC      | x       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | stall                         | no   |
|     |       |          |      |           |        |         |         |         |         |         |        |       |       |        |          |      |      | (STALL <sup>[4]</sup> =<br>1) |      |
| 1   | 1     | 0        | 1    | In        | х      | UC      | х       | UC      | UC      | UC      | UC     | 1     | UC    | 1      | 1        | 1    | 0 0  | ACK (back)                    | yes  |
| NA  | K In  | /err     | one  | ous Out   |        |         |         |         |         |         | ı      |       |       |        |          |      |      |                               |      |
| 1   | 1     | 0        | 0    | Out       | х      | UC      | х       | UC      | UC      | UC      | UC     | UC    | UC    | UC     | No       | Ch   | ange | ignore                        | no   |
| ·   |       |          | ۰    |           |        | •       | •       |         |         |         |        | •     | •     |        | •        |      |      | ·                             | •    |





## Register Summary (continued)

|                                                              | Addr | Register Name                     | Bit 7                      | Bit 6                                   | Bit 5                        | Bit 4                        | Bit 3                          | Bit 2                        | Bit 1                         | Bit 0                                       | Read/Write/<br>Both <sup>[5, 6, 7]</sup> | Default/<br>Reset <sup>[8]</sup> |
|--------------------------------------------------------------|------|-----------------------------------|----------------------------|-----------------------------------------|------------------------------|------------------------------|--------------------------------|------------------------------|-------------------------------|---------------------------------------------|------------------------------------------|----------------------------------|
| RUPT                                                         |      | Global Interrupt<br>Enable        |                            | l <sup>2</sup> C<br>Interrupt<br>Enable | Interrupt<br>Enable          | DAC<br>Interrupt<br>Enable   | USB Hub<br>Interrupt<br>Enable | Enable                       | 128 μs<br>Interrupt<br>Enable | USB Bus<br>RESET In-<br>terrupt En-<br>able |                                          | -0000000                         |
| INTERRUPT                                                    |      | Endpoint Interrupt<br>Enable      | Reserved                   | Reserved                                |                              | EPB1<br>Interrupt<br>Enable  | EPB0<br>Interrupt<br>Enable    | Interrupt                    | EPA1<br>Interrupt<br>Enable   | EPA0<br>Interrupt<br>Enable                 | bbbbb                                    | 00000                            |
|                                                              | 0x24 | Timer (LSB)                       | Timer Bit 7                | Timer Bit 6                             | Timer Bit 5                  | Timer Bit 4                  | Timer Bit 3                    | Timer Bit 2                  | Timer Bit 1                   | Timer Bit 0                                 | rrrrrrr                                  | 00000000                         |
| TIMER                                                        | 0x25 | Timer (MSB)                       | Reserved                   | Reserved                                |                              | Reserved                     | Timer Bit<br>11                | Timer Bit<br>10              | Time Bit 9                    | Timer Bit 8                                 | rrrr                                     | 0000                             |
|                                                              |      | Status                            | Mode                       | Busy                                    | Mode                         | ACK                          | Addr                           | ARB Lost/<br>Restart         | Stop                          | l <sup>2</sup> C<br>Enable                  | bbbbbbbb                                 | 00000000                         |
| ς<br>Ι                                                       | 0x29 | I <sup>2</sup> C Data             | I <sup>2</sup> C Data 7    | I <sup>2</sup> C Data 6                 | I <sup>2</sup> C Data 5      | I <sup>2</sup> C Data 4      | I <sup>2</sup> C Data 3        | I <sup>2</sup> C Data 2      | I <sup>2</sup> C Data 1       | I <sup>2</sup> C Data 0                     | bbbbbbbb                                 | XXXXXXXX                         |
| RATION                                                       | 0x40 | USB Device<br>Address B           |                            | Device<br>Address B<br>Bit 6            |                              | Device<br>Address B<br>Bit 4 | Device<br>Address B<br>Bit 3   | Device<br>Address B<br>Bit 2 | Device<br>Address B<br>Bit 1  | Device<br>Address B<br>Bit 0                | bbbbbbbb                                 | 00000000                         |
| IGUF                                                         |      | EP B0 Counter Reg-<br>ister       | Data 0/1<br>Toggle         | Data Valid                              | Byte<br>Count Bit 5          | Byte<br>Count Bit 4          | Byte<br>Count Bit 3            | Byte<br>Count Bit 2          | ByteCount<br>Bit 1            | Byte<br>Count Bit 0                         | bbbbbbbb                                 | 00000000                         |
| 1 CONF                                                       |      | EP B0 Mode<br>Register            | SETUP<br>Received          | IN .                                    | Endpoint0<br>OUT<br>Received | ACK                          | Mode Bit 3                     | Mode Bit 2                   | Mode Bit 1                    | Mode Bit 0                                  | bbbbbbbb                                 | 00000000                         |
| IT B0, B                                                     | 0x43 | EP B1 Counter Reg-<br>ister       | Data 0/1<br>Toggle         | Data Valid                              | Count                        | Byte<br>Count<br>Bit 4       | Byte<br>Count<br>Bit 3         | Byte<br>Count<br>Bit 2       | Byte Count<br>Bit 1           | Byte<br>Count<br>Bit 0                      | bbbbbbbb                                 | 00000000                         |
| SUSPEND RESUME, SE0, FORCE LOW ENDPOINT B0, B1 CONFIGURATION |      | EP B1 Mode Regis-<br>ter          | STALL                      | -                                       | -                            | ACK                          | Mode Bit 3                     | Mode Bit 2                   | Mode Bit 1                    | Mode Bit 0                                  | bbbbbb                                   | 00000000                         |
|                                                              |      | Hub Port Connect<br>Status        | Reserved                   | Reserved                                | Reserved                     | Reserved                     | Port 4<br>Connect<br>Status    |                              | Port 2<br>Connect<br>Status   | Port 1<br>Connect<br>Status                 | bbbb                                     | 00000000                         |
| ORCE                                                         | 0x49 | Hub Port Enable                   | Reserved                   | Reserved                                | Reserved                     | Reserved                     | Port 4<br>Enable               |                              | Port 2<br>Enable              | Port 1<br>Enable                            | bbbb                                     | 00000000                         |
| E0, F                                                        | 0x4A | Hub Port Speed                    | Reserved                   | Reserved                                | Reserved                     | Reserved                     | Port 4<br>Speed                | Port 3<br>Speed              | Port 2<br>Speed               | Port 1<br>Speed                             | bbbb                                     | 00000000                         |
| UME, S                                                       | 0x4B | Hub Port Control<br>(Ports 4:1)   | Port 4<br>Control Bit<br>1 | Port 4<br>Control Bit<br>0              | Port 3<br>Control Bit<br>1   | Port 3<br>Control Bit<br>0   | Port 2<br>Control Bit<br>1     |                              | Port 1<br>Control Bit<br>1    | Port 1<br>Control Bit<br>0                  | bbbbbbbb                                 | 00000000                         |
| ND RES                                                       | 0x4D | Hub Port Suspend                  | Device<br>Remote<br>Wakeup | Reserved                                | Reserved                     | Reserved                     |                                |                              | Selective                     | Port 1<br>Selective<br>Suspend              | bbbbb                                    | 00000000                         |
| JSPE                                                         | -    | Hub Port Resume<br>Status         | Reserved                   | Reserved                                | Reserved                     | Reserved                     | Resume 4                       | Resume 3                     | Resume 2                      | Resume 1                                    | rrrr                                     | 00000000                         |
|                                                              | 0x4F | Hub Port SE0 Status               | Reserved                   | Reserved                                | Reserved                     | Reserved                     | SE0 Sta-                       | Port 3<br>SE0 Sta-<br>tus    | Port 2<br>SE0 Status          | Port 1<br>SE0 Sta-<br>tus                   | rrrr                                     | 00000000                         |
| , STA                                                        | 0x50 | Hub Ports Data                    | Reserved                   | Reserved                                | Reserved                     | Reserved                     | Port 4<br>Diff. Data           |                              | Port 2<br>Diff. Data          | Port 1<br>Diff. Data                        | rrrr                                     | 00000000                         |
| TROL                                                         | 0x51 | Hub Port Force Low<br>(Ports 4:1) |                            |                                         |                              |                              | Force Low<br>D+[2]             |                              |                               | Force Low<br>D–[1]                          | bbbbbbbb                                 | 00000000                         |
| HUB PORT CONTROL, STATUS                                     |      | Process Status &<br>Control       | IRQ<br>Pending             |                                         |                              | Power-on<br>Reset            | Suspend                        | Interrupt<br>Enable<br>Sense | Reserved                      | Run                                         | rbbbbrbb                                 | 00010001                         |



## Electrical Characteristics (continued)

(Fosc = 6 MHz; Operating Temperature = 0 to 70  $^{\circ}\text{C},$  V\_{CC} = 4.0 V to 5.25 V)

| Parameter             | Description                                     | Conditions                                   | Min | Max  | Unit            |
|-----------------------|-------------------------------------------------|----------------------------------------------|-----|------|-----------------|
| General Pur           | pose I/O (GPIO)                                 |                                              |     |      |                 |
| R <sub>up</sub>       | pull up Resistance (typical 14 k $\Omega$ )     |                                              | 8.0 | 24.0 | kΩ              |
| V <sub>ITH</sub>      | Input Threshold Voltage                         | All ports, LOW to HIGH edge                  | 20% | 40%  | V <sub>CC</sub> |
| V <sub>H</sub>        | Input Hysteresis Voltage                        | All ports, HIGH to LOW edge                  | 2%  | 8%   | V <sub>CC</sub> |
| V <sub>OL</sub>       | Port 0,1,2,3 Output Low Voltage                 | I <sub>OL</sub> = 3 mA                       | -   | 0.4  | V               |
|                       |                                                 | I <sub>OL</sub> = 8 mA                       | -   | 2.0  | V               |
| V <sub>OH</sub>       | Output High Voltage                             | I <sub>OH</sub> = 1.9 mA (all ports 0,1,2,3) | 2.4 | _    | V               |
| DAC Interfa           | ce                                              |                                              |     | •    |                 |
| R <sub>up</sub>       | DAC Pull Up Resistance (typical 14 k $\Omega$ ) |                                              | 8.0 | 24.0 | kΩ              |
| I <sub>sink0(0)</sub> | DAC[7:2] Sink Current (0)                       | V <sub>out</sub> = 2.0 V DC                  | 0.1 | 0.3  | mA              |
| I <sub>sink0(F)</sub> | DAC[7:2] Sink Current (F)                       | V <sub>out</sub> = 2.0 V DC                  | 0.5 | 1.5  | mA              |
| I <sub>sink1(0)</sub> | DAC[1:0] Sink Current (0)                       | V <sub>out</sub> = 2.0 V DC                  | 1.6 | 4.8  | mA              |
| Isink1(F)             | DAC[1:0] Sink Current (F)                       | V <sub>out</sub> = 2.0 V DC                  | 8   | 24   | mA              |
| I <sub>range</sub>    | Programmed Isink Ratio: max/min                 | $V_{out} = 2.0 \text{ V DC}^{[11]}$          | 4   | 6    |                 |
| T <sub>ratio</sub>    | Tracking Ratio DAC[1:0] to DAC[7:2]             | $V_{out} = 2.0 V^{[12]}$                     | 14  | 22   |                 |
| I <sub>sinkDAC</sub>  | DAC Sink Current                                | V <sub>out</sub> = 2.0 V DC                  | 1.6 | 4.8  | mA              |
| l <sub>lin</sub>      | Differential Nonlinearity                       | DAC Port <sup>[13]</sup>                     |     | 0.6  | LSB             |

Notes

11. Irange: I<sub>sinkn</sub>(15)/I<sub>sinkn</sub>(0) for the same pin.
 12. T<sub>ratio</sub> = I<sub>sink1</sub>[1:0](n)/I<sub>sink</sub>0[7:2](n) for the same n, programmed.
 13. I<sub>lin</sub> measured as largest step size vs. nominal according to measured full scale and zero programmed values.



## Quad Flat Package No Leads (QFN) Package Design Notes

Electrical contact of the part to the Printed Circuit Board (PCB) is made by soldering the leads on the bottom surface of the package to the PCB. Hence, special attention is required to the heat transfer area below the package to provide a good thermal bond to the circuit board. A Copper (Cu) fill is to be designed into the PCB as a thermal pad under the package. Heat is transferred from the FX1 through the device's metal paddle on the bottom side of the package. Heat from here, is conducted to the PCB at the thermal pad. It is then conducted from the thermal pad to the PCB inner ground plane by a 5 x 5 array of via. A via is a plated through hole in the PCB with a finished diameter of 13 mil. The QFN's metal die paddle must be soldered to the PCB's thermal pad. Solder mask is placed on the board top side over each via to resist solder flow into the via. The mask on the top side also minimizes outgassing during the solder reflow process.

For further information on this package design please refer to the application note Surface Mount Assembly of AMKOR's *MicroLeadFrame (MLF) Technology*. This application note can be downloaded from AMKOR's website from the following URL http://www.amkor.com/products/notes papers/MLF AppNote 0902.pdf. The application note provides detailed information on board mounting guidelines, soldering flow, rework process, etc.

Figure 20 displays a cross sectional area underneath the package. The cross section is of only one via. The thickness of the solder paste template should be 5 mil. It is recommended that "No Clean" type 3 solder paste is used for mounting the part. Nitrogen purge is recommended during reflow.

Figure 21 is a plot of the solder mask pattern. This pad is thermally connected and is not electrically connected inside the chip. To minimize EMI, this pad should be connected to the ground plane of the circuit board.













## **Document History Page**

|      | Document Title: CY7C66013C/CY7C66113C, Full-Speed USB (12 Mbps) Peripheral Controller with Integrated Hub<br>Document Number: 38-08024 |                    |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Rev. | ECN No.                                                                                                                                | Orig. of<br>Change | Submission<br>Date | Description of Change                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| **   | 114525                                                                                                                                 | DSG                | 3/27/02            | Change from Spec number: 38-00591 to 38-08024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| *A   | 124768                                                                                                                                 | MON                | 03/20/03           | Added register bit definitions; Added default bit state of each register.<br>Corrected the Schematic (location of the pull-up on D+). Added register<br>summary. Removed information on the availability of the part in PDIP package.<br>Modified Table 51 and provided more explanation regarding locking/unlocking<br>mechanism of the mode register. Removed any information regarding the<br>speed detect bit in Hub Port Speed register being set by hardware.                                                                                                                                            |  |  |  |
| *B   | 417632                                                                                                                                 | BHA                | See ECN            | Updated part number and ordering information. Added QFN Package Drawing<br>and Design Notes. Corrected bit names in Figures 9-3, 9-4, 9-5, 9-8, 9-9, 9-10,<br>10-5, 16-1, 18-1, 18-2, 18-3, 18-6, 18-7, 18-9, 18-10. Removed Hub Ports<br>Force Low register address 0x52. Added HAPI to Interrupt Vector Number 11<br>in Table 16-1. Corrected bit names in Section 21.0. Corrected Units in Table<br>24.0 for R <sub>UUP</sub> , R <sub>UDN</sub> , R <sub>EXT</sub> , and Z <sub>O</sub> . Added DIE diagram and related infor-<br>mation. Added HAPI to GPIO interrupt vector in Table 5-1 and figure 16-3 |  |  |  |
| *C   | 1825466                                                                                                                                | TLY/PYRS           | See ECN            | Changed Title from "CY7C66013, CY7C66113 Full Speed USB (12 Mbps)<br>Peripheral Controller with Integrated Hub" to "CY7C66013C, CY7C66113C<br>Full Speed USB (12 Mbps) Peripheral Controller with Integrated Hub".<br>Changed package description for CY7C66013C and CY7C66113C from -PVC<br>to -PVXC                                                                                                                                                                                                                                                                                                          |  |  |  |
| *D   | 2720540                                                                                                                                | DPT /<br>AESA      | 06/18/09           | Added 56 QFN 8x8x1 mm package diagram and ordering information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| *E   | 2896318                                                                                                                                | AESA               | 03/18/10           | Removed Part CY7C66113C-LFXC. Updated all package diagrams.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| *F   | 3057657                                                                                                                                | AJHA               | 10/13/10           | Added "Not recommended for new designs" watermark in the PDF.<br>No technical or content updates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| *G   | 3177081                                                                                                                                | NXZ                | 02/18/2011         | Added Ordering Code Definitions under Ordering Information.<br>Added Acronyms and Units of Measure.<br>Updated to new template.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| *H   | 4313900                                                                                                                                | AKSL               | 03/21/2014         | Removed "Not recommended for new designs" watermark.<br>Updated Package Diagrams.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| *    | 5693560                                                                                                                                | HBM                | 04/12/2017         | Updated to new template.<br>Completing Sunset Review.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |



## Sales, Solutions, and Legal Information

#### Worldwide Sales and Design Support

Cypress maintains a worldwide network of offices, solution centers, manufacturer's representatives, and distributors. To find the office closest to you, visit us at Cypress Locations.

#### Products

| ARM <sup>®</sup> Cortex <sup>®</sup> Microcontrollers | cypress.com/arm        |
|-------------------------------------------------------|------------------------|
| Automotive                                            | cypress.com/automotive |
| Clocks & Buffers                                      | cypress.com/clocks     |
| Interface                                             | cypress.com/interface  |
| Internet of Things                                    | cypress.com/iot        |
| Memory                                                | cypress.com/memory     |
| Microcontrollers                                      | cypress.com/mcu        |
| PSoC                                                  | cypress.com/psoc       |
| Power Management ICs                                  | cypress.com/pmic       |
| Touch Sensing                                         | cypress.com/touch      |
| USB Controllers                                       | cypress.com/usb        |
| Wireless Connectivity                                 | cypress.com/wireless   |

### **PSoC<sup>®</sup> Solutions**

PSoC 1 | PSoC 3 | PSoC 4 | PSoC 5LP

#### **Cypress Developer Community**

Forums | WICED IOT Forums | Projects | Video | Blogs | Training | Components

#### **Technical Support**

cypress.com/support

© Cypress Semiconductor Corporation, 2002–2017. This document is the property of Cypress Semiconductor Corporation and its subsidiaries, including Spansion LLC ("Cypress"). This document, including any software or firmware included or referenced in this document ("Software"), is owned by Cypress under the intellectual property laws and treaties of the United States and other countries worldwide. Cypress reserves all rights under such laws and treaties and does not, except as specifically stated in this paragraph, grant any license under its patents, copyrights, trademarks, or other intellectual property rights. If the Software is not accompanied by a license agreement and you do not otherwise have a written agreement with Cypress governing the use of the Software, then Cypress hereby grants you a personal, non-exclusive, nontransferable license (without the right to sublicense) (1) under its copyright rights in the Software in binary code form externally to end users (either directly or indirectly through resellers and distributors), solely for use on Cypress hardware product units, and (2) under those claims of Cypress's patents that are infringed by the Software (as provided by Cypress, unmodified) to make, use, distribute, and import the Software solely for use with Cypress hardware products. Any other use, reproduction, modification, translation, or compilation of the Software is prohibited.

TO THE EXTENT PERMITTED BY APPLICABLE LAW, CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS DOCUMENT OR ANY SOFTWARE OR ACCOMPANYING HARDWARE, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. To the extent permitted by applicable law, Cypress reserves the right to make changes to this document without further notice. Cypress does not assume any liability arising out of the application or use of any product or circuit described in this document. Any information provided in this document, including any sample design information or programming code, is provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application made of this information and any resulting product. Cypress products are not designed, intended, or authorized for use as critical components in systems designed or intended for the operation of weapons, weapons systems, nuclear installations, life-support devices or systems, other medical devices or systems (including resuscitation equipment and surgical implants), pollution control or hazardous substances management, or other uses where the failure of the device or system could cause personal injury, death, or properly damage ("Unintended Uses"). A critical component is any component of a device or system whose failure to perform can be reasonably expected to cause the failure of the device or system, or to affect its safety or effectiveness. Cypress is not liable, in whole or in part, and you shall and hereby do release Cypress from any claim, damage, or other liability arising from or related to any Unintended Uses of Cypress products.

Cypress, the Cypress logo, Spansion, the Spansion logo, and combinations thereof, WICED, PSoC, CapSense, EZ-USB, F-RAM, and Traveo are trademarks or registered trademarks of Cypress in the United States and other countries. For a more complete list of Cypress trademarks, visit cypress.com. Other names and brands may be claimed as property of their respective owners.

Document Number: 38-08024 Rev. \*I