# EZ-Host™ Programmable Embedded USB Host/Peripheral Controller # **TABLE OF CONTENTS** | 1.0 INTRODUCTION | 10 | |------------------------------------------------|----| | 1.1 EZ-Host Features | 10 | | 2.0 TYPICAL APPLICATIONS | 11 | | 3.0 FUNCTIONAL OVERVIEW | | | 3.1 Processor Core | | | 3.1.1 Processor Core | | | 3.1.2 Clocking | | | 3.1.3 Memory | | | 3.1.4 Interrupts | | | 3.1.5 General Timers and Watchdog Timer | | | 3.1.6 Power Management | | | 4.0 INTERFACE DESCRIPTIONS | 11 | | 4.1 USB Interface | 13 | | 4.1.1 USB Features | | | 4.1.2 USB Pins. | | | 4.2 OTG Interface | 14 | | 4.2.1 OTG Features | 14 | | 4.2.2 OTG Pins | | | 4.3 External Memory Interface | | | 4.3.1 External Memory Interface Features | | | 4.3.2 External Memory Access Strobes | | | 4.3.3 Page Registers | | | 4.3.4 Merge Mode | | | 4.3.5 Program Memory Hole Description | | | 4.3.6 DMA to External Memory Prohibited | | | 4.3.8 External Memory Interface Block Diagrams | | | 4.4 General Purpose I/O Interface (GPIO) | | | 4.4.1 GPIO Description | | | 4.4.2 Unused Pin Descriptions | | | 4.5 UART Interface | | | 4.5.1 UART Features | | | 4.5.2 UART Pins. | | | 4.6 I2C EEPROM Interface | | | 4.6.1 I2C EEPROM Features | | | 4.6.2 I2C EEPROM Pins | 18 | | 4.7 Serial Peripheral Interface | 18 | | 4.7.1 SPI Features | 19 | | 4.7.2 SPI Pins | | | 4.8 High-speed Serial Interface | | | 4.8.1 HSS Features | | | 4.8.2 HSS Pins | | | 4.9 Programmable Pulse/PWM Interface | | | 4.9.1 Programmable Pulse/PWM Features | | | 4.9.2 Programmable Pulse/PWM Pins. | | | 4.10 Host Port Interface | | | 4.10.1 HPI Features | | | 4.10.2 HPI Pins | | # TABLE OF CONTENTS (continued) | | 4.11 IDE Interface | | |-----|-------------------------------------------------------|--------------------------| | | 4.11.1 IDE Features | | | | 4.11.2 IDE Pins | | | | 4.12 Charge Pump Interface | | | | 4.12.1 Charge Pump Features | | | | 4.12.2 Charge Pump Pins. | | | | 4.13 Booster Interface | | | | 4.13.1 Booster Pins. | | | | 4.14 Crystal Interface | | | | 4.14.1 Crystal Pins | | | | 4.15 Boot Configuration Interface | | | | 4.16 Operational Modes | | | | 4.16.1 Coprocessor Mode | | | | 4.16.2 Standalone Mode | 26 | | 5.0 | POWER-SAVINGS AND RESET DESCRIPTION | 27 | | | 5.1 Power-Savings Mode Description | 27 | | | 5.2 Sleep | | | | 5.3 External (Remote) wakeup Source | | | | 5.4 Power-On-Reset Description | | | | 5.5 Reset Pin | | | | 5.6 USB Reset | | | 6.0 | MEMORY MAP | | | • | | | | | 6.1 Mapping | | | | 6.1.1 Internal Memory | | | | • | | | 7.0 | REGISTERS | | | | 7.1 Processor Control Registers | 30 | | | 7.1.1 CPU Flags Register [0xC000] [R] | | | | 7.1.2 Bank Register [0xC002] [R/W] | 31 | | | 7.1.3 Hardware Revision Register [0xC004] [R] | | | | 7.1.4 CPU Speed Register [0xC008] [R/W] | | | | 7.1.5 Power Control Register [0xC00A] [R/W] | | | | 7.1.6 Interrupt Enable Register [0xC00E] [R/W] | | | | 7.1.7 Breakpoint Register [0xC014] [R/W] | | | | 7.1.8 USB Diagnostic Register [0xC03C] [R/W] | | | | 7.1.9 Memory Diagnostic Register [0xC03E] [W] | | | | 7.2 External Memory Registers | | | | 7.2.1 Extended Page n Map Register [R/W] | | | | 7.2.2 Upper Address Enable Register [0xC038] [R/W] | | | | 7.2.3 External Memory Control Register [0xC03A] [R/W] | | | | 7.3 Timer Registers | ا <del>۱</del> ۰۰۰<br>۱۸ | | | 7.3.1 Watchdog Timer Register [0x0000] [R/W] | | | | 7.3.2 Tiller if Register [RW] | | | | 7.4.1 USB n Control Register [R/W] | | | | 7.4.1 03B if Control Register [R/W] | | | | 7.5.1 Host n Control Register [R/W] | | | | 7.5.2 Host n Address Register [R/W] | | | | 1.0.2 1.00t 1.7 (da1000 1.0gloto) [1.17] | | # TABLE OF CONTENTS (continued) | 7.5.3 Host n Count Register [R/W] | | |-------------------------------------------------------|----------| | 7.5.4 Host n Endpoint Status Register [R] | 47 | | 7.5.5 Host n PID Register [W] | 48 | | 7.5.6 Host n Count Result Register [R] | 49 | | 7.5.7 Host n Device Address Register [W] | 50 | | 7.5.8 Host n Interrupt Enable Register [R/W] | 50 | | 7.5.9 Host n Status Register [R/W] | | | 7.5.10 Host n SOF/EOP Count Register [R/W] | 53 | | 7.5.11 Host n SOF/EOP Counter Register [R] | 53 | | 7.5.12 Host n Frame Register [R] | | | 7.6 USB Device Only Registers | 54 | | 7.6.1 Device n Endpoint n Control Register [R/W] | 55 | | 7.6.2 Device n Endpoint n Address Register [R/W] | | | 7.6.3 Device n Endpoint n Count Register [R/W] | | | 7.6.4 Device n Endpoint n Status Register [R/W] | | | 7.6.5 Device n Endpoint n Count Result Register [R/W] | | | 7.6.6 Device n Port Select Register [R/W] | | | 7.6.7 Device n Interrupt Enable Register [R/W] | | | 7.6.8 Device n Address Register [W] | | | 7.6.9 Device n Status Register [R/W] | | | 7.6.10 Device n Frame Number Register [R] | | | 7.6.11 Device n SOF/EOP Count Register [W] | | | 7.7 OTG Control Registers | | | 7.7.1 OTG Control Register [0xC098] [R/W] | | | 7.8 GPIO Registers | | | 7.8.1 GPIO Control Register [0xC006] [R/W] | 68 | | 7.8.2 GPIO n Output Data Register [R/W] | | | 7.8.3 GPIO n Input Data Register [R] | | | 7.8.4 GPIO n Direction Register [R/W] | 71 | | 7.9 IDE Registers | | | 7.9.1 IDE Mode Register [0xC048] [R/W] | 71 | | 7.9.2 IDE Start Address Register [0xC04A] [R/W] | | | 7.9.3 IDE Stop Address Register [0xC04C] [R/W] | | | 7.9.4 IDE Control Register [0xC04E] [R/W] | | | 7.9.5 IDE PIO Port Registers [0xC050 - 0xC06F] [R/W] | | | 7.10 HSS Registers | | | 7.10.1 HSS Control Register [0xC070] [R/W] | | | 7.10.2 HSS Baud Rate Register [0xC072] [R/W] | 70<br>77 | | 7.10.3 HSS Transmit Gap Register [0xC074] [R/W] | | | 7.10.4 HSS Data Register [0xC076] [R/W] | | | 7.10.5 HSS Receive Address Register [0xC078] [R/W] | | | 7.10.6 HSS Receive Counter Register [0xC07A] [R/W] | 79 | | 7.10.7 HSS Transmit Address Register [0xC07C] [R/W] | 79 | | 7.10.8 HSS Transmit Counter Register [0xC07E] [R/W] | | | 7.11 HPI Registers | | | 7.11.1 HPI Breakpoint Register [0x0140] [R] | | | 7.11.2 Interrupt Routing Register [0x0140] [R] | | | 7.11.3 SIEXmsg Register [W] | | | 7.11.4 HPI Mailbox Register [0xC0C6] [R/W] | | | 7.11.5 HPI Status Port [] [HPI: R] | 83 | # TABLE OF CONTENTS (continued) | 7.12 SPI Registers | | |-----------------------------------------------------|-----| | 7.12.1 SPI Configuration Register [0xC0C8] [R/W] | | | 7.12.2 SPI Control Register [0xC0CA] [R/W] | | | 7.12.3 SPI Interrupt Enable Register [0xC0CC] [R/W] | | | 7.12.4 SPI Status Register [0xC0CE] [R] | 89 | | 7.12.5 SPI Interrupt Clear Register [0xC0D0] [W] | | | 7.12.6 SPI CRC Control Register [0xC0D2] [R/W] | | | 7.12.7 SPI CRC Value Register [0xC0D4] [R/W] | | | 7.12.8 SPI Data Register [0xC0D6] [R/W] | | | 7.12.9 SPI Transmit Address Register [0xC0D8] [R/W] | | | 7.12.10 SPI Transmit Count Register [0xC0DA] [R/W] | | | 7.12.11 SFI Receive Address Register [0xC0DC [R/W] | | | 7.13 UART Registers | | | 7.13.1 UART Control Register [0xC0E0] [R/W] | ۰۰۰ | | 7.13.2 UART Status Register [0xC0E2] [R] | | | 7.13.3 UART Data Register [0xC0E4] [R/W] | | | 7.14 PWM Registers | | | 7.14.1 PWM Control Register [0xC0E6] [R/W] | | | 7.14.2 PWM Maximum Count Register [0xC0E8] [R/W] | | | 7.14.3 PWM n Start Register [R/W] | | | 7.14.4 PWM n Stop Register [R/W] | | | 7.14.5 PWM Cycle Count Register [0xC0FA] [R/W] | 100 | | 3.0 PIN DIAGRAM | 101 | | 9.0 PIN DESCRIPTIONS | | | 10.0 ABSOLUTE MAXIMUM RATINGS | | | 11.0 OPERATING CONDITIONS | | | | | | 12.0 CRYSTAL REQUIREMENTS (XTALIN, XTALOUT) | | | 13.0 DC CHARACTERISTICS | 105 | | 13.1 USB Transceiver | 106 | | 14.0 AC TIMING CHARACTERISTICS | 107 | | 14.1 Reset Timing | 107 | | 14.2 Clock Timing | | | 14.3 SRAM Read Cycle | | | 14.4 SRAM Write Cycle | | | 14.5 I2C EEPROM Timing | | | 14.6 HPI (Host Port Interface) Write Cycle Timing | 111 | | 14.7 HPI (Host Port Interface) Read Cycle Timing | | | 14.8 IDE Timing | | | 14.9 HSS BYTE Mode Transmit | 113 | | 14.10 HSS Block Mode Transmit | | | 14.11 HSS BYTE and BLOCK Mode Receive | | | 14.12 Hardware CTS/RTS Handshake | | | 15.0 REGISTERS SUMMARY | | | 16.0 ORDERING INFORMATION | | | 17.0 PACKAGE DIAGRAMS | | | IT N DACKACE DIACDAMS | 118 | # **LIST OF FIGURES** | Figure 1-1. | Block Diagram | .10 | |-------------|-------------------------------------------------------------|------| | Figure 4-1. | Page n Registers External Address Pins Logic | .15 | | | Interfacing to 64k × 8 Memory Array | | | Figure 4-3. | Interfacing up to 256k × 16 for External Code/Data | . 17 | | | Interfacing up to 512k × 8 for External Code/Data | | | | Charge Pump | | | | Power Supply Connection With Booster | | | | Power Supply Connection Without Booster | | | | Crystal Interface | | | | Minimum Standalone Hardware Configuration – Peripheral Only | | | • | Memory Map | | | | Processor Control Registers | | | | CPU Flags Register | | | • | Bank Register | | | • | Revision Register | | | • | CPU Speed Register | | | | Power Control Register | | | | Interrupt Enable Register | | | Figure 7-8. | Breakpoint Register | 36 | | Figure 7-9. | USB Diagnostic Register | 37 | | Figure 7-10 | ). Memory Diagnostic Register | 38 | | Figure 7-11 | . External Memory Control Registers | 39 | | Figure 7-12 | 2. Extended Page n Map Register | 39 | | Figure 7-13 | B. External Memory Control Register | 39 | | Figure 7-14 | External Memory Control Register | 40 | | | i. Timer Registers | | | Figure 7-16 | S. Watchdog Timer Register | 41 | | Figure 7-17 | '. Timer n Register | 42 | | Figure 7-18 | B. General USB Registers | 42 | | Figure 7-19 | ). USB n Control Register | 43 | | Figure 7-20 | ). USB Host Only Register | 45 | | Figure 7-21 | . Host n Control Register | 45 | | | P. Host n Address Register | | | Figure 7-23 | 3. Host n Count Register | 46 | | | . Host n Endpoint Status Register | | | Figure 7-25 | i. Host n PID Register | 49 | | | 5. Host n Count Result Register | | | Figure 7-27 | '. Host n Device Address Register | 50 | | | B. Host n Interrupt Enable Register | | | | ). Host n Status Register | | | | ). Host n SOF/EOP Count Register | | | | . Host n SOF/EOP Counter Register | | | Figure 7-32 | P. Host n Frame Register | 54 | | | B. USB Device Only Registers | | | | Device n Endpoint n Control Register | | | | i. Device n Endpoint n Address Register | | | | 6. Device n Endpoint n Count Register | | | | '. Device n Endpoint n Status Register | | | Figure 7-38 | B. Device n Endpoint n Count Result Register | 60 | # LIST OF FIGURES (continued) | | . Device n Port Select Register | | |-------------|---------------------------------------|------| | Figure 7-40 | . Device n Interrupt Enable Register | . 61 | | Figure 7-41 | . Device n Address Register | . 63 | | | . Device n Status Register | | | • | . Device n Frame Number Register | | | • | Device n SOF/EOP Count Register | | | | OTG Registers | | | | OTG Control Register | | | • | . GPIO Registers | | | • | · · · · · · · · · · · · · · · · · · · | | | | . GPIO Control Register | | | | . GPIO n Output Data Register | | | | . GPIO n Input Data Register | | | | . GPIO n Direction Register | | | | . IDE Registers | | | | . IDE Mode Register | | | Figure 7-54 | . IDE Start Address Register | . 72 | | Figure 7-55 | . IDE Stop Address Register | . 72 | | Figure 7-56 | . IDE Control Register | .73 | | Figure 7-57 | . HSS Registers | . 74 | | Figure 7-58 | . HSS Control Register | . 75 | | | . HSS Baud Rate Register | | | | . HSS Transmit Gap Register | | | | . HSS Data Register | | | | . HSS Receive Address Register | | | | . HSS Receive Counter Register | | | • | . HSS Transmit Address Register | | | • | . HSS Transmit Counter Register | | | • | . HPI Registers | | | | . HPI Breakpoint Register | | | | Interrupt Routing Register | | | | SIEXmsg Register | | | | . HPI Mailbox Register | | | • | | | | | . HPI Status Port | | | | . SPI Registers | | | | . SPI Configuration Register | | | | • | . 87 | | | . SPI Interrupt Enable Register | | | | . SPI Status Register | | | | . SPI Interrupt Clear Register | | | | . SPI CRC Control Register | | | • | . SPI CRC Value Register | | | | . SPI Data Register | | | Figure 7-81 | . SPI Transmit Address Register | . 93 | | Figure 7-82 | . SPI Transmit Count Register | . 93 | | Figure 7-83 | . SPI Receive Address Register | . 93 | | | . SPI Receive Count Register | | | • | . UART Registers | | | | . UART Control Register | | | • | UART Status Register | 95 | # LIST OF FIGURES (continued) | Figure 7-88. UART Data Register | 96 | |-----------------------------------------|-----| | Figure 7-89. PWM Registers | | | Figure 7-90. PWM Control Register | | | Figure 7-91. PWM Maximum Count Register | | | Figure 7-92. PWM n Start Register | 99 | | Figure 7-93. PWM n Stop Register | 99 | | Figure 7-94. PWM Cycle Count Register | | | Figure 8-1. EZ-Host Pin Diagram | 101 | | · · | | # LIST OF TABLES | Table 4-1. Interface Options for GPIO Pins | . 12 | |-------------------------------------------------------------|------| | Table 4-2. Interface Options for External Memory Bus Pins | . 12 | | Table 4-3. USB Port Configuration Options | . 13 | | Table 4-4. USB Interface Pins | .14 | | Table 4-5. OTG Interface Pins | .14 | | Table 4-6. External Memory Interface Pins | . 16 | | Table 4-7. UART Interface Pins | | | Table 4-8. I2C EEPROM Interface Pins | . 18 | | Table 4-9. SPI Interface Pins | | | Table 4-10. HSS Interface Pins | .20 | | Table 4-11. PWM Interface Pins | .20 | | Table 4-12. HPI Interface Pins | .21 | | Table 4-13. HPI Addressing | .21 | | Table 4-14. IDE Throughput | .22 | | Table 4-15. IDE Interface Pins | | | Table 4-16. Charge Pump Interface Pins | .23 | | Table 4-17. Charge Pump Interface Pins | .24 | | Table 4-18. Crystal Pins | .25 | | Table 4-19. Boot Configuration Interface | .25 | | Table 5-1. Wakeup Sources | . 27 | | Table 7-1. Bank Register Example | | | Table 7-2. CPU Speed Definition | | | Table 7-3. Force Select Definition | | | Table 7-4. Memory Arbitration Select | | | Table 7-5. Period Select Definition | | | Table 7-6. USB Data Line Pull-up and Pull-down Resistors | | | Table 7-7. Port A/B Force D± State | .44 | | Table 7-8. Port Select Definition | .47 | | Table 7-9. PID Select Definition | | | Table 7-10. Mode Select Definition | | | Table 7-11. Mode Select Definition | | | Table 7-12. IDE PIO Port Registers | | | Table 7-13. Scale Select Field Definition for SCK Frequency | .86 | | Table 7-14. CRC Mode Definition | | | Table 7-15. UART Baud Select Definition | | | | . 97 | | Table 9-1. Pin Descriptions1 | | | Table 12-1. Crystal Requirements1 | | | Table 13-1. DC Characteristics1 | | | Table 13-2. DC Characteristics: Charge Pump1 | | | Table 15-1. Register Summary1 | | | Table 16-1. Ordering Information | 118 | ## 1.0 INTRODUCTION EZ-Host™ (CY7C67300) is Cypress Semiconductor's first full-speed, low-cost multiport host/peripheral controller. EZ-Host is designed to easily interface to most high-performance CPUs to add USB host functionality. EZ-Host has its own 16-bit RISC processor to act as a coprocessor or operate in standalone mode. EZ-Host also has a programmable I/O interface block allowing a wide range of interface options. Figure 1-1. Block Diagram #### 1.1 EZ-Host Features - Single-chip programmable USB dual-role (Host/Peripheral) controller with two configurable Serial Interface Engines (SIEs) and four USB ports - Support for USB On-The-Go (OTG) protocol - On-chip 48-MHz 16-bit processor with dynamically switchable clock speed - Configurable I/O block supporting a variety of I/O options or up to 32 bits of General Purpose I/O (GPIO) - 4K x 16 internal masked ROM containing built-in BIOS that supports a communication ready state with access to I<sup>2</sup>C EEPROM Interface, external ROM, UART, or USB - 8K x 16 internal RAM for code and data buffering - Extended memory interface port for external SRAM and ROM - 16-bit parallel Host Port Interface (HPI) with a DMA/Mailbox data path for an external processor to directly access all of the on-chip memory and control on-chip SIEs - Fast serial port supports from 9600 baud to 2.0 Mbaud - · SPI support in both master and slave - · On-chip 16-bit DMA/Mailbox data path interface - Supports 12-MHz external crystal or clock - 3.3V operation - Package option 100-pin TQFP # 2.0 Typical Applications EZ-Host is a very powerful and flexible dual role USB controller that supports a wide variety of applications. It is primarily intended to enable host capability in applications such as: - · Set-top boxes - Printers - KVM switches - Kiosks - · Automotive applications - · Wireless access points. ## 3.0 Functional Overview ## 3.1 Processor Core #### 3.1.1 Processor EZ-Host has a general-purpose 16-bit embedded RISC processor that runs at 48 MHz. ## 3.1.2 Clocking EZ-Host requires a 12-MHz source for clocking. Either an external crystal or TTL level oscillator may be used. EZ-Host has an internal PLL that produces a 48-MHz internal clock from the 12-MHz source. #### 3.1.3 Memory EZ-Host has a built-in 4K × 16 masked ROM and an 8K × 16 internal RAM. The masked ROM contains the EZ-Host BIOS. The internal RAM can be used for program code or data. ## 3.1.4 Interrupts EZ-Host provides 128 interrupt vectors. The first 48 vectors are hardware interrupts and the following 80 vectors are software interrupts. ## 3.1.5 General Timers and Watchdog Timer EZ-Host has two built-in programmable timers and a Watchdog timer. All three timers can generate an interrupt to the EZ-Host. ## 3.1.6 Power Management EZ-Host has one main power saving mode, Sleep. Sleep mode pauses all operations and provides the lowest power state. # 4.0 Interface Descriptions EZ-Host has a wide variety of interface options for connectivity. With several interface options available, EZ-Host can act as a seamless data transport between many different types of devices. See *Table 4-1* and *Table 4-2* to understand how the interfaces share pins and which can coexist. It should be noted that some interfaces have more then one possible port location selectable through the GPIO Control Register [0xC006]. Below are some general guidelines: - · HPI and IDE interfaces are mutually exclusive. - If 16-bit external memory is required, then HSS and SPI default locations must be used. - I<sup>2</sup>C EEPROM and OTG do not conflict with any interfaces. Table 4-1. Interface Options for GPIO Pins | GPIO Pins | HPI | IDE | PWM | HSS | SPI | UART | I2C | OTG | |-----------|-----|---------|------|--------------------|---------------------|-------------------|---------|-------| | GPIO31 | | | | | | | SCL/SDA | | | GPIO30 | | | | | | | SCL/SDA | | | GPIO29 | | | | | | | | OTGID | | GPIO28 | | | | | | TX <sup>[1]</sup> | | | | GPIO27 | | | | | | RX <sup>[1]</sup> | | | | GPIO26 | | | PWM3 | CTS <sup>[1]</sup> | | | | | | GPIO25 | | | | | | | | | | GPIO24 | INT | IOREADY | | | | | | | | GPIO23 | nRD | IOR | | | | | | | | GPIO22 | nWR | IOW | | | | | | | | GPIO21 | nCS | | | | | | | | | GPIO20 | A1 | CS1 | | | | | | | | GPIO19 | A0 | CS0 | | | | | | | | GPIO18 | | A2 | PWM2 | RTS <sup>[1]</sup> | | | | | | GPIO17 | | A1 | PWM1 | RXD <sup>[1]</sup> | | | | | | GPIO16 | | A0 | PWM0 | TXD <sup>[1]</sup> | | | | | | GPIO15 | D15 | D15 | | | | | | | | GPIO14 | D14 | D14 | | | | | | | | GPIO13 | D13 | D13 | | | | | | | | GPIO12 | D12 | D12 | | | | | | | | GPIO11 | D11 | D11 | | | MOSI <sup>[1]</sup> | | | | | GPIO10 | D10 | D10 | | | SCK <sup>[1]</sup> | | | | | GPIO9 | D9 | D9 | | | nSSI <sup>[1]</sup> | | | | | GPIO8 | D8 | D8 | | | MISO <sup>[1]</sup> | | | | | GPIO7 | D7 | D7 | | | | TX <sup>[2]</sup> | | | | GPIO6 | D6 | D6 | | | | RX <sup>[2]</sup> | | | | GPIO5 | D5 | D5 | | | | | | | | GPIO4 | D4 | D4 | | | | | | | | GPIO3 | D3 | D3 | | | | | | | | GPIO2 | D2 | D2 | | | | | | | | GPIO1 | D1 | D1 | | | | | | | | GPIO0 | D0 | D0 | | | | | | | Table 4-2. Interface Options for External Memory Bus Pins | MEM Pins | HPI | IDE | PWM | HSS | SPI | UART | I2C | OTG | |----------|-----|-----|-----|--------------------|---------------------|------|-----|-----| | D15 | | | | CTS <sup>[2]</sup> | | | | | | D14 | | | | RTS <sup>[2]</sup> | | | | | | D13 | | | | RXD <sup>[2]</sup> | | | | | | D12 | | | | TXD <sup>[2]</sup> | | | | | | D11 | | | | | MOSI <sup>[2]</sup> | | | | | D10 | | | | | SCK <sup>[2]</sup> | | | | | D9 | | | | | nSSI <sup>[2]</sup> | | | | | D8 | | | | | MISO <sup>[2]</sup> | | | | | D[7:0] | | | | | | | | | | A[18:0] | | | | | | | | | | CONTROL | | | | | | | | | # Notes: - Default interface location. Alternate interface location. ## 4.1 USB Interface EZ-Host has two built-in Host/Peripheral SIEs and four USB transceivers that meet the USB 2.0 specification requirements for full and low speed (high speed is not supported). In Host mode, EZ-Host supports four downstream ports, each support control, interrupt, bulk, and isochronous transfers. In Peripheral mode, EZ-Host supports one peripheral port with eight endpoints for each of the two SIEs. Endpoint 0 is dedicated as the control endpoint and only supports control transfers. Endpoints 1 though 7 support Interrupt, Bulk (up to 64 Bytes/packet), or Isochronous transfers (up to 1023 Bytes/packet size). EZ-Host also supports a combination of Host and Peripheral ports simultaneously as shown in *Table 4-3*. **Table 4-3. USB Port Configuration Options** | Port Configurations | Port 1A | Port 1B | Port 2A | Port 2B | | | | |------------------------|------------|-------------|----------------|------------|--|--|--| | OTG | OTG | _ | _ | _ | | | | | OTG + 2 Hosts | OTG | _ | Host | Host | | | | | OTG + 1 Host | OTG | _ | Host | _ | | | | | OTG + 1 Host | OTG | _ | _ | Host | | | | | OTG + 1 Peripheral | OTG | _ | Peripheral | _ | | | | | OTG + 1 Peripheral | OTG | _ | _ | Peripheral | | | | | 4 Hosts | Host | Host | Host | Host | | | | | 3 Hosts | | Any Combina | ation of Ports | • | | | | | 2 Hosts | | Any Combina | ation of Ports | | | | | | 1 Host | | Any | Port | | | | | | 2 Hosts + 1 Peripheral | Host | Host | Peripheral | _ | | | | | 2 Hosts + 1 Peripheral | Host | Host | _ | Peripheral | | | | | 2 Hosts + 1 Peripheral | Peripheral | _ | Host | Host | | | | | 2 Hosts + 1 Peripheral | _ | Peripheral | Host | Host | | | | | 1 Host + 1 Peripheral | Host | _ | Peripheral | _ | | | | | 1 Host + 1 Peripheral | Host | _ | _ | Peripheral | | | | | 1 Host + 1 Peripheral | _ | Host | _ | Peripheral | | | | | 1 Host + 1 Peripheral | _ | Host | Peripheral | _ | | | | | 1 Host + 1 Peripheral | Peripheral | _ | Host | _ | | | | | 1 Host + 1 Peripheral | Peripheral | _ | _ | Host | | | | | 1 Host + 1 Peripheral | _ | Peripheral | _ | Host | | | | | 1 Host + 1 Peripheral | _ | Peripheral | Host | _ | | | | | 2 Peripherals | Peripheral | _ | Peripheral | _ | | | | | 2 Peripherals | Peripheral | _ | _ | Peripheral | | | | | 2 Peripherals | _ | Peripheral | _ | Peripheral | | | | | 2 Peripherals | _ | Peripheral | Peripheral | _ | | | | | 1 Peripheral | | Any Port | | | | | | # 4.1.1 USB Features - USB 2.0-compliant for full and low speed - Up to four downstream USB host ports - · Up to two upstream USB peripheral ports - · Configurable endpoint buffers (pointer and length), must reside in internal RAM - Up to eight available peripheral endpoints (one control endpoint) - Supports Control, Interrupt, Bulk, and Isochronous transfers - · Internal DMA channels for each endpoint - · Internal pull-up and pull-down resistors - Internal Series termination resistors on USB data lines # 4.1.2 USB Pins. Table 4-4. USB Interface Pins | Pin Name | Pin Number | |----------|------------| | DM1A | 22 | | DP1A | 23 | | DM1B | 18 | | DP1B | 19 | | DM2A | 9 | | DP2A | 10 | | DM2B | 4 | | DP2B | 5 | ## 4.2 OTG Interface EZ-Host has one USB port that is compatible with the USB On-The-Go supplement to the USB 2.0 specification. The USB OTG port has a various hardware features to support Session Request Protocol (SRP) and Host Negotiation Protocol (HNP). OTG is only supported on USB PORT 1A. #### 4.2.1 OTG Features - · Internal Charge Pump to supply and control VBUS - VBUS Valid Status (above 4.4V) - VBUS Status for 2.4V< VBUS <0.8V - · ID Pin Status - Switchable $2K\Omega$ internal discharge resistor on VBUS - Switchable $500\Omega$ internal Pull-up resistor on VBUS - · Individually switchable internal Pull-up and Pull-down resistors on the USB Data Lines # 4.2.2 OTG Pins. Table 4-5. OTG Interface Pins | Pin Name | Pin Number | |----------|------------| | DM1A | 22 | | DP1A | 23 | | OTGVBUS | 11 | | OTGID | 41 | | CSwitchA | 13 | | CSwitchB | 12 | # 4.3 External Memory Interface EZ-Host provides a robust interface to a wide variety of external memory arrays. All available external memory array locations can contain either code or data. The CY16 RISC processor directly addresses a flat memory space from 0x0000 to 0xFFFF. ## 4.3.1 External Memory Interface Features - Supports 8-bit or 16-bit SRAM or ROM - SRAM or ROM can be used for code or data space - · Direct addressing of SRAM or ROM - Two external memory mapped page registers # 4.3.2 External Memory Access Strobes Access to external memory is sampled asynchronously on the rising edge of strobes with a minimum of one wait state cycle. Up to seven wait state cycles may be inserted for external memory access. Each additional wait state cycle stretches the external memory access time by 21 nsec. An external memory device with 12-nsec access time is necessary to support 48-MHz code execution. ## 4.3.3 Page Registers EZ-Host allows extended data or program code to be stored in external SRAM, or ROM. The total size of extended memory can be up to 512K bytes. The CY16 processor can access extended memory via two address regions of 0x8000-0x9FFF and 0xA000-0xBFFF. The page register 0xC018 can be used to control the address region 0x8000-0x9FFF and the page register 0xC01A controls the address region of 0xA000-0xBFFF. Figure 4-1 illustrates that when the nXMEMSEL pin is asserted the upper CPU address pins are driven by the contents of the Page x Registers. Figure 4-1. Page n Registers External Address Pins Logic ## 4.3.4 Merge Mode Merge modes enabled through the External Memory Control Register [0xC03] allow combining of external memory regions in accordance with the following: - nXMEMSEL is active from 0x8000 to 0xBFFF - nXRAMSEL is active from 0x4000 to 0x7FFF when RAM Merge is disabled; nXRAMSEL is active from 0x4000 to 0xBFFF when RAM Merge is enabled - nXROMSEL is active from 0xC100 to 0xDFFF when ROM Merge is disabled; nXROMSEL is active from 0x8000 to 0xDFFF (excluding the 0xC000 to 0xC0FF area) when ROM Merge is enabled ## 4.3.5 Program Memory Hole Description Code residing in the 0xC000-0xC0FF address space is not accessible by the cpu. # 4.3.6 DMA to External Memory Prohibited EZ-Host supports an internal DMA engine to rapidly move data between different functional blocks within the chip. This DMA engine is used for SIE1, SIE2, HPI, SPI, HSS, and IDE but it can only transfer data between the specified block and internal RAM or ROM. Setting up the DMA engine to transfer to or from an external memory space might result in internal RAM data corruption because the hardware (i.e HSS/HPI/SIE1/SIE2/IDE) does not explicitly check the address range. For example, setting up a DMA transfer to external address 0x8000 might result in a DMA transfer into address 0x0000. External Memory Related Resource Considerations: - By default A[18:15] are not available for general addressing and are driven high on power up. The <u>Upper Address Enable</u> Register must be written appropriately to enable A[18:15] for general addressing purposes. - 47k ohm external pull-up on A15-pin for 12-MHz crystal operation. - During the 3-msec BIOS boot procedure the CPU external memory bus is active. - ROM boot load value 0xC3B6 located at 0xC100. - HPI, HSS, SPI, SIE1, SIE2, and IDE can't DMA to external memory arrays. - Page 1 banking is always enabled and is in effect from 0x8000 to 0x9FFF. - Page 2 banking is always enabled and is in effect from 0xA000 to 0xBFFF. - CPU memory bus strobes may wiggle when chip selects are inactive. # 4.3.7 External Memory Interface Pins Table 4-6. External Memory Interface Pins | Pin Name | Pin Number | | |-------------------------|------------|--| | nWR | 64 | | | nRD | 62 | | | nXMEMSEL (optional nCS) | 34 | | | nXROMSEL (ROM nCS) | 35 | | | nXRAMSEL (RAM nCS) | 36 | | | A18 | 96 | | | A17 | 95 | | | A16 | 97 | | | A15 | 38 | | | A14 | 33 | | | A13 | 32 | | | A12 | 31 | | | A11 | 30 | | | A10 | 27 | | | A9 | 25 | | | A8 | 24 | | | A7 | 20 | | | A6 | 17 | | | A5 | 8 | | | A4 | 7 | | | A3 | 3 | | | A2 | 2 | | | A1 | 1 | | | nBEL/A0 | 99 | | | nBEH | 98 | | | D15 | 67 | | | D14 | 68 | | | D13 | 69 | | | D12 | 70 | | | D11 | 71 | | | D10 | 72 | | | D9 | 73 | | | D8 | 74 | | | D7 | 76 | | | D6 | 77 | | | D5 | 78 | | | D4 | 79 | | | D3 | 80 | | | D2 | 81 | | | D1 | 82 | | | D0 | 83 | | | I. | | | # 4.3.8 External Memory Interface Block Diagrams Figure 4-2 illustrates how to connect a 64k × 8 memory array (SRAM/ROM) to the EZ-Host external memory interface. # Interfacing to 64K x 8 External Memory Array Figure 4-2. Interfacing to 64k × 8 Memory Array Figure 4-3 illustrates the interface for connecting a 16-bit ROM or 16-bit RAM to the EZ-Host external memory interface. In 16-bit mode, up to 256K words of external ROM or RAM are supported. Note that the Address lines do not map directly. # Up to 256k x 16 External Code/Data (Page Mode) Figure 4-3. Interfacing up to 256k × 16 for External Code/Data Figure 4-4 illustrates the interface for connecting an 8-bit ROM or 8-bit RAM to the EZ-Host external memory interface. In 8-bit mode, up to 512K bytes of external ROM or RAM are supported. # Up to 512k x 8 External Code/Data (Page Mode) Figure 4-4. Interfacing up to 512k × 8 for External Code/Data # 4.4 General Purpose I/O Interface (GPIO) EZ-Host has up to 32 GPIO signals available. Several other optional interfaces use GPIO pins as well and may reduce the overall number of available GPIOs. ## 4.4.1 GPIO Description All Inputs are sampled asynchronously with state changes occurring at a rate of up to two 48-MHZ clock cycles. GPIO pins are latched directly into registers, a single flip-flop. ## 4.4.2 Unused Pin Descriptions Unused USB pins should be three-stated with the D+ line pulled high through the internal pull-up resistor and the D- line pulled low through the internal pull-down resistor. Unused GPIO pins should be configured as outputs and driven low. ## 4.5 UART Interface EZ-Host has a built-in UART interface. The UART interface supports data rates from 900 to 115.2K baud. It can be used as a development port or for other interface requirements. The UART interface is exposed through GPIO pins. ## 4.5.1 UART Features - · Supports baud rates of 900 to 115.2K - 8-N-1 #### 4.5.2 UART Pins. Table 4-7. UART Interface Pins | Pin Name | Pin Number | |----------|------------| | TX | 42 | | RX | 43 | # 4.6 I<sup>2</sup>C EEPROM Interface EZ-Host provides a master only I<sup>2</sup>C interface for external serial EEPROMs. The serial EEPROM can be used to store application specific code and data. This I<sup>2</sup>C interface is only to be used for loading code out of EEPROM, it is not a general I<sup>2</sup>C interface. The I<sup>2</sup>C EEPROM interface is a BIOS implementation and is exposed through GPIO pins. Please refer to the BIOS documentation for additional details on this interface. # 4.6.1 I<sup>2</sup>C EEPROM Features - Supports EEPROMs up to 64KB (512K bit) - · Auto-detection of EEPROM size ## 4.6.2 I2C EEPROM Pins. Table 4-8. I2C EEPROM Interface Pins | Pin Name | Pin Number | | |--------------|------------|--| | SMALL EEPROM | | | | SCK | 39 | | | SDA | 40 | | | LARGE EEPROM | | | | SCK | 40 | | | SDA | 39 | | # 4.7 Serial Peripheral Interface EZ-Host provides a SPI interface for added connectivity. EZ-Host may be configured as either an SPI master or SPI slave. The SPI interface can be exposed through GPIO pins or the External Memory port. ## 4.7.1 SPI Features - · Master or slave mode operation - DMA block transfer and PIO byte transfer modes - · Full duplex or half duplex data communication - · 8-byte receive FIFO and 8-byte transmit FIFO - Selectable master SPI clock rates from 250 KHz to 12 MHz - · Selectable master SPI clock phase and polarity - Slave SPI signaling synchronization and filtering - · Slave SPI clock rates up to 2 MHz - · Maskable interrupts for block and byte transfer modes - · Individual bit transfer for non-byte aligned serial communication in PIO mode - · Programmable delay timing for the active/inactive master SPI clock - · Auto or manual control for master mode slave select signal - · Complete access to internal memory #### 4.7.2 SPI Pins The SPI port has a few different pin location options as shown in *Table 4-9*. The port location is selectable via the GPIO Control Register [0xC006]. Table 4-9. SPI Interface Pins | Pin Name | Pin Number | |--------------------|------------| | Default Location | | | nSSI | 56 or 65 | | SCK | 61 | | MOSI | 60 | | MISO | 66 | | Alternate Location | | | nSSI | 73 | | SCK | 72 | | MOSI | 71 | | MISO | 74 | # 4.8 High-speed Serial Interface EZ-Host provides an HSS interface. The HSS interface is a programmable serial connection with baud rate from 9600 baud to 2.0 Mbaud. The HSS interface supports both byte and block mode operations as well as hardware and software handshaking. Complete control of EZ-Host can be accomplished through this interface via an extensible API and communication protocol. The HSS interface can be exposed through GPIO pins or the External Memory port. # 4.8.1 HSS Features - · 8 bits, no parity code - · Programmable baud rate from 9600 baud to 2 Mbaud - · Selectable 1- or 2-stop bit on transmit - · Programmable inter-character gap timing for Block Transmit - · 8-byte receive FIFO - · Glitch filter on receive - Block mode transfer directly to/from EZ-Host internal memory (DMA transfer) - · Selectable CTS/RTS hardware signal handshake protocol - · Selectable XON/XOFF software handshake protocol - Programmable Receive interrupt, Block Transfer Done interrupts - · Complete access to internal memory ## 4.8.2 HSS Pins The HSS port has a few different pin location options as shown in *Table 4-10*. The port location is selectable via the GPIO Control Register [0xC006]. Table 4-10. HSS Interface Pins | Pin Name | Pin Number | |--------------------|------------| | Default Location | | | CTS | 67 | | RTS | 68 | | RX | 69 | | TX | 70 | | Alternate Location | | | CTS | 44 | | RTS | 53 | | RX | 54 | | TX | 55 | # 4.9 Programmable Pulse/PWM Interface EZ-Host has four built-in PWM output channels. Each channel provides a programmable timing generator sequence that can be used to interface to various image sensors or other applications. The PWM interface is exposed through GPIO pins. ## 4.9.1 Programmable Pulse/PWM Features - Four independent programmable waveform generators - Programmable predefined frequencies ranging from 5.90 KHz to 48 MHz - · Configurable polarity - · Continuous and one-shot mode available # 4.9.2 Programmable Pulse/PWM Pins. Table 4-11. PWM Interface Pins | Pin Name | Pin Number | |----------|------------| | PWM3 | 44 | | PWM2 | 53 | | PWM1 | 54 | | PWM0 | 55 | #### 4.10 Host Port Interface EZ-Host has an HPI interface. The HPI interface provides DMA access to the EZ-Host internal memory by an external host, plus a bidirectional mailbox register for supporting high-level communication protocols. This port is designed to be the primary high-speed connection to a host processor. Complete control of EZ-Host can be accomplished through this interface via an extensible API and communication protocol. Other than the HW communication protocols, a host processor has identical control over EZ-Host whether connecting to the HPI or HSS port. The HPI interface is exposed through GPIO pins. #### 4.10.1 HPI Features - · 16-bit data bus interface - 16 MB/s throughput - · Auto-Increment of address pointer for fast block mode transfers - · Direct memory access (DMA) to internal memory - · Bidirectional Mailbox register - · Byte Swapping - · Complete access to internal memory - · Complete control of SIEs through HPI - Dedicated HPI Status Register 4.10.2 HPI Pins. Table 4-12. HPI Interface Pins<sup>[3, 4]</sup> | Pin Name | Pin Number | |----------|------------| | INT | 46 | | nRD | 47 | | nWR | 48 | | nCS | 49 | | A1 | 50 | | A0 | 52 | | D15 | 56 | | D14 | 57 | | D13 | 58 | | D12 | 59 | | D11 | 60 | | D10 | 61 | | D9 | 65 | | D8 | 66 | | D7 | 86 | | D6 | 87 | | D5 | 89 | | D4 | 90 | | D3 | 91 | | D2 | 92 | | D1 | 93 | | D0 | 94 | The two HPI address pins are used to address one of four possible HPI port registers as shown in Table 4-13 below. Table 4-13. HPI Addressing | HPI A[1:0] | A1 | A0 | |-------------|----|----| | HPI Data | 0 | 0 | | HPI Mailbox | 0 | 1 | | HPI Address | 1 | 0 | | HPI Status | 1 | 1 | # 4.11 IDE Interface EZ-Host has an IDE interface. The IDE interface supports PIO mode 0-4 as specified in the Information Technology-AT Attachment–4 with Packet Interface Extension (ATA/ATAPI-4) Specification, T13/1153D Rev 18. There is no need for firmware to use programmable wait states. The CPU read/write cycle is automatically extended as needed for direct CPU to IDE read/write accesses. The EZ-Host IDE interface also has a BLOCK transfer mode that allows EZ-Host to read/write large blocks of data to/from the IDE Data Register and move it to/from the EZ-Host onchip memory directly without intervention of the CPU. The IDE interface is exposed through GPIO pins. *Table 4-14* lists the achieved throughput for maximum block mode data transfer rate (with IDE\_IORDY true) for the various IDE PIO modes. Notes: - 3. HPI\_INT is for the Outgoing Mailbox Interrupt. - 4. HPI strobes are negative logic sampled on rising edge. Table 4-14. IDE Throughput | Mode | ATA/ATAPI-4<br>Min. Cycle Time | Actual<br>Min. Cycle Time | ATA/ATPI-4<br>Max. Transfer Rate | Actual<br>Max. Transfer Rate | |------------|--------------------------------|---------------------------|----------------------------------|------------------------------| | PIO Mode 0 | 600 ns | 30T = 625 ns | 3.33 MB/s | 3.2 MB/s | | PIO Mode 1 | 383 ns | 20T = 416.7 ns | 5.22 MB/s | 4.8 MB/s | | PIO Mode 2 | 240 | 13T = 270.8 ns | 8.33 MB/s | 7.38 MB/s | | PIO Mode 3 | 180 ns | 10T = 208.3 ns | 11.11 MB/s | 9.6 MB/s | | PIO Mode 4 | 120 ns | 8T = 166.7 ns | 16.67 MB/s | 12.0 MB/s | T = System clock period = 1/48 MHz. # 4.11.1 IDE Features - Programmable I/O mode 0-4 - · Block mode transfers - Direct memory access to/from internal memory through the IDE Data Register # 4.11.2 IDE Pins Table 4-15. IDE Interface Pins | Pin Name | Pin Number | |----------|------------| | IORDY | 46 | | IOR | 47 | | IOW | 48 | | CS1 | 50 | | CS0 | 52 | | A2 | 53 | | A1 | 54 | | A0 | 55 | | D15 | 56 | | D14 | 57 | | D13 | 58 | | D12 | 59 | | D11 | 60 | | D10 | 61 | | D9 | 65 | | D8 | 66 | | D7 | 86 | | D6 | 87 | | D5 | 89 | | D4 | 90 | | D3 | 91 | | D2 | 92 | | D1 | 93 | | D0 | 94 | # 4.12 Charge Pump Interface VBUS for the USB OTG port can be produced by EZ-Host using its built-in charge pump and some external components. The circuit connections should look similar to the diagram below. Figure 4-5. Charge Pump ## Component details: - D1 and D2: Schottky diodes with a current rating greater than 60 mA - C1: Ceramic capacitor with a capacitance of 0.1 uF - C2: Capacitor value should be no more that 6.5 uF since that is the maximum capacitance allowed by the USB OTG spec for a dual-role device. The minimum value of C2 is 1 uF. There are no restrictions on the type of capacitor for C2. If the VBUS charge pump circuit is not to be used, CSWITCHA, CSWITCHB, and OTGVBUS can be left unconnected. ## 4.12.1 Charge Pump Features • Meets OTG Supplement Requirements, see DC Characteristics: Charge Pump Table 13-2 for details. ## 4.12.2 Charge Pump Pins. Table 4-16. Charge Pump Interface Pins | Pin Name | Pin Number | |----------|------------| | OTGVBUS | 11 | | CSwitchA | 13 | | CSwitchB | 12 | ## 4.13 Booster Interface EZ-Host has an on-chip power booster circuit for use with power supplies that range between 2.7V and 3.6V. The booster circuit boosts the power to 3.3V nominal to supply power for the entire chip. The booster circuit requires an external inductor, diode, and capacitor. During power down mode, the circuit is disabled to save power. The figure below shows how to connect the booster circuit. Figure 4-6. Power Supply Connection With Booster # Component details: - L1: Inductor with inductance of 10 uH and a current rating of at least 250 mA - D1: Schottky diode with a current rating of at least 250 mA - C1: Tantalum or ceramic capacitor with a capacitance of at least 2.2 uF. Figure 4-7 shows how to connect the power supply when the booster circuit is not being used. Figure 4-7. Power Supply Connection Without Booster # 4.13.1 Booster Pins. Table 4-17. Charge Pump Interface Pins | Pin Name | Pin Number | |----------|------------| | BOOSTVcc | 16 | | VSWITCH | 14 | # 4.14 Crystal Interface The recommended crystal circuit to be used with EZ-Host is shown in *Figure 4-8* If an oscillator is used instead of a crystal circuit, connect it to XTALIN and leave XTALOUT unconnected. For further information on the crystal requirements, see Crystal Requirements *Table 12-1*. It should be noted that the CLKSEL pin (pin 38) is sampled after reset to determine what crystal or clock source frequency is used. For normal operation, 12 MHz is required so the CLKSEL pin **must** have a 47-kohm pull-up resistor to $V_{CC}$ . Figure 4-8. Crystal Interface ## 4.14.1 Crystal Pins Table 4-18. Crystal Pins | Pin Name | Pin Number | |----------|------------| | XTALIN | 29 | | XTALOUT | 28 | # 4.15 Boot Configuration Interface EZ-Host can boot into any one of four modes. The mode it boots into is determined by the TTL voltage level of GPIO[31:30] at the time nRESET is deasserted. The table below shows the different boot pin combinations possible. After a reset pin event occurs, the BIOS bootup procedure executes for up to 3 ms. GPIO[31:30] are sampled by the BIOS during bootup only. After bootup these pins are available to the application as GPIOs. Table 4-19. Boot Configuration Interface | GPIO31 (Pin 39) | GPIO30 (Pin 40) | Boot Mode | |-----------------|-----------------|-----------------------------------------------| | 0 | 0 | Host Port Interface (HPI) | | 0 | 1 | High-Speed Serial (HSS) | | 1 | 0 | Serial Peripheral Interface (SPI, slave mode) | | 1 | 1 | I <sup>2</sup> C EEPROM (Standalone Mode) | GPIO[31:30] should be pulled high or low as needed using resistors tied to $V_{CC}$ or GND with resistor values between 5K $\Omega$ and 15K $\Omega$ . GPIO[31:30] should not be tied directly to $V_{CC}$ or GND. Note that in standalone mode, the pull-ups on those two pins are used for the serial I2C EEPROM (if implemented). The resistors used for these pull-ups should conform to the serial EEPROM manufacturer's requirements. If any mode other then standalone is chosen, EZ-Host will be in coprocessor mode. The device will power up with the appropriate communication interface enabled according to its boot pins and wait idle until a coprocessor communicates with it. See the BIOS documentation for greater detail of the boot process. ## 4.16 Operational Modes #### 4.16.1 Coprocessor Mode EZ-Host can act as a coprocessor to an external host processor. In this mode, an external host processor drives EZ-Host and is the main processor rather then EZ-Host's own 16-bit internal CPU. An external host processor may interface to EZ-Host through one of the following three interfaces in coprocessor mode: - HPI mode, a 16-bit parallel interface with up to 16 MB transfer rate - · HSS mode, a serial interface with up to 2 MBaud transfer rate - SPI mode, a serial interface with up to 2 Mb/s transfer rate. At bootup GPIO[31:30] determine which of these three interfaces are used for coprocessor mode. See *Table 4-19* for details. Bootloading begins from the selected interface after POR + 3 ms of BIOS boot-up. #### 4.16.2 Standalone Mode In standalone mode, there is no external processor connected to EZ-Host. Instead, EZ-Host's own internal 16-bit CPU is the main processor and firmware is typically downloaded from an EEPROM. Optionally, firmware may also be downloaded via USB. See *Table 4-19* for booting into standalone mode. After booting into standalone mode (GPIO[31:30] = '11'), the following pins are effected: - GPIO[31:20] are configured as output pins to examine the EEPROM contents - GPIO[28:27] are enabled for debug UART mode - GPIO[29] is configured for as OTGID for OTG applications on PORT1A - If OTGID is logic 1 then PORT1A (OTG) is configured as a USB peripheral - If OTGID is logic 0 then PORT1A (OTG) is configured as a USB host - · Ports 1B, 2A, and 2B default as USB peripheral ports - · All other pins remain INPUT pins. ## 4.16.2.1 Minimum Hardware Requirements for Standalone Mode – Peripheral Only ## Minimum Standalone Hardware Configuration - Peripheral Only Figure 4-9. Minimum Standalone Hardware Configuration – Peripheral Only # 5.0 Power-Savings and Reset Description # 5.1 Power-Savings Mode Description EZ-Host has one main power-savings mode, Sleep. For detailed information on Sleep mode, see section 5.2. Sleep mode is used for USB applications to support USB suspend and non USB applications as the main chip power down mode. In addition, EZ-Host is capable of slowing down the CPU clock speed through the CPU Speed Register [0xC008] without affecting other peripheral timing. Reducing the CPU clock speed from 48 MHz to 24 MHz will reduce the overall current draw by around 8mA while reducing it from 48 MHz to 3 MHz will reduce the overall current draw by approximately 15 mA. # 5.2 Sleep Sleep mode is the main chip power down mode and is also used for USB suspend. Sleep mode is entered by setting the Sleep Enable (bit 1) of the Power Control Register [0xC00A]. During Sleep mode (USB Suspend) the following events and states are true: - · GPIO pins maintain their configuration during sleep (in suspend) - · External Memory Address pins are driven low - · XTALOUT will be turned off - · Internal PLL will be turned off - Firmware should disable the charge pump (OTG Control Register [0xC098]) causing OTGVBUS to drop below 0.2V. Otherwise OTGVBUS will only drop to V<sub>CC</sub> – (2 schottky diode drops). - · Booster circuit will be turned off - · USB transceivers will be turned off - · CPU will suspend until a programmable wakeup event. # 5.3 External (Remote) wakeup Source There are several possible events available to wake EZ-Host from Sleep mode as shown in *Table 5-1*. These may also be used as remote wakeup options for USB applications. See the Power-down Control Register [0xC00A] for details. Upon wakeup, code will begin executing within 200 µs, the time it takes the PLL to stabilize. Table 5-1. Wakeup Sources<sup>[5, 6]</sup> | Wakeup Source<br>(if enabled) | Event | |-------------------------------|-----------------| | USB Resume | D+/D- Signaling | | OTGVBUS | Level | | OTGID | Any Edge | | HPI | Read | | HSS | Read | | SPI | Read | | IRQ1 (GPIO 25) | Any Edge | | IRQ0 (GPIO 24) | Any Edge | ## 5.4 Power-On-Reset Description The length of the power-on-reset event can be defined by (VCC ramp to valid) + (Crystal start up). A typical application might utilize a 12-ms power-on-reset event = $\sim$ 7 ms + $\sim$ 5 ms, respectively. #### 5.5 Reset Pin The Reset pin is active low and requires a minimum pulse duration of 16 12-MHz clock cycles (1.3 µs). A reset event will restore all registers to their default POR settings. Code execution will then begin 200 µs later at 0xFF00 with an immediate jump to 0xE000, the start of BIOS. Please refer to BIOS documentation for addition details. ## 5.6 USB Reset A USB Reset will affect registers 0xC090 and 0xC0B0, all other registers remain unchanged. **Notes:** - 5. Read data will be discarded (dummy data). - HPI\_INT will assert on a USB Resume. # 6.0 Memory Map # 6.1 Mapping The total memory space directly addressable by the CY16 processor is 64K (0x0000-0xFFFF). Program, data, and I/O are contained within this 64K space. This memory space is byte addressable. Figure 6-1. shows the various memory region address locations. ## 6.1.1 Internal Memory Of the internal memory, 15K bytes are allocated for user's program and data. The lower memory space from 0x0000 to 0x04A2 is reserved for interrupt vectors, general-purpose registers, USB control registers, stack, and other BIOS variables. The upper internal memory space contains EZ-Host control registers from 0xC000 to 0xC0FF and the BIOS ROM itself from 0xE000 to 0xFFFF. For more information on the reserved lower memory or the BIOS ROM, please refer to the Programmers documentation and/or the BIOS documentation. During development with the EZ-Host toolset, the lower area of User's space (0x04A4 to 0x1000) should be left available to load the GDB stub. The GDB stub is required to allow the toolset debug access into EZ-Host. The chip select pins are not active during accesses to internal memory. ## 6.1.2 External Memory up to 32KB of external memory from 0x4000 - 0xBFFF is available via one chip select line (nXRAMSEL) with RAM Merge enabled (BIOS default). Additionally, another 8KB region from 0xC100 - 0xDFFF is available via a second chip select line (nXROMSEL) giving 40KB of total available external memory. Together with the internal 15KB, this gives a total of either ~48KB (1 chip select) or ~56KB (2 chip selects) of available memory for either code or data. Please note that the memory map and pin names (nXRAMSEL/nXROMSEL) define specific memory regions for RAM vs. ROM. This allows the BIOS to look in the upper external memory space at 0xC100 for SCAN vectors (enabling code to be loaded/executed from ROM). If no SCAN vectors are required in the design (external memory is used exclusively for data), then all external memory regions can be used for RAM. Similarly, the external memory can be used exclusively for code space (ROM). If more external memory is required, EZ-Host has enough address lines to support up to 512KB. However, this will require complex code banking/paging schemes via the Extended Page Registers. For further information on setting up the external memory, see the External Memory Interface Section. # **Internal Memory** Figure 6-1. Memory Map # 7.0 Registers Some registers have different functions for a read vs. a write access or USB host vs. USB device mode. Therefore, registers of this type will have multiple definitions for the same address. The default register values listed in this datasheet may get altered to some other value during the BIOS initialization. Please refer to the BIOS documentation for Register initialization information. ## 7.1 Processor Control Registers There are nine registers dedicated to general processor control. Each of these registers are covered in this section and are summarized in *Figure 7-1*. | Register Name | Address | R/W | |----------------------------|---------|-----| | CPU Flags Register | 0xC000 | R | | Register Bank Register | 0xC002 | R/W | | Hardware Revision Register | 0xC004 | R | | CPU Speed Register | 0xC008 | R/W | | Power Control Register | 0xC00A | R/W | | Interrupt Enable Register | 0xC00E | R/W | | Breakpoint Register | 0xC014 | R/W | | USB Diagnostic Register | 0xC03C | W | | Memory Diagnostic Register | 0xC03E | W | Figure 7-1. Processor Control Registers # 7.1.1 CPU Flags Register [0xC000] [R] | Bit# | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|----------|----------|----|-------------------------------|------------------|------------------|---------------|--------------|--| | Field | | Reserved | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | Reserved | | | Global<br>Interrupt<br>Enable | Negative<br>Flag | Overflow<br>Flag | Carry<br>Flag | Zero<br>Flag | | | Read/Write | - | - | - | R | R | R | R | R | | | Default | 0 | 0 | 0 | X | X | X | X | X | | Figure 7-2. CPU Flags Register ## **Register Description** The CPU Flags Register is a read-only register that gives processor flags status. # Global Interrupt Enable (Bit 4) The Global Interrupt Enable bit indicates if the Global Interrupts are enabled. - 1: Enabled - 0: Disabled ## Negative Flag (Bit 3) The Negative Flag bit indicates if an arithmetic operation results in a negative answer. - 1: MS result bit is '1' - 0: MS result bit is not '1' # Overflow Flag (Bit 2) The Overflow Flag bit indicates if an overflow condition occurred. An overflow condition can occur if an arithmetic result was either larger than the destination operand size (for addition) or smaller than the destination operand should allow for subtraction. 1: Overflow occurred ## 0: Overflow did not occur ## Carry Flag (Bit 1) The Carry Flag bit indicates if an arithmetic operation resulted in a Carry for addition, or borrow for subtraction. - 1: Carry/Borrow occurred - 0: Carry/Borrow did not occur # Zero Flag (Bit 0) The Zero Flag bit indicates if an instruction execution resulted in a '0'. - 1: Zero occurred - 0: Zero did not occur # 7.1.2 Bank Register [0xC002] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------|---------|-----|-----|-----|----------|-----|-----| | Field | | Address | | | | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Address | | | | | Reserved | | | | Read/Write | R/W | R/W | R/W | - | - | - | - | - | | Default | 0 | 0 | 0 | Х | Х | Х | Х | Х | Figure 7-3. Bank Register # **Register Description** The Bank Register maps registers R0–R15 into RAM. The eleven MSBs of this register are used as a base address for registers R0–R15. A register address is automatically generated by: - 1. Shifting the four LSBs of the register address left by 1. - 2. ORing the four shifted bits of the register address with the twelve MSBs of the Bank Register. - 3. Forcing the LSB to zero. For example, if the Bank Register is left at its default value of 0x0100, and R2 is read, then the physical address 0x0102 will be read. Refer to *Table 7-1* for details. Table 7-1. Bank Register Example | Register | Hex Value | Binary Value | | | |--------------|----------------------|---------------------|--|--| | Bank | 0x0100 | 0000 0001 0000 0000 | | | | R14 | 0x000E << 1 = 0x001C | 0000 0000 0001 1100 | | | | RAM Location | 0x011C | 0000 0001 0001 1100 | | | ## **Address** (Bits [15:4]) The Address field is used as a base address for all register addresses to start from. ## Reserved All reserved bits should be written as '0'. # 7.1.3 Hardware Revision Register [0xC004] [R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|----------|----|-------|------|----|---|---| | Field | | | | Revis | sion | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | Revision | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | Х | Х | X | Х | Х | Х | Х | Х | Figure 7-4. Revision Register Document #: 38-08015 Rev. \*E Page 31 of 119 # **Register Description** The Hardware Revision Register is a read-only register that indicates the silicon revision number. The first silicon revision is represented by 0x0101. This number will be increased by one for each new silicon revision. # Revision (Bits [15:0]) The Revision field contains the silicon revision number. # 7.1.4 CPU Speed Register [0xC008] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|--------------------|----------|----|----|-----|-----|-----|-----|--|--| | Field | | Reserved | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | Reserved CPU Speed | | | | | | | | | | | Read/Write | - | - | - | - | R/W | R/W | R/W | R/W | | | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | Figure 7-5. CPU Speed Register # **Register Description** The CPU Speed Register allows the processor to operate at a user-selected speed. This register will only affect the CPU, all other peripheral timing is still based on the 48-MHz system clock (unless otherwise noted). # CPU Speed (Bits[3:0]) The CPU Speed field is a divisor that selects the operating speed of the processor as defined in Table 7-2. Table 7-2. CPU Speed Definition | CPU Speed [3:0] | Processor Speed | |-----------------|-----------------| | 0000 | 48 MHz/1 | | 0001 | 48 MHz/2 | | 0010 | 48 MHz/3 | | 0011 | 48 MHz/4 | | 0100 | 48 MHz/5 | | 0101 | 48 MHz/6 | | 0110 | 48 MHz/7 | | 0111 | 48 MHz/8 | | 1000 | 48 MHz/9 | | 1001 | 48 MHz/10 | | 1010 | 48 MHz/11 | | 1011 | 48 MHz/12 | | 1100 | 48 MHz/13 | | 1101 | 48 MHz/14 | | 1110 | 48 MHz/15 | | 1111 | 48 MHz/16 | ## Reserved All reserved bits should be written as '0'. ## 7.1.5 Power Control Register [0xC00A] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|-----------------------|----------|-----------------------|-----------------------| | Field | Host/Device 2B<br>Wake<br>Enable | Host/Device 2A<br>Wake<br>Enable | Host/Device 1B<br>Wake<br>Enable | Host/Device 1A<br>Wake<br>Enable | OTG<br>Wake<br>Enable | Reserved | HSS<br>Wake<br>Enable | SPI<br>Wake<br>Enable | | Read/Write | R/W | R/W | R/W | R/W | R/W | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----------------------|----------|---|-----------------------|----------|----------------|-----------------|----------------| | Field | HPI<br>Wake<br>Enable | Reserved | | GPI<br>Wake<br>Enable | Reserved | Boost 3V<br>OK | Sleep<br>Enable | Halt<br>Enable | | Read/Write | R/W | - | - | R/W | - | R | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-6. Power Control Register ## **Register Description** The Power Control Register controls the power-down and wakeup options. Either the sleep mode or the halt mode options can be selected. All other writable bits in this register can be used as a wakeup source while in sleep mode. ## Host/Device 2B Wake Enable (Bit 15) The Host/Device 2B Wake Enable bit enables or disables a wakeup condition to occur on a Host/Device 2B transition. This wake up from the SIE port does not cause an interrupt to the on-chip CPU. - 1: Enable wakeup on Host/Device 2B transition - 0: Disable wakeup on Host/Device 2B transition #### Host/Device 2A Wake Enable (Bit 14) The Host/Device 2A Wake Enable bit enables or disables a wakeup condition to occur on an Host/Device 2A transition. This wake up from the SIE port does not cause an interrupt to the on-chip CPU. - 1: Enable wakeup on Host/Device 2A transition - 0: Disable wakeup on Host/Device 2A transition ## Host/Device 1B Wake Enable (Bit 13) The Host/Device 1B Wake Enable bit enables or disables a wakeup condition to occur on an Host/Device 1B transition. This wake up from the SIE port does not cause an interrupt to the on-chip CPU. - 1: Enable wakeup on Host/Device 1B transition - 0: Disable wakeup on Host/Device 1B transition ## Host/Device 1A Wake Enable (Bit 12) The Host/Device 1A Wake Enable bit enables or disables a wakeup condition to occur on an Host/Device 1A transition. This wake up from the SIE port does not cause an interrupt to the on-chip CPU. - 1: Enable wakeup on Host/Device 1A transition - 0: Disable wakeup on Host/Device 1A transition #### OTG Wake Enable (Bit 11) The OTG Wake Enable bit enables or disables a wakeup condition to occur on either an OTG VBUS\_Valid or OTG ID transition (IRQ20). - 1: Enable wakeup on OTG VBUS valid or OTG ID transition - 0: Disable wakeup on OTG VBUS valid or OTG ID transition # HSS Wake Enable (Bit 9) The HSS Wake Enable bit enables or disables a wakeup condition to occur on an HSS Rx serial input transition. The processor may take several hundreds of microseconds before being operational after wakeup. Therefore, the incoming data byte that causes the wakeup will be discarded. - 1: Enable wakeup on HSS Rx serial input transition - 0: Disable wakeup on HSS Rx serial input transition ## SPI Wake Enable (Bit 8) The SPI Wake Enable bit enables or disables a wakeup condition to occur on a falling SPI\_nSS input transition. The processor may take several hundreds of microseconds before being operational after wakeup. Therefore, the incoming data byte that causes the wakeup will be discarded. - 1: Enable wakeup on falling SPI nSS input transition - 0: Disable SPI nSS interrupt ## HPI Wake Enable (Bit 7) The HPI Wake Enable bit enables or disables a wakeup condition to occur on an HPI interface read. - 1: Enable wakeup on HPI interface read - 0: Disable wakeup on HPI interface read ## GPI Wake Enable (Bit 4) The GPI Wake Enable bit enables or disables a wakeup condition to occur on a GPIO(25:24) transition. - 1: Enable wakeup on GPIO(25:24) transition - 0: Disable wakeup on GPIO(25:24) transition #### Boost 3V OK (Bit 2) The Boost 3V OK bit is a read only bit that returns the status of the OTG Boost circuit. - 1: Boost circuit not ok and internal voltage rails are below 3.0V - 0: Boost circuit ok and internal voltage rails are at or above 3.0V #### Sleep Enable (Bit 1) Setting this bit to '1' will immediately initiate SLEEP mode. While in SLEEP mode, the entire chip is paused, achieving the lowest standby power state. All operations are paused, the internal clock is stopped, the booster circuit and OTG VBUS charge pump are all powered down, and the USB transceivers are powered down. All counters and timers are paused but will retain their values; enabled PWM outputs freeze in their current states. SLEEP mode exits by any activity selected in this register. When SLEEP mode ends, instruction execution will resume within 0.5 ms. - 1: Enable Sleep mode - 0: No function #### Halt Enable (Bit 0) Setting this bit to '1' will immediately initiate HALT mode. While in HALT mode, only the CPU is stopped. The internal clock still runs and all peripherals still operate, including the USB engines. The power saving using HALT in most cases will be minimal, but in applications that are very CPU intensive the incremental savings may provide some benefit. The HALT state is exited when any enabled interrupt is triggered. Upon exiting the HALT state, one or two instructions immediately following the HALT instruction may be executed before the waking interrupt is serviced (you may want to follow the HALT instruction with two NOPs). - 1: Enable Halt mode - 0: No function ## Reserved All reserved bits should be written as '0'. ## 7.1.6 Interrupt Enable Register [0xC00E] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|----------|----|----------------------------|----------------------------|----------|--------------------------------------|--------------------------------------| | Field | | Reserved | | OTG<br>Interrupt<br>Enable | SPI<br>Interrupt<br>Enable | Reserved | Host/Device 2<br>Interrupt<br>Enable | Host/Device 1<br>Interrupt<br>Enable | | Read/Write | - | - | - | R/W | R/W | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----------------------------|-----------------------------------|------------------------------------|----------|-----------------------------|-----------------------------|--------------------------------|--------------------------------| | Field | HSS<br>Interrupt<br>Enable | In Mailbox<br>Interrupt<br>Enable | Out Mailbox<br>Interrupt<br>Enable | Reserved | UART<br>Interrupt<br>Enable | GPIO<br>Interrupt<br>Enable | Timer 1<br>Interrupt<br>Enable | Timer 0<br>Interrupt<br>Enable | | Read/Write | R/W | R/W | R/W | - | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Figure 7-7. Interrupt Enable Register # **Register Description** The Interrupt Enable Register allows control of the hardware interrupt vectors. ## OTG Interrupt Enable (Bit 12) The OTG Interrupt Enable bit enables or disables the OTG ID/OTG4.4V Valid hardware interrupt. - 1: Enable OTG interrupt - 0: Disable OTG interrupt ## SPI Interrupt Enable (Bit 11) The SPI Interrupt Enable bit enables or disables the following three SPI hardware interrupts: SPI TX, SPI RX, and SPI DMA Block Done. - 1: Enable SPI interrupt - 0: Disable SPI interrupt # Host/Device 2 Interrupt Enable (Bit 9) The Host/Device 2 Interrupt Enable bit enables or disables all of the following Host/Device 2 hardware interrupts: Host 2 USB Done, Host 2 USB SOF/EOP, Host 2 Wakeup/Insert/Remove, Device 2 Reset, Device 2 SOF/EOP or WakeUp from USB, Device 2 Endpoint n. - 1: Enable Host 2 and Device 2 interrupt - 0: Disable Host 2 and Device 2 interrupt # Host/Device 1 Interrupt Enable (Bit 8) The Host/Device 1 Interrupt Enable bit enables or disables all of the following Host/Device 1 hardware interrupts: Host 1 USB Done, Host 1 USB SOF/EOP, Host 1 Wakeup/Insert/Remove, Device 1 Reset, Device 1 SOF/EOP or WakeUp from USB, Device 1 Endpoint n. - 1: Enable Host 1 and Device 1 interrupt - 0: Disable Host 1 and Device 1 interrupt # **HSS Interrupt Enable** (Bit 7) The HSS Interrupt Enable bit enables or disables the following High-speed Serial Interface hardware interrupts: HSS Block Done, and HSS RX Full. - 1: Enable HSS interrupt - 0: Disable HSS interrupt ## In Mailbox Interrupt Enable (Bit 6) The In Mailbox Interrupt Enable bit enables or disables the HPI: Incoming Mailbox hardware interrupt. - 1: Enable MBXI interrupt - 0: Disable MBXI interrupt ## Out Mailbox Interrupt Enable (Bit 5) The Out Mailbox Interrupt Enable bit enables or disables the HPI: Outgoing Mailbox hardware interrupt. - 1: Enable MBXO interrupt - 0: Disable MBXO interrupt # **UART Interrupt Enable** (Bit 3) The UART Interrupt Enable bit enables or disables the following UART hardware interrupts: UART TX, and UART RX. - 1: Enable UART interrupt - 0: Disable UART interrupt ## **GPIO Interrupt Enable (Bit 2)** The GPIO Interrupt Enable bit enables or disables the General Purpose I/O Pins Interrupt (see the GPIO Control Register). When the GPIO bit is reset, all pending GPIO interrupts are also cleared - 1: Enable GPIO interrupt - 0: Disable GPIO interrupt # Timer 1 Interrupt Enable (Bit 1) The Timer 1 Interrupt Enable bit enables or disables the Timer1 Interrupt Enable. When this bit is reset, all pending Timer 1 interrupts are cleared. - 1: Enable TM1 interrupt - 0: Disable TM1 interrupt ## Timer 0 Interrupt Enable (Bit 0) The Timer 0 Interrupt Enable bit enables or disables the Tlmer0 Interrupt Enable. When this bit is reset, all pending Timer 0 interrupts are cleared. - 1: Enable TM0 interrupt - 0: Disable TM0 interrupt ## Reserved All reserved bits should be written as '0'. ## 7.1.7 Breakpoint Register [0xC014] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|---------|-----|-----|-----|-----|-----|-----|-----|--| | Field | Address | | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | Address | | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 7-8. Breakpoint Register # **Register Description** The Breakpoint Register holds the breakpoint address. When the program counter match this address, the INT127 interrupt occurs. To clear this interrupt, a zero value should be written to this register. ## Address (Bits [15:0]) The Address field is a 16-bit field containing the breakpoint address. 0 ### 7.1.8 USB Diagnostic Register [0xC03C] [R/W] | Bit# | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|----------|--------------|-----|-----|--| | Field | Port 2B<br>Diagnostic<br>Enable | Port 2A<br>Diagnostic<br>Enable | Port 1B<br>Diagnostic<br>Enable | Port 1A<br>Diagnostic<br>Enable | | Reserved | | | | | Read/Write | R/W | R/W | R/W | R/W | - | - | - | - | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | T | T | T | T | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | Reserved | Pull-down<br>Enable | LS Pull-up<br>Enable | FS Pull-up<br>Enable | Reserved | Force Select | | | | | Read/Write | - | R/W | R/W | R/W | - | R/W | R/W | R/W | | Figure 7-9. USB Diagnostic Register ### **Register Description** Default The USB Diagnostic Register provides control of diagnostic modes. It is intended for use by device characterization tests, not for normal operations. This register is Read/Write by the on-chip CPU but is write only via the HPI port. ### Port 2B Diagnostic Enable (Bit 15) The Port 2B Diagnostic Enable bit enables or disables Port 2B for the test conditions selected in this register. - 1: Apply any of the following enabled test conditions: J/K, DCK, SE0, RSF, RSL, PRD - 0: Do not apply test conditions ### Port 2A Diagnostic Enable (Bit 14) The Port 2A Diagnostic Enable bit enables or disables Port 2A for the test conditions selected in this register. - 1: Apply any of the following enabled test conditions: J/K, DCK, SE0, RSF, RSL, PRD - 0: Do not apply test conditions #### Port 1B Diagnostic Enable (Bit 13) The Port 1B Diagnostic Enable bit enables or disables Port 1B for the test conditions selected in this register. - 1: Apply any of the following enabled test conditions: J/K, DCK, SE0, RSF, RSL, PRD - 0: Do not apply test conditions ## Port 1A Diagnostic Enable (Bit 12) The Port 1A Diagnostic Enable bit enables or disables Port 1A for the test conditions selected in this register. - 1: Apply any of the following enabled test conditions: J/K, DCK, SE0, RSF, RSL, PRD - 0: Do not apply test conditions #### Pull-down Enable (Bit 6) The Pull-down Enable bit enables or disables full-speed pull-down resistors (pull-down on both D+ and D-) for testing. - 1: Enable pull-down resistors on both D+ and D- - 0: Disable pull-down resistors on both D+ and D- # LS Pull-up Enable (Bit 5) The LS Pull-up Enable bit enables or disables a low-speed pull-up resistor (pull-up on D-) for testing. - 1: Enable low-speed pull-up resistor on D- - 0: Pull-up resistor is not connected on D- ### FS Pull-up Enable (Bit 4) The FS Pull-up Enable bit enables or disables a full-speed pull-up resistor (pull up on D+) for testing. - 1: Enable full-speed pull-up resistor on D+ - 0: Pull-up resistor is not connected on D+ ## Force Select (Bits [2:0]) The Force Select field bit selects several different test condition states on the data lines (D+/D-). Refer to *Table 7-3* for details. #### Table 7-3. Force Select Definition | Force Select [2:0] | Data Line State | |--------------------|-----------------| | 1xx | Assert SE0 | | 01x | Toggle JK | | 001 | Assert J | | 000 | Assert K | #### Reserved All reserved bits should be written as '0'. # 7.1.9 Memory Diagnostic Register [0xC03E] [W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|----------|----------|----|----|----|---------------------------------|---| | Field | | | Reserved | | | | Memory<br>Arbitration<br>Select | | | Read/Write | - | - | - | - | - | W | W | W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | Reserved | | | | | | | | Read/Write | - | - | - | - | - | - | - | W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-10. Memory Diagnostic Register ## **Register Description** The Memory Diagnostic Register provides control of diagnostic modes. ## Memory Arbitration Select (Bits[10:8]) The Memory Arbitration Select field is defined in Table 7-4. Table 7-4. Memory Arbitration Select | Memory Arbitration<br>Select [3:0] | Memory Arbitration Timing | |------------------------------------|-------------------------------| | 111 | 1/8, 7 of every 8 cycles dead | | 110 | 2/8, 6 of every 8 cycles dead | | 101 | 3/8, 5 of every 8 cycles dead | | 100 | 4/8, 4 of every 8 cycles dead | | 011 | 5/8, 3 of every 8 cycles dead | | 010 | 6/8, 2 of every 8 cycles dead | | 001 | 7/8, 1 of every 8 cycles dead | | 000 | 8/8, all cycles available | # Monitor Enable (Bit 0) The Monitor Enable bit enables or disables monitor mode. In monitor mode the internal address bus is echoed to the external address pins. - 1: Enable monitor mode - 0: Disable monitor mode #### Reserved All reserved bits should be written as '0'. ## 7.2 External Memory Registers There are four registers dedicated to controlling the external memory interface. Each of these registers are covered in this section and are summarized in *Figure 7-11* | Register Name | Address | R/W | |----------------------------------|---------|-----| | Extended Page 1 Map Register | 0xC018 | R/W | | Extended Page 2 Map Register | 0xC01A | R/W | | Upper Address Enable Register | 0xC038 | R/W | | External Memory Control Register | 0xC03A | R/W | Figure 7-11. External Memory Control Registers ## 7.2.1 Extended Page n Map Register [R/W] - Extended Page 1 Map Register 0xC018 - Extended Page 2 Map Register 0xC01A | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|---------|-----|-----|-------|-----|-----|-----|--|--|--| | Field | | Address | | | | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | - | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Ad | dress | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-12. Extended Page n Map Register #### **Register Description** The Extended Page n Map Register contains the Page n high-order address bits. These bits are always appended to accesses to the Page n Memory mapped space. ## Address (Bits [15:0]) The Address field contains the high-order bits 28 to 13 of the Page n address. The address pins [8:0] (Page n address [21:13]) will reflect the content of this register when the CPU accesses the address 0x8000-0x9FFF. For the SRAM mode, the address pin on [4:0] (Page n address [17:13]) will be used. Bit [8] (Page n address [21]) should be set to '0', so that Page n reads/writes will access external areas (SRAM, ROM or peripherals). nXMEMSEL will be the external Chip Select for this space. # 7.2.2 Upper Address Enable Register [0xC038] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|----------|------|-------|----|----------------------------|----------|---|---|--|--| | Field | Reserved | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | Default | Х | Х | Х | Х | Х | Х | Х | X | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | | Rese | erved | | Upper<br>Address<br>Enable | Reserved | | | | | | Read/Write | - | - | - | - | R/W | | | | | | | Default | Х | Х | Х | Х | 0 | Х | Х | Х | | | Figure 7-13. External Memory Control Register ## **Register Description** The Upper Address Enable Register enables/disables the four most significant bits of the external address A[18:15]. This register defaults to having the Upper Address disabled. It should be noted that on power up pins A[18:15] are driven high. #### **Upper Address Enable (Bit 3)** The Upper Address Enable bit enables/disables the four most significant bits of the external address A[18:15]. - 1: Enable A[18:15] of the external memory interface for general addressing. - 0: Disable A[18:15], Not available. #### Reserved All reserved bits should be written as '0'. ## 7.2.3 External Memory Control Register [0xC03A] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------------------|-------|----------------------|----------------------|----------------------|-----|---------------------|-----| | Field | Rese | erved | XRAM Merge<br>Enable | XROM Merge<br>Enable | XMEM Width<br>Select | | XMEM Wait<br>Select | | | Read/Write | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | Default | Х | X | X | X | Х | X | X | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | XROM Width<br>Select | | XROM Wait<br>Select | | XRAM Width<br>Select | | XRAM Wait<br>Select | | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | Х | Figure 7-14. External Memory Control Register #### **Register Description** The External Memory Control Register provides control of Wait States for the external SRAM or ROM. All wait states are based off of 48 MHz. ## XRAM Merge Enable (Bit 13) The XRAM Merge Enable bit will enable or disable the RAM merge feature. When the RAM merge feature is enabled, the nXRAMSEL will be active when ever the nXMEMSEL is active. - 1: Enable RAM merge - 0: Disable RAM merge ## XROM Merge Enable (Bit 12) The XROM Merge Enable bit will enable or disable the ROM merge feature. When the ROM merge feature is enabled, the nXROMSEL will be active when ever the nXMEMSEL is active. - 1: Enable ROM merge - 0: Disable ROM merge ## XMEM Width Select (Bit 11) The XMEM Width Select bit selects the extended memory width. - 1: Extended memory = 8 - 0: Extended memory = 16 #### XMEM Wait Select (Bits [10:8]) The XMEM Wait Select field selects the extended memory wait state from 0 to 7. ### XROM Width Select (Bit 7) The XROM Width Select bit selects the external ROM width. - 1: External memory = 8 - 0: External memory = 16 ## XROM Wait Select (Bits[6:4]) The XROM Wait Select field selects the external ROM wait state from 0 to 7. ## XRAM Width Select (Bit 3) The XRAM Width Select bit selects the external RAM width. - 1: External memory = 8 - 0: External memory = 16 ## XRAM Wait Select (Bits[2:0]) The XRAM Wait Select field selects the external RAM wait state from 0 to 7. #### Reserved All reserved bits should be written as '0'. # 7.3 Timer Registers There are three registers dedicated to timer operations. Each of these registers are discussed in this section and are summarized in *Figure 7-15*. | Register Name | Address | R/W | |-------------------------|---------|-----| | Watchdog Timer Register | 0xC00C | R/W | | Timer 0 Register | 0xC010 | R/W | | Timer 1 Register | 0xC012 | R/W | Figure 7-15. Timer Registers ## 7.3.1 Watchdog Timer Register [0xC00C] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|-----|----------|------------------|-----|-------------|----------------|---------------|-----------------|--|--| | Field | | Reserved | | | | | | | | | | Read/Write | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | Res | erved | Time-out<br>Flag | | riod<br>ect | Lock<br>Enable | WDT<br>Enable | Reset<br>Strobe | | | | Read/Write | R/W W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Figure 7-16. Watchdog Timer Register ## **Register Description** The Watchdog Timer Register provide status and control over the Watchdog timer. The Watchdog timer can also interrupt the processor. ### Time-out Flag (Bit 5) The Time-out Flag bit indicates if the Watchdog timer has expired. The processor can read this bit after exiting a reset to determine if a Watchdog time-out occurred. This bit will be cleared on the next external hardware reset. - 1: Watchdog timer expired. - 0: Watchdog timer did not expire. ### Period Select (Bits [4:3]) The Period Select field is defined in *Table 7-5*. If this time expires before the Reset Strobe bit is set, the internal processor will get reset. Table 7-5. Period Select Definition | Period Select[4:3] | WDT Period Value | |--------------------|------------------| | 00 | 1.4 ms | | 01 | 5.5 ms | | 10 | 22.0 ms | | 11 | 66.0 ms | #### Lock Enable (Bit 2) The Lock Enable bit will not allow any writes to this register until a reset. In doing so the Watchdog timer can be set up and enabled permanently so that it can only be cleared on reset (the WDT Enable bit is ignored). - 1: Watchdog timer permanently set - 0: Watchdog timer not permanently set ## WDT Enable (Bit 1) The WDT Enable bit enables or disables the Watchdog timer. - 1: Enable Watchdog timer operation - 0: Disable Watchdog timer operation ## Reset Strobe (Bit 0) The Reset Strobe is a write-only bit that resets the Watchdog timer count. It must be set to '1' before the count expires to avoid a Watchdog trigger 1: Reset Count #### Reserved All reserved bits should be written as '0'. #### 7.3.2 Timer n Register [R/W] - Timer 0 Register 0xC010. - Timer 1 Register 0xC012. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|-----|-------|-----|-----|------|-----|-----|-----|--|--| | Field | | Count | | | | | | | | | | Read/Write | R/W | | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | | | | C | ount | | | | | | | Read/Write | R/W | | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Figure 7-17. Timer n Register #### **Register Description** The Timer n Register sets the Timer n count. Both Timer 0 and Timer 1 decrement by one every 1-µs clock tick. Each can provide an interrupt to the CPU when the timer reaches zero. ## Count (Bits [15:0]) The Count field sets the Timer count. ## 7.4 General USB Registers There is one set of registers dedicated to general USB control. This set consists of two identical registers: one for Host/Device Port 1 and one for Host/Device Port 2. This register set has functions for both USB host and USB peripheral options and is covered in this section and summarized in *Figure 7-8*. USB Host only registers are covered in section 4.5, and USB device-only registers are covered in section 7.2. | Register Name | Address (SIE1/SIE2) | R/W | | |------------------------|---------------------|-----|--| | USB n Control Register | 0xC08A / 0xC0AA | R/W | | Figure 7-18. General USB Registers ## 7.4.1 USB n Control Register [R/W] - USB 1 Control Register 0xC08A. - USB 2 Control Register 0xC0AA. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------------------------|------------------------|------------------------|------------------------|-----|-----|----------------|-------------------------------| | Field | Port B<br>D+<br>Status | Port B<br>D–<br>Status | Port A<br>D+<br>Status | Port A<br>D–<br>Status | LOB | LOA | Mode<br>Select | Port B<br>Resistors<br>Enable | | Read/Write | R | R | R | R | R/W | R/W | R/W | R/W | | Default | Х | Х | Х | Х | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------------------------------|------|---------------------|------|---------------------|-------------------|-----------------------------|-----------------------------| | Field | Port A<br>Resistors<br>Enable | Forc | rt B<br>e D±<br>ate | Ford | rt A<br>e D±<br>ate | Suspend<br>Enable | Port B<br>SOF/EOP<br>Enable | Port A<br>SOF/EOP<br>Enable | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-19. USB n Control Register The USB n Control Register is used in both host and device mode. It monitors and controls the SIE and the data lines of the USB ports. This register can be accessed by the HPI interface. ## Port B D+ Status (Bit 15) The Port B D+ Status bit is a read-only bit that indicates the value of DATA+ on Port B. 1: D+ is HIGH 0: D+ is LOW ## Port B D- Status (Bit 14) The Port B D– Status bit is a read-only bit that indicates the value of DATA– on Port B. 1: D- is HIGH 0: D- is LOW ### Port A D+ Status (Bit 13) The Port A D+ Status bit is a read-only bit that indicates the value of DATA+ on Port A. 1: D+ is HIGH 0: D+ is LOW ## Port A D- Status (Bit 12) The Port A D- Status bit is a read-only bit that indicates the value of DATA- on Port A. 1: D- is HIGH 0: D- is LOW ## **LOB** (Bit 11) The LOB bit selects the speed of Port B. 1: Port B is set to low-speed mode 0: Port B is set to full-speed mode # **LOA** (Bit 10) The LOA bit selects the speed of Port A. 1: Port A is set to low-speed mode 0: Port A is set to full-speed mode ### Mode Select (Bit 9) The Mode Select bit sets the SIE for host or device operation. When set for device operation only one USB port is supported. The active port is selected by the Port Select bit in the Host n Count Register. - 1: Host mode - 0: Device mode #### Port B Resistors Enable (Bit 8) The Port B Resistors Enable bit enables or disables the pull-up/pull-down resistors on Port B. When enabled, the Mode Select bit and LOB bit of this Register will set the pull-up/pull-down resistors appropriately. When the Mode Select is set for Host mode, the pull-down resistors on the data lines (D+ and D-) are enabled. When the Mode Select is set for Device mode, a single pull-up resistor on either D+ or D-, determined by the LOB bit, will be enabled. See *Table 7-6* for details. - 1: Enable pull-up/pull-down resistors - 0: Disable pull-up/pull-down resistors #### Port A Resistors Enable (Bit 7) The Port A Resistors Enable bit enables or disables the pull-up/pull-down resistors on Port A. When enabled, the Mode Select bit and LOA bit of this Register will set the pull-up/pull-down resistors appropriately. When the Mode Select is set for Host mode, the pull-down resistors on the data lines (D+ and D-) are enabled. When the Mode Select is set for Device mode, a single pull-up resistor on either D+ or D-, determined by the LOA bit, will be enabled. See *Table 7-6* for details. - 1: Enable pull-up/pull-down resistors - 0: Disable pull-up/pull-down resistors Table 7-6. USB Data Line Pull-up and Pull-down Resistors | L0A/L0B | Mode Select | Port n Resistors Enable Function | | | | |---------|-------------|----------------------------------|-----------------------------------------|--|--| | X | X | 0 | Pull-up/Pull-down on D+ and D– Disabled | | | | Х | 1 | 1 | Pull-down on D+ and D– Enabled | | | | 1 | 0 | 1 | Pull-up on USB D– Enabled | | | | 0 | 0 | 1 | Pull-up on USB D+ Enabled | | | #### Port B Force D± State (Bits [6:5]) The Port B Force D± State field controls the forcing state of the D+ D– data lines for Port B. This field will force the state of the Port B data lines independent of the Port Select bit setting. See *Table 7-7* for details. #### Port A Force D± State (Bits [4:3]) The Port A Force D± State field controls the forcing state of the D+ D– data lines for Port A. This field will force the state of the Port A data lines independent of the Port Select bit setting. See *Table 7-7* for details. Table 7-7. Port A/B Force D± State | Port A/B F | orce D± State | Function | |------------|---------------|----------------------------| | 0 | 0 | Normal Operation | | 0 | 1 | Force USB Reset, SE0 State | | 1 | 0 | Force J-State | | 1 | 1 | Force K-State | ## Suspend Enable (Bit 2) The Suspend Enable bit enables or disables the suspend feature on both ports. When suspend is enabled the USB transceivers are powered down and can not transmit or received USB packets but can still monitor for a wakeup condition. - 1: Enable suspend - 0: Disable suspend #### Port B SOF/EOP Enable (Bit 1) The Port B SOF/EOP Enable bit is only applicable in host mode. In device mode this bit should be written as '0'. In host mode this bit enables or disables SOFs or EOPs for Port B. Either SOFs or EOPs will be generated depending on the LOB bit in the USB n Control Register when Port B is active. - 1: Enable SOFs or EOPs - 0: Disable SOFs or EOPs #### Port A SOF/EOP Enable (Bit 0) The Port A SOF/EOP Enable bit is only applicable in host mode. In device mode this bit should be written as '0'. In host mode this bit enables or disables SOFs or EOPs for Port A. Either SOFs or EOPs will be generated depending on the LOA bit in the USB n Control Register when Port A is active. - 1: Enable SOFs or EOPs - 0: Disable SOFs or EOPs #### Reserved All reserved bits should be written as '0'. # 7.5 USB Host Only Registers There are twelve sets of dedicated registers for USB host only operation. Each set consists of two identical registers (unless otherwise noted), one for Host Port 1 and one for Host Port 2. These register sets are covered in this section and summarized in *Figure 7-20*. | Register Name | Address (Host 1 / Host 2) | R/W | |----------------------------------|---------------------------|-----| | Host n Control Register | 0xC080 / 0xC0A0 | R/W | | Host n Address Register | 0xC082 / 0xC0A2 | R/W | | Host n Count Register | 0xC084 / 0xC0A4 | R/W | | Host n Endpoint Status Register | 0xC086 / 0xC0A6 | R | | Host n PID Register | 0xC086 / 0xC0A6 | W | | Host n Count Result Register | 0xC088 / 0xC0A8 | R | | Host n Device Address Register | 0xC088 / 0xC0A8 | W | | Host n Interrupt Enable Register | 0xC08C / 0xC0AC | R/W | | Host n Status Register | 0xC090 / 0xC0B0 | R/W | | Host n SOF/EOP Count Register | 0xC092 / 0xC0B2 | R/W | | Host n SOF/EOP Counter Register | 0xC094 / 0xC0B4 | R | | Host n Frame Register | 0xC096 / 0xC0B6 | R | Figure 7-20. USB Host Only Register ### 7.5.1 Host n Control Register [R/W] - Host 1 Control Register 0xC080. - Host 2 Control Register 0xC0A0. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|--------------------|--------------------|----------------|---------------|----------|----|---|---------------|--|--| | Field | | Reserved | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | • | | | • | | • | • | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | Preamble<br>Enable | Sequence<br>Select | Sync<br>Enable | ISO<br>Enable | Reserved | | | Arm<br>Enable | | | | Read/Write | R/W | R/W | R/W | R/W | - | - | - | R/W | | | | Default | n | 0 | Λ | n | n | n | 0 | 0 | | | Figure 7-21. Host n Control Register ## **Register Description** The Host n Control Register allows high-level USB transaction control. ## Preamble Enable (Bit 7) The Preamble Enable bit enables or disables the transmission of a preamble packet before all low speed packets. This bit should only be set when communicating with a low-speed device. - 1: Enable Preamble packet - 0: Disable Preamble packet #### Sequence Select (Bit 6) The Sequence Select bit sets the data toggle for the next packet. This bit has no effect on receiving data packets, sequence checking must be handled in firmware. - 1: Send DATA1 - 0: Send DATA0 #### Sync Enable (Bit 5) The Sync Enable bit will synchronize the transfer with the SOF packet in full speed mode and the EOP packet in low-speed mode. - 1: The next enabled packet will be transferred after the SOF or EOP packet is transmitted - 0: The next enabled packet will be transferred as soon as the SIE is free #### ISO Enable (Bit 4) The ISO Enable bit enables or disables an Isochronous transaction. - 1: Enable Isochronous transaction - 0: Disable Isochronous transaction #### Arm Enable (Bit 0) The Arm Enable bit arms an endpoint and starts a transaction. This bit is automatically cleared to '0' when a transaction is complete. - 1: Arm endpoint and begin transaction - 0: Endpoint disarmed #### Reserved All reserved bits should be written as '0'. ## 7.5.2 Host n Address Register [R/W] - Host 1 Address Register 0xC082. - Host 2 Address Register 0xC0A2. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|---------|-----|-----|-------|-----|-----|-----| | Field | | Address | | | | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Ad | dress | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-22. Host n Address Register ### **Register Description** The Host n Address Register is used as the base pointer into memory space for the current host transactions. ## Address (Bits [15:0]) The Address field sets the address pointer into internal RAM or ROM. # 7.5.3 Host n Count Register [R/W] - Host 1 Count Register 0xC084. - Host 2 Count Register 0xC0A4. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|----------------|----------|-----|------|-----|-----|-----| | Field | Reserved | Port<br>Select | Reserved | | | Cou | nt | | | Read/Write | - | R/W | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-23. Host n Count Register Document #: 38-08015 Rev. \*E The Host n Count Register is used to hold the number of bytes (packet length) for the current transaction. The maximum packet length is 1023 bytes in ISO mode. The Host Count value is used to determine how many bytes to transmit, or the maximum number of bytes to receive. If the number of received bytes is greater then the Host Count value then an overflow condition will be flagged by the Overflow bit in the Host n Endpoint Status Register. #### Port Select (Bit 14) The Port Select bit selects which of the two active ports is selected and is summarized in Table 7-8. - 1: Port 1B or Port 2B is enabled - 0: Port 1A or Port 2A is enabled Table 7-8. Port Select Definition | Port Select | Host/Device 1<br>Active Port | Host/Device 2<br>Active Port | |-------------|------------------------------|------------------------------| | 0 | Α | Α | | 1 | В | В | #### Count (Bits [9:0]) The Count field sets the value for the current transaction data packet length. This value is retained when switching between host and device mode, and back again. #### Reserved All reserved bits should be written as '0'. ## 7.5.4 Host n Endpoint Status Register [R] - Host 1 Endpoint Status Register 0xC086. - Host 2 Endpoint Status Register 0xC0A6. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|----|----|----|------------------|-------------------|------|-------| | Field | Reserved | | | | Overflow<br>Flag | Underflow<br>Flag | Rese | erved | | Read/Write | - | - | - | - | R | R | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---------------|-------------|-----------------------------|----------|--------------------|------------------|---------------|-------------| | Field | Stall<br>Flag | NAK<br>Flag | Length<br>Exception<br>Flag | Reserved | Sequence<br>Status | Time-out<br>Flag | Error<br>Flag | ACK<br>Flag | | Read/Write | R | R | R | - | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-24. Host n Endpoint Status Register #### **Register Description** The Host n Endpoint Status Register is a read-only register that provides status for the last USB transaction. ## Overflow Flag (Bit 11) The Overflow Flag bit indicates that the received data in the last data transaction exceeded the maximum length specified in the Host n Count Register. The Overflow Flag should be checked in response to a Length Exception signified by the Length Exception Flag set to '1'. - 1: Overflow condition occurred - 0: Overflow condition did not occur # Underflow Flag (Bit 10) The Underflow Flag bit indicates that the received data in the last data transaction was less then the maximum length specified in the Host n Count Register. The Underflow Flag should be checked in response to a Length Exception signified by the Length Exception Flag set to '1'. - 1: Underflow condition occurred - 0: Underflow condition did not occur #### Stall Flag (Bit 7) The Stall Flag bit indicates that the peripheral device replied with a Stall in the last transaction. - 1: Device returned Stall - 0: Device did not return Stall ## NAK Flag (Bit 6) The NAK Flag bit indicates that the peripheral device replied with a NAK in the last transaction. - 1: Device returned NAK - 0: Device did not return NAK ### Length Exception Flag (Bit 5) The Length Exception Flag bit indicates the received data in the data stage of the last transaction does not equal the maximum Host Count specified in the Host n Count Register. A Length Exception can either mean an overflow or underflow and the Overflow and Underflow flags (bits 11 and 10 respectively) should be checked to determine which event occurred. - 1: An overflow or underflow condition occurred - 0: An overflow or underflow condition did not occur #### Sequence Status (Bit 3) The Sequence Status bit indicates the state of the last received data toggle from the device. Firmware is responsible for monitoring and handling the sequence status. The Sequence bit is only valid if the ACK bit is set to '1'. The Sequence bit is set to '0' when an error is detected in the transaction and the Error bit will be set. - 1: DATA1 - 0: DATA0 ## Time-out Flag (Bit 2) The Time-out Flag bit indicates if a timeout condition occurred for the last transaction. A time-out condition can occur when a device either takes too long to respond to a USB host request or takes too long to respond with a handshake. - 1: Time-out occurred - 0: Time-out did not occur ## Error Flag (Bit 1) The Error Flag bit indicates a transaction failed for any reason other than the following: Time-out, receiving a NAK, or receiving a STALL. Overflow and Underflow are not considered errors and do not affect this bit. CRC5 and CRC16 errors will result in an Error flag along with receiving incorrect packet types. - 1: Error detected - 0: No error detected #### ACK Flag (Bit 0) The ACK Flag bit indicates two different conditions depending on the transfer type. For non-Isochronous transfers, this bit represents a transaction ending by receiving or sending an ACK packet. For Isochronous transfers, this bit represents a successful transaction which will not be represented by an ACK packet. - 1: For non-Isochronous transfers, the transaction was ACKed. For Isochronous transfers, the transaction was completed successfully - **0:** For non-Isochronous transfers, the transaction was not ACKed. For Isochronous transfers, the transaction did not completed successfully ### 7.5.5 Host n PID Register [W] - Host 1 PID Register 0xC086. - Host 2 PID Register 0xC0A6. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|-------|--------|------|-------|---------|-----------|---| | Field | | | | Rese | erved | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | PID S | Select | | | Endpoir | nt Select | | | Read/Write | W | W | W | W | W | W | W | W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-25. Host n PID Register The Host n PID Register is a write-only register that provides the PID and Endpoint information to the USB SIE to be used in the next transaction. ## PID Select (Bits [7:4]) The PID Select field defined as in *Table 7-9*. ACK and NAK tokens are automatically sent based on settings in the Host n Control Register and do not need to be written in this register. Table 7-9. PID Select Definition | PID TYPE | PID Select [7:4] | |----------|------------------| | SETUP | 1101 (D Hex) | | IN | 1001 (9 Hex) | | OUT | 0001 (1 Hex) | | SOF | 0101 (5 Hex) | | PREAMBLE | 1100 (C Hex) | | NAK | 1010 (A Hex) | | STALL | 1110 (E Hex) | | DATA0 | 0011 (3 Hex) | | DATA1 | 1011 (B Hex) | ## Endpoint Select (Bits [3:0]) The Endpoint field, which allows addressing up to 16 different endpoints. ## Reserved All reserved bits should be written as '0'. # 7.5.6 Host n Count Result Register [R] - Host 1 Count Result Register 0xC088. - Host 2 Count Result Register 0xC0A8. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|----|----|-----|-------|----|---|---| | Field | | | | Res | ult | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Re | esult | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-26. Host n Count Result Register The Host n Count Register is a read-only register that contains the size difference in bytes between the Host Count Value specified in the Host n Count Register and the last packet received. If an overflow or underflow condition occurs, i.e., the received packet length differs from the value specified in the Host n Count Register, the Length Exception Flag bit in the Host n Endpoint Status Register will be set. The value in this register is only value when the Length Exception Flag bit is set and the Error Flag bit is not set, both bits are in the Host n Endpoint Status Register. #### **Result** (Bits [15:0]) The Result field will contain the differences in bytes between the received packet and the value specified in the Host n Count Register. If an overflow condition occurs, Result [15:10] will be set to '111111', a 2's complement value indicating the additional byte count of the received packet. If an underflow condition occurs, Result [15:0] will indicate the excess bytes count (number of bytes not used). #### Reserved All reserved bits should be written as '0'. ### 7.5.7 Host n Device Address Register [W] - Host 1 Device Address Register 0xC088. - Host 2 Device Address Register 0xC0A8. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|----|----|------|---------|----|---|---| | Field | | | | Rese | rved | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Reserved | | | | Address | | | | | Read/Write | - | W | W | W | W | W | W | W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-27. Host n Device Address Register #### **Register Description** The Host n Device Address Register is a write-only register that contains the USB Device Address that the host wishes to communicate with. ## Address (Bits [6:0]) The Address field contains the value of the USB address for the next device that the host is going to communicate with. This value needs to be written by firmware. #### Reserved All reserved bits should bit written as '0'. ### 7.5.8 Host n Interrupt Enable Register [R/W] - Host 1 Interrupt Enable Register 0xC08C. - Host 2 Interrupt Enable Register 0xC0AC. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----------------------------|------------------------|----|----------|----|----|-----|----------| | Field | VBUS<br>Interrupt<br>Enable | ID Interrupt<br>Enable | | Reserved | | | | Reserved | | Read/Write | R/W | R/W | | | | | R/W | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|------------------------------------|------------------------------------|-----|-------------------------------------------------|------------|---|-----------------------------|-----| | Field | Port B<br>Wake Interrupt<br>Enable | Port A<br>Wake Interrupt<br>Enable | | Port A Connect<br>Change<br>Interrupt<br>Enable | t Reserved | | Done<br>Interrupt<br>Enable | | | Read/Write | R/W | R/W | R/W | R/W | - | - | - | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-28. Host n Interrupt Enable Register Document #: 38-08015 Rev. \*E Page 50 of 119 The Host n Interrupt Enable Register will allow control over host related interrupts. In this register a bit set to '1' enables the corresponding interrupt while '0' disables the interrupt. #### VBUS Interrupt Enable (Bit 15) The VBUS Interrupt Enable bit will enable or disable the OTG VBUS interrupt. When enabled this interrupt will trigger on both rising and falling edge of VBUS at the 4.4V status (only supported in Port 1A). This bit is only available for Host 1 and is a reserved bit in Host 2. - 1: Enable VBUS interrupt - 0: Disable VBUS interrupt ## ID Interrupt Enable (Bit 14) The ID Interrupt Enable bit will enable or disable the OTG ID interrupt. When enabled this interrupt will trigger on both rising and falling edge of OTG ID pin (only supported in Port 1A). This bit is only available for Host 1 and is a reserved bit in Host 2. - 1: Enable ID interrupt - 0: Disable ID interrupt ## SOF/EOP Interrupt Enable (Bit 9) The SOF/EOP Interrupt Enable bit will enable or disable the SOF/EOP timer interrupt - 1: Enable SOF/EOP timer interrupt - 0: Disable SOF/EOP timer interrupt #### Port B Wake Interrupt Enable (Bit 7) The Port B Wake Interrupt Enable bit will enable or disable the remote wakeup interrupt for Port B - 1: Enable remote wakeup interrupt for Port B - 0: Disable remote wakeup interrupt for Port B #### Port A Wake Interrupt Enable (Bit 6) The Port A Wake Interrupt Enable bit will enable or disable the remote wakeup interrupt for Port A - 1: Enable remote wakeup interrupt for Port A - 0: Disable remote wakeup interrupt for Port A # Port B Connect Change Interrupt Enable (Bit 5) The Port B Connect Change Interrupt Enable bit will enable or disable the Port B Connect Change interrupt on Port B. This interrupt will trigger when either a device is inserted (SE0 state to J state) or a device is removed (J state to SE0 state). - 1: Enable Connect Change interrupt - 0: Disable Connect Change interrupt #### Port A Connect Change Interrupt Enable (Bit 4) The Port A Connect Change Interrupt Enable bit will enable or disable the Connect Change interrupt on Port A. This interrupt will trigger when either a device is inserted (SE0 state to J state) or a device is removed (J state to SE0 state). - 1: Enable Connect Change interrupt - 0: Disable Connect Change interrupt ## Done Interrupt Enable (Bit 0) The Done Interrupt Enable bit enables or disables the USB Transfer Done interrupt. The USB Transfer Done will trigger when either the host responding with and ACK, or a device responds with any of the following: ACK, NAK, STALL, or Time-out. This interrupt is used for both Port A and Port B. - 1: Enable USB Transfer Done interrupt - 0: Disable USB Transfer Done interrupt #### Reserved All reserved bits should be written as '0'. ### 7.5.9 Host n Status Register [R/W] - Host 1 Status Register 0xC090. - · Host 2 Status Register 0xC0B0. | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------------------|-------------------|----|------|---------------------------|----------|-----|---| | Field | VBUS Interrupt Flag | ID Interrupt Flag | | Rese | SOF/EOP<br>Interrupt Flag | Reserved | | | | Read/Write | R/W | R/W | - | - | - | - | R/W | - | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----------------------------------|----------------------------------|--------------------------------------------|--------------------------------------------|-------------------------|-------------------------|----------|------------------------| | Field | Port B<br>Wake Interrupt<br>Flag | Port A<br>Wake Interrupt<br>Flag | Port B Connect<br>Change<br>Interrupt Flag | Port A Connect<br>Change Interrupt<br>Flag | Port B<br>SE0<br>Status | Port A<br>SE0<br>Status | Reserved | Done Interrupt<br>Flag | | Read/Write | R/W | R/W | R/W | R/W | R/W | R/W | - | R/W | | Default | Х | X | X | Х | Х | X | Х | Х | Figure 7-29. Host n Status Register ## **Register Description** The Host n Status Register will provide status information for host operation. Pending interrupts can be cleared by writing a '1' to the corresponding bit. This register can be accessed by the HPI interface. #### VBUS Interrupt Flag (Bit 15) The VBUS Interrupt Flag bit indicates the status of the OTG VBUS interrupt (only for Port 1A). When enabled this interrupt will trigger on both the rising and falling edge of VBUS at 4.4V. This bit is only available for Host 1 and is a reserved bit in Host 2. - 1: Interrupt triggered - 0: Interrupt did not trigger #### ID Interrupt Flag (Bit 14) The ID Interrupt Flag bit indicates the status of the OTG ID interrupt (only for Port 1A). When enabled this interrupt will trigger on both the rising and falling edge of the OTG ID pin. This bit is only available for Host 1 and is a reserved bit in Host 2. - 1: Interrupt triggered - 0: Interrupt did not trigger ## SOF/EOP Interrupt Flag (Bit 9) The SOF/EOP Interrupt Flag bit indicates the status of the SOF/EOP Timer interrupt. This bit will trigger '1' when the SOF/EOP timer expires. - 1: Interrupt triggered - 0: Interrupt did not trigger ### Port B Wake Interrupt Flag (Bit 7) The Port B Wake Interrupt Flag bit indicates remote wakeup on PortB - 1: Interrupt triggered - 0: Interrupt did not trigger # Port A Wake Interrupt Flag (Bit 6) The Port A Wake Interrupt Flag bit indicates remote wakeup on PortA - 1: Interrupt triggered - 0: Interrupt did not trigger ## Port B Connect Change Interrupt Flag (Bit 5) The Port B Connect Change Interrupt Flag bit indicates the status of the Connect Change interrupt on Port B. This bit will trigger '1' on either a rising edge or falling edge of a USB Reset condition (device inserted or removed). Together with the Port B SE0 Status bit, it can be determined whether a device was inserted or removed. - 1: Interrupt triggered - 0: Interrupt did not trigger ### Port A Connect Change Interrupt Flag (Bit 4) The Port A Connect Change Interrupt Flag bit indicates the status of the Connect Change interrupt on Port A. This bit will trigger '1' on either a rising edge or falling edge of a USB Reset condition (device inserted or removed). Together with the Port A SE0 Status bit, it can be determined whether a device was inserted or removed. - 1: Interrupt triggered - 0: Interrupt did not trigger ### Port B SE0 Status (Bit 3) The Port B SE0 Status bit indicates if Port B is in a SE0 state or not. Together with the Port B Connect Change Interrupt Flag bit, it can be determined whether a device was inserted (non-SE0 condition) or removed (SE0 condition). - 1: SE0 condition - 0: Non-SE0 condition #### Port A SE0 Status (Bit 2) The Port A SE0 Status bit indicates if Port A is in a SE0 state or not. Together with the Port A Connect change Interrupt Flag bit, it can be determined whether a device was inserted (non-SE0 condition) or removed (SE0 condition). - 1: SE0 condition - 0: Non-SE0 condition ### Done Interrupt Flag (Bit 0) The Done Interrupt Flag bit indicates the status of the USB Transfer Done interrupt. The USB Transfer Done will trigger when either the host responding with and ACK, or a device responds with any of the following: ACK, NAK, STALL, or Time-out. This interrupt is used for both Port A and Port B. - 1: Interrupt triggered - 0: Interrupt did not trigger #### 7.5.10 Host n SOF/EOP Count Register [R/W] - Host 1 SOF/EOP Count Register 0xC092 - Host 2 SOF/EOP Count Register 0xC0B2 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------|-------|-------|-----|------|-----|-----|-----| | Field | Rese | erved | Count | | | | | | | Read/Write | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | Figure 7-30. Host n SOF/EOP Count Register ## **Register Description** The Host n SOF/EOP Count Register contains the SOF/EOP Count Value that is loaded into the SOF/EOP counter. This value is loaded each time the SOF/EOP counter counts down to zero. The default value set in this register at power up is 0x2EE0 which will generate a 1ms time frame. The SOF/EOP counter is a down counter decremented at a 12-MHz rate. When this register is read, the value returned is the programmed SOF/EOP count value. ## Count (Bits [13:0]) The Count field sets the SOF/EOP counter duration. #### Reserved All reserved bits should be written as '0'. ## 7.5.11 Host n SOF/EOP Counter Register [R] - · Host 1 SOF/EOP Counter Register 0xC094 - Host 2 SOF/EOP Counter Register 0xC0B4 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------|-------|----|----|-------|----|---|---| | Field | Rese | erved | | | | | | | | Read/Write | - | - | R | R | R | R | R | R | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Co | unter | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | Х | Х | Х | Х | Х | Х | Х | Х | Figure 7-31. Host n SOF/EOP Counter Register The Host n SOF/EOP Counter Register contains the current value of the SOF/EOP down counter. This value can be used to determine the time remaining in the current frame. ### Counter (Bits [13:0]) The Counter field contains the current value of the SOF/EOP down counter. ## 7.5.12 Host n Frame Register [R] - Host 1 Frame Register 0xC096 - Host 2 Frame Register 0xC0B6 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----|----|----------|-------|-----|----|---|---| | Field | | | Reserved | Frame | | | | | | Read/Write | - | - | - | - | - | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Fr | ame | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-32. Host n Frame Register #### **Register Description** The Host n Frame Register maintains the next frame number to be transmitted (current frame number + 1). This value is updated after each SOF transmission. This register resets to 0x0000 after each CPU write to the Host n SOF/EOP Count Register (Host 1: 0xC092 Host 2: 0xC0B2). # Frame (Bits [10:0]) The Frame field contains the next frame number to be transmitted. ## Reserved All reserved bits should be written as '0'. ## 7.6 USB Device Only Registers There are eleven sets of USB Device only registers. All sets consist of at least two registers, one for Device Port 1 and one for Device Port 2. In addition, each Device port has eight possible endpoints. This gives each endpoint register set eight registers for each Device Port for a total of sixteen registers per set. The USB Device only registers are covered in this section and summarized in *Figure 7-33*. | Register Name | Address (Device 1 / Device 2) | R/W | |-------------------------------------------|-------------------------------|-----| | Device n Endpoint n Control Register | 0x02n0 | R/W | | Device n Endpoint n Address Register | 0x02n2 | R/W | | Device n Endpoint n Count Register | 0x02n4 | R/W | | Device n Endpoint n Status Register | 0x02n6 | R/W | | Device n Endpoint n Count Result Register | 0x02n8 | R/W | | Device n Port Select Register | 0xC084 / 0xC0A4 | R/W | | Device n Interrupt Enable Register | 0xC08C / 0xC0AC | R/W | | Device n Address Register | 0xC08E / 0xC0AE | R/W | | Device n Status Register | 0xC090 / 0xCB0 | R/W | | Device n Frame Number Register | 0xC092 / 0xC0B2 | R | | Device n SOF/EOP Count Register | 0xC094 / 0xC0B4 | W | Figure 7-33. USB Device Only Registers #### 7.6.1 Device n Endpoint n Control Register [R/W] - Device n Endpoint 0 Control Register [Device 1: 0x0200 Device 2: 0x0280] - Device n Endpoint 1 Control Register [Device 1: 0x0210 Device 2: 0x0290] - Device n Endpoint 2 Control Register [Device 1: 0x0220 Device 2: 0x02A0] - Device n Endpoint 3 Control Register [Device 1: 0x0230 Device 2: 0x02B0] - Device n Endpoint 4 Control Register [Device 1: 0x0240 Device 2: 0x02C0] - Device n Endpoint 5 Control Register [Device 1: 0x0250 Device 2: 0x02D0] - Device n Endpoint 6 Control Register [Device 1: 0x0260 Device 2: 0x02E0] - Device n Endpoint 7 Control Register [Device 1: 0x0270 Device 2: 0x02F0] | Bit# | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------------------------|--------------------|-----------------|---------------|----------------------------|---------------------|--------|---------------| | Field | | | | Rese | erved | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | Х | Х | X | Х | Х | Х | Х | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | IN/OUT<br>Ignore<br>Enable | Sequence<br>Select | Stall<br>Enable | ISO<br>Enable | NAK<br>Interrupt<br>Enable | Direction<br>Select | Enable | Arm<br>Enable | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | Х | Figure 7-34. Device n Endpoint n Control Register # **Register Description** The Device n Endpoint n Control Register provides control over a single EP in device mode. There are a total of eight endpoints for each of the two ports. All endpoints have the same definition for their Device n Endpoint n Control Register. ## IN/OUT Ignore Enable (Bit 6) The IN/OUT Ignore Enable bit will force endpoint 0 (EP0) to ignore all IN and OUT requests. This bit should be set so that EP0 only excepts Setup packets at the start of each transfer. This bit must be cleared to except IN/OUT transactions. This bit only applies to EP0. - 1: Ignore IN/OUT requests - 0: Do not ignore IN/OUT requests #### Sequence Select (Bit 6) The Sequence Select bit will determine whether a DATA0 or a DATA1 will be sent for the next data toggle. This bit has no effect on receiving data packets, sequence checking must be handled in firmware. - 1: Send a DATA1 - 0: Send a DATA0 #### Stall Enable (Bit 5) The Stall Enable bit will send a Stall in response to the next request (unless it is a set-up request which are always ACKed). This is a sticky bit and will continue to respond with Stalls until cleared by firmware. - 1: Send Stall - 0: Do not send Stall #### ISO Enable (Bit 4) The ISO Enable bit enables and disables an Isochronous transaction. This bit is only valid for EPs 1–7 and has no function for EP0. - 1: Enable Isochronous transaction - 0: Disable Isochronous transaction ### NAK Interrupt Enable (Bit 3) The NAK Interrupt Enable bit enables and disables the generation of an Endpoint n interrupt when the device responds to the host with a NAK. The Endpoint n Interrupt Enable bit in the Device n Interrupt Enable Register must also be set. When a NAK is sent to the host, the corresponding EP Interrupt Flag in the Device n Status Register will be set. In addition, the NAK Flag in the Device n Endpoint n Status Register will be set. - 1: Enable NAK interrupt - 0: Disable NAK interrupt ## Direction Select (Bit 2) The Direction Select bit needs to be set according to the expected direction of the next data stage in the next transaction. If the data stage direction is different from what is set it this bit, it will get NAKed and either the IN Exception Flag or the OUT Exception Flag will be set in the Device n Endpoint n Status Register. If a set-up packet is received and the Direction Select bit is set incorrectly, the set-up will get ACKed and the Set-up Status Flag will be set (please refer to the set-up bit of the Device n Endpoint n Status Register for details). - 1: OUT transfer (host to device) - 0: IN transfer (device to host) #### Enable (Bit 1) The Enable bit must be set to allow transfers to the endpoint. If Enable is set to '0' then all USB traffic to this endpoint will be ignored. If Enable is set '1' and Arm Enable (bit 0) is set '0' then NAKs will automatically be returned from this endpoint (except setup packets which are always ACKed as long as the Enable bit is set.) - 1: Enable transfers to an endpoint - 0: Do not allow transfers to an endpoint #### Arm Enable (Bit 0) The Arm Enable bit arms the endpoint to transfer or receive a packet. This bit is cleared to '0' when a transaction is complete. - 1: Arm endpoint - Endpoint disarmed ### Reserved All reserved bits should bit written as '0'. #### 7.6.2 Device n Endpoint n Address Register [R/W] - Device n Endpoint 0 Address Register [Device 1: 0x0202 Device 2: 0x0282] - Device n Endpoint 1 Address Register [Device 1: 0x0212 Device 2: 0x0292] - Device n Endpoint 2 Address Register [Device 1: 0x0222 Device 2: 0x02A2] - Device n Endpoint 3 Address Register [Device 1: 0x0232 Device 2: 0x02B2] - Device n Endpoint 4 Address Register [Device 1: 0x0242 Device 2: 0x02C2] - Device n Endpoint 5 Address Register [Device 1: 0x0252 Device 2: 0x02D2] - Device n Endpoint 6 Address Register [Device 1: 0x0262 Device 2: 0x02E2] - Device n Endpoint 7 Address Register [Device 1: 0x0272 Device 2: 0x02F2] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|------|-------|-----|-----|-----| | Field | | | | Addr | ess | | | | | Read/Write | R/W | Default | X | X | Х | Х | Х | X | X | Х | | | | • | • | • | • | | • | • | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Ad | dress | | | | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | X | Figure 7-35. Device n Endpoint n Address Register The Device n Endpoint n Address Register is used as the base pointer into memory space for the current Endpoint transaction. There are a total of eight endpoints for each of the two ports. All endpoints have the same definition for their Device n Endpoint n Address Register. ## Address (Bits [15:0]) The Address field sets the base address for the current transaction on a signal endpoint. ## 7.6.3 Device n Endpoint n Count Register [R/W] - Device n Endpoint 0 Count Register [Device 1: 0x0204 Device 2: 0x0284] - Device n Endpoint 1 Count Register [Device 1: 0x0214 Device 2: 0x0294] - Device n Endpoint 2 Count Register [Device 1: 0x0224 Device 2: 0x02A4] - Device n Endpoint 3 Count Register [Device 1: 0x0234 Device 2: 0x02B4] - Device n Endpoint 4 Count Register [Device 1: 0x0244 Device 2: 0x02C4] - Device n Endpoint 5 Count Register [Device 1: 0x0254 Device 2: 0x02D4] - Device n Endpoint 6 Count Register [Device 1: 0x0264 Device 2: 0x02E4] - Device n Endpoint 7 Count Register [Device 1: 0x0274 Device 2: 0x02F4] | | | I | | | l | I | I | I | |------------|-----|-----|------|-------|------|-----|-------|-----| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Field | | | Rese | erved | | | Count | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | Х | X | Х | Х | Х | Х | X | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Co | ount | | | | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | Х | Figure 7-36. Device n Endpoint n Count Register ## **Register Description** The Device n Endpoint n Count Register designates the maximum packet size that can be received from the host for OUT transfers for a single endpoint. This register also designates the packet size to be sent to the host in response to the next IN token for a single endpoint. The maximum packet length is 1023 bytes in ISO mode. There are a total of eight endpoints for each of the two ports. All endpoints have the same definition for their Device n Endpoint n Count Register. ## Count (Bits [9:0]) The Count field sets the current transaction packet length for a single endpoint. ### Reserved All reserved bits should be written as '0'. ## 7.6.4 Device n Endpoint n Status Register [R/W] - Device n Endpoint 0 Status Register [Device 1: 0x0206 Device 2: 0x0286] - Device n Endpoint 1 Status Register [Device 1: 0x0216 Device 2: 0x0296] - Device n Endpoint 2 Status Register [Device 1: 0x0226 Device 2: 0x02A6] - Device n Endpoint 3 Status Register [Device 1: 0x0236 Device 2: 0x02B6] - Device n Endpoint 4 Status Register [Device 1: 0x0246 Device 2: 0x02C6] - Device n Endpoint 5 Status Register [Device 1: 0x0256 Device 2: 0x02D6] - Device n Endpoint 6 Status Register [Device 1: 0x0266 Device 2: 0x02E6] - Device n Endpoint 7 Status Register [Device 1: 0x0276 Device 2: 0x02F6] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|----|----|----|------------------|-------------------|-----------------------|----------------------| | Field | Reserved | | | | Overflow<br>Flag | Underflow<br>Flag | OUT<br>Exception Flag | IN<br>Exception Flag | | Read/Write | - | | | | | R/W | R/W | R/W | | Default | Х | Х | X | Х | Х | X | Х | Х | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---------------|-------------|--------------------------|----------------|------------------|------------------|---------------|-------------| | Field | Stall<br>Flag | NAK<br>Flag | Length<br>Exception Flag | Set-up<br>Flag | Sequence<br>Flag | Time-out<br>Flag | Error<br>Flag | ACK<br>Flag | | Read/Write | R/W | Default | X | Х | Х | X | Х | X | Х | Х | Figure 7-37. Device n Endpoint n Status Register The Device n Endpoint n Status Register provides packet status information for the last transaction received or transmitted. This register is updated in hardware and does not need to be cleared by firmware. There are a total of eight endpoints for each of the two ports. All endpoints have the same definition for their Device n Endpoint n Status Register. The Device n Endpoint n Status Register is a memory based register that should be initialized to 0x0000 before USB Device operations are initiated. After initialization, this register should not be written to again. #### Overflow Flag (Bit 11) The Overflow Flag bit indicates that the received data in the last data transaction exceeded the maximum length specified in the Device n Endpoint n Count Register. The Overflow Flag should be checked in response to a Length Exception signified by the Length Exception Flag set to '1'. - 1: Overflow condition occurred - 0: Overflow condition did not occur ## Underflow Flag (Bit 10) The Underflow Flag bit indicates that the received data in the last data transaction was less then the maximum length specified in the Device n Endpoint n Count Register. The Underflow Flag should be checked in response to a Length Exception signified by the Length Exception Flag set to '1'. - 1: Underflow condition occurred - 0: Underflow condition did not occur #### **OUT Exception Flag** (Bit 9) The OUT Exception Flag bit will indicates when the device received an OUT packet when armed for an IN. - 1: Received OUT when armed for IN - 0: Received IN when armed for IN # IN Exception Flag (Bit 8) The IN Exception Flag bit will indicates when the device received an IN packet when armed for an OUT. - 1: Received IN when armed for OUT - 0: Received OUT when armed for OUT #### Stall Flag (Bit 7) The Stall Flag bit indicates that a Stall packet was sent to the host. - 1: Stall packet was sent to the host - 0: Stall packet was not sent ### NAK Flag (Bit 6) The NAK Flag bit indicates that a NAK packet was sent to the host. - 1: NAK packet was sent to the host - 0: NAK packet was not sent #### Length Exception Flag (Bit 5) The Length Exception Flag bit indicates the received data in the data stage of the last transaction does not equal the maximum Endpoint Count specified in the Device n Endpoint n Count Register. A Length Exception can either mean an overflow or underflow and the Overflow and Underflow flags (bits 11 and 10 respectively) should be checked to determine which event occurred - 1: An overflow or underflow condition occurred - 0: An overflow or underflow condition did not occur #### Set-up Flag (Bit 4) The Set-up Flag bit indicates that a set-up packet was received. In device mode set-up packets get stored at memory location 0x0300 for Device 1 and 0x0308 for Device 2. Set-up packets are always accepted regardless of the Direction Select and Arm Enable bit settings as long as the Device n EP n Control Register Enable bit is set. - 1: Set-up packet was received - 0: Set-up packet was not received #### Sequence Flag (Bit 3) The Sequence Flag bit indicates whether the last data toggle received was a DATA1 or a DATA0. This bit has no effect on receiving data packets, sequence checking must be handled in firmware. - 1: DATA1 was received - 0: DATA0 was received ## Time-out Flag (Bit 2) The Time-out Flag bit indicates whether a time-out condition occurred on the last transaction. On the device side, a time-out can occur if the device sends a data packet in response to an IN request but then does not receive a handshake packet in a predetermined time. It can also occur if the device does not receive the data stage of an OUT transfer in time. - 1: Time-out occurred - 0: Time-out condition did not occur ### Error Flag (Bit 2) The Error Flag bit will be set if a CRC5 and CRC16 error occurs, or if an incorrect packet type is received. Overflow and underflow are not considered errors and do not affect this bit. - 1: Error occurred - 0: Error did not occur # ACK Flag (Bit 0) The ACK Flag bit indicates whether the last transaction was ACKed. - 1: ACK occurred - 0: ACK did not occur #### 7.6.5 Device n Endpoint n Count Result Register [R/W] - Device n Endpoint 0 Count Result Register [Device 1: 0x0208 Device 2: 0x0288] - Device n Endpoint 1 Count Result Register [Device 1: 0x0218 Device 2: 0x0298] - Device n Endpoint 2 Count Result Register [Device 1: 0x0228 Device 2: 0x02A8] - Device n Endpoint 3 Count Result Register [Device 1: 0x0238 Device 2: 0x02B8] - Device n Endpoint 4 Count Result Register [Device 1: 0x0248 Device 2: 0x02C8] - Device n Endpoint 5 Count Result Register [Device 1: 0x0258 Device 2: 0x02D8] - Device n Endpoint 6 Count Result Register [Device 1: 0x0268 Device 2: 0x02E8] - Device n Endpoint 7 Count Result Register [Device 1: 0x0278 Device 2: 0x02F8] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|-----|-------|-----|-----|-----| | Field | | | | Res | ult | | | | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | • | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Re | esult | | | | | Read/Write | R/W | Default | Х | Х | Х | Х | X | Х | Х | Х | Figure 7-38. Device n Endpoint n Count Result Register The Device n Endpoint n Count Register contains the size difference in bytes between the Endpoint Count specified in the Device n Endpoint n Count Register and the last packet received. If an overflow or underflow condition occurs, i.e., the received packet length differs from the value specified in the Device n Endpoint n Count Register, the Length Exception Flag bit in the Device n Endpoint n Status Register will be set. The value in this register is only value when the Length Exception Flag bit is set and the Error Flag bit is not set, both bits are in the Device n Endpoint n Status Register. The Device n Endpoint n Count Result Register is a memory-based register that should be initialized to 0x0000 before USB Device operations are initiated. After initialization, this register should not be written to again. #### **Result** (Bits [15:0]) The Result field will contain the differences in bytes between the received packet and the value specified in the Device n Endpoint n Count Register. If an overflow condition occurs, Result [15:10] will be set to '111111', a "2"s complement value indicating the additional byte count of the received packet. If an underflow condition occurs, Result [15:0] will indicate the excess bytes count (number of bytes not used). ## Reserved All reserved bits should be written as '0'. ## 7.6.6 Device n Port Select Register [R/W] - Device n Port Select Register 0xC084 - Device n Port Select Register 0xC0A4 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|----------------|----|----------|-------|----|---|---| | Field | Reserved | Port<br>Select | | Reserved | | | | | | Read/Write | - | R/W | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | , | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Res | erved | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-39. Device n Port Select Register #### **Register Description** The Device n Port Select Register selects either port A or port B for the static device port. ## Port Select (Bit 14) The Port Select bit selects which of the two ports is enabled - 1: Port 1B or Port 2B is enabled - 0: Port 1A or Port 2A is enabled #### 7.6.7 Device n Interrupt Enable Register [R/W] - Device 1 Interrupt Enable Register 0xC08C - Device 2 Interrupt Enable Register 0xC0AC | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|--------------------------|------------------------|------|-------|-----------------------------------------|----------|--------------------------------|---------------------------| | Field | VBUS<br>Interrupt Enable | ID Interrupt<br>Enable | Rese | erved | SOF/EOP<br>Time-out<br>Interrupt Enable | Reserved | SOF/EOP<br>Interrupt<br>Enable | Reset<br>Interrupt Enable | | Read/Write | R/W | R/W | - | - | R/W | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------| | Field | EP7 Interrupt<br>Enable | EP6 Interrupt<br>Enable | EP5 Interrupt<br>Enable | EP4 Interrupt<br>Enable | EP3 Interrupt<br>Enable | EP2 Interrupt<br>Enable | EP1 Interrupt<br>Enable | EP0 Interrupt<br>Enable | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-40. Device n Interrupt Enable Register The Device n Interrupt Enable Register provides control over device-related interrupts including eight different endpoint interrupts. #### VBUS Interrupt Enable (Bit 15) The VBUS Interrupt Enable bit will enable or disable the OTG VBUS interrupt. When enabled this interrupt will trigger on both rising and falling edge of VBUS at the 4.4V status (only supported in Port 1A). This bit is only available for Device 1 and is a reserved bit in Device 2. - 1: Enable VBUS interrupt - 0: Disable VBUS interrupt #### ID Interrupt Enable (Bit 14) The ID Interrupt Enable bit will enable or disable the OTG ID interrupt. When enabled this interrupt will trigger on both rising and falling edge of OTG ID pin (only supported in Port 1A). This bit is only available for Device 1 and is a reserved bit in Device 2. - 1: Enable ID interrupt - 0: Disable ID interrupt ## SOF/EOP Time-out Interrupt Enable (Bit 11) The SOF/EOP Time-out Interrupt Enable bit will enable or disable the SOF/EOP Time-out Interrupt. When enabled this interrupt will trigger when the USB host fails to send a SOF or EOP packet within the time period specified in the Device n SOF/EOP Count Register. In addition, the Device n Frame Register counts the number of times the SOF/EOP Time-out Interrupt triggers between receiving SOF/EOPs. - 1: SOF/EOP time-out occurred - 0: SOF/EOP time-out did not occur ## SOF/EOP Interrupt Enable (Bit 9) The SOF/EOP Interrupt Enable bit will enable or disable the SOF/EOP received interrupt. - 1: Enable SOF/EOP received interrupt - 0: Disable SOF/EOP received interrupt #### Reset Interrupt Enable (Bit 8) The Reset Interrupt Enable bit will enable or disable the USB Reset Detected interrupt - 1: Enable USB Reset Detected interrupt - 0: Disable USB Reset Detected interrupt ## EP7 Interrupt Enable (Bit 7) The EP7 Interrupt Enable bit will enable or disable endpoint seven (EP7) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP7 Transaction Done interrupt - 0: Disable EP7 Transaction Done interrupt #### EP6 Interrupt Enable (Bit 6) The EP6 Interrupt Enable bit will enable or disable endpoint seven (EP6) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP6 Transaction Done interrupt - 0: Disable EP6 Transaction Done interrupt #### **EP5 Interrupt Enable** (Bit 5) The EP5 Interrupt Enable bit will enable or disable endpoint seven (EP5) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt - 1: Enable EP5 Transaction Done interrupt - 0: Disable EP5 Transaction Done interrupt ### EP4 Interrupt Enable (Bit 4) The EP4 Interrupt Enable bit will enable or disable endpoint seven (EP4) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP4 Transaction Done interrupt - 0: Disable EP4 Transaction Done interrupt #### EP3 Interrupt Enable (Bit 3) The EP3 Interrupt Enable bit will enable or disable endpoint seven (EP3) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP3 Transaction Done interrupt - 0: Disable EP3 Transaction Done interrupt #### EP2 Interrupt Enable (Bit 2) The EP2 Interrupt Enable bit will enable or disable endpoint seven (EP2) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP2 Transaction Done interrupt - 0: Disable EP2 Transaction Done interrupt #### EP1 Interrupt Enable (Bit 1) The EP1 Interrupt Enable bit will enable or disable endpoint seven (EP1) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP1 Transaction Done interrupt - 0: Disable EP1 Transaction Done interrupt #### EP0 Interrupt Enable (Bit 0) The EP0 Interrupt Enable bit will enable or disable endpoint seven (EP0) Transaction Done interrupt. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the device's given Endpoint: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, the NAK Interrupt Enable bit in the Device n Endpoint Control Register can also be set so that NAK responses will trigger this interrupt. - 1: Enable EP0 Transaction Done interrupt - 0: Disable EP0 Transaction Done interrupt #### Reserved All reserved bits should be written as '0'. ## 7.6.8 Device n Address Register [W] - Device 1 Address Register 0xC08E - Device 2 Address Register 0xC0AE | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|----------|----------|----|----|---------|----|---|---|--|--| | Field | | Reserved | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | Reserved | | | | Address | | | | | | | Read/Write | - | W | W | W | W | W | W | W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Figure 7-41. Device n Address Register ## **Register Description** The Device n Address Register holds the device address assigned by the host. This register initializes to the default address 0 at reset but must be updated by firmware when the host assigns a new address. Only USB data sent to the address contained in this register will be responded to, all others are ignored. #### Address (Bits [6:0]) The Address field contains the USB address of the device assigned by the host. #### Reserved All reserved bits should be written as '0'. # 7.6.9 Device n Status Register [R/W] - Device 1 Status Register 0xC090 - Device 2 Status Register 0xC0B0 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------------------------|----------------------|---------------|---------------|---------------|---------------|---------------------------|-------------------------| | Field | VBUS Interrupt<br>Flag | ID Interrupt<br>Flag | Reserved | | | | SOF/EOP<br>Interrupt Flag | Reset Interrupt<br>Flag | | Read/Write | R/W | R/W | - | - | - | - | R/W | R/W | | Default | X | X | Х | Х | X | Х | Х | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | EP7 Interrupt | EP6 Interrupt | EP5 Interrupt | EP4 Interrupt | EP3 Interrupt | EP2 Interrupt | EP1 Interrupt | EP0 Interrupt | | DIL# | 1 | O | ວ | 4 | 3 | 2 | | U | |------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------| | Field | EP7 Interrupt<br>Flag | EP6 Interrupt<br>Flag | EP5 Interrupt<br>Flag | EP4 Interrupt<br>Flag | EP3 Interrupt<br>Flag | EP2 Interrupt<br>Flag | EP1 Interrupt<br>Flag | EP0 Interrupt<br>Flag | | Read/Write | R/W | Default | Х | Х | Х | Х | Х | Х | Х | Х | Figure 7-42. Device n Status Register # **Register Description** The Device n Status Register provides status information for device operation. Pending interrupts can be cleared by writing a '1' to the corresponding bit. This register can be accessed by the HPI interface. ## VBUS Interrupt Flag (Bit 15) The VBUS Interrupt Flag bit indicates the status of the OTG VBUS interrupt (only for Port 1A). When enabled this interrupt will trigger on both the rising and falling edge of VBUS at 4.4V. This bit is only available for Device 1 and is a reserved bit in Device 2. - 1: Interrupt triggered - 0: Interrupt did not trigger ### ID Interrupt Flag (Bit 14) The ID Interrupt Flag bit indicates the status of the OTG ID interrupt (only for Port 1A). When enabled this interrupt will trigger on both the rising and falling edge of the OTG ID pin. This bit is only available for Device 1 and is a reserved bit in Device 2. - 1: Interrupt triggered - 0: Interrupt did not trigger ### SOF/EOP Interrupt Flag (Bit 9) The SOF/EOP Interrupt Flag bit indicates if the SOF/EOP received interrupt has triggered. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Reset Interrupt Flag (Bit 8) The Reset Interrupt Flag bit indicates if the USB Reset Detected interrupt has triggered. - 1: Interrupt triggered - 0: Interrupt did not trigger ## EP7 Interrupt Flag (Bit 7) The EP7 Interrupt Flag bit indicates if the endpoint seven (EP7) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger ## EP6 Interrupt Flag (Bit 6) The EP6 Interrupt Flag bit indicates if the endpoint six (EP6) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger #### EP5 Interrupt Flag (Bit 5) The EP5 Interrupt Flag bit indicates if the endpoint five (EP5) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger ## EP4 Interrupt Flag (Bit 4) The EP4 Interrupt Flag bit indicates if the endpoint four (EP4) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger ## EP3 Interrupt Flag (Bit 3) The EP3 Interrupt Flag bit indicates if the endpoint three (EP3) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger #### EP2 Interrupt Flag (Bit 2) The EP2 Interrupt Flag bit indicates if the endpoint two (EP2) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger ### EP1 Interrupt Flag (Bit 1) The EP1 Interrupt Flag bit indicates if the endpoint one (EP1) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger ## EP0 Interrupt Flag (Bit 0) The EP0 Interrupt Flag bit indicates if the endpoint zero (EP0) Transaction Done interrupt has triggered. An EPx Transaction Done interrupt will trigger when any of the following responses or events occur in a transaction for the devices given EP: send/receive ACK, send STALL, Time-out occurs, IN Exception Error, or OUT Exception Error. In addition, if the NAK Interrupt Enable bit in the Device n Endpoint Control Register is set, this interrupt will also trigger when the device NAKs host requests. - 1: Interrupt triggered - 0: Interrupt did not trigger #### Reserved All reserved bits should be written as '0'. ### 7.6.10 Device n Frame Number Register [R] - Device 1 Frame Number Register 0xC092 - Device 2 Frame Number Register 0xC0B2 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|--------------------------|-------|---------------------------------------|----|-----|----|-------|---|--| | Field | SOF/EOP<br>Time-out Flag | Time- | SOF/EOP<br>Time-out Interrupt Counter | | | | Frame | | | | Read/Write | R | R | R | R | - | R | R | R | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | | | | Fr | ame | | | | | | Read/Write | R | R | R | R | R | R | R | R | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 7-43. Device n Frame Number Register ## **Register Description** The Device n Frame Number Register is a read-only register that contains the Frame number of the last SOF packet received. This register also contains a count of SOF/EOP Time-out occurrences. ### SOF/EOP Time-out Flag (Bit 15) The SOF/EOP Time-out Flag bit indicates when an SOF/EOP Time-out Interrupt occurs. - 1: An SOF/EOP Time-out interrupt occurred - 0: An SOF/EOP Time-out interrupt did not occur # SOF/EOP Time-out Interrupt Counter (Bits [14:12]) The SOF/EOP Time-out Interrupt Counter field will increment by 1 from 0 to 7 for each SOF/EOP Time-out Interrupt. This field resets to 0 when a SOF/EOP is received. This field is only updated when the SOF/EOP Time-out Interrupt Enable bit in the Device n Interrupt Enable Register is set. Page 66 of 119 #### Frame (Bits [10:0]) The Frame field contains the frame number from the last received SOF packet in full-speed mode. This field has no function for low-speed mode. If a SOF Time-out occurs, this field will contain the last received Frame number. #### 7.6.11 Device n SOF/EOP Count Register [W] - Device 1 SOF/EOP Count Register 0xC094 - Device 2 SOF/EOP Count Register 0xC0B4 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |------------|------|-------|----|----|------|-----|---|---|--|--|--|--| | Field | Rese | erved | | | Cou | int | | | | | | | | Read/Write | - | - | R | R | R | R | R | R | | | | | | Default | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Field | | | | Co | ount | | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | | | | | | Default | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | Figure 7-44. Device n SOF/EOP Count Register ## **Register Description** The Device n SOF/EOP Count Register should be written with the time expected between receiving a SOF/EOPs. If the SOF/EOP counter expires before an SOF/EOP is received, an SOF/EOP Time-out Interrupt can be generated. The SOF/EOP Time-out Interrupt Enable and SOF/EOP Time-out Interrupt Enable and SOF/EOP Time-out Interrupt Enable and Status Registers respectively. The SOF/EOP count should be set slightly greater than the expected SOF/EOP interval. The SOF/EOP counter decrements at a 12-MHz rate. Therefore, in the case of an expected 1-ms SOF/EOP interval, the SOF/EOP count should be set slightly greater then 0x2EE0. #### Count (Bits [13:0]) The Count field contains the current value of the SOF/EOP down counter. At power-up and reset, this value is set to 0x2EE0 and for expected 1-ms SOF/EOP intervals, this SOF/EOP count should be increased slightly. ### Reserved All reserved bits should be written as '0'. ## 7.7 OTG Control Registers There is one register dedicated for On-The-Go operation. This register is covered in this section and summarized in Figure 7-45. | Register Name | Address | R/W | |----------------------|---------|-----| | OTG Control Register | C098H | R/W | Figure 7-45. OTG Registers ## 7.7.1 OTG Control Register [0xC098] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------|-------|------------------------|--------------------|-----------------------|--------------------------|----------------------|----------------------| | Field | Rese | erved | VBUS<br>Pull-up Enable | Receive<br>Disable | Charge Pump<br>Enable | VBUS<br>Discharge Enable | D+<br>Pull-up Enable | D–<br>Pull-up Enable | | Read/Write | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|------------------------|------------------------|----------|---|---|--------------------|--------------|--------------------| | Field | D+<br>Pull-down Enable | D–<br>Pull-down Enable | Reserved | | | OTG Data<br>Status | ID<br>Status | VBUS Valid<br>Flag | | Read/Write | R/W | R/W | - | - | - | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | Х | Х | X | Figure 7-46. OTG Control Register Document #: 38-08015 Rev. \*E The OTG Control Register allows control and monitoring over the OTG port on Port1A. ### VBUS Pull-up Enable (Bit 13) The VBUS Pull-up Enable bit enables or disables a $500\Omega$ pull-up resistor onto OTG VBus. 1: $500\Omega$ pull-up resistor enabled **0:** $500\Omega$ pull-up resistor disabled ## Receive Disable (Bit 12) The Receive Disable bit enables or powers down (disables) the OTG receiver section. 1: OTG receiver powered down and disabled 0: OTG receiver enabled ## Charge Pump Enable (Bit 11) The Charge Pump Enable bit enables or disables the OTG VBus charge pump. 1: OTG VBus charge pump enabled 0: OTG VBus charge pump disabled ## VBUS Discharge Enable (Bit 10) The VBUS Discharge Enable bit enables or disables a $2K\Omega$ discharge pull-down resistor onto OTG VBus. 1: $2K\Omega$ pull-down resistor enabled **0:** $2K\Omega$ pull-down resistor disabled #### D+ Pull-up Enable (Bit 9) The D+ Pull-up Enable bit enables or disables a pull-up resistor on the OTG D+ data line. 1: OTG D+ dataline pull-up resistor enabled 0: OTG D+ dataline pull-up resistor disabled #### D- Pull-up Enable (Bit 8) The D- Pull-up Enable bit enables or disables a pull-up resistor on the OTG D- data line. 1: OTG D- dataline pull-up resistor enabled 0: OTG D- dataline pull-up resistor disabled ## D+ Pull-down Enable (Bit 7) The D+ Pull-down Enable bit enables or disables a pull-down resistor on the OTG D+ data line. 1: OTG D+ dataline pull-down resistor enabled 0: OTG D+ dataline pull-down resistor disabled ### D- Pull-down Enable (Bit 6) The D- Pull-down Enable bit enables or disables a pull-down resistor on the OTG D- data line. 1: OTG D- dataline pull-down resistor enabled 0: OTG D- dataline pull-down resistor disabled # OTG Data Status (Bit 2) The OTG Data Status bit is a read-only bit and indicates the TTL logic state of the OTG VBus pin. 1: OTG VBus is greater then 2.4V 0: OTG VBus is less then 0.8V ## ID Status (Bit 1) The ID Status bit is a read-only bit that indicates the state of the OTG ID pin on Port A. **1:** OTG ID Pin is not connected directly to ground (>10k $\Omega$ ) 0: OTG ID Pin is connected directly ground (< $10\Omega)$ #### VBUS Valid Flag (Bit 0) The VBUS Valid Flag bit indicates whether OTG VBus is greater then 4.4V. After turning on VBUS, firmware should wait at least 10 µs before this reading this bit. - 1: OTG VBus is greater then 4.4V - 0: OTG VBus is less then 4.4V #### Reserved All reserved bits should bit written as '0'. # 7.8 GPIO Registers There are seven registers dedicated for GPIO operations. These seven registers are covered in this section and summarized in *Figure 7-47*. | Register Name | Address | R/W | |----------------------------|---------|-----| | GPIO Control Register | 0xC006 | R/W | | GPIO0 Output Data Register | 0xC01E | R/W | | GPIO0 Input Data Register | 0xC020 | R | | GPIO0 Direction Register | 0xC022 | R/W | | GPIO1 Output Data Register | 0xC024 | R/W | | GPIO1 Input Data Register | 0xC026 | R | | GPIO1 Direction Register | 0xC028 | R/W | Figure 7-47. GPIO Registers ## 7.8.1 GPIO Control Register [0xC006] [R/W] 0 0 0 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|-------------------------|------------------|---------------|------------------|--------------------------------|-----------------------|--------------------------------|-----------------------|--| | Field | Write Protect<br>Enable | UD | Reserved | | SAS<br>Enable | | Mode<br>Select | | | | Read/Write | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | HSS<br>Enable | HSS XD<br>Enable | SPI<br>Enable | SPI XD<br>Enable | Interrupt 1<br>Polarity Select | Interrupt 1<br>Enable | Interrupt 0<br>Polarity Select | Interrupt 0<br>Enable | | | Read/Write | R/W | Figure 7-48. GPIO Control Register 0 0 0 0 ## **Register Description** Default The GPIO Control Register configures the GPIO pins for various interface options. It also controls the polarity of the GPIO interrupt on IRQ1 (GPIO25) and IRQ0 (GPIO24). ## Write Protect Enable (Bit 15) The Write Protect Enable bit enables or disables the GPIO write protect. When Write Protect is enabled, the GPIO Mode Select [10:8] field read-only until a chip reset. - 1: Enable Write Protect - 0: Disable Write Protect #### **UD** (Bit 14) The UD bit routes the Host/Device 1A Port's transmitter enable status to GPIO[30]. This is for use with an external ESD protection circuit when needed. - 1: Route the signal to GPIO[30] - 0: Do not route the signal to GPIO[30] 0 #### SAS Enable (Bit 11) The SAS Enable bit, when in SPI mode, will reroute the SPI port SPI\_nSSI pin to GPIO[15] rather then GPIO[9] or XD[9] (per SG/SX). - 1: Reroute SPI nss to GPIO[30] - 0: Leave SPI nss on GPIO[9] ## Mode Select (Bits [10:8]) The Mode Select field selects how GPIO[15:0] and GPIO[24:19] are used as defined in Table 7-10. #### Table 7-10. Mode Select Definition | Mode Select [10:8] | GPIO Configuration | |--------------------|---------------------------------------------------------------------------------| | 111 | Reserved | | 110 | SCAN — (HW) Scan diagnostic. For production test only. Not for normal operation | | 101 | HPI — Host Port Interface | | 100 | IDE — Integrated Drive Electronics or | | 011 | Reserved | | 010 | Reserved | | 001 | Reserved | | 000 | GPIO — General Purpose Input Output | ## HSS Enable (Bit 7) The HSS Enable bit routes HSS to GPIO[26, 18:16]. If the HSS XD Enable bit is set, it will override this bit and HSS will be routed to XD[15:12]. - 1: HSS is routed to GPIO - 0: HSS is not routed to GPIOs. GPIO[26, 18:16] are free for other purposes #### HSS XD Enable (Bit 6) The HSS XD Enable bit routes HSS to XD[15:12] (external memory data bus). This bit overrides the HSS Enable bit. - 1: HSS is routed to XD[15:12] - 0: HSS is not routed to XD[15:12] ### SPI Enable (Bit 5) The SPI Enable bit routes SPI to GPIO[11:8]. If the SAS Enable bit is set, it will override the SPI Enable and route SPI\_nSSI to GPIO15. If the SPI XD Enable bit is set, it will override both bits and the SPI will be routed to XD[11:8] (external memory data bus). - 1: SPI is routed to GPIO[11:8] - 0: SPI is not routed to GPIO[11:8]. GPIO[11:8] are free for other purposes ### SPI XD Enable (Bit 4) The SPI XD Enable bit routes SPI to XD[11:8] (external memory data bus). This bit overrides the SPI Enable bit. - 1: SPI is routed to XD[11:8] - 0: SPI is not routed to XD[11:8] # Interrupt 1 Polarity Select (Bit 3) The Interrupt 1 Polarity Select bit selects the polarity for IRQ1. - 1: Sets IRQ1 to rising edge - 0: Sets IRQ1 to falling edge ## Interrupt 1 Enable (Bit 2) The Interrupt 1 Enable bit enables or disables IRQ1. The GPIO bit on the interrupt Enable Register must also be set in order for this for this interrupt to be enabled. - 1: Enable IRQ1 - 0: Disable IRQ1 ### Interrupt 0 Polarity Select (Bit 1) The Interrupt 0 Polarity Select bit selects the polarity for IRQ0. - 1: Sets IRQ0 to rising edge - 0: Sets IRQ0 to falling edge ## Interrupt 0 Enable (Bit 0) The Interrupt 0 Enable bit enables or disables IRQ0. The GPIO bit on the interrupt Enable Register must also be set in order for this for this interrupt to be enabled. - 1: Enable IRQ0 - 0: Disable IRQ0 #### Reserved All reserved bits should be written as '0'. ## 7.8.2 GPIO n Output Data Register [R/W] - GPIO 0 Output Data Register 0xC01E - GPIO 1 Output Data Register 0xC024 | | | 1 | | | | | | | | |------------|-----|------|-----|-----|-----|-----|-----|-----|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Field | | Data | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | | | | D | ata | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 7-49. GPIO n Output Data Register # **Register Description** The GPIO n Output Data Register controls the output data of the GPIO pins. The GPIO 0 Output Data Register controls GPIO15 to GPIO30 while the GPIO 1 Output Data Register controls GPIO31 to GPIO16. When read, this register reads back the last data written, not the data on pins configured as inputs (see Input Data Register). # Data (Bits [15:0]) The Data field[15:0] writes to the corresponding GPIO 15–0 or GPIO31–16 pins as output data. #### 7.8.3 GPIO n Input Data Register [R] - GPIO 0 Input Data Register 0xC020 - GPIO 1 Input Data Register 0xC026 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|------|----|----|----|----|----|---|---| | Field | | | | Da | ta | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Data | | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-50. GPIO n Input Data Register ## **Register Description** The GPIO n Input Data Register reads the input data of the GPIO pins. The GPIO 0 Input Data Register reads from GPIO15 to GPIO0 while the GPIO 1 Input Data Register reads from GPIO31 to GPIO16. #### Data (Bits [15:0]) The Data field[15:0] contains the voltage values on the corresponding GPIO15-0 or GPIO31-16 input pins. ## 7.8.4 GPIO n Direction Register [R/W] - GPIO 0 Direction Register 0xC022 - GPIO 1 Direction Register 0xC028 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|------------------|------------------|-----|-----|-----|-----|-----|-----|--| | Field | | Direction Select | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | Direction Select | | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 7-51. GPIO n Direction Register ### **Register Description** The GPIO n Direction Register controls the direction of the GPIO data pins (input/output). The GPIO 0 Direction Register controls GPIO15 to GPIO0 while the GPIO 1 Direction Register controls GPIO31 to GPIO16. ### Direction Select (Bits [15:0]) The Direction Select field[15:0] configures the corresponding GPIO15–0 or GPIO31–16 pins as either input or output. When any bit of this register is set to '1', the corresponding GPIO data pin becomes an output. When any bit of this register is set to '0', the corresponding GPIO data pin becomes an input. ### 7.9 IDE Registers In addition to the standard IDE PIO Port registers, there are four registers dedicated to IDE operation. These registers are covered in this section and summarized in *Figure 7-52*. | Register Name | Address | R/W | |----------------------------|---------------|-----| | IDE Mode Register | 0xC048 | R/W | | IDE Start Address Register | 0xC04A | R/W | | IDE Stop Address Register | 0xC04C | R/W | | IDE Control Register | 0xC04E | R/W | | IDE PIO Port Registers | 0xC050-0xC06F | R/W | Figure 7-52. IDE Registers ## 7.9.1 IDE Mode Register [0xC048] [R/W] | | | • | | • | | | | | |------------|----------|----|----|----|-------------|-----|-----|-----| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Field | Reserved | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Reserved | | | | Mode Select | | | | | Read/Write | - | - | - | - | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-53. IDE Mode Register # **Register Description** The IDE Mode Register allows the selection of IDE PIO Modes 0, 1, 2, 3, or 4. The default setting is zero which means IDE PIO Mode 0. ## Mode Select (Bits [2:0]) The Mode Select field sets PIO Mode 0 to 4 in IDE mode. Refer to Table 7-11 for a definition of this field. Table 7-11. Mode Select Definition | Mode Select [2:0] | Mode | |-------------------|-----------------------------| | 000 | IDE PIO Mode 0 | | 001 | IDE PIO Mode 1 | | 010 | IDE PIO Mode 2 | | 011 | IDE PIO Mode 3 | | 100 | IDE PIO Mode 4 | | 101 | Reserved | | 110 | Reserved | | 111 | Disable IDE port operations | #### Reserved All reserved bits should be written as '0'. ## 7.9.2 IDE Start Address Register [0xC04A] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------|-----|-----|-----|-----|-----|-----|-----| | Field | Address | | | | | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Address | | | | | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-54. IDE Start Address Register #### **Register Description** The IDE Start Address Register holds the start address for an IDE block transfer. This register is byte addressed and IDE block transfers are 16-bit words, therefore the LSB of the start address is ignored. Block transfers begin at IDE Start Address and end with the final word at IDE Stop Address. When IDE Start Address equals IDE Stop Address, the block transfer moves one word of data. The hardware keeps an internal memory address counter. The two MSBs of the addresses are not modified by the address counter. Therefore the IDE Start Address and IDE Stop Address must reside within the same 16-Kbyte block. ## Address (Bits [15:0]) The Address field sets the start address for an IDE block transfer. ## 7.9.3 IDE Stop Address Register [0xC04C] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|---------|-----|-----|-----|-----|-----|-----|-----|--| | Field | Address | | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | Address | | | | | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Figure 7-55. IDE Stop Address Register Document #: 38-08015 Rev. \*E Page 72 of 119 #### **Register Description** The IDE Stop Address Register holds the stop address for an IDE block transfer. This register is byte addressed and IDE block transfers are 16-bit words therefore the LSB of the stop address is ignored. Block transfers begin at IDE Start Address and end with the final word at IDE Stop Address. When IDE Start Address equals IDE Stop Address, the block transfer moves one word of data. The hardware keeps an internal memory address counter. The two MSBs of the addresses are not modified by the address counter. Therefore the IDE Start Address and IDE Stop Address must reside within the same 16-Kbyte block. ## Address (Bits [15:0]) The Address field sets the stop address for an IDE block transfer. #### 7.9.4 IDE Control Register [0xC04E] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |------------|----|----------|-------|----|---------------------|----------------------------|--------------|---------------|--|--|--|--| | Field | | Reserved | | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Field | | Res | erved | | Direction<br>Select | IDE<br>Interrupt<br>Enable | Done<br>Flag | IDE<br>Enable | | | | | | Read/Write | - | - | - | - | R/W | R/W | R/W | R/W | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Figure 7-56. IDE Control Register #### **Register Description** The IDE Control Register controls block transfers in IDE mode. #### **Direction Select** (Bit 3) The Direction Select bit sets the block mode transfer direction. - 1: Data is written to the external device - 0: Data is read from the external device ## IDE Interrupt Enable (Bit 2) The IDE Interrupt Enable bit enables or disables the block transfer done interrupt. When enabled, the Done Flag is sent to the CPU as cpuide\_intr interrupt. When disabled, the cpuide\_intr is set LOW. - 1: Enable block transfer done interrupt - 0: Disable block transfer done interrupt ## Done Flag (Bit 1) The Done Flag bit is automatically set to '1' by hardware when a block transfer is complete. The CPU clears this bit by writing a '0' to it. When IDE Interrupt Enable is set this bit generates the signal for the cpuide\_intr interrupt. - 1: Block transfer is complete - 0: Clears IDE Done Flag ## IDE Enable (Bit 0) The IDE Enable bit will start a block transfer. It is reset to '0' when the block transfer is complete - 1: Start block transfer - 0: Block transfer complete #### Reserved # 7.9.5 IDE PIO Port Registers [0xC050 - 0xC06F] [R/W] All IDE PIO Port Registers [0xC050 - 0xC06F] in *Table 7-12* are defined in detail in the Information Technology-AT Attachment -4 with Packet Interface Extension (ATA/ATAPI-4) Specification, T13/1153D Rev 18. In *Table 7-12* below, the Address column denotes the CY7C67300 register address for the corresponding ATA/ATAPI register. The IDE\_nCS[1:0] field defines the ATA interface CS addressing bits and the IDE\_A[2:0] field define the ATA interface address bits. The combination of IDE\_nCS and IDE\_A are the ATA interface register address. Table 7-12. IDE PIO Port Registers | Address | ATA/ATAPI Register | IDE_nCS[1:0] | IDE_A[2:0] | |---------|-------------------------------------------------------------------|--------------|------------| | 0xC050 | DATA Register | '10' | ,000, | | 0xC052 | Read: Error Register<br>Write: Feature Register | '10' | '001' | | 0xC054 | Sector Count Register | '10' | '010' | | 0xC056 | Sector Number Register | '10' | '011' | | 0xC058 | Cylinder Low Register | '10' | '100' | | 0xC05A | Cylinder High Register | '10' | '101' | | 0xC05C | Device/Head Register | '10' | '110' | | 0xC05E | Read: Status Register<br>Write: Command Register | '10' | '111' | | 0xC060 | Not Defined | '01' | '000' | | 0xC062 | Not Defined | '01' | '001' | | 0xC064 | Not Defined | '01' | '010' | | 0xC066 | Not Defined | '01' | '011' | | 0xC068 | Not Defined | '01' | '100' | | 0xC06A | Not Defined | '01' | '101' | | 0xC06C | Read: Alternate Status Register<br>Write: Device Control Register | '01' | '110' | | 0xC06E | Not Defined | '01' | '111' | # 7.10 HSS Registers There are eight registers dedicated to HSS operation. Each of these registers are covered in this section and summarized in *Figure 7-57*. | Register Name | Address | R/W | |-------------------------------|---------|-----| | HSS Control Register | 0xC070 | R/W | | HSS Baud Rate Register | 0xC072 | R/W | | HSS Transmit Gap Register | 0xC074 | R/W | | HSS Data Register | 0xC076 | R/W | | HSS Receive Address Register | 0xC078 | R/W | | HSS Receive Length Register | 0xC07A | R/W | | HSS Transmit Address Register | 0xC07C | R/W | | HSS Transmit Length Register | 0xC07E | R/W | Figure 7-57. HSS Registers # 7.10.1 HSS Control Register [0xC070] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------------|---------------------------|---------------------------|------|----------------|---------------|--------------------------------|-----------------------------| | Field | HSS<br>Enable | RTS<br>Polarity<br>Select | CTS<br>Polarity<br>Select | XOFF | XOFF<br>Enable | CTS<br>Enable | Receive<br>Interrupt<br>Enable | Done<br>Interrupt<br>Enable | | Read/Write | R/W | R/W | R/W | R | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|--------------------------------------|-------------------------------------|-----------------|-------------------|--------------------------|-----------------------------|---------------------------------|--------------------------| | Field | Transmit<br>Done Interrupt<br>Enable | Receive<br>Done Interrupt<br>Enable | One<br>Stop Bit | Transmit<br>Ready | Packet<br>Mode<br>Select | Receive<br>Overflow<br>Flag | Receive<br>Packet Ready<br>Flag | Receive<br>Ready<br>Flag | | Read/Write | R/W | R/W | R/W | R | R/W | R/W | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-58. HSS Control Register #### **Register Description** The HSS Control Register provides high-level status and control over the HSS port. ## HSS Enable (Bit 15) The HSS Enable bit enables or disables HSS operation. 1: Enables HSS operation 0: Disables HSS operation ## RTS Polarity Select (Bit 14) The RTS Polarity Select bit selects the polarity of RTS. 1: RTS is true when LOW 0: RTS is true when HIGH ## CTS Polarity Select (Bit 13) The CTS Polarity Select bit selects the polarity of CTS. 1: CTS is true when LOW 0: CTS is true when HIGH ## **XOFF** (Bit 12) The XOFF bit is a read-only bit that indicates if an XOFF has been received. This bit will automatically clear when an XON has been received. 1: XOFF received 0: XON received ## XOFF Enable (Bit 11) The XOFF Enable bit enables or disables XON/XOFF software handshaking. 1: Enable XON/XOFF software handshaking 0: Disable XON/XOFF software handshaking #### CTS Enable (Bit 10) The CTS Enable bit enables or disables CTS/RTS hardware handshaking. 1: Enable CTS/RTS hardware handshaking 0: Disable CTS/RTS hardware handshaking ## Receive Interrupt Enable (Bit 9) The Receive Interrupt Enable bit enables or disables the Receive Ready and Receive Packet Ready interrupts. 1: Enable the Receive Ready and Receive Packet Ready interrupts 0: Disable the Receive Ready and Receive Packet Ready interrupts #### Done Interrupt Enable (Bit 8) The Done Interrupt Enable bit enables or disables the Transmit Done and Receive Done interrupts. - 1: Enable the Transmit Done and Receive Done interrupts - 0: Disable the Transmit Done and Receive Done interrupts #### Transmit Done Interrupt Flag (Bit 7) The Transmit Done Interrupt Flag bit indicates the status of the Transmit Done Interrupt. It will set when a block transmit is finished. To clear the interrupt, a '1' should be written to this bit. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Receive Done Interrupt Flag (Bit 6) The Receive Done Interrupt Flag bit indicates the status of the Receive Done Interrupt. It will set when a block transmit is finished. To clear the interrupt, a '1' should be written to this bit. - 1: Interrupt triggered - 0: Interrupt did not trigger #### One Stop Bit (Bit 5) The One Stop Bit bit selects between one and two stop bits for transmit byte mode. In receive mode, the number of stop bits may vary and does not need to be fixed. - 1: One stop bit - 0: Two stop bits #### Transmit Ready (Bit 4) The Transmit Ready bit is a read-only bit that indicates if the HSS Transmit FIFO is ready for the CPU to load new data for transmission. - 1: HSS transmit FIFO ready for loading - 0: HSS transmit FIFO not ready for loading ## Packet Mode Select (Bit 3) The Packet Mode Select bit selects between Receive Packet Ready and Receive Ready as the interrupt source for the RxIntr interrupt. - 1: Selects Receive Packet Ready as the source - 0: Selects Receive Ready as the source ### Receive Overflow Flag (Bit 2) The Receive Overflow Flag bit indicates if the Receive FIFO overflowed when set. This flag can be cleared by writing a '1' to this bit. - 1: Overflow occurred - 0: Overflow did not occur ## Receive Packet Ready Flag (Bit 1) The Receive Packet Ready Flag bit is a read only bit that indicates if the HSS receive FIFO is full with eight bytes or not. - 1: HSS receive FIFO is full - 0: HSS receive FIFO is not full #### Receive Ready Flag (Bit 0) The Receive Ready Flag is a read only bit that indicates if the HSS receive FIFO is empty or not. - 1: HSS receive FIFO is not empty (one or more bytes is reading for reading) - 0: HSS receive FIFO is empty ## 7.10.2 HSS Baud Rate Register [0xC072] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|----------|-----|-----|------|-----|-----|-----|-----|--| | Field | Reserved | | | Baud | | | | | | | Read/Write | - | - | - | R/W | R/W | R/W | R/W | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | | | | B | aud | | | | | | Read/Write | R/W | | Default | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | | Figure 7-59. HSS Baud Rate Register ## **Register Description** The HSS Baud Rate Register will set the HSS Baud Rate. At reset, the default value is 0x0017 which will set the baud rate to 2.0 MHz. #### Baud (Bits [12:0]) The Baud field is the baud rate divisor minus one, in units of 1/48 MHz. Therefore the Baud Rate = 48 MHz/(Baud + 1). This puts a constraint on the Baud Value as follows: $(24 - 1) \le \text{Baud} \ge (5000 - 1)$ #### Reserved All reserved bits should be written as '0'. ## 7.10.3 HSS Transmit Gap Register [0xC074] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|------------|------------|-----|-----|-----| | Field | | | | Rese | erved | | | | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Transmit ( | Gap Select | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Figure 7-60. HSS Transmit Gap Register ## **Register Description** The HSS Transmit Gap Register is only valid in block transmit mode. It allows for a programmable number of stop bits to be inserted thus overwriting the One Stop Bit in the HSS Control Register. The default reset value of this register is 0x0009, equivalent to two stop bits. ## Transmit Gap Select (Bits [7:0]) The Transmit Gap Select field sets the inactive time between transmitted bytes. The inactive time = (Transmit Gap Select – 7) \* bit time. Therefore an Transmit Gap Select Value of 8 is equal to having one Stop bit. #### Reserved ## 7.10.4 HSS Data Register [0xC076] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|----------|-----|-----|-----|-----|-----|-----|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Da | ata | • | | | | | | | Read/Write | R/W | | | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | Figure 7-61. HSS Data Register ## **Register Description** The HSS Data Register contains data received on the HSS port (not for block receive mode) when read. This receive data is valid when the Receive Ready bit of the HSS Control Register is set to '1'. Writing to this register will initiate a single byte transfer of data. The Transmit Ready Flag in the HSS Control Register should read '1' before writing to this register (this avoids disrupting the previous/current transmission). #### Data (Bits [7:0]) The Data field contains the data received or to be transmitted on the HSS port. #### Reserved All reserved bits should be written as '0'. ## 7.10.5 HSS Receive Address Register [0xC078] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|------|-------|-----|-----|-----| | Field | | | | Addr | ess | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Ad | dress | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-62. HSS Receive Address Register ## **Register Description** The HSS Receive Address Register is used as the base pointer address for the next HSS block receive transfer. ## Address (Bits [15:0]) The Address field sets the base pointer address for the next HSS block receive transfer. ## 7.10.6 HSS Receive Counter Register [0xC07A] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|---------|-----|-------|-----|-----|-----| | Field | | | Counter | | | | | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Co | unter | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-63. HSS Receive Counter Register # **Register Description** The HSS Receive Counter Register designates the block byte length for the next HSS receive transfer. This register should be loaded with the word count minus one to start the block receive transfer. As each byte is received this register value is decremented. When read, this register indicates the remaining length of the transfer. #### Counter (Bits [9:0]) The Counter field value is equal to the word count minus one giving a maximum value of 0x03FF (1023) or 2048 bytes. When the transfer is complete this register returns 0x03FF until reloaded. #### Reserved All reserved bits should be written as '0'. ## 7.10.7 HSS Transmit Address Register [0xC07C] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|---------|-----|-----|-------|-----|-----|-----|--|--|--| | Field | | Address | | | | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Ad | dress | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-64. HSS Transmit Address Register ## **Register Description** The HSS Transmit Address Register is used as the base pointer address for the next HSS block transmit transfer. #### Address (Bits [15:0]) The Address field sets the base pointer address for the next HSS block transmit transfer. # 7.10.8 HSS Transmit Counter Register [0xC07E] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|---------|-------|-----|-----|-----| | Field | | | | Counter | | | | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Co | unter | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-65. HSS Transmit Counter Register Document #: 38-08015 Rev. \*E Page 79 of 119 #### **Register Description** The HSS Transmit Counter Register designates the block byte length for the next HSS transmit transfer. This register should be loaded with the word count minus one to start the block transmit transfer. As each byte is transmitted this register value is decremented. When read, this register indicates the remaining length of the transfer. #### Counter (Bits [9:0]) The Counter field value is equal to the word count minus one giving a maximum value of 0x03FF (1023) or 2048 bytes. When the transfer is complete this register returns 0x03FF until reloaded. #### Reserved All reserved bits should be written as '0'. ## 7.11 HPI Registers There are five registers dedicated to HPI operation. In addition, there is an HPI status port which can be address over HPI. Each of these registers is covered in this section and are summarized in *Figure 7-66*. | Register Name | Address | R/W | |----------------------------|---------|-----| | HPI Breakpoint Register | 0x0140 | R | | Interrupt Routing Register | 0x0142 | R | | SIE1msg Register | 0x0144 | W | | SIE2msg Register | 0x0148 | W | | HPI Mailbox Register | 0xC0C6 | R/W | Figure 7-66. HPI Registers ## 7.11.1 HPI Breakpoint Register [0x0140] [R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|----|---------|----|----|-------|----|---|---|--|--|--| | Field | | Address | | | | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Ad | dress | | | | | | | | Read/Write | R | R | R | R | R | R | R | R | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-67. HPI Breakpoint Register ## **Register Description** The HPI Breakpoint Register is a special on-chip memory location that the external processor can access using normal HPI memory read/write cycles. This register is read only by the CPU but is read/write by the HPI port. The contents of this register have the same effect as the Breakpoint Register [0xC014]. This special Breakpoint Register is used by software debuggers which interface through the HPI port instead of the serial port. When the program counter matches the Breakpoint Address, the INT127 interrupt will trigger. To clear this interrupt, a zero value should be written to this register. #### Address (Bits [15:0]) The Address field is a 16-bit field containing the breakpoint address. ### 7.11.2 Interrupt Routing Register [0x0142] [R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----------------------|---------------------|---------------------------|---------------------------|---------------------------|---------------------------|-------------------------|----------------------| | Field | VBUS to HPI<br>Enable | ID to HPI<br>Enable | SOF/EOP2 to<br>HPI Enable | SOF/EOP2 to<br>CPU Enable | SOF/EOP1 to<br>HPI Enable | SOF/EOP1 to<br>CPU Enable | Reset2 to HPI<br>Enable | HPI Swap 1<br>Enable | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|--------------------------|--------------------------|----------|---|------------------------|------------------------|-------------------------|----------------------| | Field | Resume2 to<br>HPI Enable | Resume1 to<br>HPI Enable | Reserved | | Done2 to HPI<br>Enable | Done1 to HPI<br>Enable | Reset1 to HPI<br>Enable | HPI Swap 0<br>Enable | | Read/Write | - | - | - | - | - | - | - | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-68. Interrupt Routing Register ## **Register Description** The Interrupt Routing Register allows the HPI port to take over some or all of the SIE interrupts that usually go to the on-chip CPU. This register is read only by the CPU but is read/write by the HPI port. By setting the appropriate bit to '1', the SIE interrupt is routed to the HPI port to become the HPI\_INTR signal and also readable in the HPI Status Register. The bits in this register select where the interrupts are routed. The individual interrupt enable is handled in the SIE interrupt enable register. ## VBUS to HPI Enable (Bit 15) The VBUS to HPI Enable bit routes the OTG VBUS interrupt to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### ID to HPI Enable (Bit 14) The ID to HPI Enable bit routes the OTG ID interrupt to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### SOF/EOP2 to HPI Enable (Bit 13) The SOF/EOP2 to HPI Enable bit routes the SOF/EOP2 interrupt to the HPI port. - 1: Route signal to HPI port - 0: Do not route signal to HPI port ## SOF/EOP2 to CPU Enable (Bit 12) The SOF/EOP2 to CPU Enable bit routes the SOF/EOP2 interrupt to the on-chip CPU. Since the SOF/EOP2 interrupt can be routed to both the on-chip CPU and the HPI port the firmware must ensure only one of the two (CPU, HPI) resets the interrupt. - 1: Route signal to CPU - 0: Do not route signal to CPU # SOF/EOP1 to HPI Enable (Bit 11) The SOF/EOP1 to HPI Enable bit routes the SOF/EOP1 interrupt to the HPI port. - 1: Route signal to HPI port - 0: Do not route signal to HPI port ## SOF/EOP1 to CPU Enable (Bit 10) The SOF/EOP1 to CPU Enable bit routes the SOF/EOP1 interrupt to the on-chip CPU. Since the SOF/EOP1 interrupt can be routed to both the on-chip CPU and the HPI port the firmware must ensure only one of the two (CPU, HPI) resets the interrupt. - 1: Route signal to CPU - 0: Do not route signal to CPU #### Reset2 to HPI Enable (Bit 9) The Reset2 to HPI Enable bit routes the USB Reset interrupt that occurs on Device 2 to the HPI port instead of the onchip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### HPI Swap 1 Enable (Bit 8) Both HPI Swap bits (bits 8 and 0) must be set to identical values. When set to '00', the most significant data byte goes to HPI\_D[15:8] and the least significant byte goes to HPI\_D[7:0]. This is the default setting. By setting to '11', the most significant data byte goes to HPI\_D[7:0] and the least significant byte goes to HPI\_D[15:8]. #### Resume2 to HPI Enable (Bit 7) The Resume2 to HPI Enable bit routes the USB Resume interrupt that occurs on Host 2 to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### Resume1 to HPI Enable (Bit 6) The Resume1 to HPI Enable bit routes the USB Resume interrupt that occurs on Host 1 to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### Done2 to HPI Enable (Bit 3) The Done2 to HPI Enable bit routes the Done interrupt for Host/Device 2 to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### Done1 to HPI Enable (Bit 2) The Done1 to HPI Enable bit routes the Done interrupt for Host/Device 1 to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port ## Reset1 to HPI Enable (Bit 1) The Reset1 to HPI Enable bit routes the USB Reset interrupt that occurs on Device 1 to the HPI port instead of the on-chip CPU. - 1: Route signal to HPI port - 0: Do not route signal to HPI port #### HPI Swap 0 Enable (Bit 0) Both HPI Swap bits (bits 8 and 0) must be set to identical values. When set to '00', the most significant data byte goes to HPI\_D[15:8] and the least significant byte goes to HPI\_D[7:0]. This is the default setting. By setting to '11', the most significant data byte goes to HPI\_D[7:0] and the least significant byte goes to HPI\_D[15:8]. #### 7.11.3 SIEXmsg Register [W] - SIE1msq Register 0x0144 - SIE2msg Register 0x0148 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|----|------|----|----|-----|----|---|---|--|--| | Field | | Data | | | | | | | | | | Read/Write | W | W | W | W | W | W | W | W | | | | Default | X | Х | Х | Х | X | Х | Х | Х | | | | | | • | | • | | • | • | • | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | | | | D | ata | | | | | | | Read/Write | W | W | W | W | W | W | W | W | | | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | Figure 7-69. SIEXmsg Register #### **Register Description** The SIEXmsg Register allows an interrupt to be generated on the HPI port. Any write to this register will cause the SIEXmsg flag in the HPI Status Port to go high and will also cause an interrupt on the HPI\_INTR pin. The SIEXmsg flag is automatically cleared when the HPI port reads from this register. #### Data (Bits [15:0]) The Data field[15:0] simply needs to have any value written to it to cause SIExmsg flag in the HPI Status Port to go high. ## 7.11.4 HPI Mailbox Register [0xC0C6] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |------------|-----|---------|-----|-----|-------|-----|-----|-----|--|--| | Field | | Message | | | | | | | | | | Read/Write | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Field | | | | Mes | ssage | | | | | | | Read/Write | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Figure 7-70. HPI Mailbox Register ## **Register Description** The HPI Mailbox Register provides a common mailbox between the CY7C67300 and the external host processor. If enabled, the HPI Mailbox RX Full interrupt will trigger when the external host processor writes to this register. When the CY7C67300 reads this register the HPI Mailbox RX Full interrupt will automatically get cleared. If enabled, the HPI Mailbox TX Empty interrupt will trigger when the external host processor reads from this register. The HPI Mailbox TX Empty interrupt will automatically clear when the CY7C67300 writes to this register. In addition, when the CY7C67300 writes to this register, the HPI\_INTR signal on the HPI port will assert signaling the external processor that there is data in the mailbox to read. The HPI\_INTR signal will de-assert when the external host processor reads from this register. #### Message (Bits [15:0]) The Message field contains the message that the host processor wrote to the HPI Mailbox Register. ## 7.11.5 HPI Status Port [] [HPI: R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----------------|-----------------|----------|------------------|---------------|------------------|----------------|---------------------| | Field | VBUS<br>Flag | ID<br>Flag | Reserved | SOF/EOP2<br>Flag | Reserved | SOF/EOP1<br>Flag | Reset2<br>Flag | Mailbox In<br>Flag | | Read/Write | R | R | - | R | - | R | R | R | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Resume2<br>Flag | Resume1<br>Flag | SIE2msg | SIE1msg | Done2<br>Flag | Done1<br>Flag | Reset1<br>Flag | Mailbox Out<br>Flag | | Read/Write | R | R | R | R | R | R | R | R | | Default | Х | Х | X | X | X | X | Х | Х | Figure 7-71. HPI Status Port #### **Register Description** The HPI Status Port provides the external host processor with the MailBox status bits plus several SIE status bits. This register is not accessible from the on-chip CPU. The additional SIE status bits are provided to aid external device driver firmware development, and are not recommended for applications that do not have an intimate relationship with the on-chip BIOS. Reading from the HPI Status Port does not result in a CPU HPI interface memory access cycle. The external host may continuously poll this register without degrading the CPU or DMA performance. #### VBUS Flag (Bit 15) The VBUS Flag bit is a read-only bit that indicates whether OTG VBus is greater then 4.4V. After turning on VBUS, firmware should wait at least 10 µs before this reading this bit. - 1: OTG VBus is greater then 4.4V - 0: OTG VBus is less then 4.4V #### ID Flag (Bit 14) The ID Flag bit is a read-only bit that indicates the state of the OTG ID pin. #### SOF/EOP2 Flag (Bit 12) The SOF/EOP2 Flag bit is a read-only bit that indicates if a SOF/EOP interrupt occurs on either Host/Device 2. - 1: Interrupt triggered - 0: Interrupt did not trigger ## SOF/EOP1 Flag (Bit 10) The SOF/EOP1 Flag bit is a read-only bit that indicates if a SOF/EOP interrupt occurs on either Host/Device 1. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Reset2 Flag (Bit 9) The Reset2 Flag bit is a read-only bit that indicates if a USB Reset interrupt occurs on either Host/Device 2. - 1: Interrupt triggered - 0: Interrupt did not trigger #### Mailbox In Flag (Bit 8) The Mailbox In Flag bit is a read-only bit that indicates if a message is ready in the incoming mailbox. This interrupt clears when on-chip CPU reads from the HPI Mailbox Register. - 1: Interrupt triggered - 0: Interrupt did not trigger #### Resume2 Flag (Bit 7) The Resume2 Flag bit is a read-only bit that indicates if a USB resume interrupt occurs on either Host/Device 2. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Resume1 Flag (Bit 6) The Resume1 Flag bit is a read-only bit that indicates if a USB resume interrupt occurs on either Host/Device 1. - 1: Interrupt triggered - 0: Interrupt did not trigger #### SIE2msg (Bit 5) The SIE2msg Flag bit is a read only bit that indicates if the CY7C67300 CPU has written to the SIE2msg register. This bit will clear on an HPI read. - 1: The SIE2msg register has been written by the CY7C67300 CPU - 0: The SIE2msg register has not been written by the CY7C67300 CPU ## SIE1msg (Bit 4) The SIE1msg Flag bit is a read only bit that indicates if the CY7C67300 CPU has written to the SIE1msg register. This bit will clear on an HPI read. - 1: The SIE1msg register has been written by the CY7C67300 CPU - 0: The SIE1msg register has not been written by the CY7C67300 CPU ### Done2 Flag (Bit 3) In host mode the Done2 Flag bit is a read-only bit that indicates if a host packet done interrupt occurs on Host 2. In device mode this read-only bit indicates if an any of the endpoint interrupts occurs on Device 2. Firmware will need to determine which endpoint interrupt occurred. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Done1 Flag (Bit 2) In host mode the Done 1 Flag bit is a read-only bit that indicates if a host packet done interrupt occurs on Host 1. In device mode this read-only bit indicates if an any of the endpoint interrupts occurs on Device 1. Firmware will need to determine which endpoint interrupt occurred. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Reset1 Flag (Bit 1) The Reset1 Flag bit is a read-only bit that indicates if a USB Reset interrupt occurs on either Host/Device 1. - 1: Interrupt triggered - 0: Interrupt did not trigger ## Mailbox Out Flag (Bit 0) The Mailbox Out Flag bit is a read-only bit that indicates if a message is ready in the outgoing mailbox. This interrupt clears when the external host reads from the HPI Mailbox Register. - 1: Interrupt triggered - 0: Interrupt did not trigger ## 7.12 SPI Registers There are twelve registers dedicated to SPI operation. Each of these registers is covered in this section and summarized in *Figure 7-72*. | Register Name | Address | R/W | |-------------------------------|---------|-----| | SPI Configuration Register | 0xC0C8 | R/W | | SPI Control Register | 0xC0CA | R/W | | SPI Interrupt Enable Register | 0xC0CC | R/W | | SPI Status Register | 0xC0CE | R | | SPI Interrupt Clear Register | 0xC0D0 | W | | SPI CRC Control Register | 0xC0D2 | R/W | | SPI CRC Value | 0xC0D4 | R/W | | SPI Data Register | 0xC0D6 | R/W | | SPI Transmit Address Register | 0xC0D8 | R/W | | SPI Transmit Count Register | 0xC0DA | R/W | | SPI Receive Address Register | 0xC0DC | R/W | | SPI Receive Count Register | 0xC0DE | R/W | Figure 7-72. SPI Registers ## 7.12.1 SPI Configuration Register [0xC0C8] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------------------------|------------------|------------------------|-----------------|-----|-----|-----|----------| | Field | 3Wire<br>Enable | Phase<br>Select | SCK Polarity<br>Select | Scale Select | | | | Reserved | | Read/Write | R/W - | | Default | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | Master<br>Active<br>Enable | Master<br>Enable | SS<br>Enable | SS Delay Select | | | | | | Read/Write | R | R/W | Default | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | Figure 7-73. SPI Configuration Register ## **Register Description** The SPI Configuration Register controls the SPI port. Fields apply to both master and slave mode unless otherwise noted. ## 3Wire Enable (Bit 15) The 3Wire Enable bit indicates if the MISO and MOSI data lines are tied together allowing only half duplex operation. - 1: MISO and MOSI data lines are tied together - **0:** Normal MISO and MOSI Full Duplex operation (not tied together) #### Phase Select (Bit 14) The Phase Select bit selects advanced or delayed SCK phase. This field only applies to master mode. - 1: Advanced SCK phase - 0: Delayed SCK phase ## SCK Polarity Select (Bit 13) This SCK Polarity Select bit selects the polarity of SCK. - 1: Positive SCK polarity - 0: Negative SCK polarity ## Scale Select (Bits [12:9]) The Scale Select field provides control over the SCK frequency, based on 48 MHz. Refer to *Table 7-13* for a definition of this field. This field only applies to master mode. Table 7-13. Scale Select Field Definition for SCK Frequency | Scale Select [12:9] | SCK Frequency | |---------------------|---------------| | 0000 | 12 MHz | | 0001 | 8 MHz | | 0010 | 6 MHz | | 0011 | 4 MHz | | 0100 | 3 MHz | | 0101 | 2 MHz | | 0110 | 1.5 MHz | | 0111 | 1 MHz | | 1000 | 750 KHz | | 1001 | 500 KHz | | 1010 | 375 KHz | | 1011 | 250 KHz | | 1100 | 375 KHz | Document #: 38-08015 Rev. \*E Table 7-13. Scale Select Field Definition for SCK Frequency (continued) | Scale Select [12:9] | SCK Frequency | |---------------------|---------------| | 1101 | 250 KHz | | 1110 | 375 KHz | | 1111 | 250 KHz | #### Master Active Enable (Bit 7) The Master Active Enable bit is a read only bit that indicates if the master state machine is active or idle. This field only applies to master mode. - 1: Master state machine is active - 0: Master state machine is idle ## Master Enable (Bit 6) The Master Enable bit sets the SPI interface to master or slave. This bit is only writable when the Master Active Enable bit reads '0', otherwise value will not change. - 1: Master SPI interface - 0: Slave SPI interface #### SS Enable (Bit 5) The SS Enable bit enables or disables the master SS output. - 1: Enable master SS output - 0: Disable master SS output (three-state master SS output, for single SS line in slave mode) ## SS Delay Select (Bits [4:0]) When the SS Delay Select field is set to '00000' this indicates manual mode. In manual mode SS is controlled by SS Manual bit of the SPI Control Register. When the SS Delay Select field is set between '00001' to '11111', this value indicates the count in half bit times of auto transfer delay for: SS low to SCK active, SCK inactive to SShigh, SS high time. This field only applies to master mode. #### 7.12.2 SPI Control Register [0xC0CA] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------------|--------------|--------------|-------------|--------------|----------------|-------------------|--------------------------| | Field | SCK<br>Strobe | FIFO<br>Init | Byte<br>Mode | Full Duplex | SS<br>Manual | Read<br>Enable | Transmit<br>Ready | Receive<br>Data<br>Ready | | Read/Write | W | W | R/W | R/W | R/W | R/W | R | R | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-------------------|-----------------|-----|----------------------------------------|-----|-----|-----|-----| | Field | Transmit<br>Empty | Receive<br>Full | Tr | Transmit Bit Length Receive Bit Length | | | | th | | Read/Write | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | Default | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-74. SPI Control Register #### **Register Description** The SPI Control Register controls the SPI port. Fields apply to both master and slave mode unless otherwise noted. #### SCK Strobe (Bit 15) The SCK Strobe bit starts the SCK strobe at the selected frequency and polarity (set in the SPI Configuration Register), but not phase. This bit feature can only be enabled when in master mode and must be during a period of inactivity. This bit is self clearing. - 1: SCK Strobe Enable - 0: No Function ### FIFO Init (Bit 14) The FIFO Init bit will initialize the FIFO and clear the FIFO Error Status bit. This bit is self clearing. - 1: FIFO Init Enable - 0: No Function ## Byte Mode (Bit 13) The Byte Mode bit selects between PIO (byte mode) and DMA (block mode) operation. - 1: Set PIO (byte mode) operation - 0: Set DMA (block mode) operation #### Full Duplex (Bit 12) The Full Duplex bit selects between full duplex and half duplex operation. - 1: Enable full duplex. Full duplex is not allowed and will not set if the 3Wire Enable bit of the SPI Configuration Register is set to '1' - 0: Enable half duplex operation ## SS Manual (Bit 11) The SS Manual bit activates or deactivates SS if the SS Delay Select field of the SPI Control Register is all zeros and is configured as master interface. This field only applies to master mode. - 1: Activate SS, master drives SS line asserted LOW - 0: De-activate SS, master drives SS line deasserted HIGH #### Read Enable (Bit 10) The Read Enable bit will initiate a read phase for a master mode transfer or set the slave to receive (in slave mode). - 1: Initiates a read phase for a master transfer or sets a slave to receive. In master mode this bit is sticky and remains set until the read transfer begins. - 0: Initiates the write phase for slave operation #### Transmit Ready (Bit 9) The Transmit Ready bit is a read-only bit that indicates if the transmit port is ready to empty and ready to be written. - 1: Ready for data to be written to the port. The transmit FIFO is not full. - 0: Not ready for data to be written to the port ## Receive Data Ready (Bit 8) The Receive Data Ready bit is a read only bit that indicates if the receive port has data ready. - 1: Receive port has data ready to read - 0: Receive port does not have data ready ## Transmit Empty (Bit 7) The Transmit Empty bit is a read-only bit that indicates if the transmit FIFO is empty. - 1: Transmit FIFO is empty - 0: Transmit FIFO is not empty #### Receive Full (Bit 6) The Receive Full bit is a read only bit that indicates if the receive FIFO is full. - 1: Receive FIFO is full - 0: Receive FIFO is not full # Transmit Bit Length (Bits [5:3]) The Transmit Bit Length field controls whether a full byte or partial byte is to be transmitted. If Transmit Bit Length is '000' then a full byte will be transmitted. If Transmit Bit Length is '001' to '111', then the value indicates the number of bits that will be transmitted. ## Receive Bit Length (Bits [2:0]) The Receive Bit Length field controls whether a full byte or partial byte will be received. If Receive Bit Length is '000' then a full byte will be received. If Receive Bit Length is '001' to '111', then the value indicates the number of bits that will be received. ## 7.12.3 SPI Interrupt Enable Register [0xC0CC] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |------------|----|----------|----------|----|----|--------------------------------|---------------------------------|---------------------------------|--|--|--|--| | Field | | Reserved | | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Field | | | Reserved | | | Receive<br>Interrupt<br>Enable | Transmit<br>Interrupt<br>Enable | Transfer<br>Interrupt<br>Enable | | | | | | Read/Write | - | - | - | - | - | R/W | R/W | R/W | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Figure 7-75. SPI Interrupt Enable Register ## **Register Description** The SPI Interrupt Enable Register controls the SPI port. ## Receive Interrupt Enable (Bit 2) The Receive Interrupt Enable bit will enable or disable the byte mode receive interrupt (RxIntVal). - 1: Enable byte mode receive interrupt - 0: Disable byte mode receive interrupt ## Transmit Interrupt Enable (Bit 1) The Transmit Interrupt Enable bit will enable or disable the byte mode transmit interrupt (TxIntVal). - 1: Enables byte mode transmit interrupt - 0: Disables byte mode transmit interrupt # Transfer Interrupt Enable (Bit 0) The Transfer Interrupt Enable bit will enable or disable the block mode interrupt (XfrBlkIntVal). - 1: Enables block mode interrupt - 0: Disables block mode interrupt ## Reserved All reserved bits should be written as '0'. ## 7.12.4 SPI Status Register [0xC0CE] [R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|--------------------|----------|------|-------|----|------------------------------|-------------------------------|-------------------------------|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | FIFO Error<br>Flag | | Rese | erved | | Receive<br>Interrupt<br>Flag | Transmit<br>Interrupt<br>Flag | Transfer<br>Interrupt<br>Flag | | | | | Read/Write | R | - | - | - | - | R | R | R | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-76. SPI Status Register ## **Register Description** The SPI Status Register is a read-only register that provides status for the SPI port. ## FIFO Error Flag (Bit 7) The FIFO Error Flag bit is a read-only bit that indicates if a FIFO error occurred. When this bit is set to '1' and the Transmit Empty bit of the SPI Control Register is set to '1', then a Tx FIFO underflow has occurred. Similarly, when set with the Receive Full bit of the SPI Control Register, an Rx FIFO overflow has occurred. This bit automatically clears when the SPI FIFO Init Enable bit of the SPI Control register is set. - 1: Indicates FIFO error - 0: Indicates no FIFO error #### Receive Interrupt Flag (Bit 2) The Receive Interrupt Flag is a read-only bit that indicates if a byte mode receive interrupt has triggered. - 1: Indicates a byte mode receive interrupt has triggered - 0: Indicates a byte mode receive interrupt has not triggered ## **Transmit Interrupt Flag** (Bit 1) The Transmit Interrupt Flag is a read-only bit that indicates a byte mode transmit interrupt has triggered. - 1: Indicates a byte mode transmit interrupt has triggered - 0: Indicates a byte mode transmit interrupt has not triggered ## Transfer Interrupt Flag (Bit 0) The Transfer Interrupt Flag is a read-only bit that indicates a block mode interrupt has triggered. - 1: Indicates a block mode interrupt has triggered - 0: Indicates a block mode interrupt has not triggered ## 7.12.5 SPI Interrupt Clear Register [0xC0D0] [W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|----|----------|------|-------|----|----|--------------------------------|--------------------------------|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | Rese | erved | | | Transmit<br>Interrupt<br>Clear | Transfer<br>Interrupt<br>Clear | | | | | Read/Write | - | - | - | - | - | - | W | W | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-77. SPI Interrupt Clear Register #### **Register Description** The SPI Interrupt Clear Register is a write-only register that allows the SPI Transmit and SPI Transfer Interrupts to be cleared. ## Transmit Interrupt Clear (Bit 1) The Transmit Interrupt Clear bit is a write-only bit that will clear the byte mode transmit interrupt. This bit is self-clearing. - 1: Clear the byte mode transmit interrupt - 0: No function ## Transfer Interrupt Clear (Bit 0) The Transfer Interrupt Clear bit is a write-only bit that will clear the block mode interrupt. This bit is self-clearing. - 1: Clear the block mode interrupt - 0: No function #### Reserved ## 7.12.6 SPI CRC Control Register [0xC0D2] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|----------|-----|---------------|--------------|----------------|---------------|----------------|----------| | Field | CRC Mode | | CRC<br>Enable | CRC<br>Clear | Receive<br>CRC | One in<br>CRC | Zero in<br>CRC | Reserved | | Read/Write | R/W | R/W | R/W | R/W | R/W | R | R | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Res | served | | | | | Read/Write | - | | | | | | | - | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-78. SPI CRC Control Register ## **Register Description** The SPI CRC Control Register provides control over the CRC source and polynomial value. CRC Mode (Bits [15:14) The CRCMode field selects the CRC polynomial as defined in Table 7-14. ## Table 7-14. CRC Mode Definition | CRCMode [9:8] | CRC Polynomial | |---------------|---------------------------------------------------| | 00 | MMC 16-bit: X^16 + X^12 + X^5 + 1(CCITT Standard) | | 01 | CRC7 7-bit: X^7+ X^3 + 1 | | 10 | MST 16-bit: X^16+ X^15 + X^2 + 1 | | 11 | Reserved, 16-bit polynomial 1. | ## CRC Enable (Bit 13) The CRC Enable bit will enable or disable the CRC operation. - 1: Enables CRC operation - 0: Disables CRC operation ## CRC Clear (Bit 12) The CRC Clear bit will clear the CRC with a load of all ones. This bit is self clearing and always reads '0'. - 1: Clear CRC with all ones - 0: No Function ## Receive CRC (Bit 11) The Receive CRC bit determines whether the receive bit stream or the transmit bit stream is used for the CRC data input in full duplex mode. This bit is a don't care in half duplex mode. - 1: Assigns the receive bit stream - 0: Assigns the transmit bit stream #### One in CRC (Bit 10) The One in CRC bit is a read-only bit that indicates if the CRC value is all zeros or not - 1: CRC value is not all zeros - 0: CRC value is all zeros ## Zero in CRC (Bit 9) The Zero in CRC bit is a read-only bit that indicates if the CRC value is all ones or not - 1: CRC value is not all ones - 0: CRC value is all ones ## Reserved ## 7.12.7 SPI CRC Value Register [0xC0D4] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|--| | Field | | CRC | | | | | | | | | | | Read/Write | R/W | | | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | C | RC | | | | | | | | Read/Write | R/W | | | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | Figure 7-79. SPI CRC Value Register ## **Register Description** The SPI CRC Value Register contains the CRC value. ## CRC (Bits [15:0]) The CRC field contains the SPI CRC. In CRC Mode CRC7, the CRC value will be a seven bit value [6:0]. Therefore bits [15:7] are invalid in CRC7 mode. ## 7.12.8 SPI Data Register [0xC0D6] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|----------|-----|-----|-----|-----|-----|-----|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | | | | | | | | | | | | Default | Х | Х | Х | X | X | Х | Х | Х | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Da | ata | | | | | | | | Read/Write | R/W | | | | Default | Х | Х | Х | Х | Х | Х | Х | Х | | | | Figure 7-80. SPI Data Register ## **Register Description** The SPI Data Register contains data received on the SPI port when read. Reading it empties the eight byte receive FIFO in PIO byte mode. This receive data is valid when the receive bit of the SPI Interrupt Value is set to '1' (RxIntVal triggers) or the Receive Data Ready bit of the SPI Control Register is set to '1'. Writing to this register in PIO byte mode will initiate a transfer of data, the number of bits defined by Transmit Bit Length field in the SPI Control Register. # Data (Bits [7:0]) The Data field contains data received or to be transmitted on the SPI port. #### Reserved ## 7.12.9 SPI Transmit Address Register [0xC0D8] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|------------------------|-----|-----|-------|-----|-----|-----|--|--|--| | Field | | Address | | | | | | | | | | | Read/Write | R/W | /W R/W R/W R/W R/W R/W | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Ad | dress | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-81. SPI Transmit Address Register # **Register Description** The SPI Transmit Address Register is used as the base address for the SPI transmit DMA. ## Address (Bits [15:0]) The Address field sets the base address for the SPI transmit DMA. ## 7.12.10 SPI Transmit Count Register [0xC0DA] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|----------|-------|------|-----|-----|-----| | Field | | | Reserved | Count | | | | | | Read/Write | - | - | - | - | - | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-82. SPI Transmit Count Register ## **Register Description** The SPI Transmit Count Register designates the block byte length for the SPI transmit DMA transfer. ## Count (Bits [10:0]) The Count field sets the count for the SPI transmit DMA transfer. ## Reserved All reserved bits should be written as '0'. # 7.12.11 SPI Receive Address Register [0xC0DC [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|---------------------------|-----|-----|-------|-----|-----|-----|--|--|--| | Field | | Address | | | | | | | | | | | Read/Write | R/W | W R/W R/W R/W R/W R/W R/W | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Ad | dress | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-83. SPI Receive Address Register Document #: 38-08015 Rev. \*E Page 93 of 119 ## **Register Description** The SPI Receive Address Register is issued as the base address for the SPI Receive DMA. ## Address (Bits [15:0]) The Address field sets the base address for the SPI receive DMA. ## 7.12.12 SPI Receive Count Register [0xC0DE] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|----------|-------|------|-----|-----|-----| | Field | | | Reserved | Count | | | | | | Read/Write | - | - | - | - | - | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-84. SPI Receive Count Register ## **Register Description** The SPI Receive Count Register designates the block byte length for the SPI receive DMA transfer. ## Count (Bits [10:0]) The Count field sets the count for the SPI receive DMA transfer. #### Reserved All reserved bits should be written as '0'. ## 7.13 UART Registers There are three registers dedicated to UART operation. Each of these registers is covered in this section and summarized in *Figure 7-85*. | Register Name | Address | R/W | |-----------------------|---------|-----| | UART Control Register | 0xC0E0 | R/W | | UART Status Register | 0xC0E2 | R | | UART Data Register | 0xC0E4 | R/W | Figure 7-85. UART Registers ## 7.13.1 UART Control Register [0xC0E0] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |------------|----|----------|----|--------------|-------------|-----|-----|-------------|--| | Field | | Reserved | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Field | | Reserved | | Scale Select | Baud Select | | | UART Enable | | | Read/Write | - | - | - | R/W | R/W | R/W | R/W | R/W | | | Default | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | Figure 7-86. UART Control Register ## **Register Description** The UART Control Register enables or disables the UART allowing GPIO28 (UART\_TXD) and GPIO27 (UART\_RXD) to be freed up for general use. This register must also be written to set the baud rate which is based on a 48-MHz clock. #### Scale Select (Bit 4) The Scale Select bit acts as a prescaler that will divide the baud rate by eight. - 1: Enable prescaler - 0: Disable prescaler ## Baud Select (Bits [3:1]) Please refer to Table 7-15 for a definition of this field. Table 7-15. UART Baud Select Definition | Baud Select [3:1] | Baud Rate w/ DIV8 = 0 | Baud Rate w/ DIV8 = 1 | |-------------------|-----------------------|-----------------------| | 000 | 115.2 KBaud | 14.4 KBaud | | 001 | 57.6 KBaud | 7.2 KBaud | | 010 | 38.4 KBaud | 4.8 KBaud | | 011 | 28.8 KBaud | 3.6 KBaud | | 100 | 19.2 KBaud | 2.4 KBaud | | 101 | 14.4 KBaud | 1.8 KBaud | | 110 | 9.6 KBaud | 1.2 KBaud | | 111 | 7.2 KBaud | 0.9 KBaud | #### **UART Enable** (Bit 0) The UART Enable bit enables or disables the UART. - 1: Enable UART - 0: Disable UART. This allows GPIO28 and GPIO27 to be used for general use. #### Reserved All reserved bits should bit written as '0'. ## 7.13.2 UART Status Register [0xC0E2] [R] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|----|----------|-----|-------|----|----|--------------|---------------|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | Res | erved | | | Receive Full | Transmit Full | | | | | Read/Write | - | - | - | - | - | - | R | R | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-87. UART Status Register ## **Register Description** The UART Status Register is a read-only register that indicates the status of the UART buffer. ## Receive Full (Bit 1) The Receive Full bit indicates whether the receive buffer is full. It can be programmed to interrupt the CPU as interrupt #5 when the buffer is full. This can be done though the UART bit of the Interrupt Enable Register (0xC00E). This bit will automatically get cleared when data is read from the UART Data Register. - 1: Receive buffer full - 0: Receive buffer empty ## Transmit Full (Bit 0) The Transmit Full bit indicates whether the transmit buffer is full or not. It can be programmed to interrupt the CPU as interrupt #4 when the buffer is empty. This can be done though the UART bit of the Interrupt Enable Register (0xC00E). This bit will automatically be set to '1' after data is written by EZ-Host to the UART Data Register (to be transmitted). This bit will automatically be cleared to '0' after the data is transmitted. - 1: Transmit buffer full (transmit busy) - 0: Transmit buffer is empty and ready for a new byte of data ## 7.13.3 UART Data Register [0xC0E4] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |------------|-----|----------|-----|-----|-----|-----|-----|-----|--|--|--| | Field | | Reserved | | | | | | | | | | | Read/Write | - | - | - | - | - | - | - | - | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Field | | | | Da | ata | | | | | | | | Read/Write | R/W | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Figure 7-88. UART Data Register ## **Register Description** The UART Data Register contains data to be transmitted or received from the UART port. Data written to this register will start a data transmission and also causes the UART Transmit Full Flag of the UART Status Register to set. When data received on the UART port is read from this register, the UART Receive Full Flag of the UART Status Register will get cleared. # Data (Bits [7:0]) The Data field is where the UART data to be transmitted or received is located #### Reserved All reserved bits should be written as '0'. ## 7.14 PWM Registers There are eleven registers dedicated to PWM operation. Each of these registers are covered in this section and summarized in *Figure 7-89*. | Register Name | Address | R/W | |----------------------------|---------|-----| | PWM Control Register | 0xC0E6 | R/W | | PWM Maximum Count Register | 0xC0E8 | R/W | | PWM0 Start Register | 0xC0EA | R/W | | PWM0 Stop Register | 0xC0EC | R/W | | PWM1 Start Register | 0xC0EE | R/W | | PWM1 Stop Register | 0xC0F0 | R/W | | PWM2 Start Register | 0xC0F2 | R/W | | PWM2 Stop Register | 0xC0F4 | R/W | | PWM3 Start Register | 0xC0F6 | R/W | | PWM3 Stop Register | 0xC0F8 | R/W | | PWM Cycle Count Register | 0xC0FA | R/W | | | | | Figure 7-89. PWM Registers Document #: 38-08015 Rev. \*E Page 96 of 119 ## 7.14.1 PWM Control Register [0xC0E6] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|---------------|----|----------|----|-----|--------------------|-----|-----| | Field | PWM<br>Enable | | Reserved | | | Prescale<br>Select | | | | Read/Write | R/W | - | - | - | R/W | R/W | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------|-----------------|-----------------|-----------------| | Field | PWM 3<br>Polarity<br>Select | PWM 2<br>Polarity<br>Select | PWM 1<br>Polarity<br>Select | PWM 0<br>Polarity<br>Select | PWM 3<br>Enable | PWM 2<br>Enable | PWM 1<br>Enable | PWM 0<br>Enable | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-90. PWM Control Register ## **Register Description** The PWM Control Register provides high-level control over all four of the PWM channels. ## PWM Enable (Bit 15) The PWM Enable bit starts and stops PWM operation. - 1: Start operation - 0: Stop operation ## Prescale Select (Bits [11:9]) The Prescale Select field sets the frequency of all the PWM channels as defined in Table 7-16. **Table 7-16. Prescaler Select Definition** | Prescale Select [11:9] | Frequency | |------------------------|-----------| | 000 | 48.00 MHz | | 001 | 24.00 MHz | | 010 | 06.00 MHz | | 011 | 01.50 MHz | | 100 | 375 kHz | | 101 | 93.80 kHz | | 110 | 23.40 kHz | | 111 | 05.90 kHz | #### Mode Select (Bit 8) The Mode Select bit selects between continuous PWM cycling and one shot mode. The default is continuous repeat. - 1: Enable One Shot mode. The mode runs the number of counter cycles set in the PWM Cycle Count Register and then stops. - 0: Enable Continuous mode. Runs in continuous mode and starts over once the PWM cycle count is reached. ## PWM 3 Polarity Select (Bit 7) The PWM 3 Polarity Select bit selects the polarity for PWM 3. - 1: Sets the polarity to active HIGH or rising edge pulse - 0: Sets the polarity to active LOW # PWM 2 Polarity Select (Bit 6) The PWM 2 Polarity Select bit selects the polarity for PWM 2. - 1: Sets the polarity to active HIGH or rising edge pulse - 0: Sets the polarity to active LOW ## PWM 1 Polarity Select (Bit 5) The PWM 1 Polarity Select bit selects the polarity for PWM 1. - 1: Sets the polarity to active HIGH or rising edge pulse - 0: Sets the polarity to active LOW ## PWM 0 Polarity Select (Bit 4) The PWM 0 Polarity Select bit selects the polarity for PWM 0. - 1: Sets the polarity to active HIGH or rising edge pulse - 0: Sets the polarity to active LOW ## PWM 3 Enable (Bit 3) The PWM 3 Enable bit enables or disables PWM 3. - 1: Enable PWM 3 - 0: Disable PWM 3 ### PWM 2 Enable (Bit 2) The PWM 2 Enable bit enables or disables PWM 2. - 1: Enable PWM 2 - 0: Disable PWM 2 ## PWM 1 Enable (Bit 1) The PWM 1 Enable bit enables or disables PWM 1. - 1: Enable PWM 1 - 0: Disable PWM 1 ## PWM 0 Enable (Bit 0) The PWM 0 Enable bit enables or disables PWM 0. - 1: Enable PWM 0 - 0: Disable PWM 0 # 7.14.2 PWM Maximum Count Register [0xC0E8] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|-----|-------|------|-----|-----|-----| | Field | | | Cou | Count | | | | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-91. PWM Maximum Count Register ## **Register Description** The PWM Maximum Count Register designates the maximum window for each pulse cycle. Each count tick is based on the clock frequency set in the PWM Control Register. ## Count (Bits [9:0]) The Count field sets the maximum cycle time. ## Reserved #### 7.14.3 PWM n Start Register [R/W] - PWM 0 Start Register 0xC0EA - PWM 1 Start Register 0xC0EE - PWM 2 Start Register 0xC0F2 - PWM 3 Start Register 0xC0F6 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-----|------|---------|-------|-----|-----|-----| | Field | | | Addr | Address | | | | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Ad | dress | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-92. PWM n Start Register #### **Register Description** The PWM n Start Register designates where in the window defined by the PWM Maximum Count Register to start the PWM pulse for a given channel. ## Address (Bits [9:0]) The Address field designates when to start the PWM pulse. If this start value is equal to the Stop Count Value then the output stays at false. #### Reserved All reserved bits should be written as '0'. ## 7.14.4 PWM n Stop Register [R/W] - PWM 0 Stop Register 0xC0EC - PWM 1 Stop Register 0xC0F0 - PWM 2 Stop Register 0xC0F4 - PWM 3 Stop Register 0xC0F8 | I WIVI 3 SIG | p register ox | 501 0 | | | | | | | |--------------|---------------|-------|-----|---------|-------|-----|-----|-----| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Field | | | | Address | | | | | | Read/Write | - | - | - | - | - | - | R/W | R/W | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | Ad | dress | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-93. PWM n Stop Register ## **Register Description** The PWM n Stop Register designates where in the window defined by the PWM Maximum Count Register to stop the PWM pulse for a given channel. #### Address (Bits [9:0]) The Address field designates when to stop the PWM pulse. If the PWM Start value is equal to the PWM Stop value then the output stays at '0'. If the PWM Stop value is greater then the PWM Maximum Count value then the output stays at true. ## Reserved # 7.14.5 PWM Cycle Count Register [0xC0FA] [R/W] | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |------------|-----|-------|-----|-----|------|-----|-----|-----| | Field | | Count | | | | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | • | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Field | | | | C | ount | | | | | Read/Write | R/W | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 7-94. PWM Cycle Count Register ## **Register Description** The PWM Cycle Count Register designates the number of cycles to run when in one shot mode. One shot mode is enabled by setting the Mode Select bit of the PWM Control Register to '1'. ## Count (Bits [9:0]) The Count field designates the number of cycles (plus one) to run when in one shot mode. For example, Cycles = PWM Cycle Count + 1, therefore for 2 cycles set PWM Cycle Count = 1. # 8.0 Pin Diagram # 9.0 Pin Descriptions Table 9-1. Pin Descriptions | Pin | Name | Type | Description | |-----|----------|------|--------------------------------------------------------------------------------| | 67 | D15/CTS | I/O | D15: External Memory Data Bus<br>CTS: HSS CTS | | 68 | D14/RTS | I/O | D14: External Memory Data Bus<br>RTS: HSS RTS | | 69 | D13/RXD | I/O | D13: External Memory Data Bus RXD: HSS RXD (Data is received on this pin) | | 70 | D12/TXD | I/O | D12: External Memory Data Bus TXD: HSS TXD (Data is transmitted from this pin) | | 71 | D11/MOSI | I/O | D11: External Memory Data Bus MOSI: SPI MOSI | Table 9-1. Pin Descriptions (continued) | Pin | Name | Type | Description | |-----|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 72 | D10/SCK | I/O | D10: External Memory Data Bus<br>SCK: SPI SCK | | 73 | D9/nSSI | I/O | D9: External Memory Data Bus nSSI: SPI nSSI | | 74 | D8/MISO | I/O | D8: External Memory Data Bus<br>MISO: SPI MISO | | 76 | D7 | I/O | External Memory Data Bus | | 77 | D6 | I/O | | | 78 | D5 | I/O | | | 79 | D4 | I/O | | | 80 | D3 | I/O | | | 81 | D2 | I/O | | | 82 | D1 | I/O | | | 83 | D0 | I/O | | | 33 | A14 | Output | External Memory Address Bus | | 32 | A13 | Output | | | 31 | A12 | Output | | | 30 | A11 | Output | | | 27 | A10 | Output | | | 25 | A9 | Output | | | 24 | A8 | Output | | | 20 | A7 | Output | | | 17 | A6 | Output | | | 8 | A5 | Output | | | 7 | A4 | Output | | | 3 | A3 | Output | | | 2 | A2 | Output | | | 1 | A1 | Output | | | 99 | nBEL/A0 | Output | nBEL: Low Byte Enable for 16-bit Memories A0: External Memory Address bit A0 for 0-8 bit memories | | 98 | nBEH | Output | High Byte Enable for 16-bit memories | | 64 | nWR | Output | External Memory Write pulse | | 62 | nRD | Output | External Memory Read pulse | | 97 | A16 | Output | A16: External SRAM A16 | | 95 | A17 | Output | A17: External SRAM A17 | | 96 | A18 | Output | A18: External SRAM A18 | | 34 | nMEMSEL | Output | External Memory Select 0 | | 35 | nROMSEL | Output | External Memory Select 1 | | 36 | nRAMSEL | Output | External Memory Select 2 | | 38 | A15/CLKSEL | 1/0 | A15: External SRAM A15 CLKSEL: Sampled directly after reset to determine what crystal or clock source frequency is being used. 12MHz is required for normal operation so the CLKSEL pin <b>must</b> have a 47 kohm Pull-up to V <sub>CC</sub> . After reset this pin will function as A15. | | 39 | GPIO31/SCK | I/O | GPIO31: General Purpose I/O<br>SCK: I2C EEPROM SCK | | 40 | GPIO30/SDA | I/O | GPIO30: General Purpose I/O<br>SDA: I2C EEPROM SDA | Table 9-1. Pin Descriptions (continued) | Pin | Name | Type | Description | | |-----|---------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 41 | GPIO29/OTGID | I/O | GPIO29: General Purpose I/O OTGID: Input for OTG ID pin. When used as OTGID, this pin should be tied high through an external pull-up resistor. Assuming VCC=3.0V a 10K to 40K resistor should be used. | | | 42 | GPIO28/TX | I/O | GPIO28: General Purpose I/O TX: UART TX (Data is transmitted from this pin) | | | 43 | GPIO27/RX | I/O | GPIO27: General Purpose I/O RX: UART RX (Data is received on this pin) | | | 44 | GPIO26/CTS/PWM3 | I/O | GPIO26: General Purpose I/O CTS: HSS CTS PWM3: PWM channel 3 | | | 45 | GPIO25/IRQ1 | I/O | GPIO25: General Purpose I/O IRQ1: Interrupt Request 1. See Register 0xC006. This pin is also one of two possible GPIO wakeup sources. | | | 46 | GPIO24/INT/<br>IORDY/IRQ0 | I/O | GPIO24: General Purpose I/O INT: HPI INT IORDY: IDE IORDY IRQ0: Interrupt Request 0. See Register 0xC006. This pin is also one of two possible GPIO wakeup sources. | | | 47 | GPIO23/nRD/IOR | I/O | GPIO23: General Purpose I/O nRD: HPI nRD IOR: IDE IOR | | | 48 | GPIO22/nWR/IOW | I/O | GPIO22: General Purpose I/O nWR: HPI nWR IOW: IDE IOW | | | 49 | GPIO21/nCS | I/O | GPIO21: General Purpose I/O nCS: HPI nCS | | | 50 | GPIO20/A1/CS1 | I/O | GPIO20: General Purpose I/O A1: HPI A1 CS1: IDE CS1 | | | 52 | GPIO19/A0/CS0 | I/O | GPIO19: General Purpose I/O A0: HPI A0 CS0: IDE CS0 | | | 53 | GPIO18/A2/RTS/<br>PWM2 | I/O | GPIO18: General Purpose I/O A2: IDE A2 RTS: HSS RTS PWM2: PWM channel 2 | | | 54 | GPIO17/A1/RXD/<br>PWM1 | I/O | GPIO17: General Purpose I/O A1: IDE A1 RXD: HSS RXD (Data is received on this pin) PWM1: PWM channel 1 | | | 55 | GPIO16/A0/TXD/<br>PWM0 | I/O | GPIO16: General Purpose I/O A0: IDE A0 TXD: HSS TXD (Data is transmitted from this pin) PWM0: PWM channel 0 | | | 56 | GPIO15/D15/nSSI | I/O | GPIO15: General Purpose I/O D15: D15 for HPI or IDE nSSI: SPI nSSI | | | 57 | GPIO14/D14 | I/O | GPIO14: General Purpose I/O D14: D14 for HPI or IDE | | | 58 | GPIO13/D13 | I/O | GPIO13: General Purpose I/O<br>D13: D13 for HPI or IDE | | | 59 | GPIO12/D12 | I/O | GPIO12: General Purpose I/O<br>D12: D12 for HPI or IDE | | Table 9-1. Pin Descriptions (continued) | Pin | Name | Туре | Description | |--------------------|----------------------|------------------|--------------------------------------------------------------------| | 60 | GPIO11/D11/MOSI | I/O | GPIO11: General Purpose I/O D11: D11 for HPI or IDE MOSI: SPI MOSI | | 61 | GPIO10/D10/SCK | I/O | GPIO10: General Purpose I/O D10: D10 for HPI or IDE SCK: SPI SCK | | 65 | GPIO9/D9/nSSI | I/O | GPIO9: General Purpose I/O D9: D9 for HPI or IDE nSSI: SPI nSSI | | 66 | GPIO8/D8/MISO | I/O | GPIO8: General Purpose I/O D8: D8 for HPI or IDE MISO: SPI MISO | | 86 | GPIO7/D7 | I/O | GPIO7: General Purpose I/O D7: D7 for HPI or IDE | | 87 | GPIO6/D6 | I/O | GPIO6: General Purpose I/O D6: D6 for HPI or IDE | | 89 | GPIO5/D5 | I/O | GPIO5: General Purpose I/O<br>D5: D5 for HPI or IDE | | 90 | GPIO4/D4 | I/O | GPIO4: General Purpose I/O D4: D4 for HPI or IDE | | 91 | GPIO3/D3 | I/O | GPIO3: General Purpose I/O D3: D3 for HPI or IDE | | 92 | GPIO2/D2 | I/O | GPIO2: General Purpose I/O D2: D2 for HPI or IDE | | 93 | GPIO1/D1 | I/O | GPIO1: General Purpose I/O D1: D1 for HPI or IDE | | 94 | GPIO0/D0 | I/O | GPIO0: General Purpose I/O D0: D0 for HPI or IDE | | 22 | DM1A | I/O | USB Port 1A D- | | 23 | DP1A | I/O | USB Port 1A D+ | | 18 | DM1B | I/O | USB Port 1B D- | | 19 | DP1B | I/O | USB Port 1B D+ | | 9 | DM2A | I/O | USB Port 2A D- | | 10 | DP2A | I/O | USB Port 2A D+ | | 4 | DM2B | I/O | USB Port 2B D- | | 5 | DP2B | I/O | USB Port 2B D+ | | 29 | XTALIN | Input | Crystal input or Direct Clock input | | 28 | XTALOUT | Output | Crystal output. Leave floating if direct clock source is used. | | 85 | nRESET | Input | Reset | | 84 | Reserved | - | Tie to Gnd for normal operation. | | 16 | BOOSTV <sub>CC</sub> | Power | Booster Power input: 2.7V to 3.6V | | 14 | VSWITCH | Analog<br>Output | Booster switching output | | 15 | BOOSTGND | Ground | Booster Ground | | 11 | OTGVBUS | Analog I/O | USB OTG Vbus | | 13 | CSWITCHA | Analog | Charge Pump Capacitor | | 12 | CSWITCHB | Analog | Charge Pump Capacitor | | 21 | AV <sub>CC</sub> | Power | USB Power | | 6 | AGND | Ground | USB Ground | | 37, 63, 88 | V <sub>CC</sub> | Power | Main V <sub>CC</sub> | | 26, 51, 75,<br>100 | GND | Ground | Main Ground | # 10.0 Absolute Maximum Ratings This section lists the absolute maximum ratings. Stresses above those listed can cause permanent damage to the device. Exposure to maximum rated conditions for extended periods can affect device operation and reliability. | Storage Temperature | —40°C to +125°C | |---------------------------------------------------|--------------------------------| | Ambient Temperature with Power Supplied | | | Supply Voltage to Ground Potential | 0.0V to +3.6V | | DC Input Voltage to Any General Purpose Input Pin | 5.5V | | DC Voltage Applied to XTALIN | 0.5V to V <sub>CC</sub> + 0.5V | | Static Discharge Voltage | >2000V | | Max Output Current, per I/O | 4 mA | # 11.0 Operating Conditions | T <sub>A</sub> (Ambient Temperature Under Bias) | —40°C to +85°C | |-------------------------------------------------------|-------------------| | Supply Voltage (V <sub>CC</sub> , AV <sub>CC</sub> ) | +3.0V to +3.6V | | Supply Voltage (BoostV <sub>CC</sub> ) <sup>[7]</sup> | +2.7V to +3.6V | | Ground Voltage | | | F <sub>OSC</sub> (Oscillator or Crystal Frequency) | 12 MHz ± 500 ppm | | | Parallel Resonant | # 12.0 Crystal Requirements (XTALIN, XTALOUT) ## Table 12-1. Crystal Requirements | Crystal Requirements<br>(XTALIN, XTALOUT) | Min. | Typical | Max. | Unit | |-------------------------------------------|------|---------|------|------| | Parallel Resonant Frequency | | 12 | | MHz | | Frequency Stability | -500 | | +500 | PPM | | Load Capacitance | 20 | | 33 | pF | | Driver Level | | | 500 | μW | | Start-up Time | | | 5 | ms | | Mode of Vibration: Fundamental | | | | | # 13.0 DC Characteristics Table 13-1. DC Characteristics [8] | Parameter | Description | Conditions | Min. | Тур. | Max. | Unit | |------------------------------------|-----------------------|--------------------------------------|-------|------|-------|------| | V <sub>CC</sub> , AV <sub>CC</sub> | Supply Voltage | | 3.0 | 3.3 | 3.6 | V | | BoosV <sub>CC</sub> | Supply Voltage | | 2.7 | | 3.6 | V | | V <sub>IH</sub> | Input HIGH Voltage | | 2.0 | | 5.5 | V | | $V_{IL}$ | Input LOW Voltage | | | | 0.8 | V | | I <sub>I</sub> | Input Leakage Current | 0< V <sub>IN</sub> < V <sub>CC</sub> | -10.0 | | +10.0 | μА | | V <sub>OH</sub> | Output Voltage HIGH | I <sub>OUT</sub> = 4 mA | 2.4 | | | V | | V <sub>OL</sub> | Output LOW Voltage | I <sub>OUT</sub> = –4 mA | | | 0.4 | V | | I <sub>OH</sub> | Output Current HIGH | | | | 4 | mA | | I <sub>OL</sub> | Output Current LOW | | | | 4 | mA | - 7. The on-chip voltage booster circuit boosts BoostV $_{\rm CC}$ to provide a nominal 3.3V V $_{\rm CC}$ supply. - 8. All tests were conducted with Charge pump off. Table 13-1. DC Characteristics (continued)<sup>[8]</sup> | Parameter | Description | Conditions | Min. | Тур. | Max. | Unit | |-------------------------------------|-------------------------------------|------------------------------------------------|------|------|------|------| | C <sub>IN</sub> | Input Pin Capacitance | Except D+/D- | | | 10 | pF | | | | D+/D- | | | 15 | pF | | V <sub>HYS</sub> | Hysteresis on nReset Pin | | 250 | | | mV | | I <sub>CC</sub> <sup>[9, 10]</sup> | Supply Current | 4 transceivers powered | | 80 | 100 | mA | | I <sub>CCB</sub> <sup>[9, 10]</sup> | Supply Current with Booster Enabled | 4 transceivers powered | | 135 | 180 | mA | | I <sub>SLEEP</sub> | Sleep Current | USB Peripheral: includes 1.5K internal pull-up | | 210 | 500 | μА | | | | Without 1.5K internal pull-up | | 5 | 30 | μА | | I <sub>SLEEPB</sub> | Sleep Current with Booster Enabled | USB Peripheral: includes 1.5K internal pull-up | | 190 | 500 | μА | | | | Without 1.5K internal pull-up | | 5 | 30 | μА | Table 13-2. DC Characteristics: Charge Pump | Parameter | Description | Conditions | Min. | Тур. | Max. | Unit | |---------------------------|--------------------------------------------------|--------------------------------------|-------|------|------|------| | V <sub>A_VBUS_OUT</sub> | Regulated OTGVBUS Voltage | 8 mA< I <sub>LOAD</sub> < 10 mA | 4.4 | | 5.25 | V | | T <sub>A_VBUS_RISE</sub> | V <sub>BUS</sub> Rise Time | I <sub>LOAD</sub> = 10 mA | | | 100 | ms | | I <sub>A_VBUS_OUT</sub> | Maximum Load Current | | 8 | | 10 | mA | | C <sub>DRD_VBUS</sub> | OUTVBUS Bypass Capacitance | 4.4V< V <sub>BUS</sub> < 5.25V | 1.0 | | 6.5 | pF | | V <sub>A_VBUS_LKG</sub> | OTGVBUS Leakage Voltage | OTGVBUS not driven | | | 200 | mV | | V <sub>DRD_DATA_LKG</sub> | Dataline Leakage Voltage | | | | 342 | mV | | I <sub>CHARGE</sub> | Charge Pump Current Draw | I <sub>LOAD</sub> = 8 mA | | 20 | 20 | mA | | | | I <sub>LOAD</sub> = 0 mA | | 0 | 1 | mA | | I <sub>CHARGEB</sub> | Charge Pump Current Draw with | I <sub>LOAD</sub> = 8 mA | | 30 | 45 | mA | | | Booster Active | I <sub>LOAD</sub> = 0 mA | | 0 | 5 | mA | | I <sub>B_DSCHG_IN</sub> | B-Device (SRP Capable)<br>Discharge Current | 0V< V <sub>BUS</sub> < 5.25V | | | 8 | mA | | V <sub>A_VBUS_VALID</sub> | A-Device VBUS Valid | | 4.4 | | | V | | V <sub>A_SESS_VALID</sub> | A-Device Session Valid | | 0.8 | | 2.0 | V | | V <sub>B_SESS_VALID</sub> | B-Device Session Valid | | 0.8 | | 4.0 | V | | V <sub>A_SESS_END</sub> | B-Device Session End | | 0.2 | | 0.8 | V | | E | Efficiency When Loaded | I <sub>LOAD</sub> = 8mA, VCC = 3.3V | | 75 | | % | | R <sub>PD</sub> | Data Line Pull-down | | 14.25 | | 24.8 | Ω | | R <sub>A_BUS_IN</sub> | A-device V <sub>BUS</sub> Input Impedance to GND | V <sub>BUS</sub> is not being driven | 40 | | 100 | kΩ | | R <sub>B_SRP_UP</sub> | B-device V <sub>BUS</sub> SRP Pull-up | Pull-up voltage = 3.0V | 281 | | | Ω | | R <sub>B_SRP_DWN</sub> | B-device V <sub>BUS</sub> SRP Pull-down | | 656 | | | Ω | ## **USB Transceiver** USB 2.0-certified in full- and low-speed modes. <sup>1&</sup>lt;sub>CC</sub> and I<sub>CCB</sub> values are the same regardless of USB host or peripheral configuration. There is no appreciable difference in I<sub>CC</sub> and I<sub>CCB</sub> values when only two transceivers are powered. #### **AC Timing Characteristics** 14.0 #### **Reset Timing** 14.1 # **Reset Timing** | Parameter | Description | Min. | Typical | Max. | Unit | |--------------------|-----------------------------------|------|---------|------|------------------------| | t <sub>RESET</sub> | nRESET pulse width | 16 | | | clocks <sup>[11]</sup> | | TOACT | nRESET HIGH to nRD or nWRx active | 200 | | | μs | #### 14.2 **Clock Timing** # **Clock Timing** | Parameter | Description | Min. | Typical | Max. | Unit | |-----------------------------------|------------------------------------------|-------|---------|------|------| | f <sub>CLK</sub> | Clock frequency | | 12.0 | | MHz | | v <sub>XINH</sub> <sup>[12]</sup> | Clock input high (XTALOUT left floating) | 1.5 | 3.0 | 3.6 | V | | t <sub>CLK</sub> | Clock period | 83.17 | 83.33 | 83.5 | ns | | t <sub>HIGH</sub> | Clock high time | 36 | | 44 | ns | | $t_{LOW}$ | Clock low time | 36 | | 44 | ns | | t <sub>RISE</sub> | Clock rise time | | | 5.0 | ns | | t <sub>FALL</sub> | Clock fall time | | | 5.0 | ns | | Duty Cycle | | 45 | | 55 | % | - 11. Clock is 12-MHz nominal. 12. V<sub>XINH</sub> is required to be 3.0 V to obtain an internal 50/50 duty cycle clock. #### 14.3 **SRAM Read Cycle** | Parameter | Description | Min. | Typical | Max. | Unit | |----------------------------------|--------------------------|------|---------|------|------| | t <sub>CR</sub> | CS LOW to RD LOW | 1 | | | ns | | t <sub>RDH</sub> | RD HIGH to data hold | 0 | | | ns | | t <sub>CDH</sub> | CS HIGH to data hold | 0 | | | ns | | t <sub>RPW</sub> <sup>[13]</sup> | RD LOW time | 38 | | 45 | ns | | t <sub>AR</sub> | RD LOW to address valid | | | 0 | ns | | t <sub>AC</sub> <sup>[14]</sup> | RAM access to data valid | | | 12 | ns | <sup>13. 0</sup> wait state cycle. 14. t<sub>AC</sub> External SRAM access time = 12 ns for zero and one wait states. The External SRAM access time = 12 ns + (n - 1)\*T for wait states = n, n > 1, T = 48-MHz clock period. # 14.4 SRAM Write Cycle | Parameter | Description | Min. | Typical | Max. | Unit | |----------------------------------|-------------------------------|------|---------|------|------| | t <sub>AW</sub> | Write address valid to WE LOW | 7 | | | ns | | t <sub>CSW</sub> | CS LOW to WE LOW | 7 | | | ns | | t <sub>DW</sub> | Data valid to WE HIGH | 15 | | | ns | | t <sub>WPW</sub> <sup>[15]</sup> | WE pulse width | 15 | | | ns | | t <sub>DH</sub> | Data hold from WE HIGH | 4.5 | | | ns | | t <sub>WC</sub> | WE HIGH to CS HIGH | 13 | | | ns | <sup>15.</sup> $t_{WPW}$ The write pulse width = 18.8 ns min. for zero and one wait states. The write pulse = 18.8 ns + $(n-1)^*T$ for wait states = n, n > 1, T = 48-MHz clock period. # 14.5 I2C EEPROM Timing # 1. I2C EEPROM Bus Timing - Serial I/O | Parameter | Description | Min. | Typical | Max. | Unit | |---------------------|----------------------------------|------|---------|------|------| | f <sub>SCL</sub> | Clock Frequency | | | 400 | kHz | | t <sub>LOW</sub> | Clock Pulse Width Low | 1300 | | | ns | | t <sub>HIGH</sub> | Clock Pulse Width High | 600 | | | ns | | t <sub>AA</sub> | Clock Low to Data Out Valid | 900 | | | ns | | t <sub>BUF</sub> | Bus Idle Before New Transmission | 1300 | | | ns | | t <sub>HD.STA</sub> | Start Hold Time | 600 | | | ns | | t <sub>SU.STA</sub> | Start Set-up Time | 600 | | | ns | | HD.DAT | Data In Hold Time | 0 | | | ns | | t <sub>SU.DAT</sub> | Data In Set-up Time | 100 | | | ns | | t <sub>R</sub> | Input Rise Time | | | 300 | ns | | t <sub>F</sub> | Input Fall Time | | | 300 | ns | | tsu.sto | Stop Set-up Time | 600 | | | ns | | t <sub>DH</sub> | Data Out Hold Time | 0 | | | ns | # 14.6 HPI (Host Port Interface) Write Cycle Timing | Parameter | Description | Min. | Typical | Max. | Unit | |-------------------|--------------------|------|---------|------|-------------------| | t <sub>ASU</sub> | Address set-up | -1 | | | ns | | t <sub>AH</sub> | Address hold | -1 | | | ns | | t <sub>CSSU</sub> | Chip select set-up | -1 | | | ns | | t <sub>CSH</sub> | Chip select hold | -1 | | | ns | | t <sub>DSU</sub> | Data set-up | 6 | | | ns | | t <sub>WDH</sub> | Write data hold | 2 | | | ns | | t <sub>WP</sub> | Write pulse width | 2 | | | T <sup>[16]</sup> | | t <sub>CYC</sub> | Write cycle time | 6 | | | T <sup>[16]</sup> | # Note: 16. T = system clock period = 1/48 MHz. # 14.7 HPI (Host Port Interface) Read Cycle Timing | Parameter | Description | Min. | Typical | Max. | Unit | |-------------------|-----------------------------------------------------------------------------|------|---------|------|-------------------| | t <sub>ASU</sub> | Address set-up | -1 | | | ns | | t <sub>AH</sub> | Address hold | -1 | | | ns | | t <sub>CSSU</sub> | Chip select set-up | -1 | | | ns | | t <sub>CSH</sub> | Chip select hold | -1 | | | ns | | t <sub>ACC</sub> | Data access time, from HPI_nRD falling | | | 1 | T <sup>[16]</sup> | | t <sub>RDH</sub> | Read data hold, relative to the earlier of HPI_nRD rising or HPI_nCS rising | 0 | | 7 | ns | | t <sub>RP</sub> | Read pulse width | 2 | | | T <sup>[16]</sup> | | t <sub>CYC</sub> | Read cycle time | 6 | | | T <sup>[16]</sup> | ## 14.8 IDE Timing The IDE interface supports PIO mode 0-4 as specified in the Information Technology-AT Attachment–4 with Packet Interface Extension (ATA/ATAPI-4) Specification, T13/1153D Rev 18. #### 14.9 HSS BYTE Mode Transmit qt\_clk, CPU\_A, CPUHSS\_cs, CPU\_wr are internal signals, included in the diagram to illustrate relationship between CPU operations and HSS port operations. Bit 0 is LSB of data byte. Data bits are HIGH true: HSS TxD HIGH = data bit value '1'. BT = bit time = 1/baud rate. #### 14.10 HSS Block Mode Transmit BLOCK mode transmit timing is similar to BYTE mode, except the STOP bit time is controlled by the HSS GAP value. The BLOCK mode STOP bit time, $t_{GAP} = (HSS\_GAP - 9)$ BT, where BT is the bit time, and HSS\_GAP is the content of the HSS Transmit Gap Register 90xC074]. The default t<sub>GAP</sub> is 2 BT. BT = bit time = 1/baud rate. ## 14.11 HSS BYTE and BLOCK Mode Receive Receive data arrives asynchronously relative to the internal clock. Incoming data bit rate may deviate from the programmed baud rate clock by as much as $\pm 5\%$ (with HSS\_RATE value of 23 or higher). BYTE mode received bytes are buffered in a FIFO. The FIFO not empty condition becomes the RxRdy flag. BLOCK mode received bytes are written directly to the memory system. Bit 0 is LSB of data byte. Data bits are HIGH true: HSS RxD HIGH = data bit value '1'. BT = bit time = 1/baud rate. ## 14.12 Hardware CTS/RTS Handshake Start of transmission delayed until HSS\_CTS goes high Start of transmission not delayed by HSS\_CTS $t_{CTSsetup}$ : HSS\_CTS set-up time before HSS\_RTS = 1.5T min. $t_{CTShold}$ : HSS\_CTS hold time after START bit = 0 ns min. T = 1/48 MHz. When RTS/CTS hardware handshake is enabled, transmission can be help off by deasserting HSS\_CTS at least 1.5T before HSS\_RTS. Transmission resumes when HSS\_CTS returns HIGH. HSS\_CTS must remain HIGH until START bit. HSS\_RTS is deasserted in the third data bit time. An application may choose to hold HSS\_CTS until HSS\_RTS is deasserted, which always occurs after the START bit. # 15.0 Registers Summary Table 15-1. Register Summary | R/W | Address | Register | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Default High | |-----|-----------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|-----------------------------------|---------------------------|-----------------------------------|-----------------------|--------------| | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default Low | | R | 0x0140 | HPI Breakpoint | Address | | | | | | | | 0000 0000 | | | | | Address | | | | | | | | 0000 0000 | | R | 0x0142 | Interrupt Routing | VBUS to HPI<br>Enable | ID to HPI<br>Enable | SOF/EOP2 to<br>HPI Enable | SOF/EOP2 to<br>CPU Enable | SOF/EOP1 to<br>HPI Enable | SOF/EOP1 to<br>CPU Enable | Reset2 to HPI<br>Enable | HPI Swap 1<br>Enable | 0001 0100 | | | | | Resume2 to<br>HPI Enable | Resume1 to<br>HPI Enable | Reserved | | Done2 to HPI<br>Enable | Done1 to HPI<br>Enable | Reset1 to HPI<br>Enable | HPI Swap 0<br>Enable | 0000 0000 | | W | 1: 0x0144 | SIEXmsg | Data | | | | | | | | XXXX XXXX | | | 2: 0x0148 | | Data | | | | | | | | XXXX XXXX | | R/W | 0x02n0 | Device n Endpoint n Control | Reserved | | | | | | | | XXXX XXXX | | | | | IN/OUT<br>Ignore Enable | Sequence<br>Select | Stall<br>Enable | ISO<br>Enable | NAK Interrupt<br>Enable | Direction<br>Select | Enable | ARM<br>Enable | XXXX XXXX | | R/W | 0x02n2 | Device n Endpoint n Address | Address | | | | | | | | XXXX XXXX | | | | | Address | | | | | | | | XXXX XXXX | | R.W | 0x02n4 | Device n Endpoint n Count | Reserved | | | | | | Count | | XXXX XXXX | | | | | Count | | | | | | | | XXXX XXXX | | R/W | 0x02n6 | Device n Endpoint n Status | Reserved | | | | Overflow<br>Flag | Underflow<br>Flag | OUT<br>Exception Flag | IN<br>Exception Flag | XXXX XXXX | | | | | Stall<br>Flag | NAK<br>Flag | Length<br>Exception Flag | Setup<br>Flag | Sequence<br>Status | Timeout<br>Flag | Error<br>Flag | ACK<br>Flag | XXXX XXXX | | R/W | 0x02n8 | Device n Endpoint n Count Result | Result | | | | | | | | XXXX XXXX | | | | | Result | | | | | | | | XXXX XXXX | | R | 0xC000 | CPU Flags | Reserved | | | | | | | | 0000 0000 | | | | | Reserved | | | Global Inter-<br>rupt Enable | Negative<br>Flag | Overflow<br>Flag | Carry<br>Flag | Zero<br>Flag | 000x xxxx | | R/W | 0xC002 | Bank | Address | | | | | | | | 0000 0001 | | | | | Address | | | | Reserved | | | | 000x xxxx | | R | 0xC004 | Hardware Revision | Revision | | | | | | | | XXXX XXXX | | | | | Revision | | | | | | | | XXXX XXXX | | R/W | 0xC006 | GPIO Control | Write Protect<br>Enable | UD | Reserved | | SAS<br>Enable | Mode<br>Select | | | 0000 0000 | | | | | HSS<br>Enable | HSS XD<br>Enable | SPI<br>Enable | SPI XD<br>Enable | Interrupt 1<br>Polarity<br>Select | Interrupt 1<br>Enable | Interrupt 0<br>Polarity<br>Select | Interrupt 0<br>Enable | 0000 0000 | | R/W | 0xC008 | CPU Speed | Reserved | | | | | | • | • | 0000 0000 | | | | | .Reserved | | | | CPU Speed | | | | 0000 1111 | | R/W | 0xC00A | Power Control | Host/Device<br>2B Wake<br>Enable | Host/Device<br>2A Wake<br>Enable | Host/Device<br>1B Wake<br>Enable | Host/Device<br>1A Wake<br>Enable | OTG<br>Wake<br>Enable | Reserved | HSS<br>Wake<br>Enable | SPI<br>Wake<br>Enable | 0000 0000 | | | | | HPI<br>Wake Enable | Reserved | | GPI<br>Wake Enable | Reserved | Boost 3V<br>OK | Sleep<br>Enable | Halt<br>Enable | 0000 0000 | | R/W | 0xC00C | Watchdog Timer | Reserved | | | | | | | • | 0000 0000 | | | | | Reserved | | Timeout<br>Flag | Period<br>Select | | Lock<br>Enable | WDT<br>Enable | Reset<br>Strobe | 0000 0000 | Table 15-1. Register Summary (continued) | R/W | 0xC00E | | | | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Default High | |-------------------|-----------------------------|-------------------------|---------------------------------|-----------------------------------|------------------------------------|---------------------------------|-----------------------------|---------------------------------|--------------------------------------|--------------------------------------|------------------------| | R/W | 0xC00E | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default Low | | | | Interrupt Enable | Reserved | ı | • | OTG Interrupt<br>Enable | SPI Interrupt<br>Enable | Reserved | Host/Device 2<br>Interrupt<br>Enable | Host/Device 1<br>Interrupt<br>Enable | 0000 0000 | | | | | HSS<br>Interrupt<br>Enable | In Mailbox<br>Interrupt<br>Enable | Out Mailbox<br>Interrupt<br>Enable | Reserved | UART<br>Interrupt<br>Enable | GPIO<br>Interrupt<br>Enable | Timer 1<br>Interrupt<br>Enable | Timer 0<br>Interrupt<br>Enable | 0001 0000 | | R/W | 0xC098 | OTG Control | Reserved | | VBUS<br>Pullup<br>Enable | Receive<br>Disable | | VBUS<br>Discharge<br>Enable | D+<br>Pullup<br>Enable | D-<br>Pullup<br>Enable | 0000 0000 | | | | | D+ Pulldown<br>Enable | D- Pulldown<br>Enable | Reserved | | | OTG Data<br>Status | ID<br>Status | VBUS Valid<br>Flag | 0000 0xxx | | R/W | 0: 0xC010<br>1: 0xC012 | Timer n | Count | | | | | | | | 1111 1111 | | R/W | 0xC014 | Breakpoint | AddressAddress | | | | | | | | 0000 0000 | | R/W | 1: 0xC018 | Extended Page n Map | Address | | | | | | | | 0000 0000 | | | 2: 0xC01A | | Address | | | | | | | | 0000 0000 | | R/W | | GPIO n Output Data | Data | | | | | | | | 0000 0000 | | | 1: 0xC024 | | Data | | | | | | | | 0000 0000 | | R | 0: 0xC020 | GPIO n Input Data | Data | | | | | | | | 0000 0000 | | | 1: 0xC026 | | Data | | | | | | | | 0000 0000 | | R/W | 0: 0xC022<br>1: 0xC028 | GPIO n Direction | Direction Selec | | | | | | | | 0000 0000 | | | 1. UXCU28 | | Direction Sel | ect | | | | | | | 0000 0000 | | R/W | 0xC038 | Upper Address Enable | Reserved | | | | | | | | XXXX XXXX | | | | | Reserved | | | | Upper<br>Address<br>Enable | Reserved | | | xxxx 0xxx | | R/W | 0xC03A | External Memory Control | Reserved | | XRAM | XROM | XMEM<br>Width Select | XMEM<br>Wait Select | | | XXXX XXXX | | | | | XROM<br>Width Select | XROM<br>Wait Select | Merge Enable | Merge Enable | XRAM<br>Width Select | XRAM<br>Wait Select | | | XXXX XXXX | | R/W | 0xC03C | USB Diagnostic | Port 2B<br>Diagnostic<br>Enable | Port 2A<br>Diagnostic<br>Enable | Port 1B<br>Diagnostic<br>Enable | Port 1A<br>Diagnostic<br>Enable | Reserved | | | | 0000 0000 | | | | | Reserved | Pulldown<br>Enable | LS Pullup<br>Enable | FS Pullup<br>Enable | Reserved | Force Select | | | 0000 0000 | | W | 0xC03E | Memory Diagnostic | Reserved | | | | | Memory<br>Arbitration<br>Select | | | 0000 0000 | | | | | Reserved | | | | | | | Monitor<br>Enable | 0000 0000 | | R/W | 0xC048 | IDE Mode | Reserved | | | | T | | | | 0000 0000 | | D 444 | 0.0044 | IDE OL LA LI | Reserved | | | | Reserved | Mode Select | | | 0000 0000 | | R/W | 0xC04A | IDE Start Address | Address Address | | | | | | | | 0000 0000 | | R/W | 0xC04C | IDE Stop Address | Address | | | | | | | | 0000 0000 | | 1000 | 0,0040 | IDE Otop Address | Address | | | | | | | | 0000 0000 | | R/W | 0xC04E | IDE Control | Reserved | | | | | | | | 0000 0000 | | | | | Reserved | | | | Direction<br>Select | IDE Interrupt<br>Enable | Done<br>Flag | IDE<br>Enable | 0000 0000 | | - | 0xC050-<br>0xC06E | IDE PIO Port | | | | | 1 | | j. 1429 | | <u>,</u> L | | R/W | 0xC070 | HSS Control | HSS<br>Enable | RTS<br>Polarity<br>Select | CTS<br>Polarity<br>Select | XOFF | XOFF<br>Enable | CTS<br>Enable | Receive<br>Interrupt<br>Enable | Done<br>Interrupt<br>Enable | 0000 0000 | | DAM | 0.0070 | 100 0 | Interrupt Flag | Receive Done<br>Interrupt Flag | One<br>Stop Bit | Transmit<br>Ready | Packet Mode<br>Select | Receive<br>Overflow Flag | Receive Pack-<br>et Ready Flag | Receive<br>Ready Flag | 0000 0000 | | R/W | 0xC072 | HSS Baud Rate | Reserved<br>Baud | | | HSS Baud | | | | | 0000 0000<br>0001 0111 | | R/W | 0xC074 | HSS Transmit Gap | Reserved | | | | | | | | 0000 0000 | | | | | Transmit Gap S | Select | | | | | | | 0000 1001 | | R/W | 0xC076 | HSS Data | Reserved | | | | | | | | XXXX XXXX | | | | | Data | | | | | | | | XXXX XXXX | | R/W | 0xC078 | HSS Receive Address | Address | | | | | | | | 0000 0000 | | | 0,,007.4 | HCC Deceive Country | Address | | | | | | Caunta | | 0000 0000 | | D/M/ | 0xC07A | HSS Receive Counter | Reserved<br>Counter | | | | | | Counter | | 0000 0000 | | R/W | | HSS Transmit Address | Address | | | | | | | | 0000 0000 | | | $0 \times C \cup 2 \subset$ | 1100 Hansiliit Auuless | | | | | | | | | 0000 0000 | | | 0xC07C | | | | | | | | | | | | R/W | | HSS Transmit Counter | Address<br>Reserved | | | | | | Counter | | | | R/W | | HSS Transmit Counter | Reserved | | | | | | Counter | | 0000 0000 | | R/W<br>R/W<br>R/W | | HSS Transmit Counter | | | | | | | Counter | | | Table 15-1. Register Summary (continued) | R/W | Address | Register | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Default High | |--------|------------------|---------------------------|--------------------------|--------------------------|--------------------------|----------------------------|---------------------|---------------------|---------------------------|------------------------------|--------------| | IV/VV | Audiess | Register | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 10 | Bit 1 | Bit 0 | Default Low | | R/W | 0xC082 | Hoot n Addroop | | Dit 0 | ысэ | DIC 4 | Dit 3 | Dit 2 | DIC I | DIL V | | | R/VV | 0xC062<br>0xC0A2 | Host n Address | Address | | | | | | | | 0000 0000 | | D 0.47 | 0.0004 | | Address | D 10 1 1 | | | | | io . | | 0000 0000 | | R/W | 0xC084<br>0xC0A4 | Host n Count | Reserved | Port Select | Reserved | | | | Count | | 0000 0000 | | | | | Count | | | | | | | | 0000 0000 | | R/W | 0xC084<br>0xC0A4 | Device n Port Select | Reserved | Port Select | Reserved | | | | | | 0000 0000 | | | UXCUA4 | | Reserved | | | | | | | | 0000 0000 | | R | 0xC086 | Host n PID | Reserved | | | | Overflow | Underflow | Reserved | | 0000 0000 | | | 0xC0A6 | | 0. " | NIA IZ | l. a | In . | Flag | Flag | _ | Lague | 2000 2000 | | | | | Stall<br>Flag | NAK<br>Flag | Length<br>Exception Flag | Reserved | Sequence<br>Status | Timeout<br>Flag | Error<br>Flag | ACK<br>Flag | 0000 0000 | | W | 0xC086 | Host n EP Status | Reserved | i lug | Exceptioning | <u> </u> | Cidido | i iug | i lug | i lug | 0000 0000 | | ** | 0xC0A4 | 1103t II El Otatus | PID Select | | | | Endpoint Sele | act | | | 0000 0000 | | R | 0xC088 | Host n Count Result | Result | | | | Litupoliti Sele | 301 | | | 0000 0000 | | K | 0xC088 | Host II Count Result | | | | | | | | | | | | 0.000 | | Result | | | | | | | | 0000 0000 | | W | 0xC088<br>0xC0A8 | Host n Device Address | Reserved | | | | | | | | 0000 0000 | | | | | Reserved | Address | ·- | 1- | | 1 | T | | 0000 0000 | | R/W | 0xC08A<br>0xC0AA | USB n Control | Port B<br>D+ Status | Port B<br>D- Status | Port A<br>D+ Status | Port A<br>D- Status | LOB | LOA | Mode<br>Select | Port B Resis-<br>tors Enable | xxxx 0000 | | | UXCUAA | | Port A | Port B | D1 Status | Port A | | Cuanand | Port B | Port A | 0000 0000 | | | | | Resistors | Force D+/- | | Force D+/- | | Suspend<br>Enable | SOF/EOP | SOF/EOP | 0000 0000 | | | | | Enable | State | | State | | | Enable | Enable | | | R/W | 0xC08C | Host 1 Interrupt Enable | VBUS | ID | Reserved | | | | SOF/EOP | Reserved | 0000 0000 | | | | | Interrupt<br>Enable | Interrupt<br>Enable | | | | | Interrupt<br>Enable | | | | | | | Port B | Port A | Port B Connect | Port A Con- | Reserved | | | Done | 0000 0000 | | | | | Wake Interrupt | Wake Interrupt | Change<br>Interrupt En- | nect Change | reserved | | | Interrupt | 0000 0000 | | | | | Enable | Enable | Interrupt En-<br>able | Interrupt<br>Enable | | | | Enable | | | R/W | 0xC08C | Device 1 Interrupt Enable | VBUS | ID | Reserved | Lilable | SOF/EOP | Reserved | SOF/EOP | Reset | 0000 0000 | | IK/VV | UXCUBC | Device i interrupt Enable | Interrupt | Interrupt | Reserved | | Timeout | Reserved | Interrupt | Interrupt | 0000 0000 | | | | | Enable | Enable | | | Interrupt | | Enable | Enable | | | | | | | | | | Enable | | | | | | | | | EP7 | EP6 | EP5 | EP4 | EP3 | EP2 | EP1 | EP0 | 0000 0000 | | | | | Interrupt<br>Enable | | R/W | 0xC08E | Device n Address | Reserved | LITABIC | Lilabic | LIIADIC | Lilabic | LITABIC | Lilabic | Litable | 0000 0000 | | 17/44 | 0xC0AE | Device il Address | Reserved | Address | | | | | | | 0000 0000 | | R/W | 0xC090 | Host 1 Status | VBUS | ID | Reserved | | | | SOF/EOP | Reserved | | | IK/VV | 0.000 | HOSE I Status | Interrupt Flag | Interrupt Flag | Reserved | | | | Interrupt Flag | Reserved | XXXX XXXX | | | | | Port B | Port A | Port B Connect | Port A Con- | Port B | Port A | Reserved | Done | xxxx xxxx | | | | | | Wake Interrupt | Change | nect Change | SE0 | SE0 | | Interrupt | | | D.04/ | 0.000 | 5 | Flag | Flag | Interrupt Flag | Interrupt Flag | Status | Status | 005/505 | Flag | | | R/W | 0xC090 | Device 1 Status | VBUS<br>Interrupt Flag | ID<br>Interrupt Flag | Reserved | | | | SOF/EOP<br>Interrupt Flag | Reset<br>Interrupt Flag | XXXX XXXX | | | | | EP7 | EP6 | EP5 | EP4 | EP3 | EP2 | EP1 | EP0 | XXXX XXXX | | | | | Interrupt Flag | Interrupt Flag | Interrupt Flag | Interrupt Flag | Interrupt Flag | | Interrupt Flag | Interrupt Flag | **** | | R/W | 0xC092 | Host n SOF/EOP Count | Reserved | | Count | _ | | _ | • | • | 0010 1110 | | | 0xC0B2 | | Count | | I | | | | | | 1110 0000 | | R | 0xC092 | Device n Frame Number | SOF/EOP | SOF/EOP | | | Reserved | Frame | | | 0000 0000 | | | 0xC0B2 | | Timeout | Timeout | | | | | | | | | | | | Flag | Interrupt Coun | t | | | | | | | | | | | Frame | | | | | | | | 0000 0000 | | R | | Host n SOF/EOP Counter | Reserved | | Counter | | | | | | XXXX XXXX | | | 0xC0B4 | | Counter | | | | | | | | XXXX XXXX | | W | 0xC094<br>0xC0B4 | Device n SOF/EOP Count | Reserved | | Count | | | | | | 0010 1110 | | | UXCUB4 | | Count | | | | | | | | 1110 0000 | | R | 0xC096 | Host n Frame | Reserved | | | | | Frame | | | 0000 0000 | | | 0xC0B6 | | Frame | | | | | | | | 0000 0000 | | R/W | 0xC0AC | Host 2 Interrupt Enable | Reserved | | | | | | SOF/EOP | Reserved | 0000 0000 | | | | · | | | | | | | Interrupt | | | | | | | Dort D | Dort ^ | Dort D. Carrer | Dort A Co- | Dogger (c -l | | Enable | Done | 0000 0000 | | | | | Port B<br>Wake Interrupt | Port A<br>Wake Interrupt | Port B Connect<br>Change | Port A Con-<br>nect Change | Reserved | | | Done<br>Interrupt | 0000 0000 | | | | | Enable | Enable | Interrupt | Interrupt | | | | Enable | | | | | | | | Enable | Enable | | | | <u> </u> | | | R/W | 0xC0AC | Device 2 Interrupt Enable | Reserved | | | | SOF/EOP<br>Timeout | Wake | SOF/EOP | Reset | 0000 0000 | | | | | | | | | Interrupt | Interrupt<br>Enable | Interrupt<br>Enable | Interrupt<br>Enable | | | | | | | | | | Enable | | | | | | | | | EP7 | EP6 | EP5 | EP4 | EP3 | EP2 | EP1 | EP0 | 0000 0000 | | | | | Interrupt<br>Enable | | I | 1 | | LITADIC | LIGUIC | LIGDIC | LIIGUIG | LIIGDIC | LITADIO | LIMBIC | LITADIC | 1 | Table 15-1. Register Summary (continued) | R/W | Address | Register | | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Default High | |--------|----------------------------------|----------------------|----------------------------------|----------------------------------|-----------------------------------------------|-----------------------------------------------|-------------------------------------------|-------------------------------|--------------------------------|--------------------------------|--------------| | 204: | 0.0554 | | | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default Low | | R/W | 0xC0B0 | Host 2 Status | Reserved | | | | | | SOF/EOP<br>Interrupt<br>Flag | Reserved | XXXX XXXX | | | | | Port B<br>Wake Interrupt<br>Flag | Port A<br>Wake Interrupt<br>Flag | Port B<br>Connect<br>Change<br>Interrupt Flag | Port A<br>Connect<br>Change<br>Interrupt Flag | Port B<br>SE0<br>Status | Port A<br>SE0<br>Status | Reserved | Done<br>Interrupt<br>Flag | XXXX XXXX | | R/W | 0xC0B0 | Device 2 Status | Reserved | | | | SOF/EOP<br>Timeout<br>Interrupt<br>Enable | Wake<br>Interrupt<br>Flag | SOF/EOP<br>Interrupt<br>Flag | Reset<br>Interrupt<br>Flag | XXXX XXXX | | DAM | 0,,0006 | LIDI Meilkey | EP7<br>Interrupt Flag | EP6<br>Interrupt Flag | EP5<br>Interrupt Flag | EP4<br>Interrupt Flag | EP3<br>Interrupt Flag | EP2<br>Interrupt Flag | EP1<br>Interrupt Flag | EP0<br>Interrupt Flag | XXXX XXXX | | R/W | 0xC0C6 | HPI Mailbox | MessageMessage | | | | | | | | 0000 0000 | | R/W | 0xC0C8 | SPI Configuration | 3Wire | Phase | SCK | Scale Select | | | | Reserved | 1000 0000 | | | | J | Enable | Select | Polarity Select | | | | | | | | | | | Master<br>Active Enable | Master<br>Enable | SS<br>Enable | SS Delay Sele | ect | | | | 0001 1111 | | R/W | 0xC0CA | SPI Control | SCK | FIFO | Byte | FullDuplex | SS | Read | Transmit | receive | 0000 0001 | | | | | Strobe<br>Transmit | Init<br>receive | Mode<br>Transmit Bit Le | anath | Manual | Enable<br>Receive Bit Le | Ready | Data Ready | 1000 0000 | | | | | Empty | Full | Hansiiii bii Le | engui | | Receive bit Le | rigui | | 1000 0000 | | R/W | 0xC0CC | SPI Interrupt Enable | Reserved | | | | | | | | 0000 0000 | | | | | Reserved | | | | | Receive Inter-<br>rupt Enable | Transmit Inter-<br>rupt Enable | Transfer Inter-<br>rupt Enable | 0000 0000 | | R | 0xC0CE | SPI Status | Reserved | | | | | ., | | ., | 0000 0000 | | | | | FIFO Error | Reserved | | | | Receive | Transmit | Transfer | 0000 0000 | | W | 0xC0D0 | SPI Interrupt Clear | Flag<br>Reserved | | | | | Interrupt Flag | Interrupt Flag | Interrupt Flag | 0000 0000 | | | ONG GEO | or rinterrupt oreas | Reserved | | | | | | Transmit | Transmit | 0000 0000 | | | | | | | lana. | lana | 1= . | | Interrupt Clear | Interrupt Clear | | | R/W | 0xC0D2 | SPI CRC Control | CRC Mode | | CRC<br>Enable | CRC<br>Clear | Receive<br>CRC | One in CRC | Zero in CRC | Reserved | 0000 0000 | | R/W | 0xC0D4 | SPI CRC Value | CRC | | | | | | | | 1111 1111 | | | | | CRC | | | | | | | | 1111 1111 | | R/W | 0xC0D6 | SPI Data Port t | Reserved | | | | | | | | XXXX XXXX | | D 44/ | 0.0000 | ODI T | Data | | | | | | | | XXXX XXXX | | R/W | 0xC0D8 | SPI Transmit Address | AddressAddress | | | | | | | | 0000 0000 | | R/W | 0xC0DA | SPI Transmit Count | Reserved | | | | | Count | | | 0000 0000 | | | | | Count | | | | | | | | 0000 0000 | | R/W | 0xC0DC | SPI Receive Address | Address | | | | | | | | 0000 0000 | | | | | Address | | | | | | | | 0000 0000 | | R/W | 0xC0DE | SPI Receive Count | Reserved | | | | | Count | | | 0000 0000 | | R/W | 0xC0E0 | UART Control | Count | | | | | | | | 0000 0000 | | | OXOGEO | Oraci Gondoi | Reserved | | | Scale Select | Baud Select | | | UART Enable | 0000 0111 | | R | 0xC0E2 | UART Status | Reserved | | | ·! | | | | | 0000 0000 | | | | | Reserved | | | | | | Receive<br>Full | Transmit<br>Full | 0000 0000 | | R/W | 0xC0E4 | UART Data | Reserved | | | | | | i uii | i uli | 0000 0000 | | | | | Data | | | | | | | | 0000 0000 | | R/W | 0xC0E6 | PWM Control | PWM | Reserved | | | Prescale | | | Mode | 0000 0000 | | | | | Enable<br>PWM3 | PWM2 | PWM1 | PWM0 | Select<br>PWM3 | PWM2 | PWM1 | Select<br>PWM0 | 0000 0000 | | | | | | | | Polarity Select | | Enable | Enable | Enable | 0000 0000 | | R/W | 0xC0E8 | PWM Maximum Count | Reserved | • | • | • | • | • | Count | • | 0000 0000 | | D 0.47 | 0. | DWM - Ott | Count | | | | | | IA dalaasa | | 0000 0000 | | R/W | 0:<br>0xC0EA | PWM n Start | Address | | | | | | Address | | 0000 0000 | | | 1:<br>0xC0EE<br>2: 0xC0F2 | | Audiess | | | | | | | | 5000 0000 | | R/W | 3: 0xC0F6<br>0: | PWM n Stop | Reserved | | | | | | Address | | 0000 0000 | | | 0xC0EC<br>1: 0xC0F0<br>2: 0xC0F4 | · | Address | | | | | | , | | 0000 0000 | | DAM. | 3: 0xC0F8 | | Court | | | | | | | | 0000 0000 | | R/W | 0xC0FA | PWM Cycle Count | Count | | | | | | | | 0000 0000 | | R | | HPI Status Port | Count<br>VBUS | ID | Reserved | SOF/EOP2 | Reserved | SOF/EOP1 | Reset2 | Mailbox In | 0000 0000 | | | | | Flag | Flag | | Flag | | Flag | Flag | Flag | | | | | | Resume2 Flag | Resume1 Flag | SIE2msg | SIE1msg | Done2 Flag | Done1 Flag | Reset1 Flag | Mailbox Out<br>Flag | | # 16.0 Ordering Information Table 16-1. Ordering Information | Ordering Code | Package Type | Temperature Range | |-----------------|-----------------|-------------------| | CY7C67300-100AI | 100 TQFP | –40 to 85°C | | CY3663 | Development Kit | | # 17.0 Package Diagrams ## 100-Pin Thin Plastic Quad Flat Pack (TQFP) A100 Purchase of $I^2C$ components from Cypress, or one of its sublicensed Associated Companies, conveys a license under the Philips $I^2C$ Patent Rights to use these components in an $I^2C$ system, provided that the system conforms to the $I^2C$ Standard Specification as defined by Philips. EZ-Host is a trademark of Cypress Semiconductor. All product and company names mentioned in this document may be the trademarks of their respective holders. # **Document History Page** | REV. | ECN NO. | Issue Date | Orig. of ate Change Description of Change | | | | | | |------|---------|------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | ** | 111872 | 03/22/02 | MUL | New Data Sheet | | | | | | *A | 116989 | 08/23/02 | MUL | Preliminary Data Sheet | | | | | | *B | 125262 | 04/10/03 | MUL | Added Memory Map Section and Ordering Information Section<br>Moved Functional Register Map Tables into Register section<br>General Clean-up | | | | | | *C | 126210 | 05/23/03 | MUL | Added Interface Description Section and Power Savings and Reset Section Added Char Data General Clean-up | | | | | | *D | 127335 | 05/29/03 | KKV | Corrected font to enable correct symbol display | | | | | | *E | 129395 | 10/01/03 | MUL | Final Data Sheet Changed Memory Map Section and added CLKSEL to Pin Description Added USB OTG Logo General Clean-up | | | | |