ISP1583 Hi-Speed Universal Serial Bus Peripheral Controller Rev. 06 -- 20 August 2007 Product data sheet 1. General description The ISP1583 is a cost-optimized and feature-optimized Hi-Speed Universal Serial Bus (USB) Peripheral Controller. It fully complies with Ref. 1 "Universal Serial Bus Specification Rev. 2.0", supporting data transfer at high-speed (480 Mbit/s) and full-speed (12 Mbit/s). The ISP1583 provides high-speed USB communication capacity to systems based on microcontrollers or microprocessors. It communicates with a microcontroller or microprocessor of a system through a high-speed general-purpose parallel interface. The ISP1583 supports automatic detection of Hi-Speed USB system operation. Original USB fall-back mode allows the device to remain operational under full-speed conditions. It is designed as a generic USB Peripheral Controller so that it can fit into all existing device classes, such as imaging class, mass storage devices, communication devices, printing devices and human interface devices. The ISP1583 is a low-voltage device, which supports I/O pad voltages from 1.65 V to 3.6 V. The internal generic Direct Memory Access (DMA) block allows easy integration into data streaming applications. In addition, the various configurations of the DMA block are tailored for mass storage applications. The modular approach to implementing a USB Peripheral Controller allows the designer to select the optimum system microcontroller from the wide variety available. The ability to reuse existing architecture and firmware shortens the development time, eliminates risk and reduces cost. The result is fast and efficient development of the most cost-effective USB peripheral solution. The ISP1583 also incorporates features such as SoftConnect, a reduced frequency crystal oscillator, and integrated termination resistors. These features allow significant cost savings in system design and easy implementation of advanced USB functionality into PC peripherals. 2. Features n Complies fully with: u Ref. 1 "Universal Serial Bus Specification Rev. 2.0" u Most device class specifications u ACPI, OnNow and USB power management requirements n Supports data transfer at high-speed (480 Mbit/s) and full-speed (12 Mbit/s) n Direct interface to ATA/ATAPI peripherals; applicable only in split bus mode ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller n High performance USB Peripheral Controller with integrated Serial Interface Engine (SIE), Parallel Interface Engine (PIE), FIFO memory and data transceiver n Automatic Hi-Speed USB mode detection and Original USB fall-back mode n Supports sharing mode n Supports I/O voltage range of 1.65 V to 3.6 V n Supports VBUS sensing n High-speed DMA interface n Configurable direct access data path from the microprocessor to an ATA device n Fully autonomous and multi-configuration DMA operation n Seven IN endpoints, seven OUT endpoints, and a fixed control IN and OUT endpoint n Integrated physical 8 kB of multi-configuration FIFO memory n Endpoints with double buffering to increase throughput and ease real-time data transfer n Bus-independent interface with most microcontrollers and microprocessors n 12 MHz crystal oscillator with integrated PLL for low EMI n Software-controlled connection to the USB bus (SoftConnect) n Low-power consumption in operation and power-down modes; suitable for use in bus-powered USB devices n Supports Session Request Protocol (SRP) that adheres to Ref. 2 "On-The-Go Supplement to the USB Specification Rev. 1.2" n Internal power-on and low-voltage reset circuits; also supports software reset n Operation over the extended USB bus voltage range (DP, DM and VBUS) n 5 V tolerant I/O pads n Operating temperature range from -40 C to +85 C n Available in HVQFN64 and TFBGA64 halogen-free and lead-free packages 3. Applications n n n n n n n n n Personal digital assistant Mass storage device, for example: CD, DVD, Magneto-Optical (MO) and Zip drives Digital video camera Digital still camera 3G mobile phone MP3 player Communication device, for example: router and modem Printer Scanner ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 2 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 4. Ordering information Table 1. Ordering information Type number Package Name Description Version ISP1583BS HVQFN64 plastic thermal enhanced very thin quad flat package; no leads; 64 terminals; body 9 x 9 x 0.85 mm SOT804-1 ISP1583ET TFBGA64 plastic thin fine-pitch ball grid array package; 64 balls; body 6 x 6 x 0.8 mm SOT543-1 ISP1583ET1 TFBGA64 plastic thin fine-pitch ball grid array package; 64 balls; body 4 x 4 x 0.8 mm SOT969-1 ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 3 of 100 xxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx x xxxxxxxxxxxxxx xxxxxxxxxx xxx xxxxxx xxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxx xxxxx xxxxxx xx xxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxx xxxxxxx xxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxx xxxxxxxxxxxxxx xxxxxx xx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxx xxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxx xxxxx x x CS0_N DA0(3) DA2 DIOR DACK DIOW XTAL1 XTAL2 3 4 55 58 21 22 62 60 17 9 57 10 11 12 8 ISP1583 3.3 V SoftConnect 1.5 k RPU RREF EOT 14 DMA HANDLER DMA INTERFACE INTRQ 15 IORDY(1) 2 6 NXP SIE/PIE HI-SPEED USB TRANSCEIVER MEMORY MANAGEMENT UNIT 12 k 37 to 40, 42 to 53 DMA REGISTERS 16 DATA[15:0] Rev. 06 -- 20 August 2007 62 BUS_CONF(3) 60 MODE0(2) 34 RESET_N 7 POWER-ON RESET internal reset INTEGRATED RAM (8 kB) 61 VOLTAGE 1.8 V digital REGULATORS supply 32, 56 DGND AGND VCC1V8 64 63 SUSPEND WAKEUP 19 OTG SRP MODULE 15 16 CS_N ALE/A0 RW_N/RD_N DS_N/WR_N READY(1) INT 26, 41, 54 VCC(I/O) 004aaa268 The figure shows the ISP1583BS pinout. For the ISP1583ET and ISP1583ET1 ballouts, see Table 2. (1) Pin 15 is shared by READY and IORDY. (2) Pin 60 is shared by MODE0 and DA1. (3) Pin 62 is shared by BUS_CONF and DA0. Fig 1. Block diagram ISP1583 4 of 100 (c) NXP B.V. 2007. All rights reserved. The direction of pins DREQ, DACK, DIOR and DIOW is determined by bit MASTER (DMA Hardware register) and bit ATA_MODE (DMA Configuration register). Hi-Speed USB Peripheral Controller 1, 5 36 20 SYSTEM CONTROLLER MODE1 8 AD[7:0] 18 MICROCONTROLLER INTERFACE I/O pad supply 13, 35, 59 23 to 25, 27 to 31 MICROCONTROLLER HANDLER analog supply VCC(3V3) NXP Semiconductors CS1_N DA1(2) DREQ VBUS 5. Block diagram ISP1583_6 Product data sheet 12 MHz to or from USB DP DM ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 6. Pinning information DATA13 DATA12 DATA11 51 50 49 DATA15 DATA14 54 52 VCC(I/O) 55 53 VCC1V8 VBUS XTAL2 57 56 DGND XTAL1 MODE0/DA1 60 58 VCC(3V3) 61 59 WAKEUP BUS_CONF/DA0 62 SUSPEND 63 terminal 1 index area 64 6.1 Pinning DATA10 AGND 1 48 RPU 2 47 DATA9 DP 3 46 DATA8 DM 4 45 DATA7 AGND 5 44 DATA6 RREF 6 43 RESET_N 7 42 DATA5 DATA4 41 VCC(I/O) 40 DATA3 DATA2 EOT 8 DREQ 9 DACK 10 39 ISP1583BS DIOR 11 38 DATA1 DIOW 12 37 DATA0 21 22 23 24 25 26 27 28 29 30 31 32 AD1 AD2 VCC(I/O) AD3 AD4 AD5 AD6 AD7 VCC1V8 n.c. CS1_N AD0 33 CS0_N 16 20 MODE1 INT DS_N/WR_N 34 19 15 RW_N/RD_N DGND READY/IORDY 18 ALE/A0 35 17 36 14 DA2 13 CS_N DGND INTRQ 004aaa537 Transparent top view Fig 2. Pin configuration ISP1583BS (top view) ball A1 index area 1 2 3 4 5 6 7 8 9 10 A B C D E F G H J K ISP1583ET 004aaa859 Transparent top view Fig 3. Pin configuration ISP1583ET (top view) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 5 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller ISP1583ET1 ball A1 index area 1 2 3 4 5 6 7 8 A B C D E F G H 004aaa991 Transparent top view Fig 4. Pin configuration ISP1583ET1 (top view) 6.2 Pin description Table 2. Pin description Symbol[1] Pin Type[2] Description ISP1583BS ISP1583ET ISP1583ET1 AGND 1 D2 D2 - analog ground RPU 2 A1 A1 A pull-up resistor connection; this pin must be connected to 3.3 V through an external 1.5 k resistor to pull up pin DP DP 3 B1 B1 A USB D+ line connection (analog) DM 4 C1 C1 A USB D- line connection (analog) AGND 5 - - - analog ground RREF 6 D1 D1 A external bias resistor connection; this pin must be connected to ground through a 12.0 k 1 % resistor RESET_N 7 E2 C3 I reset input (500 s); a LOW level produces an asynchronous reset; connect to VCC(3V3) for power-on reset (internal POR circuit) When the RESET_N pin is LOW, ensure that the WAKEUP pin does not go from LOW to HIGH; otherwise the device will enter test mode. TTL; 5 V tolerant EOT 8 E1 D3 I end-of-transfer input (programmable polarity); used in DMA slave mode only; when not in use, connect this pin to VCC(I/O) through a 10 k resistor input pad; TTL; 5 V tolerant DREQ 9 F2 E1 I/O DMA request input or output (programmable polarity); the signal direction depends on bit MASTER in register DMA Hardware (see Table 57): * * Input: DMA master mode if bit MASTER = 1 Output: DMA slave mode if bit MASTER = 0 When not in use, in the default setting, this pin must be connected to ground through a 10 k resistor. bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 6 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Symbol[1] DACK Pin description ...continued Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 10 E2 F1 I/O DMA acknowledge input or output (programmable polarity); the signal direction depends on bit MASTER in register DMA Hardware (see Table 57): * * Input: DMA slave mode if bit MASTER = 0 Output: DMA master mode if bit MASTER = 1 When not in use, in the default setting, this pin must be connected to VCC(I/O) through a 10 k resistor. bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DIOR 11 G2 E3 I/O DMA read strobe input or output (programmable polarity); the signal direction depends on bit MASTER in register DMA Hardware (see Table 57): * * Input: DMA slave mode if bit MASTER = 0 Output: DMA master mode if bit MASTER = 1 When not in use, in the default setting, this pin must be connected to VCC(I/O) through a 10 k resistor. bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DIOW 12 G1 F1 I/O DMA write strobe input or output (programmable polarity); the signal direction depends on bit MASTER in register DMA Hardware (see Table 57): * * Input: DMA slave mode if bit MASTER = 0 Output: DMA master mode if bit MASTER = 1 When not in use, in the default setting, this pin must be connected to VCC(I/O) through a 10 k resistor. bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DGND 13 H2 F2 - digital ground INTRQ 14 H1 G2 I interrupt request input; from the ATA/ATAPI peripheral; use a 10 k resistor to pull down input pad; TTL; 5 V tolerant READY/IORDY 15 J1 G1 I/O Signal ready output -- Used in generic processor mode: * LOW: the ISP1583 is processing a previous command or data and is not ready for the next command or data transfer * HIGH: the ISP1583 is ready for the next microprocessor read or write I/O ready input -- Used in split bus mode to access ATA/ATAPI peripherals (PIO mode only) bidirectional pad; 10 ns slew-rate control; TTL; 5 V tolerant INT 16 K1 H1 O interrupt output; programmable polarity (active HIGH or LOW) and signaling (edge or level triggered) CMOS output; 8 mA drive ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 7 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Pin description ...continued Symbol[1] DA2[3] Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 17 H2 J2 O address output to select the Task File register of an ATA/ATAPI device; see Table 59 CMOS output; 8 mA drive CS_N 18 K2 E4 I RW_N/RD_N 19 J3 F3 I chip selection input input pad; TTL; 5 V tolerant Read or write input -- For the Freescale mode, this function is determined by pin MODE0 = LOW during power-up. Read input -- For the 8051 mode, this function is determined by pin MODE0 = HIGH during power-up. input pad; TTL; 5 V tolerant DS_N/WR_N 20 K3 H3 I Data selection input -- For the Freescale mode, this function is determined by pin MODE0 = LOW at power-up. Write input -- For the 8051 mode, this function is determined by pin MODE0 = HIGH at power-up. input pad; TTL; 5 V tolerant CS0_N[3] 21 J4 G3 O chip selection output 0 for the ATA/ATAPI device; see Table 59 CS1_N[3] 22 K4 F4 O chip selection output 1 for the ATA/ATAPI device; see Table 59 AD0 23 K5 G4 I/O bit 0 of the multiplexed address and data CMOS output; 8 mA drive CMOS output; 8 mA drive bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant AD1 24 J5 H4 I/O bit 1 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant AD2 25 K6 F5 I/O bit 2 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant VCC(I/O)[4] 26 J6 E5 - I/O pad supply voltage (1.65 V to 3.6 V); see Section 7.17 AD3 27 K7 H5 I/O bit 3 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant AD4 28 J7 G5 I/O bit 4 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant AD5 29 K8 G6 I/O bit 5 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 8 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Symbol[1] AD6 Pin description ...continued Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 30 H6 J8 I/O bit 6 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant AD7 31 K9 H7 I/O bit 7 of the multiplexed address and data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant VCC1V8[4] 32 K10 H8 - voltage regulator output (1.8 V 0.15 V); tapped out voltage from the internal regulator; this regulated voltage cannot drive external devices; decouple this pin using a 0.1 F capacitor; see Section 7.17 n.c. 33 - - - not connected MODE1 34 J10 G8 I mode selection input 1; used in split bus mode only: * * LOW: ALE function (address latch enable) HIGH (connect to VCC(I/O)): A0 function (address/data indicator) Remark: When operating in generic processor mode, set pin MODE1 as HIGH. input pad; TTL; 5 V tolerant DGND 35 H9 F8 - digital ground ALE/A0 36 H10 F7 I Address latch enable input -- When pin MODE1 = LOW during power-up, a falling edge on this pin latches the address on the multiplexed address and data bus AD[7:0]. Address and data selection input -- When pin MODE1 = HIGH during power-up, the function is determined by the level on this pin (detected on the rising edge of the WR_N pulse): * * HIGH: bus AD[7:0] is a register address LOW: bus AD[7:0] is register data; used in split bus mode only Remark: When operating in generic processor mode with pin MODE1 = HIGH, this pin must be pulled down using a 10 k resistor. input pad; TTL; 5 V tolerant DATA0 37 G9 F6 I/O bit 0 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA1 38 G10 E6 I/O bit 1 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA2 39 F9 E7 I/O bit 2 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA3 40 F10 E8 I/O bit 3 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 9 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Symbol[1] VCC(I/O) [4] DATA4 Pin description ...continued Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 41 E9 D7 - I/O pad supply voltage (1.65 V to 3.6 V); see Section 7.17 42 E10 D6 I/O bit 4 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA5 43 D10 D8 I/O bit 5 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA6 44 D9 D5 I/O bit 6 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA7 45 C10 D4 I/O bit 7 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA8 46 C9 C8 I/O bit 8 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA9 47 B10 C7 I/O bit 9 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA10 48 A10 A8 I/O bit 10 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA11 49 A9 C4 I/O bit 11 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA12 50 B8 B7 I/O bit 12 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA13 51 A8 A7 I/O bit 13 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA14 52 B7 C6 I/O bit 14 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant DATA15 53 A7 C5 I/O bit 15 of the bidirectional data bus bidirectional pad; 4 ns slew-rate control; TTL; 5 V tolerant VCC(I/O)[4] 54 B6 B6 - I/O pad supply voltage (1.65 V to 3.6 V); see Section 7.17 ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 10 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Pin description ...continued Symbol[1] VBUS Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 55 A6 B5 A USB bus power sensing input -- Used to detect whether the host is connected or not; connect a 1 F electrolytic or tantalum capacitor and a 1 M pull-down resistor to ground; see Section 7.15 VBUS pulsing output -- In OTG mode; connect a 1 F electrolytic or tantalum capacitor and a 1 M pull-down resistor to ground; see Section 7.15 5 V tolerant VCC1V8[4] 56 A6 B5 - voltage regulator output (1.8 V 0.15 V); tapped out voltage from the internal regulator; this regulated voltage cannot drive external devices; decouple this pin using 4.7 F and 0.1 F capacitors; see Section 7.17 XTAL2 57 A5 A5 O crystal oscillator output (12 MHz); connect a fundamental parallel-resonant crystal; leave this pin open when using an external clock source on pin XTAL1; see Table 98 XTAL1 58 A4 A4 I crystal oscillator input (12 MHz); connect a fundamental parallel-resonant crystal or an external clock source (leaving pin XTAL2 unconnected); see Table 98 DGND 59 B4 B4 - digital ground MODE0/DA1[3] 60 A3 C2 I/O Mode selection input 0 -- Selects the read/write strobe functionality in generic processor mode during power-up: * LOW: for the Freescale mode; the function of pin 19 is RW_N and pin 20 is DS_N * HIGH (connect to VCC(I/O)): for the 8051 mode; the function of pin 19 is RD_N and pin 20 is WR_N Address selection output -- Selects the Task File register of an ATA/ATAPI device during normal operation; see Table 59 bidirectional pad; 10 ns slew-rate control; TTL; 5 V tolerant VCC(3V3)[4] 61 B3 B3 - regulator supply voltage (3.3 V 0.3 V); this pin supplies the internal regulator; see Section 7.17 ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 11 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 2. Pin description ...continued Symbol[1] BUS_CONF/ DA0[3] Type[2] Description Pin ISP1583BS ISP1583ET ISP1583ET1 62 A3 B2 I/O Bus configuration input -- Selects bus mode during power-up: * LOW: split bus mode; multiplexed 8-bit address and data bus on AD[7:0], separate DMA data bus DATA[15:0][5] * HIGH (connect to VCC(I/O)): generic processor mode; separate 8-bit address on AD[7:0], 16-bit processor data bus on DATA[15:0]; DMA is multiplexed on processor bus DATA[15:0] Address selection output -- Selects the Task File register of an ATA/ATAPI device at normal operation; see Table 59 bidirectional pad; 10 ns slew-rate control; TTL; 5 V tolerant WAKEUP 63 A2 B2 I wake-up input; when this pin is at the HIGH level, the chip is prevented from going into the suspend state and wake-up the chip when already in suspend mode; when not in use, connect this pin to ground through a 10 k resistor When the RESET_N pin is LOW, ensure that the WAKEUP pin does not go from LOW to HIGH; otherwise the device will enter test mode. input pad; TTL; 5 V tolerant SUSPEND 64 C2 A2 O suspend state indicator output; used as a power switch control output to power-off or power-on external devices when going into suspend mode or recovering from suspend mode DGND - B9 - - digital ground DGND exposed die J9 pad B8, G7 - ground supply; down bonded to the exposed die pad (heat sink); to be connected to DGND during the PCB layout CMOS output; 8 mA drive [1] Symbol names ending with underscore N, for example, NAME_N, represent active LOW signals. [2] All outputs and I/O pins can source 4 mA, unless otherwise specified. [3] Control signals are not 3-stated. [4] Add a decoupling capacitor (0.1 F) to all the supply pins. For better EMI results, add a 0.01 F capacitor in parallel to 0.1 F. [5] The DMA bus is in 3-state until a DMA command (see Section 8.4.1) is executed. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 12 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7. Functional description The ISP1583 is a high-speed USB Peripheral Controller. It implements the Hi-Speed USB or the Original USB physical layer, and the packet protocol layer. It concurrently maintains up to 16 USB endpoints (control IN, control OUT, and seven IN and seven OUT configurable) along with endpoint EP0 set up, which accesses the set-up buffer. The Ref. 1 "Universal Serial Bus Specification Rev. 2.0", Chapter 9 protocol handling is executed using the external firmware. The ISP1583 has a fast general-purpose interface to communicate with most types of microcontrollers and microprocessors. This microcontroller interface is configured using pins BUS_CONF/DA0, MODE1 and MODE0/DA1 to accommodate most interface types. Two bus configurations are available, selected using input BUS_CONF/DA0 during power-up: * Generic processor mode (pin BUS_CONF/DA0 = HIGH): - AD[7:0]: 8-bit address bus (selects target register) - DATA[15:0]: 16-bit data bus (shared by processor and DMA) - Control signals: RW_N and DS_N or RD_N and WR_N (selected using pin MODE0/DA1), CS_N - DMA interface (generic slave mode only): Uses lines DATA[15:0] as data bus, DIOR and DIOW as dedicated read and write strobes * Split bus mode (pin BUS_CONF/DA0 = LOW): - AD[7:0]: 8-bit local microprocessor bus (multiplexed address and data) - DATA[15:0]: 16-bit DMA data bus - Control signals: CS_N, ALE or A0 (selected using pin MODE1), RW_N and DS_N or RD_N and WR_N (selected using pin MODE0/DA1) - DMA interface (master or slave mode): Uses DIOR and DIOW as dedicated read and write strobes For high-bandwidth data transfer, the integrated DMA handler can be invoked to transfer data to or from external memory or devices. The DMA interface can be configured by writing to proper DMA registers (see Section 8.4). The ISP1583 supports Hi-Speed USB and Original USB signaling. The USB signaling speed is automatically detected. The ISP1583 has 8 kB of internal FIFO memory, which is shared among enabled USB endpoints, including control IN and control OUT endpoints, and set-up token buffer. There are seven IN and seven OUT configurable endpoints, and two fixed control endpoints that are 64 bytes long. Any of the seven IN and seven OUT endpoints can be separately enabled or disabled. The endpoint type (interrupt, isochronous or bulk) and packet size of these endpoints can be individually configured, depending on the requirements of the application. Optional double buffering increases the data throughput of these data endpoints. The ISP1583 requires 3.3 V power supply. It has 5 V tolerant I/O pads and an internal 1.8 V regulator to power the digital logic. The I/O voltage can range from 1.65 V to 3.6 V. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 13 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller The ISP1583 operates on a 12 MHz crystal oscillator. An integrated 40 x PLL clock multiplier generates the internal sampling clock of 480 MHz. 7.1 DMA interface, DMA handler and DMA registers The DMA block can be subdivided into two blocks: DMA handler and DMA interface. The firmware writes to the DMA Command register to start a DMA transfer (see Table 49). The command opcode determines whether a generic DMA, Parallel I/O (PIO) or Multi-word DMA (MDMA) transfer will start. The handler interfaces to the same FIFO (internal RAM) as used by the USB core. On receiving the DMA command, the DMA handler directs the data from the endpoint FIFO to the external DMA device or from the external DMA device to the endpoint FIFO. The DMA interface configures the timing and the DMA handshake. Data can be transferred using either the DIOR and DIOW strobes or the DACK and DREQ handshakes. DMA configurations are set up by writing to the DMA Configuration register (see Table 54 and Table 55). For an IDE-based storage interface, applicable DMA modes are PIO and MDMA (Multi-word DMA; ATA). For a generic DMA interface, DMA modes that can be used are Generic DMA (GDMA) slave. Remark: The DMA endpoint buffer length must be a multiple of 4 bytes. For details on DMA registers, see Section 8.4. 7.2 Hi-Speed USB transceiver The analog transceiver directly interfaces to the USB cable through integrated termination resistors. The high-speed transceiver requires an external resistor (12.0 k 1 %) between pin RREF and ground to ensure an accurate current mirror that generates the Hi-Speed USB current drive. A full-speed transceiver is integrated as well. This makes the ISP1583 compliant to Hi-Speed USB and Original USB, supporting both the high-speed and full-speed physical layers. After automatic speed detection, the NXP Serial Interface Engine (SIE) sets the transceiver to use either high-speed or full-speed signaling. 7.3 MMU and integrated RAM The Memory Management Unit (MMU) manages the access to the integrated RAM that is shared by the USB, microcontroller handler and DMA handler. Data from the USB bus is stored in the integrated RAM, which is cleared only when the microcontroller has read the corresponding endpoint, or the DMA controller has written all data from the RAM of the corresponding endpoint to the DMA bus. The OUT endpoint buffer can also be forcibly cleared by setting bit CLBUF in the Control Function register. A total of 8 kB RAM is available for buffering. 7.4 Microcontroller interface and microcontroller handler The microcontroller interface allows direct interfacing to most microcontrollers and microprocessors. The interface is configured at power-up through pins BUS_CONF/DA0, MODE1 and MODE0/DA1. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 14 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller When pin BUS_CONF/DA0 = HIGH, the microcontroller interface switches to generic processor mode in which AD[7:0] is the 8-bit address bus and DATA[15:0] is the separate 16-bit data bus. If pin BUS_CONF/DA0 = LOW, the interface is in split bus mode, where AD[7:0] is the local microprocessor bus (multiplexed address and data) and DATA[15:0] is solely used as the DMA bus. When pin MODE0/DA1 = HIGH, pins RW_N/RD_N and DS_N/WR_N are the read and write strobes (8051 mode). If pin MODE0/DA1 = LOW, pins RW_N/RD_N and DS_N/WR_N represent the direction and data strobes (Freescale mode). When pin MODE1 = LOW, pin ALE/A0 is used to latch the multiplexed address on pins AD[7:0]. When pin MODE1 = HIGH, pin ALE/A0 is used to indicate address or data. Pin MODE1 is only used in split bus mode; in generic processor mode, it must be tied to VCC(I/O). The microcontroller handler allows the external microcontroller to access the register set in the NXP SIE, as well as the DMA handler. The initialization of the DMA configuration is done through the microcontroller handler. 7.5 OTG SRP module The OTG supplement defines a Session Request Protocol (SRP), which allows a B-device to request the A-device to turn on VBUS and start a session. This protocol allows the A-device, which may be battery-powered, to conserve power by turning off VBUS when there is no bus activity while still providing a means for the B-device to initiate bus activity. Any A-device, including a PC or laptop, can respond to SRP. Any B-device, including a standard USB peripheral, can initiate SRP. The ISP1583 is a device that can initiate SRP. 7.6 NXP high-speed transceiver 7.6.1 NXP Parallel Interface Engine (PIE) In the High-Speed (HS) transceiver, the NXP PIE interface uses a 16-bit parallel bidirectional data interface. The functions of the HS module also include bit-stuffing or de-stuffing and Non-Return-to-Zero Inverted (NRZI) encoding or decoding logic. 7.6.2 Peripheral circuit To maintain a constant current driver for HS transmit circuits and to bias other analog circuits, an internal band gap reference circuit and an RREF resistor form the reference current. This circuit requires an external precision resistor (12.0 k 1 %) connected to the analog ground. 7.6.3 HS detection The ISP1583 handles more than one electrical state, Full-Speed (FS) or High-Speed (HS), under the USB specification. When the USB cable is connected from the peripheral to the Host Controller, the ISP1583 defaults to the FS state, until it sees a bus reset from the Host Controller. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 15 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller During the bus reset, the peripheral initiates an HS chirp to detect whether the Host Controller supports Hi-Speed USB or Original USB. If the HS handshake shows that there is an HS host connected, then the ISP1583 switches to the HS state. In the HS state, the ISP1583 must observe the bus for periodic activity. If the bus remains inactive for 3 ms, the peripheral switches to the FS state to check for a Single-Ended Zero (SE0) condition on the USB bus. If an SE0 condition is detected for the designated time (100 s to 875 s; refer to Ref. 1 "Universal Serial Bus Specification Rev. 2.0", Section 7.1.7.6), the ISP1583 switches to the HS chirp state to perform an HS detection handshake. Otherwise, the ISP1583 remains in the FS state, adhering to the bus-suspend specification. 7.6.4 Isolation Ensure that the DP and DM lines are maintained in a clean state, without any residual voltage or glitches. Once the ISP1583 is reset and the clock is available, ensure that there are no erroneous pulses or glitches even of very small amplitude on the DP and DM lines. Remark: If there are any erroneous unwanted pulses or glitches detected by the ISP1583 DP and DM lines, there is a possibility of the ISP1583 clocking this state into the internal core, causing unknown behaviors. 7.7 NXP Serial Interface Engine (SIE) The NXP SIE implements the full USB protocol layer. It is completely hardwired for speed and needs no firmware intervention. The functions of this block include: synchronization pattern recognition, parallel or serial conversion, bit-stuffing or de-stuffing, CRC checking or generation, Packet IDentifier (PID) verification or generation, address recognition, handshake evaluation or generation. 7.8 SoftConnect The USB connection is established by pulling pin DP (for full-speed devices) to HIGH through a 1.5 k pull-up resistor. In the ISP1583, an external 1.5 k pull-up resistor must be connected between pin RPU and 3.3 V. The RPU pin connects the pull-up resistor to pin DP, when bit SOFTCT in the Mode register is set (see Table 22 and Table 23). After a hardware reset, the pull-up resistor is disconnected by default (bit SOFTCT = 0). The USB bus reset does not change the value of bit SOFTCT. When VBUS is not present, the SOFTCT bit must be set to logic 0 to comply with the back-drive voltage. 7.9 Clear buffer Use clear buffer when data needs to be discarded under the following conditions: * IN endpoint: If the host aborts a read operation, the residual data in the IN endpoint buffer must be cleared using the CLBUF bit. See Table 36. For details on clearing the IN buffer, refer to Ref. 5 "ISP1582/83 and ISP1761 clearing an IN buffer (AN10045)". * OUT endpoint: If the host aborts a write operation, the residual data in the OUT endpoint buffer must be cleared using the CLBUF bit. See Table 36. For example, to clear a double buffer data OUT endpoint 1, set the following registers in the firmware as: ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 16 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 1. Assign a value to the DMA Endpoint register. It can be any value other than the value assigned to the Endpoint Index register. In this example, do not assign 2h to the DMA Endpoint register. See remark in Section 8.3.1. 2. Assign Endpoint Index register = 2h 3. Assign Control Function register = 10h 4. Assign Endpoint Index register = 2h 5. Assign Control Function register = 10h 7.10 Reconfiguring endpoints The ISP1583 endpoints have a limitation when implementing a composite device with at least two functionalities that require the support of alternate settings, for example, the video class and audio class devices. The ISP1583 endpoints cannot be reconfigured on the fly because it is implemented as a FIFO base. The internal RAM partition will be corrupted if there is a need to reconfigure endpoints on the fly because of alternate settings request, causing data corruption. For details and work-around, refer to Ref. 3 "ISP1581/2/3 Frequently Asked Questions (AN10046)". 7.11 System controller The system controller implements the USB power-down capabilities of the ISP1583. Registers are protected against data corruption during wake-up following a resume (from the suspend state) by locking the write access, until an unlock code is written to the Unlock Device register (see Table 88 and Table 89). 7.12 Modes of operation The ISP1583 has two bus configuration modes, selected using pin BUS_CONF/DA0 at power-up: * Split bus mode (BUS_CONF/DA0 = LOW): 8-bit multiplexed address and data bus, and separate 8-bit or 16-bit DMA bus * Generic processor mode (BUS_CONF/DA0 = HIGH): separate 8-bit address and 16-bit data bus Details of bus configurations for each mode are given in Table 3. Typical interface circuits for each mode are given in Section 13. Table 3. Bus configuration modes Pin PIO width BUS_CONF/ DA0 DMA width WIDTH = 0 WIDTH = 1 LOW D[7:0] D[15:0] AD[7:0] Description split bus mode: * * HIGH A[7:0] and D[15:0] D[7:0] D[15:0] Multiplexed address and data on pins AD[7:0] Separate 8-bit or 16-bit DMA bus on pins DATA[15:0] generic processor mode: * * Separate 8-bit address on pins AD[7:0] 16-bit data (PIO and DMA) on pins DATA[15:0] ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 17 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7.13 Pins status Table 4 illustrates the behavior of ISP1583 pins with VCC(I/O) and VCC(3V3) in various operating conditions. Table 4. ISP1583 pin status VCC(3V3) VCC(I/O) State Pin Input Output I/O 0V 0V dead[1] unknown unknown unknown 0V 1.65 V to 3.6 V plug-out[2] high-Z unknown high-Z 0 V 3.3 V 1.65 V to 3.6 V plug-in[3] high-Z unknown high-Z 3.3 V 1.65 V to 3.6 V reset state depends on how the pin is driven output high-Z 3.3 V 1.65 V to 3.6 V after reset state depends on how the pin is driven output state depends on how the pin is configured [1] Dead: the USB cable is plugged out, and VCC(I/O) is not available. [2] Plug-out: the USB cable is not present, but VCC(I/O) is available. [3] Plug-in: the USB cable is being plugged in, and VCC(I/O) is available. Table 5 illustrates the behavior of output pins with VCC(I/O) and VCC(3V3) in various operating conditions. Table 5. ISP1583 output pin status VCC(3V3) VCC(I/O) State INT SUSPEND 0V dead[1] LOW HIGH 0V 1.65 V to 3.6 V plug-out[2] LOW HIGH 0 V 3.3 V 1.65 V to 3.6 V plug-in[3] LOW HIGH 3.3 V 1.65 V to 3.6 V reset HIGH LOW 3.3 V 1.65 V to 3.6 V after reset HIGH LOW 0V [1] Dead: the USB cable is plugged out, and VCC(I/O) is not available. [2] Plug-out: the USB cable is not present, but VCC(I/O) is available. [3] Plug-in: the USB cable is being plugged in, and VCC(I/O) is available. 7.14 Interrupt 7.14.1 Interrupt output pin The Interrupt Configuration register of the ISP1583 controls the behavior of the INT output pin. The polarity and signaling mode of the INT pin can be programmed by setting bits INTPOL and INTLVL of the Interrupt Configuration register (R/W: 10h); see Table 26. Bit GLINTENA of the Mode register (R/W: 0Ch) is used to enable pin INT; see Table 23. Default settings after reset are active LOW and level mode. When pulse mode is selected, a pulse of 60 ns is generated when the OR-ed combination of all interrupt bits changes from logic 0 to logic 1. Figure 5 shows the relationship between interrupt events and pin INT. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 18 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Each of the indicated USB and DMA events is logged in a status bit of the Interrupt register and the DMA Interrupt Reason register, respectively. Corresponding bits in the Interrupt Enable register and the DMA Interrupt Enable register determine whether an event will generate an interrupt. Interrupts can be masked globally by means of bit GLINTENA of the Mode register. Field CDBGMOD[1:0] of the Interrupt Configuration register controls the generation of INT signals for the control pipe. Field DDBGMODIN[1:0] of the Interrupt Configuration register controls the generation of INT signals for the IN pipe. Field DDBGMODOUT[1:0] of the Interrupt Configuration register controls the generation of INT signals for the OUT pipe; see Table 27. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 19 of 100 xxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxx x x x xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxx xx xx xxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxx xxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxx x x xxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxx xxx NXP Semiconductors ISP1583_6 Product data sheet DMA Interrupt Reason register Interrupt Enable register GDMA_STOP IEBRST EXT_EOT IESOF INT_EOT ...... .... IEDMA ...... BSY_DONE .... Rev. 06 -- 20 August 2007 TF_RD_DONE IEP7RX CMD_INTRQ_OK IE_GDMA_STOP .............. DMA Interrupt Enable register OR IEP7TX OR Interrupt register BRESET SOF IE_EXT_EOT ...... LATCH DMA INT PULSE OR LEVEL GENERATOR Interrupt Configuration register INTPOL GLINTENA EP7TX Mode register 004aaa267 Fig 5. Interrupt logic ISP1583 EP7RX Hi-Speed USB Peripheral Controller 20 of 100 (c) NXP B.V. 2007. All rights reserved. IE_CMD_INTRQ_OK ...... IE_TF_RD_DONE LE ...... IE_BSY_DONE .... IE_INT_EOT ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7.14.2 Interrupt control Bit GLINTENA in the Mode register is a global interrupt enable or disable bit. The behavior of this bit is given in Figure 6. The following illustrations are only applicable for level trigger. Event A: When an interrupt event occurs (for example, SOF interrupt) with bit GLINTENA set to logic 0, an interrupt will not be generated at pin INT. It will, however, be registered in the corresponding Interrupt register bit. Event B: When bit GLINTENA is set to logic 1, pin INT is asserted because bit SOF in the Interrupt register is already set. Event C: If the firmware sets bit GLINTENA to logic 0, pin INT will still be asserted. The bold line shows the desired behavior of pin INT. De-assertion of pin INT can be achieved either by clearing all the bits in the Interrupt register or the DMA Interrupt Reason register, depending on the event. Remark: When clearing an interrupt event, perform write to all the bytes of the register. For more information on interrupt control, see Section 8.2.2, Section 8.2.5 and Section 8.5.1. A B C INT pin GLINTENA = 0 (during this time, an interrupt event occurs, for example, SOF asserted) GLINTENA = 1 SOF asserted GLINTENA = 0 SOF asserted 004aaa394 Pin INT: HIGH = de-assert; LOW = assert (individual interrupts are enabled). Fig 6. Behavior of bit GLINTENA 7.15 VBUS sensing The VBUS pin is one of the ways to wake up the clock when the ISP1583 is suspended with bit CLKAON set to logic 0 (clock off option). To detect whether the host is connected or not, that is VBUS sensing, a 1 M resistor and a 1 F electrolytic or tantalum capacitor must be added to damp the overshoot on plug in. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 21 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 55 ISP1583 1 M 1 F USB CONNECTOR 004aaa449 The figure shows the ISP1583BS pinout. For the ISP1583ET and ISP1583ET1 ballouts, see Table 2. Fig 7. Resistor and electrolytic or tantalum capacitor needed for VBUS sensing 001aaf440 Fig 8. Oscilloscope reading: no resistor and capacitor in the network 001aaf441 Fig 9. Oscilloscope reading: with resistor and capacitor in the network ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 22 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7.16 Power-on reset The ISP1583 requires a minimum pulse width of 500 s. The RESET_N pin can either be connected to VCC(3V3) (using the internal POR circuit) or externally controlled (by the microcontroller, ASIC, and so on). When VCC(3V3) is directly connected to the RESET_N pin, the internal pulse width tPORP will typically be 200 ns. The power-on reset function can be explained by viewing the dips at t2 to t3 and t4 to t5 on the VCC(POR) curve (Figure 10). t0 -- The internal POR starts with a HIGH level. t1 -- The detector will see the passing of the trip level and a delay element will add another tPORP before it drops to LOW. t2 to t3 -- The internal POR pulse will be generated whenever VCC(POR) drops below Vtrip for more than 11 s. t4 to t5 -- The dip is too short (< 11 s) and the internal POR pulse will not react and will remain LOW. VBAT(POR) Vtrip t0 t1 t4 t3 t2 t5 PORP(1) tPORP tPORP 004aaa389 (1) PORP = Power-On Reset Pulse. Fig 10. POR timing Figure 11 shows the availability of the clock with respect to the external POR. VCC(3V3) 500 s external clock 2 ms RESET_N A B C 004aaa906 Power on VCC(3V3) at A. Stable external clock is to be available at B. The ISP1583 is operational at C. Fig 11. Clock with respect to the external POR ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 23 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7.17 Power supply The ISP1583 can be powered by 3.3 V 0.3 V, and from 1.65 V to 3.6 V at the interface. For connection details, see Figure 12. If the ISP1583 is powered by VCC(3V3) = 3.3 V, an integrated 3.3 V-to-1.8 V voltage regulator provides a 1.8 V supply voltage for the internal logic. In sharing mode (that is, when VCC(3V3) is not present and VCC(I/O) is present), all I/O pins are input type, the interrupt pin is connected to ground, and the suspend pin is connected to VCC(I/O). See Table 5. 61 3.3 V 0.3 V VCC(3V3) 0.1 F 0.01 F 26 VCC(I/O) 1.65 V to 3.6 V 0.01 F 41 0.1 F VCC(I/O) 0.01 F 0.1 F ISP1583 54 VCC(I/O) 0.01 F 56 4.7 F(1) 32 0.1 F VCC1V8 0.1 F VCC1V8 0.1 F 004aaa271 (1) At the VCC input (3.3 V) to the USB controller, if the ripple voltage is less than 20 mV, then 4.7 F standard electrolytic or tantalum capacitors (tested ESR up to 10 ) should be OK at the VCC1V8 output. If the ripple voltage at the input is higher than 20 mV, then use 4.7 F LOW ESR capacitors (ESR from 0.2 to 2 ) at the VCC1V8 output. This is to improve the high-speed signal quality at the USB side. The figure shows the ISP1583BS pinout. For the ISP1583ET and ISP1583ET1 ballouts, see Table 2. Fig 12. ISP1583 with a 3.3 V supply Table 6 shows power modes in which the ISP1583 can be operated. Table 6. Power modes VCC(3V3) VBUS [1] VCC(I/O) Power mode [2] bus-powered VBUS System-powered system-powered self-powered VBUS[1] system-powered power-sharing (hybrid) [1] The power supply to the IC (VCC(3V3)) is 3.3 V. Therefore, if the application is bus-powered, a 3.3 V regulator needs to be used. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 24 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller [2] VCC(I/O) can range from 1.65 V to 3.6 V. If the application is bus-powered, a voltage regulator must be used. 7.17.1 Power-sharing mode to GPIO of processor for sensing VBUS 5 V-to-3.3 V VOLTAGE REGULATOR 1.5 k RPU VCC(3V3) VBUS ISP1583 VBUS 1 F USB 1 M VCC(I/O) 004aaa458 VCC(I/O) is system powered. Fig 13. Power-sharing mode As can be seen in Figure 13, in power-sharing mode, VCC(3V3) is supplied by the output of the 5 V-to-3.3 V voltage regulator. The input to the regulator is from VBUS. VCC(I/O) is supplied through the power source of the system. When the USB cable is plugged in, the ISP1583 goes through the power-on reset cycle. In this mode, OTG is disabled. The processor will experience continuous interrupt because the default status of the interrupt pin when operating in sharing mode with VBUS not present is LOW. To overcome this, implement external VBUS sensing circuitry. The output from the voltage regulator can be connected to pin GPIO of the processor to qualify the interrupt from the ISP1583. Remark: When the core power is applied, the ISP1583 must be reset using the RESET_N pin. The minimum width of the reset pulse width must be 2 ms. VCC(I/O) VCC(3V3) INT power off power off 004aaa459 Fig 14. Interrupt pin status during power off in power-sharing mode ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 25 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 7. Operation truth table for SoftConnect ISP1583 operation Power supply Bit SOFTCT in Mode register VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS Normal bus operation 3.3 V 3.3 V 3.3 V 5V enabled Core power is lost 0V 3.3 V 0V 0V not applicable Table 8. Operation truth table for clock off during suspend ISP1583 operation Power supply Clock will wake up: Clock off during suspend VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V enabled 0V 3.3 V 0V 0V not applicable After a resume and After a bus reset Core power is lost Table 9. Operation truth table for back voltage compliance ISP1583 operation Power supply VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS Back voltage is not measured in this mode 3.3 V 3.3 V 3.3 V 5V enabled Back voltage is not an issue because core power is lost 0V 3.3 V 0V 0V not applicable Table 10. Operation truth table for OTG ISP1583 operation SRP is not applicable Power supply OTG register VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V not applicable 3.3 V 0V 0V not applicable OTG is not possible because VBUS is not 0 V present and so core power is lost ISP1583_6 Product data sheet Bit SOFTCT in Mode register (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 26 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 7.17.2 Self-powered mode 1.5 k RPU VCC(3V3) VBUS VBUS USB ISP1583 1 F 1 M VCC(I/O) 004aaa461 VCC(I/O) and VCC(3V3) are system powered. Fig 15. Self-powered mode In self-powered mode, VCC(3V3) and VCC(I/O) are supplied by the system. See Figure 15. Table 11. Operation truth table for SoftConnect ISP1583 operation Power supply Normal bus operation No pull up on DP [1] VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V 3.3 V 3.3 V 3.3 V 0 Bit SOFTCT in Mode register enabled V[1] disabled When the USB cable is removed, SoftConnect is disabled. Table 12. Operation truth table for clock off during suspend ISP1583 operation Power supply Clock will wake up: Clock off during suspend VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V enabled 3.3 V 3.3 V 3.3 V 0V5V enabled After a resume and After a bus reset Clock will wake up: After detecting the presence of VBUS Table 13. Operation truth table for back voltage compliance ISP1583 operation Power supply VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V enabled Back voltage is not an issue because pull 3.3 V up on DP will not be present when VBUS is not present 3.3 V 3.3 V 0V disabled Back voltage is not measured in this mode ISP1583_6 Product data sheet Bit SOFTCT in Mode register (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 27 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 14. Operation truth table for OTG ISP1583 operation Power supply OTG register VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS SRP is not applicable 3.3 V 3.3 V 3.3 V 5V not applicable SRP is possible 3.3 V 3.3 V 3.3 V 0V operational 7.17.3 Bus-powered mode 5 V-to-3.3 V VOLTAGE REGULATOR VBUS VCC(3V3) 1.65 V to 3.3 V VBUS USB ISP1583 1 F 1 M VCC(I/O) 1.5 k RPU 004aaa463 VCC(I/O) is powered by VBUS. Fig 16. Bus-powered mode In bus-powered mode (see Figure 16), VCC(3V3) and VCC(I/O) are supplied by the output of the 5 V-to-3.3 V voltage regulator. The input to the regulator is from VBUS. On plugging the USB cable, the ISP1583 goes through the power-on reset cycle. In this mode, OTG is disabled. Table 15. Operation truth table for SoftConnect ISP1583 operation Power supply VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS Bit SOFTCT in Mode register Normal bus operation 3.3 V 3.3 V 3.3 V 5V enabled Power is lost 0V 0V 0V 0V not applicable Table 16. Operation truth table for clock off during suspend ISP1583 operation Clock will wake up: Power supply Clock off during suspend VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS 3.3 V 3.3 V 3.3 V 5V enabled 0V 0V 0V 0V not applicable After a resume and After a bus reset Power is lost ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 28 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 17. Operation truth table for back voltage compliance ISP1583 operation Power supply VCC(3V3) VCC(I/O) RPU (3.3 V) VBUS Back voltage is not measured in this mode 3.3 V 3.3 V 3.3 V 5V enabled Power is lost 0V 0V 0V 0V not applicable Table 18. Operation truth table for OTG ISP1583 operation Power supply OTG register VCC(3V3) VCC(I/O) RPU (3.3 V) SRP is not applicable 3.3 V 3.3 V 3.3 V 5V not applicable Power is lost 0V 0V 0V 0V not applicable ISP1583_6 Product data sheet Bit SOFTCT in Mode register VBUS (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 29 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 8. Register description Table 19. Register overview Name Destination Address Description Size (bytes) Reference Address device 00h USB device address and enable 1 Section 8.2.1 on page 32 Mode device 0Ch power-down options, global interrupt enable, SoftConnect 2 Section 8.2.2 on page 32 Interrupt Configuration device 10h interrupt sources, trigger mode, output polarity 1 Section 8.2.3 on page 34 OTG device 12h OTG implementation 1 Section 8.2.4 on page 35 Interrupt Enable device 14h interrupt source enabling 4 Section 8.2.5 on page 37 Endpoint Index endpoints 2Ch endpoint selection, data flow direction 1 Section 8.3.1 on page 39 Control Function endpoint 28h endpoint buffer management 1 Section 8.3.2 on page 40 Data Port endpoint 20h data access to endpoint FIFO 2 Section 8.3.3 on page 41 Buffer Length endpoint 1Ch packet size counter 2 Section 8.3.4 on page 42 Buffer Status endpoint 1Eh buffer status for each endpoint 1 Section 8.3.5 on page 43 Endpoint MaxPacketSize endpoint 04h maximum packet size 2 Section 8.3.6 on page 44 Endpoint Type endpoint 08h selects endpoint type: isochronous, bulk or interrupt 2 Section 8.3.7 on page 45 DMA Command DMA controller 30h controls all DMA transfers 1 Section 8.4.1 on page 48 DMA Transfer Counter DMA controller 34h sets byte count for DMA transfer 4 Section 8.4.2 on page 50 DMA Configuration DMA controller 38h byte 0: sets GDMA configuration (counter enable, data strobing, bus width) 1 Section 8.4.3 on page 51 39h byte 1: sets ATA configuration (IORDY 1 enable, mode selection: ATA, MDMA, PIO) 3Ch endian type, master or slave selection, signal polarity for DACK, DREQ, DIOW, DIOR, EOT Initialization registers Data flow registers DMA registers DMA Hardware DMA controller ISP1583_6 Product data sheet 1 Section 8.4.4 on page 52 (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 30 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 19. Register overview ...continued Name Destination Address Description Size (bytes) Reference Task File 1F0 ATAPI peripheral 40h single address word register: byte 0 (lower byte) is accessed first 2 Section 8.4.5 on page 54 Task File 1F1 ATAPI peripheral 48h IDE device access 1 Task File 1F2 ATAPI peripheral 49h IDE device access 1 Task File 1F3 ATAPI peripheral 4Ah IDE device access 1 Task File 1F4 ATAPI peripheral 4Bh IDE device access 1 Task File 1F5 ATAPI peripheral 4Ch IDE device access 1 Task File 1F6 ATAPI peripheral 4Dh IDE device access 1 Task File 1F7 ATAPI peripheral 44h IDE device access (write only; reading 1 returns FFh) Task File 3F6 ATAPI peripheral 4Eh IDE device access 1 Task File 3F7 ATAPI peripheral 4Fh IDE device access 1 DMA Interrupt Reason DMA controller 50h shows reason (source) for DMA interrupt 2 Section 8.4.6 on page 56 DMA Interrupt Enable DMA controller 54h enables DMA interrupt sources 2 Section 8.4.7 on page 58 DMA Endpoint DMA controller 58h selects endpoint FIFO, data flow direction 1 Section 8.4.8 on page 58 DMA Strobe Timing DMA controller 60h strobe duration in MDMA mode 1 Section 8.4.9 on page 59 DMA Burst Counter DMA controller 64h DMA burst length 2 Section 8.4.10 on page 59 Interrupt device 18h shows interrupt sources 4 Section 8.5.1 on page 60 Chip ID device 70h product ID code and hardware version 3 Section 8.5.2 on page 62 Frame Number device 74h last successfully received Start-Of-Frame: lower byte (byte 0) is accessed first 2 Section 8.5.3 on page 62 Scratch device 78h allows save or restore of firmware status during suspend 2 Section 8.5.4 on page 63 Unlock Device device 7Ch re-enables register write access after suspend 2 Section 8.5.5 on page 64 Test Mode PHY 84h direct setting of the DP and DM 1 states, internal transceiver test (PHY) Section 8.5.6 on page 64 General registers 8.1 Register access Register access depends on the bus width used: * 8-bit bus: multi-byte registers are accessed lower byte (LSByte) first * 16-bit bus: for single-byte registers, the upper byte (MSByte) must be ignored Endpoint specific registers are indexed using the Endpoint Index register. The target endpoint must be selected before accessing the following registers: ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 31 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller * * * * * * Buffer Length Buffer Status Control Function Data Port Endpoint MaxPacketSize Endpoint Type Remark: Write zero to all reserved bits, unless otherwise specified. 8.2 Initialization registers 8.2.1 Address register (address: 00h) This register sets the USB assigned address and enables the USB device. Table 20 shows the Address register bit allocation. Bits DEVADDR will be cleared whenever a bus reset, a power-on reset or a soft reset occurs. Bit DEVEN will be cleared whenever a power-on reset or a soft reset occurs. In response to standard USB request SET_ADDRESS, the firmware must write the (enabled) device address to the Address register, followed by sending an empty packet to the host. The new device address is activated when the device receives an acknowledgment from the host for the empty packet token. Table 20. Address register: bit allocation Bit 7 Symbol 5 4 DEVEN Reset Bus reset 6 3 2 1 0 DEVADDR[6:0] 0 0 0 0 0 0 0 0 unchanged 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Table 21. Address register: bit description Bit Symbol Description 7 DEVEN Device Enable: Logic 1 enables the device. The device will not respond to the host, unless this bit is set. 6 to 0 DEVADDR[6:0] Device Address: This field specifies the USB device address. 8.2.2 Mode register (address: 0Ch) This register consists of 2 bytes (bit allocation: see Table 22). The Mode register controls resume, suspend and wake-up behavior, interrupt activity, soft reset, clock signals and SoftConnect operation. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 32 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 22. Mode register: bit allocation Bit 15 14 13 TEST2 TEST1 TEST0 Reset - - - - - Bus reset - - - - Access R R R - Symbol Bit 12 11 10 9 8 DMA CLKON VBUSSTAT - 0 -[1] - - 0 -[1] - - R/W R reserved 7 6 5 4 3 2 1 0 CLKAON SNDRSU GOSUSP SFRESET GLINTENA WKUPCS PWRON SOFTCT Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 unchanged 0 0 unchanged R/W R/W R/W R/W R/W R/W R/W R/W Symbol Access [1] Value depends on the status of the VBUS pin. Table 23. Mode register: bit description Bit Symbol Description 15 TEST2 This bit reflects the MODE1 pin setting. Only for test purposes. 14 TEST1 This bit reflects the MODE0/DA1 pin setting. Only for test purposes. 13 TEST0 This bit reflects the BUS_CONF/DA0 pin setting. Only for test purposes. 12 to 10 - reserved 9 DMA Clock On: DMACLKON 0 -- Power save mode; the DMA circuit will stop completely to save power. 1 -- Supply clock to the DMA circuit. 8 VBUSSTAT VBUS Pin Status: This bit reflects the VBUS pin status. 7 CLKAON Clock Always On: Logic 1 indicates that internal clocks are always running when in the suspend state. Logic 0 switches off the internal oscillator and PLL when the device goes into suspend mode. The device will consume less power if this bit is set to logic 0. The clock is stopped about 2 ms after bit GOSUSP is set and then cleared. 6 SNDRSU Send Resume: Writing logic 1, followed by logic 0 will generate a 10 ms upstream resume signal. Remark: The upstream resume signal is generated 5 ms after this bit is set to logic 0. 5 GOSUSP Go Suspend: Writing logic 1, followed by logic 0 will activate suspend mode. 4 SFRESET Soft Reset: Writing logic 1, followed by logic 0 will enable a software-initiated reset to the ISP1583. A soft reset is similar to a hardware-initiated reset (using the RESET_N pin). ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 33 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 23. Mode register: bit description ...continued Bit Symbol Description 3 GLINTENA Global Interrupt Enable: Logic 1 enables all interrupts. Individual interrupts can be masked by clearing the corresponding bits in the Interrupt Enable register. When this bit is not set, an unmasked interrupt will not generate an interrupt trigger on the interrupt pin. If global interrupt, however, is enabled while there is any pending unmasked interrupt, an interrupt signal will be immediately generated on the interrupt pin. (If the interrupt is set to pulse mode, the interrupt events that were generated before the global interrupt is enabled will not appear on the interrupt pin.) 2 WKUPCS Wake-up on Chip selection: Logic 1 enables wake-up from suspend mode through a valid register read on the ISP1583. (A read will invoke the chip clock to restart. If you write to the register before the clock gets stable, it may cause malfunctioning.) 1 PWRON Power On: The SUSPEND pin output control. 0 -- The SUSPEND pin is HIGH when the ISP1583 is in the suspend state. Otherwise, the SUSPEND pin is LOW. 1 -- When the device is woken up from the suspend state, there will be a 1 ms active HIGH pulse on the SUSPEND pin. The SUSPEND pin will remain LOW in all other states. 0 SOFTCT SoftConnect: Logic 1 enables the connection of the 1.5 k pull-up resistor on pin RPU to the DP pin. The status of the chip is shown in Table 24. Table 24. Status of the chip Bus state SoftConnect = on SoftConnect = off VBUS on pull-up resistor on pin DP pull-up resistor on pin DP is removed; suspend interrupt is generated after 3 ms of no bus activity VBUS off pull-up resistor on pin DP is present; pull-up resistor on pin DP is removed; suspend interrupt is generated after suspend interrupt is generated after 3 ms of 3 ms of no bus activity no bus activity 8.2.3 Interrupt Configuration register (address: 10h) This 1-byte register determines the behavior and polarity of the INT output. The bit allocation is shown in Table 25. When the USB SIE receives or generates an ACK, NAK or NYET, it will generate interrupts, depending on three Debug mode fields. CDBGMOD[1:0] -- interrupts for control endpoint 0 DDBGMODIN[1:0] -- interrupts for DATA IN endpoints 1 to 7 DDBGMODOUT[1:0] -- interrupts for DATA OUT endpoints 1 to 7 The Debug mode settings for CDBGMOD, DDBGMODIN and DDBGMODOUT allow you to individually configure when the ISP1583 sends an interrupt to the external microprocessor. Table 27 lists available combinations. Bit INTPOL controls the signal polarity of the INT output: active HIGH or LOW, rising or falling edge. For level-triggering, bit INTLVL must be made logic 0. By setting INTLVL to logic 1, an interrupt will generate a pulse of 60 ns (edge-triggering). ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 34 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 25. Interrupt Configuration register: bit allocation Bit 7 Symbol CDBGMOD[1:0] Reset 1 1 1 1 1 1 0 0 Bus reset 1 1 1 1 1 1 unchanged unchanged R/W R/W R/W R/W R/W R/W R/W R/W Access 6 Table 26. 5 4 3 DDBGMODIN[1:0] 2 DDBGMODOUT[1:0] 1 0 INTLVL INTPOL Interrupt Configuration register: bit description Bit Symbol Description 7 to 6 CDBGMOD[1:0] Control Endpoint 0 Debug Mode: For values, see Table 27 5 to 4 DDBGMODIN[1:0] Data Debug Mode IN: For values, see Table 27 3 to 2 DDBGMODOUT[1:0] Data Debug Mode OUT: For values, see Table 27 1 INTLVL Interrupt Level: Selects signaling mode on output INT (0 = level; 1 = pulsed). In pulsed mode, an interrupt produces a 60 ns pulse. 0 INTPOL Interrupt Polarity: Selects signal polarity on output INT (0 = active LOW, 1 = active HIGH). Table 27. Debug mode settings Value CDBGMOD DDBGMODIN DDBGMODOUT 00h interrupt on all ACK and NAK interrupt on all ACK and NAK interrupt on all ACK, NYET and NAK 01h interrupt on all ACK interrupt on ACK interrupt on ACK and NYET 1Xh interrupt on all ACK and first NAK[1] interrupt on all ACK and first NAK[1] interrupt on all ACK, NYET and first NAK[1] [1] First NAK: the first NAK on an IN or OUT token is generated after a set-up token and an ACK sequence. 8.2.4 OTG register (address: 12h) The bit allocation of the OTG register is given in Table 28. Table 28. OTG register: bit allocation Bit 7 Symbol 6 reserved 5 4 3 2 1 0 DP BSESSVALID INITCOND DISCV VP OTG Reset - - 0 - - 0 0 0 Bus reset - - 0 - - 0 0 0 Access - - R/W R/W R/W R/W R/W R/W ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 35 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 29. OTG register: bit description Bit Symbol Description[1] 7 to 6 - reserved 5 DP Data Pulsing: Used for data-line pulsing to toggle DP to generate the required data-line pulsing signal. The default value of this bit is logic 0. This bit must be cleared when data-line pulsing is completed. 4 BSESS VALID B-Session Valid: The device can initiate another VBUS discharge sequence after data-line pulsing and VBUS pulsing, and before it clears this bit and detects a session valid. This bit is latched to logic 1 once VBUS exceeds the B-device session valid threshold. Once set, it remains at logic 1. To clear this bit, write logic 1. (The ISP1583 continuously updates this bit to logic 1 when the B-session is valid. If the B-session is valid after it is cleared, it is set back to logic 1 by the ISP1583). 0 -- It implies that SRP has failed. To proceed to a normal operation, the device can restart SRP, clear bit OTG or proceed to an error handling process. 1 -- It implies that the B-session is valid. The device clears bit OTG, goes into normal operation mode, and sets bit SOFTCT (DP pull-up) in the Mode register. The OTG host has a maximum of 5 s before it responds to a session request. During this period, the ISP1583 may request to suspend. Therefore, the device firmware must wait for some time if it wishes to know the SRP result (success: if there is minimum response from the host within 5 s; failure: if there is no response from the host within 5 s). 3 INIT COND Initial Condition: Write logic 1 to clear this bit. Wait for more than 2 ms and check the bit status. If it reads logic 0, it means that VBUS remains lower than 0.8 V, and DP or DM are at SE0 during the elapsed time. The device can then start a B-device SRP. If it reads logic 1, it means that the initial condition of SRP is violated. So, the device must abort SRP. The bit is set to logic 1 by the ISP1583 when initial conditions are not met, and only writing logic 1 clears the bit. (If initial conditions are not met after this bit has been cleared, it will be set again). Remark: This implementation does not cover the case if an initial SRP condition is violated when this bit is read and data-line pulsing is started. 2 DISCV Discharge VBUS: Set to logic 1 to discharge VBUS. The device discharges VBUS before starting a new SRP. The discharge can take as long as 30 ms for VBUS to be charged less than 0.8 V. This bit must be cleared (write logic 0) before a session end. 1 VP VBUS Pulsing: Used for VBUS pulsing to toggle VP to generate the required VBUS pulsing signal. This bit must be set for more than 16 ms and must be cleared before 26 ms. 0 OTG On-The-Go: 1 -- Enables the OTG function. The VBUS sensing functionality will be disabled. 0 -- Normal operation. All OTG control bits will be masked. Status bits are undefined. [1] No interrupt is designed for OTG. The VBUS interrupt, however, may assert as a side effect during the VBUS pulsing. When OTG is in progress, the VBUS interrupt may be set because VBUS is charged over the VBUS sensing threshold or the OTG host has turned on the VBUS supply to the device. Even if the VBUS interrupt is found during SRP, the device must complete data-line pulsing and VBUS pulsing before starting the B_SESSION_VALID detection. OTG implementation applies to the device with self-power capability. If the device works in sharing mode, it must provide a switch circuit to supply power to the ISP1583 core during SRP. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 36 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 8.2.4.1 Session Request Protocol (SRP) The ISP1583 can initiate an SRP. The B-device initiates SRP by data-line pulsing, followed by VBUS pulsing. The A-device can detect either data-line pulsing or VBUS pulsing. The ISP1583 can initiate the B-device SRP by performing the following steps: 1. Set the OTG bit to start SRP. 2. Detect initial conditions by following the instructions given in bit INITCOND of the OTG register. 3. Start data-line pulsing: set bit DP of the OTG register to logic 1. 4. Wait for 5 ms to 10 ms. 5. Stop data-line pulsing: set bit DP of the OTG register to logic 0. 6. Start VBUS pulsing: set bit VP of the OTG register to logic 1. 7. Wait for 10 ms to 20 ms. 8. Stop VBUS pulsing: set bit VP of the OTG register to logic 0. 9. Discharge VBUS for about 30 ms: optional by using bit DISCV of the OTG register. 10. Detect bit BSESSVALID of the OTG register for a successful SRP with bit OTG cleared. 11. Once bit BSESSVALID is detected, turn on the SOFTCT bit to start normal bus enumeration. The B-device must complete both data-line pulsing and VBUS pulsing within 100 ms. Remark: When disabling OTG, data-line pulsing bit DP and VBUS pulsing bit VP must be cleared by writing logic 0. 8.2.5 Interrupt Enable register (address: 14h) This register enables or disables individual interrupt sources. The interrupt for each endpoint can individually be controlled using the associated bits IEPnRX or IEPnTX, here n represents the endpoint number. All interrupts can be globally disabled using bit GLINTENA in the Mode register (see Table 22). An interrupt is generated when the USB SIE receives or generates an ACK or NAK on the USB bus. The interrupt generation depends on Debug mode settings of bit fields CDBGMOD[1:0], DDBGMODIN[1:0] and DDBGMODOUT[1:0] in the Interrupt Configuration register. All data IN transactions use the Transmit buffers (TX), which are handled by bits DDBGMODIN[1:0]. All data OUT transactions go through the Receive buffers (RX), which are handled by bits DDBGMODOUT[1:0]. Transactions on control endpoint 0 (IN, OUT and SETUP) are handled by bits CDBGMOD[1:0]. Interrupts caused by events on the USB bus (SOF, suspend, resume, bus reset, set up and high-speed status) can also be individually controlled. A bus reset disables all enabled interrupts, except bit IEBRST (bus reset), which remains logic 1. The Interrupt Enable register consists of 4 bytes. The bit allocation is given in Table 30. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 37 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 30. Interrupt Enable register: bit allocation Bit 31 30 29 28 Symbol 27 26 reserved 25 24 IEP7TX IEP7RX Reset - - - - - - 0 0 Bus reset - - - - - - 0 0 Access - - - - - - R/W R/W 23 22 21 20 19 18 17 16 Bit Symbol IEP6TX IEP6RX IEP5TX IEP5RX IEP4TX IEP4RX IEP3TX IEP3RX Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Bit 15 14 13 12 11 10 9 8 IEP2TX IEP2RX IEP1TX IEP1RX IEP0TX IEP0RX reserved IEP0SETUP Reset 0 0 0 0 0 0 - 0 Bus reset 0 0 0 0 0 0 - 0 R/W R/W R/W R/W R/W R/W - R/W 7 6 5 4 3 2 1 0 IEVBUS IEDMA IEHS_STA IERESM IESUSP IEPSOF IESOF IEBRST 0 0 0 0 0 0 0 0 Symbol Access Bit Symbol Reset Bus reset Access 0 0 0 0 0 0 0 1 R/W R/W R/W R/W R/W R/W R/W R/W Table 31. Interrupt Enable register: bit description Bit Symbol Description 31 to 26 - reserved 25 IEP7TX Logic 1 enables interrupt from the indicated endpoint. 24 IEP7RX Logic 1 enables interrupt from the indicated endpoint. 23 IEP6TX Logic 1 enables interrupt from the indicated endpoint. 22 IEP6RX Logic 1 enables interrupt from the indicated endpoint. 21 IEP5TX Logic 1 enables interrupt from the indicated endpoint. 20 IEP5RX Logic 1 enables interrupt from the indicated endpoint. 19 IEP4TX Logic 1 enables interrupt from the indicated endpoint. 18 IEP4RX Logic 1 enables interrupt from the indicated endpoint. 17 IEP3TX Logic 1 enables interrupt from the indicated endpoint. 16 IEP3RX Logic 1 enables interrupt from the indicated endpoint. 15 IEP2TX Logic 1 enables interrupt from the indicated endpoint. 14 IEP2RX Logic 1 enables interrupt from the indicated endpoint. 13 IEP1TX Logic 1 enables interrupt from the indicated endpoint. 12 IEP1RX Logic 1 enables interrupt from the indicated endpoint. 11 IEP0TX Logic 1 enables interrupt from control IN endpoint 0. 10 IEP0RX Logic 1 enables interrupt from control OUT endpoint 0. 9 - reserved 8 IEP0SETUP Logic 1 enables interrupt for the set-up data received on endpoint 0. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 38 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 31. Interrupt Enable register: bit description ...continued Bit Symbol Description 7 IEVBUS Logic 1 enables interrupt for VBUS sensing. 6 IEDMA Logic 1 enables interrupt on DMA Interrupt Reason register change detection. 5 IEHS_STA Logic 1 enables interrupt on detecting a high-speed status change. 4 IERESM Logic 1 enables interrupt on detecting a resume state. 3 IESUSP Logic 1 enables interrupt on detecting a suspend state. 2 IEPSOF Logic 1 enables interrupt on detecting a pseudo SOF. 1 IESOF Logic 1 enables interrupt on detecting an SOF. 0 IEBRST Logic 1 enables interrupt on detecting a bus reset. 8.3 Data flow registers 8.3.1 Endpoint Index register (address: 2Ch) The Endpoint Index register selects a target endpoint for register access by the microcontroller. The register consists of 1 byte, and the bit allocation is shown in Table 32. The following registers are indexed: * * * * * * Buffer length Buffer status Control function Data port Endpoint MaxPacketSize Endpoint type For example, to access the OUT data buffer of endpoint 1 using the Data Port register, the Endpoint Index register must first be written with 02h. Remark: The Endpoint Index register and the DMA Endpoint register must not point to the same endpoint, irrespective of IN and OUT. Remark: The delay time from the Write Endpoint Index register to the Read Data Port register must be at least 190 ns. Remark: The delay time from the Write Endpoint Index register to the Write Data Port register must be at least 100 ns. Table 32. Endpoint Index register: bit allocation Bit 7 Symbol 6 reserved 5 4 3 EP0SETUP 2 1 ENDPIDX[3:0] 0 DIR Reset - - 0 0 0 0 0 0 Bus reset - - 0 0 0 0 0 0 Access - - R/W R/W R/W R/W R/W R/W ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 39 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 33. Endpoint Index register: bit description Bit Symbol Description 7 to 6 - reserved 5 EP0SETUP Endpoint 0 Setup: Selects the SETUP buffer for endpoint 0. 0 -- Data buffer 1 -- SETUP buffer Must be logic 0 for access to endpoints other than set-up token buffer. 4 to 1 ENDPIDX[3:0] Endpoint Index: Selects the target endpoint for register access of buffer length, buffer status, control function, data port, endpoint type and MaxPacketSize. 0 DIR Direction Bit: Sets the target endpoint as IN or OUT. 0 -- Target endpoint refers to OUT (RX) FIFO 1 -- Target endpoint refers to IN (TX) FIFO Table 34. Addressing of endpoint buffers Buffer name EP0SETUP ENDPIDX DIR SETUP 1 00h 0 Control OUT 0 00h 0 Control IN 0 00h 1 Data OUT 0 0Xh 0 Data IN 0 0Xh 1 8.3.2 Control Function register (address: 28h) The Control Function register performs the buffer management on endpoints. It consists of 1 byte, and the bit configuration is given in Table 35. Register bits can stall, clear or validate any enabled endpoint. Before accessing this register, the Endpoint Index register must first be written to specify the target endpoint. Table 35. Control Function register: bit allocation Bit 7 Symbol 6 5 reserved 4 3 2 1 0 CLBUF VENDP DSEN STATUS STALL 0 0 0 0 0 Reset - - - Bus reset - - - 0 0 0 0 0 Access - - - R/W R/W W R/W R/W ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 40 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 36. Bit Control Function register: bit description Symbol Description 7 to 5 - reserved. 4 Clear Buffer: Logic 1 clears the TX or RX buffer of the indexed endpoint. The RX buffer is automatically cleared once the endpoint is completely read. This bit is set only when it is necessary to forcefully clear the buffer. For details, see Section 7.9. CLBUF Remark: If using double buffer, to clear both the buffers issue the CLBUF command two times, that is, set and clear this bit two times. 3 VENDP Validate Endpoint: Logic 1 validates data in the TX FIFO of an IN endpoint to send on the next IN token. In general, the endpoint is automatically validated when its FIFO byte count has reached endpoint MaxPacketSize. This bit is set only when it is necessary to validate the endpoint with the FIFO byte count, which is below endpoint MaxPacketSize. Remark: Use either bit VENDP or register Buffer Length to validate endpoint FIFO with FIFO bytes. 2 DSEN Data Stage Enable: This bit controls the response of the ISP1583 to a control transfer. After the completion of the set-up stage, firmware must determine whether a data stage is required. For control OUT, firmware will set this bit and the ISP1583 goes into the data stage. Otherwise, the ISP1583 will NAK the data stage transfer. For control IN, firmware will set this bit before writing data to the TX FIFO and validate the endpoint. If no data stage is required, firmware can immediately set the STATUS bit after the set-up stage. Remark: The DSEN bit is cleared once the OUT token is acknowledged by the device and the IN token is acknowledged by the PC host. This bit cannot be read back and reading this bit will return logic 0. 1 STATUS Status Acknowledge: Only applicable for control IN or OUT. This bit controls the generation of ACK or NAK during the status stage of a SETUP transfer. It is automatically cleared when the status stage is completed, or when a SETUP token is received. No interrupt signal will be generated. 0 -- Sends NAK 1 -- Sends an empty packet following the IN token (peripheral-to-host) or ACK following the OUT token (host-to-peripheral) Remark: The STATUS bit is cleared to zero once the zero-length packet is acknowledged by the device or the PC host. Remark: Data transfers preceding the status stage must first be fully completed before the STATUS bit can be set. 0 STALL Stall Endpoint: Logic 1 stalls the indexed endpoint. This bit is not applicable for isochronous transfers. Remark: Stalling a data endpoint will confuse the Data Toggle bit about the stalled endpoint because the internal logic picks up from where it is stalled. Therefore, the Data Toggle bit must be reset by disabling and re-enabling the corresponding endpoint (by setting bit ENABLE to logic 0, followed by logic 1 in the Endpoint Type register) to reset the PID. 8.3.3 Data Port register (address: 20h) This 2-byte register provides direct access for a microcontroller to the FIFO of the indexed endpoint. The bit allocation is shown in Table 37. Peripheral-to-host (IN endpoint): After each write action, an internal counter is auto incremented (by two for a 16-bit access, by one for an 8-bit access) to the next location in the TX FIFO. When all bytes are written (FIFO byte count = endpoint MaxPacketSize), the ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 41 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller buffer is automatically validated. The data packet will then be sent on the next IN token. When it is necessary to validate the endpoint whose byte count is less than MaxPacketSize, it can be done using the Control Function register (bit VENDP) or the Buffer Length register. Remark: The buffer can automatically be validated by using the Buffer Length register (see Table 39). Host-to-peripheral (OUT endpoint): After each read action, an internal counter is auto decremented (by two for a 16-bit access, by one for an 8-bit access) to the next location in the RX FIFO. When all bytes are read, buffer contents are automatically cleared. A new data packet can then be received on the next OUT token. Buffer contents can also be cleared using the Control Function register (bit CLBUF), when it is necessary to forcefully clear contents. Remark: The delay time from the Write Endpoint Index register to the Read Data Port register must be at least 190 ns. Remark: The delay time from the Write Endpoint Index register to the Write Data Port register must be at least 100 ns. Table 37. Data Port register: bit allocation Bit 15 14 13 12 Reset 0 0 0 0 Bus reset 0 0 0 R/W R/W R/W 7 6 5 Symbol 11 10 9 8 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W 4 3 2 1 0 DATAPORT[15:8] Access Bit Symbol DATAPORT[7:0] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Table 38. Data Port register: bit description Bit Symbol Description 15 to 8 DATAPORT[15:8] data (upper byte) 7 to 0 DATAPORT[7:0] data (lower byte) 8.3.4 Buffer Length register (address: 1Ch) This register determines the current packet size (DATACOUNT) of the indexed endpoint FIFO. The bit allocation is given in Table 39. The Buffer Length register is automatically loaded with the FIFO size, when the Endpoint MaxPacketSize register is written (see Table 43). A smaller value can be written when required. After a bus reset, the Buffer Length register is made zero. IN endpoint: When data transfer is performed in multiples of MaxPacketSize, the Buffer Length register is not significant. This register is useful only when transferring data that is not a multiple of MaxPacketSize. The following two examples demonstrate the significance of the Buffer Length register. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 42 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Example 1: Consider that the transfer size is 512 bytes and the MaxPacketSize is programmed as 64 bytes, the Buffer Length register need not be filled. This is because the transfer size is a multiple of MaxPacketSize, and MaxPacketSize packets will be automatically validated because the last packet is also of MaxPacketSize. Example 2: Consider that the transfer size is 510 bytes and the MaxPacketSize is programmed as 64 bytes, the Buffer Length register must be filled with 62 bytes just before the microprocessor writes the last packet of 62 bytes. This ensures that the last packet, which is a short packet of 62 bytes, is automatically validated. Use bit VENDP in the Control register if you are not using the Buffer Length register. This is applicable only to PIO mode access. OUT endpoint: The DATACOUNT value is automatically initialized to the number of data bytes sent by the host on each ACK. Remark: When using a 16-bit microprocessor bus, the last byte of an odd-sized packet is output as the lower byte (LSByte). Remark: Buffer Length is valid only after an interrupt is generated for the OUT endpoint. Table 39. Buffer Length register: bit allocation Bit 15 14 13 12 Symbol 11 10 9 8 0 0 0 DATACOUNT[15:8] Reset 0 Bus reset Access Bit 0 0 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 7 6 5 4 3 2 1 0 Symbol DATACOUNT[7:0] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Table 40. Buffer Length register: bit description Bit Symbol Description 15 to 0 DATACOUNT[15:0] Data Count: Determines the current packet size of the indexed endpoint FIFO. 8.3.5 Buffer Status register (address: 1Eh) This register is accessed using index. The endpoint index must first be set before accessing this register for the corresponding endpoint. It reflects the status of the double buffered endpoint FIFO. Remark: This register is not applicable to the control endpoint. Remark: For endpoint IN data transfer, firmware must ensure a 200 ns delay between writing of the data packet and reading the Buffer Status register. For endpoint OUT data transfer, firmware must also ensure a 200 ns delay between the reception of the endpoint interrupt and reading the Buffer Status register. For more information, refer to Ref. 3 "ISP1581/2/3 Frequently Asked Questions (AN10046)". ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 43 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 41 shows the bit allocation of the Buffer Status register. Table 41. Buffer Status register: bit allocation Bit 7 6 5 4 Symbol 3 2 reserved 1 0 BUF1 BUF0 Reset - - - - - - 0 0 Bus reset - - - - - - 0 0 Access - - - - - - R R Table 42. Buffer Status register: bit description Bit Symbol Description 7 to 2 - reserved 1 to 0 BUF[1:0] Buffer: 00 -- Buffers are not filled. 01 -- One of the buffers is filled. 10 -- One of the buffers is filled. 11 -- Both the buffers are filled. 8.3.6 Endpoint MaxPacketSize register (address: 04h) This register determines the maximum packet size for all endpoints, except control 0. The register contains 2 bytes, and the bit allocation is given in Table 43. Each time the register is written, the Buffer Length register of the corresponding endpoint is re-initialized to the FFOSZ field value. Bits NTRANS control the number of transactions allowed in a single micro frame (for high-speed isochronous and interrupt endpoints only). Table 43. Endpoint MaxPacketSize register: bit allocation Bit 15 Symbol 14 13 12 reserved 11 10 NTRANS[1:0] 0 8 FFOSZ[10:8] Reset - - - Bus reset - - - 0 0 0 0 0 Access - - - R/W R/W R/W R/W R/W Bit 7 6 5 4 3 2 1 0 Symbol 0 9 0 0 0 FFOSZ[7:0] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 44 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 44. Endpoint MaxPacketSize register: bit description Bit Symbol Description 15 to 13 - reserved 12 to 11 NTRANS[1:0] Number of Transactions (HS mode only). 00 -- 1 packet per micro frame 01 -- 2 packets per micro frame 10 -- 3 packets per micro frame 11 -- reserved. These bits are applicable only for isochronous or interrupt transactions. 10 to 0 FFOSZ[10:0] FIFO Size: Sets the FIFO size, in bytes, for the indexed endpoint. Applies to both high-speed and full-speed operations. The ISP1583 supports all the transfers given in Ref. 1 "Universal Serial Bus Specification Rev. 2.0". Each programmable FIFO can be independently configured using its Endpoint MaxPacketSize register (R/W: 04h), but the total physical size of all enabled endpoints (IN plus OUT), including set-up token buffer, control IN and control OUT, must not exceed 8192 bytes. 8.3.7 Endpoint Type register (address: 08h) This register sets the endpoint type of the indexed endpoint: isochronous, bulk or interrupt. It also serves to enable the endpoint and configure it for double buffering. Automatic generation of an empty packet for a zero-length TX buffer can be disabled using bit NOEMPKT. The register contains 2 bytes, and the bit allocation is shown in Table 45. Table 45. Endpoint Type register: bit allocation Bit 15 14 13 12 11 10 9 8 Reset - - - - - - - - Bus reset - - - - - - - - Access - - - - - - - - Bit 7 6 5 1 Symbol reserved Symbol reserved 4 3 2 NOEMPKT ENABLE DBLBUF 0 ENDPTYP[1:0] Reset - - - 0 0 0 0 0 Bus reset - - - 0 0 0 0 0 Access - - - R/W R/W R/W R/W R/W ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 45 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 46. Endpoint Type register: bit description Bit Symbol Description 15 to 5 - reserved 4 NOEMPKT No Empty Packet: Logic 0 causes the ISP1583 to return a null length packet for the IN token after the DMA IN transfer is complete. For ATA mode or the DMA IN transfer, which does not require a null length packet after DMA completion, set to logic 1 to disable the generation of the null length packet. 3 ENABLE Endpoint Enable: Logic 1 enables the FIFO of the indexed endpoint. The memory size is allocated as specified in the Endpoint MaxPacketSize register. Logic 0 disables the FIFO. Remark: Stalling a data endpoint will confuse the Data Toggle bit on the stalled endpoint because the internal logic picks up from where it has stalled. Therefore, the Data Toggle bit must be reset by disabling and re-enabling the corresponding endpoint (by setting bit ENABLE to logic 0, followed by logic 1 in the Endpoint Type register) to reset the PID. 2 DBLBUF Double Buffering: Logic 1 enables double buffering for the indexed endpoint. Logic 0 disables double buffering. 1 to 0 ENDPTYP[1:0] Endpoint Type: These bits select the endpoint type. 00 -- not used 01 -- Isochronous 10 -- Bulk 11 -- Interrupt 8.4 DMA registers Two types of Generic DMA transfer and three types of IDE-specified transfer can be done by writing the proper opcode in the DMA Command register. Control bits are given in Table 47 (Generic DMA transfers) and Table 48 (IDE-specified transfers). GDMA read/write (opcode = 00h/01h) -- Generic DMA slave mode. Depending on the MODE[1:0] bits set in the DMA configuration register, the DACK, DIOR or DIOW signal strobes data. These signals are driven by the external DMA controller. GDMA slave mode can operate in either counter mode or EOT-only mode. In counter mode, bit DIS_XFER_CNT in the DMA Configuration register must be set to logic 0. The DMA Transfer Counter register must be programmed before any DMA command is issued. The DMA transfer counter is set by writing from the LSByte to the MSByte (address: 34h to 37h). The DMA transfer count is internally updated only after the MSByte is written. Once the DMA transfer is started, the transfer counter starts decrementing and on reaching 0, bit DMA_XFER_OK is set and an interrupt is generated by the ISP1583. If the DMA master wishes to terminate the DMA transfer, it can issue an EOT signal to the ISP1583. This EOT signal overrides the transfer counter and can terminate the DMA transfer at any time. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 46 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller In EOT-only mode, DIS_XFER_CNT must be set to logic 1. Although the DMA transfer counter can still be programmed, it will not have any effect on the DMA transfer. The DMA transfer will start once the DMA command is issued. Any of the following three ways will terminate this DMA transfer: * Detecting an external EOT * Detecting an internal EOT (short packet on an OUT token) * Issuing a GDMA stop command There are three interrupts programmable to differentiate the method of DMA termination: bits INT_EOT, EXT_EOT and DMA_XFER_OK in the DMA Interrupt Reason register (see Table 72). MDMA (master) read/write (opcode = 06h/07h) -- Generic DMA master mode. Depending on the MODE[1:0] bits set in the DMA Configuration register, the DACK, DIOR or DIOW signal strobes data. These signals are driven by the ISP1583. In master mode, BURSTCOUNTER[12:0] in the DMA Burst Counter register, DIS_XFER_CNT in the DMA Configuration register and the external EOT signal are not applicable. The DMA transfer counter is always enabled and bit DMA_XFER_OK is set to 1 once the counter reaches 0. MDMA read/write (opcode = 06h/07h) -- Multi-word DMA mode for IDE transfers. The specification of this mode can be obtained from Ref. 4 "AT Attachment with Packet Interface Extension (ATA/ATAPI-4), ANSI INCITS 317-1998 (R2003)". DIOR and DIOW are used as data strobes, while DREQ and DACK serve as handshake signals. Table 47. Control bits for Generic DMA transfers Control bits Description Reference GDMA read/write (opcode = MDMA (master) read/write 00h/01h) (opcode = 06h/07h) DMA Configuration register ATA_MODE set to logic 0 (non-ATA transfer) set to logic 1 (ATA transfer) DMA_MODE[1:0] - determines MDMA timing for DIOR and DIOW strobes DIS_XFER_CNT disables use of DMA transfer counter disables use of DMA transfer counter MODE[1:0] determines active read/write data strobe signals determines active data strobe(s) WIDTH selects DMA bus width: 8 or 16 bits selects DMA bus width: 8 or 16 bits ISP1583_6 Product data sheet Table 54 (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 47 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 47. Control bits for Generic DMA transfers ...continued Control bits Description Reference GDMA read/write (opcode = MDMA (master) read/write 00h/01h) (opcode = 06h/07h) DMA Hardware register ENDIAN[1:0] determines whether data is to determines whether data is to be byte swapped or normal; be byte swapped or normal; applicable only in 16-bit mode applicable only in 16-bit mode EOT_POL selects polarity of the EOT signal input EOT is not used MASTER set to logic 0 (slave) set to logic 1 (master) ACK_POL, DREQ_POL, WRITE_POL, READ_POL selects polarity of DMA handshake signals selects polarity of DMA handshake signals Table 48. Table 56 Control bits for IDE-specified DMA transfers Control bits Description Reference MDMA read/write (opcode = 06h/07h) DMA Configuration register Table 54 ATA_MODE set to logic 1 (ATA transfer) DMA_MODE[1:0] selects MDMA mode; timing are ATA(PI) compatible PIO_MODE[2:0] selects PIO mode; timing are ATA(PI) compatible DMA Hardware register MASTER Table 56 set to logic 0 Remark: The DMA bus defaults to 3-state, until a DMA command is executed. All the other control signals are not 3-stated. 8.4.1 DMA Command register (address: 30h) The DMA Command register is a 1-byte register (for bit allocation, see Table 49) that initiates all DMA transfer activity on the DMA controller. The register is write-only: reading it will return FFh. Remark: The DMA bus will be in 3-state, until a DMA command is executed. Table 49. DMA Command register: bit allocation Bit 7 6 5 Symbol 4 3 2 1 0 DMA_CMD[7:0] Reset 1 1 1 1 1 1 1 1 Bus reset 1 1 1 1 1 1 1 1 Access W W W W W W W W Table 50. DMA Command register: bit description Bit Symbol Description 7 to 0 DMA_CMD[7:0] DMA command code, see Table 51. PIO Read or Write that started using DMA Command register only performs a 16-bit transfer. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 48 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 51. DMA commands Code Name Description 00h GDMA Read Generic DMA IN token transfer (slave mode only): Data is transferred from the external DMA bus to the internal buffer. Strobe: DIOW by external DMA controller. 01h GDMA Write Generic DMA OUT token transfer (slave mode only): Data is transferred from the internal buffer to the external DMA bus. Strobe: DIOR by external DMA controller. 02h to 05h - reserved 06h MDMA Read Multi-word DMA Read: Data is transferred from the external DMA bus to the internal buffer. 07h MDMA Write Multi-word DMA Write: Data is transferred from the internal buffer to the external DMA bus. 0Ah Read 1F0 Read at address 1F0h: Initiates a PIO Read cycle from Task File 1F0. Before issuing this command, the task file byte count must be programmed at address 1F4h (LSByte) and 1F5h (MSByte). 0Bh Poll BSY Poll BSY status bit for ATAPI device: Starts repeated PIO Read commands to poll the BSY status bit of the ATAPI device. When BSY = 0, polling is terminated and an interrupt is generated. The interrupt can be masked but the interrupt bit will still be set. Therefore, you can manually poll this interrupt bit. 0Ch Read Task Files Read Task Files: Reads all task files. When Task File Index is set to logic 0, this command reads all registers, except 1F0h and 1F7h. If Task File Index is not logic 0, the Task register of the address set in the Task File register will be read. When the reading is completed, an interrupt is generated. The interrupt can be masked off, however, the interrupt bit will still be set. Therefore, you can manually poll this interrupt bit. 0Dh - reserved 0Eh Validate Buffer Validate Buffer (for debugging only): Request from the microcontroller to validate the endpoint buffer, following an ATA-to-USB data transfer. 0Fh Clear Buffer Clear Buffer: Request from the microcontroller to clear the endpoint buffer, after a DMA-to-USB data transfer. Logic 1 clears the TX buffer of the indexed endpoint; the RX buffer is not affected. The TX buffer is automatically cleared once data is sent on the USB bus. This bit is set only when it is necessary to forcefully clear the buffer. Remark: If using double buffer, to clear both the buffers issue the Clear Buffer command two times, that is, set and clear this bit two times. 10h Restart Restart: Request from the microcontroller to move the buffer pointers to the beginning of the endpoint FIFO. 11h Reset DMA Reset DMA: Initializes the DMA core to its power-on reset state. Remark: When the DMA core is reset during the Reset DMA command, the DREQ, DACK, DIOW and DIOR handshake pins will temporarily be asserted. This can confuse the external DMA controller. To prevent this, start the external DMA controller only after the DMA reset. 12h MDMA stop MDMA stop: This command immediately stops the MDMA data transfer. This is applicable for commands 06h and 07h only. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 49 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 51. DMA commands ...continued Code Name Description 13h GDMA stop GDMA stop: This command stops the GDMA data transfer. Any data in the OUT endpoint that is not transferred by the DMA will remain in the buffer. The FIFO data for the IN endpoint will be written to the endpoint buffer. An interrupt bit will be set to indicate the completion of the DMA Stop command. 14h to 20h - reserved 21h Read Task File register 1F1h Read Task File register 1F1h: When reading is completed, an interrupt is generated. 22h Read Task File register 1F2h Read Task File register 1F2h: When reading is completed, an interrupt is generated. 23h Read Task File register 1F3h Read Task File register 1F3h: When reading is completed, an interrupt is generated. 24h Read Task File register 1F4h Read Task File register 1F4h: When reading is completed, an interrupt is generated. 25h Read Task File register 1F5h Read Task File register 1F5h: When reading is completed, an interrupt is generated. 26h Read Task File register 1F6h Read Task File register 1F6h: When reading is completed, an interrupt is generated. 27h Read Task File register 3F6h Read Task File register 3F6h: When reading is completed, an interrupt is generated. 28h Read Task File register 3F7h Read Task File register 3F7h: When reading is completed, an interrupt is generated. 29h to FFh - reserved 8.4.2 DMA Transfer Counter register (address: 34h) This 4-byte register sets up the total byte count for a DMA transfer (DMACR). It indicates the remaining number of bytes left for transfer. The bit allocation is given in Table 52. For IN endpoint -- Because there is a FIFO in the ISP1583 DMA controller, some data may remain in the FIFO during the DMA transfer. The maximum FIFO size is 8 bytes, and the maximum delay time for data to be shifted to endpoint buffer is 60 ns. For OUT endpoint -- Data will not be cleared from the endpoint buffer, until all the data is read from the DMA FIFO. If the DMA counter is disabled in the DMA transfer, it will still decrement and rollover when it reaches zero. Table 52. DMA Transfer Counter register: bit allocation Bit 31 30 29 Symbol 28 27 26 25 24 DMACR4 = DMACR[31:24] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 23 22 21 20 19 18 17 16 Access Bit Symbol DMACR3 = DMACR[23:16] ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 50 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Bit 23 22 21 20 19 18 17 16 Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 15 14 13 12 11 10 9 8 Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 7 6 5 4 3 2 1 0 Access Bit Symbol DMACR2 = DMACR[15:8] Access Bit Symbol DMACR1 = DMACR[7:0] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Table 53. DMA Transfer Counter register: bit description Bit Symbol Description 31 to 24 DMACR4 = DMACR[31:24] DMA transfer counter byte 4 (MSByte) 23 to 16 DMACR3 = DMACR[23:16] DMA transfer counter byte 3 15 to 8 DMACR2 = DMACR[15:8] DMA transfer counter byte 2 7 to 0 DMACR1 = DMACR[7:0] DMA transfer counter byte 1 (LSByte) 8.4.3 DMA Configuration register (address: 38h) This register defines the DMA configuration for GDMA mode. The DMA Configuration register consists of 2 bytes. The bit allocation is given in Table 54. Table 54. DMA Configuration register: bit allocation Bit 15 Symbol 14 reserved 13 ATA_ MODE 12 11 10 DMA_MODE[1:0] 9 8 PIO_MODE[2:0] Reset - - 0 0 0 0 0 0 Bus reset - - 0 0 0 0 0 0 Access - - R/W R/W R/W R/W R/W R/W Bit 7 6 5 4 3 2 1 0 reserved WIDTH Symbol DIS_ XFER_CNT reserved MODE[1:0] Reset 0 - - - 0 0 - 1 Bus reset 0 - - - 0 0 - 1 R/W - - - R/W R/W - R/W Access ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 51 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 55. DMA Configuration register: bit description Bit Symbol Description[1] 15 to 14 - reserved 13 ATA_MODE ATA Mode: Mode selection of the DMA core. 0 -- Configures the DMA core for non-ATA mode. Used when issuing DMA commands 00h and 01h. 1 -- Configures the DMA core for ATA or MDMA mode. Used when issuing DMA commands 02h to 07h, 0Ah and 0Ch; also used when directly accessing Task File registers. 12 to 11 DMA_MODE [1:0] DMA Mode: These bits affect the timing for MDMA mode. 00 -- MDMA mode 0: ATA(PI) compatible timing 01 -- MDMA mode 1: ATA(PI) compatible timing 10 -- MDMA mode 2: ATA(PI) compatible timing 11 -- MDMA mode 3: enables the DMA Strobe Timing register (see Table 76 and Table 77) for non-standard strobe durations; only used in MDMA mode 10 to 8 PIO_MODE [2:0][2] PIO Mode: These bits affect the PIO timing. 000 to 100 -- PIO mode 0 to 4: ATA(PI) compatible timing 101 to 111 -- reserved 7 DIS_XFER_ CNT Disable Transfer Count: Logic 1 disables the DMA Transfer Counter (see Table 52). The transfer counter can be disabled only in GDMA slave mode; in master mode the counter is always enabled. 6 to 4 - reserved 3 to 2 MODE[1:0] Mode: These bits only affect GDMA (slave) and MDMA (master) handshake signals. 00 -- DIOR (master) or DIOW (slave): strobes data from the DMA bus into the ISP1583; DIOW (master) or DIOR (slave): puts data from the ISP1583 on the DMA bus. 01 -- DIOR (master) or DACK (slave): strobes data from the DMA bus into the ISP1583; DACK (master) or DIOR (slave): puts data from the ISP1583 on the DMA bus. 10 -- DACK (master and slave): strobes data from the DMA bus into the ISP1583 and also puts data from the ISP1583 on the DMA bus. 11 -- reserved 1 - reserved 0 WIDTH Width: This bit selects the DMA bus width for GDMA (slave) and MDMA (master). 0 -- 8-bit data bus. 1 -- 16-bit data bus [1] The DREQ pin will be driven only after performing a write access to the DMA Configuration register (that is, after configuring the DMA Configuration register). [2] PIO read or write that started using DMA Command register only performs 16-bit transfer. 8.4.4 DMA Hardware register (address: 3Ch) The DMA Hardware register consists of 1 byte. The bit allocation is shown in Table 56. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 52 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller This register determines the polarity of bus control signals (EOT, DACK, DREQ, DIOR and DIOW) and DMA mode (master or slave). It also controls whether the upper and lower parts of the data bus are swapped (bits ENDIAN[1:0]), for modes GDMA (slave) and MDMA (master) only. Table 56. DMA Hardware register: bit allocation Bit Symbol 7 6 ENDIAN[1:0] 5 4 3 2 1 0 EOT_POL MASTER ACK_POL DREQ_ POL WRITE_ POL READ_ POL Reset 0 0 0 0 0 1 0 0 Bus reset 0 0 0 0 0 1 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Table 57. DMA Hardware register: bit description Bit Symbol 7 to 6 ENDIAN[1:0] Endian: These bits determine whether the data bus is swapped between the internal RAM and the DMA bus. This only applies for modes GDMA (slave) and MDMA (master). Description 00 -- Normal data representation; 16-bit bus: MSByte on DATA[15:8] and LSByte on DATA[7:0]. 01 -- Swapped data representation; 16-bit bus: MSByte on DATA[7:0] and LSByte on DATA[15:8]. 10 -- reserved 11 -- reserved Remark: While operating with the 8-bit data bus, bits ENDIAN[1:0] must always be set to logic 00. 5 EOT_POL EOT Polarity: Selects the polarity of the End-Of-Transfer input; used in GDMA slave mode only. 0 -- EOT is active LOW 1 -- EOT is active HIGH 4 MASTER Master or Slave Selection: Selects DMA master or slave mode. 0 -- GDMA slave mode 1 -- MDMA master mode 3 ACK_POL Acknowledgment Polarity: Selects the DMA acknowledgment polarity. 0 -- DACK is active LOW 1 -- DACK is active HIGH 2 DREQ_POL DREQ Polarity: Selects the DMA request polarity. 0 -- DREQ is active LOW 1 -- DREQ is active HIGH 1 WRITE_POL Write Polarity: Selects the DIOW strobe polarity. 0 -- DIOW is active LOW 1 -- DIOW is active HIGH 0 READ_POL Read Polarity: Selects the DIOR strobe polarity. 0 -- DIOR is active LOW 1 -- DIOR is active HIGH ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 53 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 8.4.5 Task File registers (addresses: 40h to 4Fh) These registers allow direct access to the internal registers of an ATAPI peripheral using PIO mode. The supported Task File registers and their functions are shown in Table 58. The correct peripheral register is automatically addressed using pins CS1_N, CS0_N, DA2, MODE0/DA1 and BUS_CONF/DA0 (see Table 59). Table 58. Task File register functions Task file ATA function ATAPI function 1F0 data (16-bit) data (16-bit) 1F1 error/feature error/feature 1F2 sector count interrupt reason 1F3 sector number/LBA[7:0] reserved 1F4 cylinder low/LBA[15:8] cylinder low 1F5 cylinder high/LBA[23:16] cylinder high 1F6 drive/head/LBA[27:24] drive select 1F7 command status/command 3F6 alternate status/command alternate status/command 3F7 drive address reserved Table 59. ATAPI peripheral register addressing Task file CS1_N CS0_N DA2 MODE0/DA1 BUS_CONF/DA0 1F0 HIGH LOW LOW LOW LOW 1F1 HIGH LOW LOW LOW HIGH 1F2 HIGH LOW LOW HIGH LOW 1F3 HIGH LOW LOW HIGH HIGH 1F4 HIGH LOW HIGH LOW LOW 1F5 HIGH LOW HIGH LOW HIGH 1F6 HIGH LOW HIGH HIGH LOW 1F7 HIGH LOW HIGH HIGH HIGH 3F6 LOW HIGH HIGH HIGH LOW 3F7 LOW HIGH HIGH HIGH HIGH In 8-bit bus mode, 16-bit Task File register 1F0 requires two consecutive write/read accesses before the proper PIO write/read is generated on the IDE interface. The first byte is always the lower byte (LSByte). Other Task File registers can directly be accessed. Writing to Task File registers can be done in any order except for the Task File register 1F7, which must be written last. Table 60. Task File 1F0 register (address: 40h): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = LOW, MODE0/DA1 = LOW, BUS_CONF/DA0 = LOW. Bit 7 6 5 4 Reset 0 0 0 0 Bus reset 0 0 0 R/W R/W R/W Symbol Access 3 2 1 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W data (ATA or ATAPI) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 54 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 61. Task File 1F1 register (address: 48h): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = LOW, MODE0/DA1 = LOW, BUS_CONF/DA0 = HIGH. Bit 7 6 5 4 Reset 0 0 0 0 Bus reset 0 0 0 R/W R/W R/W Symbol Access 3 2 1 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W 1 0 error/feature (ATA or ATAPI) Table 62. Task File 1F2 register (address: 49h): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = LOW, MODE0/DA1 = HIGH, BUS_CONF/DA0 = LOW. Bit 7 6 Symbol 5 4 3 2 sector count (ATA) or interrupt reason (ATAPI) Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 1 0 0 0 Access Table 63. Task File 1F3 register (address: 4Ah): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = LOW, MODE0/DA1 = HIGH, BUS_CONF/DA0 = HIGH. Bit 7 6 Symbol Reset Bus reset Access 5 4 3 2 sector number/LBA[7:0] (ATA), reserved (ATAPI) 0 0 0 0 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 1 0 Table 64. Task File 1F4 register (address: 4Bh): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = HIGH, MODE0/DA1 = LOW, BUS_CONF/DA0 = LOW. Bit 7 6 Symbol 5 4 3 2 cylinder low/LBA[15:8] (ATA) or cylinder low (ATAPI) Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 1 0 Access Table 65. Task File 1F5 register (address: 4Ch): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = HIGH, MODE0/DA1 = LOW, BUS_CONF/DA0 = HIGH. Bit 7 6 Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Symbol Access 5 4 3 cylinder high/LBA[23:16] (ATA) or cylinder high (ATAPI) ISP1583_6 Product data sheet 2 (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 55 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 66. Task File 1F6 register (address: 4Dh): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = HIGH, MODE0/DA1 = HIGH, BUS_CONF/DA0 = LOW. Bit 7 6 Reset 0 0 0 0 0 Bus reset 0 0 0 0 R/W R/W R/W R/W Symbol 5 4 3 2 1 0 0 0 0 0 0 0 0 R/W R/W R/W R/W 1 0 drive/head/LBA[27:24] (ATA) or drive (ATAPI) Access Table 67. Task File 1F7 register (address: 44h): bit allocation CS1_N = HIGH, CS0_N = LOW, DA2 = HIGH, MODE0/DA1 = HIGH, BUS_CONF/DA0 = HIGH. Bit 7 6 Symbol 5 4 command (ATA) or 3 status[1]/command 2 (ATAPI) Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 Access W W W W W W W W 1 0 0 0 [1] Task File register 1F7 is a write-only register; a read will return FFh. Table 68. Task File 3F6 register (address: 4Eh): bit allocation CS1_N = LOW, CS0_N = HIGH, DA2 = HIGH, MODE0/DA1 = HIGH, BUS_CONF/DA0 = LOW. Bit 7 6 Symbol 5 4 3 2 alternate status/command (ATA or ATAPI) Reset 0 Bus reset Access 0 0 0 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 2 1 0 Table 69. Task File 3F7 register (address: 4Fh): bit allocation CS1_N = LOW, CS0_N = HIGH, DA2 = HIGH, MODE0/DA1 = HIGH, BUS_CONF/DA0 = HIGH. Bit 7 6 5 Symbol 4 3 drive address (ATA) or reserved (ATAPI) Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access 8.4.6 DMA Interrupt Reason register (address: 50h) This 2-byte register shows the source(s) of DMA interrupt. Each bit is refreshed after a DMA command is executed. An interrupt source is cleared by writing logic 1 to the corresponding bit. On detecting the interrupt, the external microprocessor must read the DMA Interrupt Reason register and mask it with the corresponding bits in the DMA Interrupt Enable register to determine the source of the interrupt. The bit allocation is given in Table 70. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 56 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 70. DMA Interrupt Reason register: bit allocation Bit Symbol 15 14 TEST3 13 reserved 12 11 10 9 8 GDMA_ STOP EXT_EOT INT_EOT INTRQ_ PENDING DMA_ XFER_OK Reset 0 - - 0 0 0 0 0 Bus reset 0 - - 0 0 0 0 0 Access R - - R/W R/W R/W R/W R/W Bit 7 6 5 Symbol reserved 4 3 2 1 0 READ_1F0 BSY_ DONE TF_RD_ DONE CMD_ INTRQ_OK reserved 0 0 0 0 - Reset - - - Bus reset - - - 0 0 0 0 - Access - - - R/W R/W R/W R/W - Table 71. DMA Interrupt Reason register: bit description Bit Symbol Description 15 TEST3 This bit is set when a DMA transfer for a packet (OUT transfer) terminates before the whole packet is transferred. This bit is a status bit, and the corresponding mask bit of this register is always 0. Writing any value other than 0 has no effect. 14 to 13 - reserved 12 GDMA_STOP GDMA Stop: When the GDMA_STOP command is issued to DMA Command registers, it means the DMA transfer has successfully terminated. 11 EXT_EOT External EOT: Logic 1 indicates that an external EOT is detected. This is applicable only in GDMA slave mode. 10 INT_EOT Internal EOT: Logic 1 indicates that an internal EOT is detected; see Table 72. 9 INTRQ_ PENDING Interrupt Pending: Logic 1 indicates that a pending interrupt was detected on pin INTRQ. 8 DMA_XFER_OK DMA Transfer OK: Logic 1 indicates that the DMA transfer is completed (DMA Transfer Counter has become zero). This bit is only used in GDMA (slave) mode and MDMA (master) mode. 7 to 5 - reserved 4 READ_1F0 Read 1F0: Logic 1 indicates that the 1F0 FIFO contains unread data and the microcontroller can start reading data. 3 BSY_DONE Busy Done: Logic 1 indicates that the BSY status bit has become zero and polling has been stopped. 2 TF_RD_DONE Task File Read Done: Logic 1 indicates that the Read Task Files command has been completed. 1 CMD_INTRQ_OK Command Interrupt OK: Logic 1 indicates that all bytes from the FIFO have been transferred (DMA Transfer Count zero) and an interrupt on pin INTRQ was detected. 0 - reserved ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 57 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 72. Internal EOT-functional relation with DMA_XFER_OK bit INT_EOT DMA_XFER_OK Description 1 0 During the DMA transfer, there is a premature termination with short packet. 1 1 DMA transfer is completed with short packet and the DMA transfer counter has reached 0. 0 1 DMA transfer is completed without any short packet and the DMA transfer counter has reached 0. 8.4.7 DMA Interrupt Enable register (address: 54h) This 2-byte register controls the interrupt generation of the source bits in the DMA Interrupt Reason register (see Table 70). The bit allocation is given in Table 73. The bit description is given in Table 71. Logic 1 enables the interrupt generation. After a bus reset, interrupt generation is disabled, with values turning to logic 0. Table 73. DMA Interrupt Enable register: bit allocation Bit Symbol 15 14 TEST4 13 reserved 12 11 10 9 8 IE_GDMA_ STOP IE_EXT_ EOT IE_INT_ EOT IE_INTRQ_ PENDING IE_DMA_ XFER_OK Reset 0 - - 0 0 0 0 0 Bus reset 0 - - 0 0 0 0 0 Access R - - R/W R/W R/W R/W R/W Bit 7 6 5 Symbol reserved 4 3 2 1 0 IE_ READ_1F0 IE_BSY_ DONE IE_TF_ RD_DONE IE_CMD_ INTRQ_OK reserved 0 0 0 0 - Reset - - - Bus reset - - - 0 0 0 0 - Access - - - R/W R/W R/W R/W - 8.4.8 DMA Endpoint register (address: 58h) This 1-byte register selects a USB endpoint FIFO as a source or destination for DMA transfers. The bit allocation is given in Table 74. Table 74. DMA Endpoint register: bit allocation Bit 7 6 Symbol 5 4 3 reserved 2 1 EPIDX[2:0] 0 DMADIR Reset - - - - 0 0 0 0 Bus reset - - - - 0 0 0 0 Access - - - - R/W R/W R/W R/W ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 58 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 75. DMA Endpoint register: bit description Bit Symbol Description 7 to 4 - reserved 3 to 1 EPIDX[2:0] Endpoint Index: selects the indicated endpoint for DMA access 0 DMADIR DMA Direction: 0 -- Selects the RX/OUT FIFO for DMA read transfers 1 -- Selects the TX/IN FIFO for DMA write transfers The DMA Endpoint register must not reference the endpoint that is indexed by the Endpoint Index register (2Ch) at any time. Doing so will result in data corruption. Therefore, if the DMA Endpoint register is unused, point it to an unused endpoint. If the DMA Endpoint register, however, is pointed to an active endpoint, the firmware must not reference the same endpoint on the Endpoint Index register. 8.4.9 DMA Strobe Timing register (address: 60h) This 1-byte register controls the strobe timing for MDMA mode, when bits DMA_MODE[1:0] in the DMA Configuration register have been set to 03h. The bit allocation is given in Table 76. Table 76. DMA Strobe Timing register: bit allocation Bit 7 6 Symbol 5 4 3 reserved 2 1 0 DMA_STROBE_CNT[4:0] Reset - - - 1 1 1 1 1 Bus reset - - - 1 1 1 1 1 Access - - - R/W R/W R/W R/W R/W Table 77. DMA Strobe Timing register: bit description Bit Symbol Description 7 to 5 - reserved 4 to 0 DMA_STROBE_ CNT[4:0] DMA Strobe Count: These bits select the strobe duration for DMA_MODE = 03h (see Table 54). The strobe duration is (N + 1) cycles[1], with N representing the value of DMA_STROBE_CNT (see Figure 17). [1] The cycle duration indicates the internal clock cycle (33.3 ns/cycle). x x (N + 1) cycles 004aaa125 Fig 17. Programmable strobe timing 8.4.10 DMA Burst Counter register (address: 64h) Table 78 shows the bit allocation of the 2-byte register. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 59 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 78. DMA Burst Counter register: bit allocation Bit 15 14 Symbol 13 12 11 reserved 10 9 8 BURSTCOUNTER[12:8] Reset - - - 0 0 0 0 0 Bus reset - - - 0 0 0 0 0 Access - - - R/W R/W R/W R/W R/W Bit 7 6 5 4 3 2 1 0 Reset 0 0 0 0 0 0 1 0 Bus reset 0 0 0 0 0 0 1 0 R/W R/W R/W R/W R/W R/W R/W R/W Symbol BURSTCOUNTER[7:0] Access Table 79. DMA Burst Counter register: bit description Bit Symbol Description 15 to 13 - reserved 12 to 0 BURSTCOUNTER [12:0] Burst Counter: This register defines the burst length. The counter must be programmed to be a multiple of two in 16-bit mode. The value of the burst counter must be programmed so that the burst counter is a factor of the buffer size. It is used to determine the assertion and de-assertion of DREQ. 8.5 General registers 8.5.1 Interrupt register (address: 18h) The Interrupt register consists of 4 bytes. The bit allocation is given in Table 80. When a bit is set in the Interrupt register, it indicates that the hardware condition for an interrupt has occurred. When the Interrupt register content is nonzero, the INT output will be asserted corresponding to the Interrupt Enable register. On detecting the interrupt, the external microprocessor must read the Interrupt register and mask it with the corresponding bits in the Interrupt Enable register to determine the source of the interrupt. Each endpoint buffer has a dedicated interrupt bit (EPnTX, EPnRX). In addition, various bus states can generate an interrupt: resume, suspend, pseudo SOF, SOF and bus reset. The DMA controller only has one interrupt bit: the source for a DMA interrupt is shown in the DMA Interrupt Reason register (see Table 70 and Table 71). Each interrupt bit can individually be cleared by writing logic 1. The DMA Interrupt bit can be cleared by writing logic 1 to the related interrupt source bit in the DMA Interrupt Reason register, followed by writing logic 1 to the DMA bit of the Interrupt register. Table 80. Interrupt register: bit allocation Bit 31 30 29 28 27 26 Reset - - - - - - Bus reset - - - - - Access - - - - - Symbol 24 EP7TX EP7RX 0 0 - 0 0 - R/W R/W reserved ISP1583_6 Product data sheet 25 (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 60 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Bit Symbol 23 22 21 20 19 18 17 16 EP6TX EP6RX EP5TX EP5RX EP4TX EP4RX EP3TX EP3RX Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Access Bit 15 14 13 12 11 10 9 8 EP2TX EP2RX EP1TX EP1RX EP0TX EP0RX reserved EP0SETUP Reset 0 0 0 0 0 0 - 0 Bus reset 0 0 0 0 0 0 - 0 R/W R/W R/W R/W R/W R/W - R/W 7 6 5 4 3 2 1 0 VBUS DMA HS_STAT RESUME SUSP PSOF SOF BRESET 0 0 0 0 0 0 0 0 Symbol Access Bit Symbol Reset Bus reset Access 0 0 0 0 0 0 0 1 R/W R/W R/W R/W R/W R/W R/W R/W Table 81. Interrupt register: bit description Bit Symbol Description 31 to 26 - reserved 25 EP7TX logic 1 indicates the endpoint 7 TX buffer as interrupt source 24 EP7RX logic 1 indicates the endpoint 7 RX buffer as interrupt source 23 EP6TX logic 1 indicates the endpoint 6 TX buffer as interrupt source 22 EP6RX logic 1 indicates the endpoint 6 RX buffer as interrupt source 21 EP5TX logic 1 indicates the endpoint 5 TX buffer as interrupt source 20 EP5RX logic 1 indicates the endpoint 5 RX buffer as interrupt source 19 EP4TX logic 1 indicates the endpoint 4 TX buffer as interrupt source 18 EP4RX logic 1 indicates the endpoint 4 RX buffer as interrupt source 17 EP3TX logic 1 indicates the endpoint 3 TX buffer as interrupt source 16 EP3RX logic 1 indicates the endpoint 3 RX buffer as interrupt source 15 EP2TX logic 1 indicates the endpoint 2 TX buffer as interrupt source 14 EP2RX logic 1 indicates the endpoint 2 RX buffer as interrupt source 13 EP1TX logic 1 indicates the endpoint 1 TX buffer as interrupt source 12 EP1RX logic 1 indicates the endpoint 1 RX buffer as interrupt source 11 EP0TX logic 1 indicates the endpoint 0 data TX buffer as interrupt source 10 EP0RX logic 1 indicates the endpoint 0 data RX buffer as interrupt source 9 - reserved 8 EP0SETUP logic 1 indicates that a SETUP token was received on endpoint 0 7 VBUS logic 1 indicates a transition from LOW to HIGH on VBUS 6 DMA DMA status: Logic 1 indicates a change in the DMA Interrupt Reason register. 5 HS_STAT High speed status: Logic 1 indicates a change from full-speed to high-speed mode (HS connection). This bit is not set, when the system goes into full-speed suspend. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 61 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 81. Interrupt register: bit description ...continued Bit Symbol Description 4 RESUME Resume status: Logic 1 indicates that a status change from suspend to resume (active) was detected. 3 SUSP Suspend status: Logic 1 indicates that a status change from active to suspend was detected on the bus. 2 PSOF Pseudo SOF interrupt: Logic 1 indicates that a pseudo SOF or SOF was received. Pseudo SOF is an internally generated clock signal (full-speed: 1 ms period, high-speed: 125 s period) that is not synchronized to the USB bus SOF or SOF. 1 SOF SOF interrupt: Logic 1 indicates that a SOF or SOF was received. 0 BRESET Bus reset: Logic 1 indicates that a USB bus reset was detected. When bit OTG in the OTG register is set, BRESET will not be set, instead, this interrupt bit will report SE0 on DP and DM for 2 ms. 8.5.2 Chip ID register (address: 70h) This read-only register contains the chip identification and hardware version numbers. The firmware must check this information to determine functions and features supported. The register contains 3 bytes, and the bit allocation is shown in Table 82. Table 82. Chip ID register: bit allocation Bit 23 22 21 20 Symbol 19 18 17 16 CHIPID[15:8] Reset 0 0 0 1 0 1 0 1 Bus reset 0 0 0 1 0 1 0 1 Access R R R R R R R R Bit 15 14 13 12 11 10 9 8 0 1 0 Symbol CHIPID[7:0] Reset 1 0 0 0 0 Bus reset 1 0 0 0 0 0 1 0 Access R R R R R R R R Bit 7 6 5 4 3 2 1 0 Symbol VERSION[7:0] Reset 0 0 1 1 0 0 0 0 Bus reset 0 0 1 1 0 0 0 0 Access R R R R R R R R Table 83. Chip ID register: bit description Bit Symbol Description 23 to 16 CHIPID[15:8] Chip ID: lower byte (15h) 15 to 8 CHIPID[7:0] Chip ID: upper byte (82h) 7 to 0 VERSION[7:0] Version: version number (30h) 8.5.3 Frame Number register (address: 74h) This read-only register contains the frame number of the last successfully received Start-Of-Frame (SOF). The register contains 2 bytes, and the bit allocation is given in Table 84. In case of 8-bit access, the register content is returned lower byte first. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 62 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 84. Frame Number register: bit allocation Bit 15 Symbol 14 13 reserved 12 11 10 MICROSOF[2:0] 9 8 SOFR[10:8] Reset - - 0 0 0 0 0 0 Bus reset - - 0 0 0 0 0 0 Access - - R R R R R R Bit 7 6 5 4 3 2 1 0 Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 Access R R R R R R R R Symbol SOFR[7:0] Table 85. Frame Number register: bit description Bit Symbol Description 15 to 14 - reserved 13 to 11 MICROSOF[2:0] micro frame number 10 to 0 SOFR[10:0] frame number 8.5.4 Scratch register (address: 78h) This 16-bit register can be used by the firmware to save and restore information. For example, the device status before it enters the suspend state. The bit allocation is given in Table 86. Table 86. Scratch register: bit allocation Bit 15 14 13 12 Symbol 11 10 9 8 SFIRH[7:0] Reset 0 0 0 0 0 0 0 0 Bus reset 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W 7 6 5 4 3 2 1 0 0 0 0 0 Access Bit Symbol Reset Bus reset Access SFIRL[7:0] 0 0 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W Table 87. Scratch register: bit description Bit Symbol Description 15 to 8 SFIRH[7:0] Scratch firmware information register (higher byte) 7 to 0 SFIRL[7:0] Scratch firmware information register (lower byte) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 63 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 8.5.5 Unlock Device register (address: 7Ch) To protect registers from getting corrupted when the ISP1583 goes into suspend, the write operation is disabled if bit PWRON in the Mode register is set to logic 0. In this case, when the chip resumes, the Unlock Device command must first be issued to this register before attempting to write to the rest of the registers. This is done by writing unlock code (AA37h) to this register. The bit allocation of the Unlock Device register is given in Table 88. Table 88. Unlock Device register: bit allocation Bit 15 14 13 12 Symbol 11 10 9 8 ULCODE[15:8] = AAh Reset not applicable Bus reset not applicable Access W W W W W W W W Bit 7 6 5 4 3 2 1 0 W W W Symbol ULCODE[7:0] = 37h Reset not applicable Bus reset not applicable Access W W W Table 89. W W Unlock Device register: bit description Bit Symbol Description 15 to 0 ULCODE[15:0] Unlock Code: Writing data AA37h unlocks internal registers and FIFOs for writing, following a resume. When bit PWRON in the Mode register is logic 1, the chip is powered. In such a case, you do not need to issue the Unlock command because the microprocessor is powered and therefore, the RW_N/RD_N, DS_N/WR_N and CS_N signals maintain their states. When bit PWRON is logic 0, the RW_N/RD_N, DS_N/WR_N and CS_N signals are floating because the microprocessor is not powered. To protect the ISP1583 registers from being corrupted during suspend, register write is locked when the chip goes into suspend. Therefore, you need to issue the Unlock command to unlock the ISP1583 registers. 8.5.6 Test Mode register (address: 84h) This 1-byte register allows the firmware to set the DP and DM pins to predetermined states for testing purposes. The bit allocation is given in Table 90. Remark: Only one bit can be set at a time. Either bit FORCEHS or FORCEFS must be set to logic 1 at a time. Of the four bits PRBS, KSTATE, JSTATE and SE0_NAK only one bit must be set at a time. This must be implemented for the Hi-Speed USB logo compliance testing. To exit test mode, power cycle is required. Table 90. Test Mode register: bit allocation Bit Symbol 7 FORCEHS Reset Bus reset 6 5 reserved 4 3 2 1 0 FORCEFS PRBS KSTATE JSTATE SE0_NAK 0 - - 0 0 0 0 0 unchanged - - unchanged 0 0 0 0 R/W - - R/W R/W R/W R/W R/W Access ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 64 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 91. Test Mode register: bit description Bit Symbol Description 7 FORCEHS Force High-Speed: Logic 1 forces the hardware to high-speed mode only and disables the chirp detection logic. 6 to 5 - reserved 4 FORCEFS Force Full-Speed: Logic 1 forces the physical layer to full-speed mode only and disables the chirp detection logic. 3 PRBS Predetermined Random Pattern: Logic 1 sets the DP and DM pins to toggle in a predetermined random pattern. 2 KSTATE K-State: Logic 1 sets the DP and DM pins to the K state. 1 JSTATE J-State: Logic 1 sets the DP and DM pins to the J state. 0 SE0_NAK SE0 NAK: Logic 1 sets the DP and DM pins to a high-speed quiescent state. The device only responds to a valid high-speed IN token with a NAK. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 65 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 9. Limiting values Table 92. Limiting values In accordance with the Absolute Maximum Rating System (IEC 60134). Symbol Parameter VCC(3V3) supply voltage VCC(I/O) input/output supply voltage VI input voltage Ilu latch-up current VI < 0 V or VI > VCC(3V3) Vesd electrostatic discharge voltage ILI < 1 A Min Max Unit -0.5 +4.6 V -0.5 +4.6 V -0.5 VCC(3V3) + 0.5 V - 100 mA pins DP, DM, VBUS, AGND and DGND -4000 +4000 V other pins -2000 +2000 V -40 +125 C [1] storage temperature Tstg [1] Conditions The maximum value for 5 V tolerant pins is 6 V. 10. Recommended operating conditions Table 93. Recommended operating conditions Symbol Parameter VCC(3V3) VCC(I/O) VI input voltage VIA(I/O) input voltage on analog I/O pins V(pu)OD Conditions Min Typ Max Unit supply voltage 3.0 - 3.6 V input/output supply voltage 1.65 - 3.6 V VCC(3V3) = 3.3 V 0 - VCC(I/O) V on pins DP and DM 0 - 3.6 V open-drain pull-up voltage 0 - VCC(3V3) V Tamb ambient temperature -40 - +85 C Tj junction temperature -40 - +125 C 11. Static characteristics Table 94. Static characteristics: supply pins VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; typical values at Tamb = 25 C; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit 3.0 3.3 3.6 V - 47 60 mA - 19 25 mA - 160 - A 1.65 3.3 3.6 V Supply voltage VCC(3V3) supply voltage ICC(3V3)(oper) operating supply current (3.3 V) high-speed full-speed ICC(3V3)(susp) suspend mode supply current (3.3 V) I/O pad supply voltage VCC(I/O) input/output supply voltage ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 66 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 94. Static characteristics: supply pins ...continued VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; typical values at Tamb = 25 C; unless otherwise specified. Symbol ICC(I/O) Parameter Conditions [1] supply current on pin VCC(I/O) Min Typ Max Unit - 3 - mA 1.65 1.8 1.95 V Regulated supply voltage VCC(1V8) [1] supply voltage (1.8 V) with voltage converter ICC(I/O) test condition: device set up under the test mode vector and I/O is subjected to external conditions. Table 95. Static characteristics: digital pins VCC(I/O) = 1.65 V to 3.6 V; VGND = 0 V; Tamb = -40 C to +85 C; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit - 0.3VCC(I/O) V V Input levels VIL LOW-level input voltage - VIH HIGH-level input voltage 0.7VCC(I/O) - - 0.15VCC(I/O) V Output levels VOL LOW-level output voltage IOL = rated drive - - VOH HIGH-level output voltage IOH = rated drive 0.8VCC(I/O) - - V -5 +5 A Leakage current [1] [1] input leakage current ILI - This value is applicable to transistor input only. The value will be different if internal pull-up or pull-down resistors are used. Table 96. Static characteristics: OTG detection VCC(I/O) = 1.65 V to 3.6 V; VGND = 0 V; Tamb = -40 C to +85 C; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit Charging and discharging resistor RDN(VBUS) pull-down resistance on pin VBUS only when bit DISCV is set in the OTG register 680 800 1030 RUP(DP) pull-up resistance on pin DP only when bit DP is set in the OTG register 300 550 780 Comparator levels VBVALID VBUS valid detection 2.0 - 4.0 V VSESEND VBUS B-session end detection 0.2 - 0.8 V Table 97. Static characteristics: analog I/O pins DP and DM VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; unless otherwise specified.[1] Symbol Parameter Conditions Min Typ Max Unit VDI differential input sensitivity |VI(DP) - VI(DM)| 0.2 - - V Input levels VCM differential common mode voltage includes VDI range 0.8 - 2.5 V VSE single-ended receiver threshold 0.8 - 2.0 V VIL LOW-level input voltage - - 0.8 V VIH HIGH-level input voltage 2.0 - - V 1.4 - 1.9 V Schmitt-trigger inputs Vth(LH) positive-going threshold voltage ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 67 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 97. Static characteristics: analog I/O pins DP and DM ...continued VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; unless otherwise specified.[1] Symbol Parameter Vth(HL) Vhys Conditions Min Typ Max Unit negative-going threshold voltage 0.9 - 1.5 V hysteresis voltage 0.4 - 0.7 V Output levels VOL LOW-level output voltage RL = 1.5 k to 3.6 V - - 0.4 V VOH HIGH-level output voltage RL = 15 k to GND 2.8 - 3.6 V OFF-state leakage current 0 V < VI < 3.3 V -10 - +10 A input capacitance pin to GND - - 10 pF ZDRV driver output impedance steady-state drive ZINP input impedance Leakage current ILZ Capacitance Cin Resistance [1] 40.5 - 49.5 10 - - M Pin DP is the USB positive data pin, and pin DM is the USB negative data pin. 12. Dynamic characteristics Table 98. Dynamic characteristics VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit external RESET_N pulse width crystal oscillator running 500 - - s Reset tW(RESET_N) Crystal oscillator fXTAL1 frequency on pin XTAL1 - 12 - MHz RS series resistance - - 100 CL load capacitance - 18 - pF External clock input tJ external clock jitter - - 500 ps clock duty cycle 45 50 55 % tr rise time - - 3 ns tf fall time - - 3 ns VI input voltage 1.65 1.8 1.95 V Table 99. Dynamic characteristics: analog I/O pins DP and DM VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; CL = 50 pF; RPU = 1.5 k on DP to VTERM; test circuit of Figure 38; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit CL = 50 pF; 10 % to 90 % of |VOH - VOL| 4 - 20 ns Driver characteristics Full-speed mode tFR rise time ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 68 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 99. Dynamic characteristics: analog I/O pins DP and DM ...continued VCC(3V3) = 3.3 V 0.3 V; VGND = 0 V; Tamb = -40 C to +85 C; CL = 50 pF; RPU = 1.5 k on DP to VTERM; test circuit of Figure 38; unless otherwise specified. Symbol Parameter Conditions Min Typ Max Unit tFF fall time CL = 50 pF; 90 % to 10 % of |VOH - VOL| 4 - 20 ns FRFM differential rise time/fall time matching tFR/tFF 90 - 111.11 % VCRS output signal crossover voltage 1.3 - 2.0 V [1] [1][2] High-speed mode tHSR rise time (10 % to 90 %) with captive cable 500 - - ps tHSF fall time (10 % to 90 %) with captive cable 500 - - ps Data source timing Full-speed mode see Figure 18 [2] 160 - 175 ns see Figure 18 [2] -2 - +5 ns see Figure 19 [2] -18.5 - +18.5 ns receiver jitter for paired transitions see Figure 19 [2] -9 - +9 ns tFEOPR receiver SE0 interval of EOP accepted as EOP; see Figure 18 [2] 82 - - ns tFST width of SE0 interval during differential transition rejected as EOP; see Figure 20 [2] - - 14 ns tFEOPT tFDEOP source SE0 interval of EOP source jitter for differential transition to SE0 transition Receiver timing Full-speed mode receiver jitter to next transition tJR1 tJR2 [1] Excluding the first transition from the idle state. [2] Characterized only, not tested. Limits guaranteed by design. TPERIOD +3.3 V crossover point extended crossover point differential data lines 0V differential data to SE0/EOP skew N x TPERIOD + t DEOP source EOP width: t EOPT receiver EOP width: t EOPR mgr776 TPERIOD is the bit duration corresponding to the USB data rate. Full-speed timing symbols have a subscript prefix `F', low-speed timing symbols have a prefix `L'. Fig 18. Source differential data-to-EOP transition skew and EOP width ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 69 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller TPERIOD +3.3 V differential data lines 0V t JR t JR1 mgr871 t JR2 consecutive transitions N x TPERIOD + t JR1 paired transitions N x TPERIOD + t JR2 TPERIOD is the bit duration corresponding to the USB data rate. Fig 19. Receiver differential data jitter t FST +3.3 V VIH(min) differential data lines 0V mgr872 Fig 20. Receiver SE0 width tolerance 12.1 Register access timing Remark: In the following subsections, RW_N/RD_N, DS_N/WR_N, READY/IORDY and ALE/A0 refer to the ISP1583 pin. 12.1.1 Generic processor mode BUS_CONF/DA0 = HIGH: generic processor mode: 12.1.1.1 8051 mode MODE0/DA1 = HIGH: 8051 mode; see Table 2 Table 100. ISP1583 register access timing parameters: separate address and data buses VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit Reading tRLRH RW_N/RD_N LOW pulse width > tRLDV - - ns tAVRL address set-up time before RW_N/RD_N LOW 0 - - ns tRHAX address hold time after RW_N/RD_N HIGH 0 - - ns tRLDV RW_N/RD_N LOW to data valid delay - - 26 ns tRHDZ RW_N/RD_N HIGH to data outputs 3-state delay 0 - 15 ns tRHSH RW_N/RD_N HIGH to CS_N HIGH delay 0 - - ns ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 70 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 100. ISP1583 register access timing parameters: separate address and data buses ...continued VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter tSLRL Conditions Min Typ Max Unit CS_N LOW to RW_N/RD_N LOW delay 2 - - ns tWLWH DS_N/WR_N LOW pulse width 15 - - ns tAVWL address set-up time before DS_N/WR_N LOW 0 - - ns tWHAX address hold time after DS_N/WR_N HIGH 0 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 11 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns tSLWL CS_N LOW to DS_N/WR_N LOW delay 2 - - ns Writing General Tcy(RW) read or write cycle time 50 - - ns tRDY1 READY/IORDY HIGH to RW_N/RD_N or DS_N/WR_N HIGH of the last access - - 91 ns Tcy(RW) t WHSH t SLWL t RHSH CS_N t WHAX t RHAX t SLRL A[7:0] t RLDV t RHDZ (read) DATA [15:0] t AVRL t RLRH RW_N/RD_N t WHDZ t AVWL (write) DATA [15:0] t DVWH t WLWH DS_N/WR_N 004aaa301 Fig 21. ISP1583 register access timing: separate address and data buses (8051 mode) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 71 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller DS_N/WR_N, RW_N/RD_N READY/IORDY 004aaa920 t RDY1 Fig 22. ISP1583 ready signal timing 12.1.1.2 Freescale mode MODE0/DA1 = LOW: Freescale mode; see Table 2 Table 101. ISP1583 register access timing parameters: separate address and data buses VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit Reading or writing tWLWH DS_N/WR_N LOW pulse width 15 - - ns tAVWL address set-up time before DS_N/WR_N LOW 0 - - ns tWHAX address hold time after DS_N/WR_N HIGH 0 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 11 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns tI1VI2L RW_N/RD_N set-up time before DS_N/WR_N LOW 0 - - ns tI2HI1X RW_N/RD_N hold time after DS_N/WR_N HIGH 0 - - ns Tcy(RW) read or write cycle time 50 - - ns tRDY1 READY/IORDY HIGH to DS_N/WR_N HIGH of the last access - - 91 ns General ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 72 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Tcy(RW) t WHSH CS_N t WHAX AD [7:0] (read) DATA [15:0] t WHDZ t AVWL (write) DATA [15:0] t DVWH t WLWH t I1VI2L DS_N/WR_N t I2HI1X read RW_N/RD_N write 004aaa379 Fig 23. ISP1583 register access timing: separate address and data buses (Freescale mode) DS_N/WR_N READY/IORDY t RDY1 004aaa380 Fig 24. ISP1583 ready signal timing ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 73 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller RW_N/RD_N or DS_N/WR_N EOT(1) 36 ns (min) DREQ t h1 004aaa378 (1) Programmable polarity: shown as active LOW. Remark: EOT must be valid for 36 ns (minimum) when pins RW_N/RD_N and DS_N/WR_N are active. Fig 25. EOT timing in generic processor mode 12.1.2 Split bus mode 12.1.2.1 ALE function 8051 mode * BUS_CONF/DA0 = LOW: split bus mode * MODE1 = LOW: ALE function - MODE0/DA1 = HIGH: 8051 mode; see Table 2 Table 102. ISP1583 register access timing parameters: multiplexed address/data bus VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit Reading tRLRH RW_N/RD_N LOW pulse width > tRLDV - - ns tRLDV RW_N/RD_N LOW to data valid delay - - 25 ns tRHDZ RW_N/RD_N HIGH to data outputs 3-state delay 0 - 15 ns tRHSH RW_N/RD_N HIGH to CS_N HIGH delay 0 - - ns tLLRL ALE/A0 LOW set-up time before RW_N/RD_N LOW 0 - - ns tWLWH DS_N/WR_N LOW pulse width 15 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 5 - - ns tLLWL ALE/A0 LOW to DS_N/WR_N LOW delay 0 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns Tcy(RW) read or write cycle time 80 - - ns tAVLL address set-up time before ALE/A0 LOW 0 - - ns Writing General ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 74 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Tcy(RW) t WHSH CS_N t RHDZ t RLDV (read) AD [7:0] data address t RLRH t LLRL t RHSH RW_N/RD_N t WHDZ (write) AD [7:0] data address t DVWH t LLWL t WLWH DS_N/WR_N t AVLL ALE/A0 004aaa382 Fig 26. ISP1583 register access timing: multiplexed address/data bus (8051 mode) Freescale mode * BUS_CONF/DA0 = LOW: split bus mode * MODE1 = LOW: ALE function - MODE0/DA1 = LOW: Freescale mode; see Table 2 Table 103. ISP1583 register access timing parameters: multiplexed address/data bus VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit Reading or writing tWLWH DS_N/WR_N LOW pulse width 15 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 5 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns General Tcy(RW) read or write cycle time 80 - - ns tI1VLL RW_N/RD_N set-up time before ALE/A0 LOW 5 - - ns tLLI2L ALE/A0 LOW to DS_N/WR_N LOW delay 5 - - ns tI2HI1X RW_N/RD_N hold time after DS_N/WR_N HIGH 5 - - ns ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 75 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Tcy(RW) t WHSH CS_N (read) AD [7:0] data address t WHDZ data address (write) AD [7:0] t I1VLL t DVWH t LLI2L t WLWH DS_N/WR_N t I2HI1X RW_N/RD_N ALE/A0 004aaa381 Fig 27. ISP1583 register access timing: multiplexed address/data bus (Freescale mode) 12.1.2.2 A0 function 8051 mode * BUS_CONF/DA0 = LOW: split bus mode * MODE1 = HIGH: A0 function - MODE0/DA1 = HIGH: 8051 mode; see Table 2 Table 104. ISP1583 register access timing parameters: multiplexed address/data bus VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit - - 26 ns Reading tRLDV RW_N/RD_N LOW to data valid delay tRHDZ RW_N/RD_N HIGH to data outputs 3-state delay 0 - 15 ns tRHSH RW_N/RD_N HIGH to CS_N HIGH delay 0 - - ns tRLRH RW_N/RD_N LOW pulse width > tRLDV - - ns tWHRH DS_N/WR_N HIGH to RW_N/RD_N HIGH delay 40 - - ns tA0WL ALE/A0 set-up time before DS_N/WR_N LOW 0 - - ns tAVWH address set-up time before DS_N/WR_N HIGH 5 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 5 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns tWLWH DS_N/WR_N LOW pulse width 15 - - ns Writing ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 76 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 104. ISP1583 register access timing parameters: multiplexed address/data bus ...continued VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter tWHWH Conditions Min Typ Max Unit DS_N/WR_N HIGH (address) to DS_N/WR_N HIGH (data) delay 40 - - ns read or write cycle time 50 - - ns General Tcy(RW) t A0WL ALE/A0 Tcy(RW) t WHSH CS_N t RHDZ t RLDV (read) AD [7:0] data address t RLRH t RHSH RW_N/RD_N t AVWH t WHRH DS_N/WR_N t WHDZ (write) AD [7:0] data address t DVWH t WLWH DS_N/WR_N t WHWH RW_N/RD_N 004aaa383 Fig 28. ISP1583 register access timing: multiplexed address/data bus (A0 function and 8051 mode) Freescale mode * BUS_CONF/DA0 = LOW: split bus mode * MODE1 = HIGH: A0 function - MODE0/DA1 = LOW: Freescale mode; see Table 2 Table 105. ISP1583 register access timing parameters: multiplexed address/data bus VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit Reading tRLDV DS_N/WR_N LOW to data valid delay - - 26 ns tRHDZ DS_N/WR_N HIGH to data outputs 3-state delay 0 - 15 ns ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 77 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 105. ISP1583 register access timing parameters: multiplexed address/data bus ...continued VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Min Typ Max Unit tRHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns tRLRH DS_N/WR_N LOW pulse width > tRLDV - - ns tWHRH DS_N/WR_N HIGH (address) to DS_N/WR_N HIGH (data read) delay 40 - - ns tA0WL ALE/A0 set-up time before DS_N/WR_N LOW 0 - - ns tAVWH address set-up time before DS_N/WR_N HIGH 5 - - ns tDVWH data set-up time before DS_N/WR_N HIGH 5 - - ns tWHDZ data hold time after DS_N/WR_N HIGH 5 - - ns tWHSH DS_N/WR_N HIGH to CS_N HIGH delay 0 - - ns tWLWH DS_N/WR_N LOW pulse width 15 - - ns tWHWH DS_N/WR_N HIGH (address) to DS_N/WR_N HIGH (data written) delay 40 - - ns Tcy(RW) read or write cycle time 50 - - ns tI2HI1X RW_N/RD_N hold time after DS_N/WR_N HIGH 5 - - ns Writing General ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 78 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller t A0WL ALE/A0 Tcy(RW) t WHSH CS_N t RHDZ t RLDV (read) AD [7:0] data address t RLRH t RHSH RW_N/RD_N t AVWH t WHRH DS_N/WR_N t WHDZ (write) AD [7:0] data address t DVWH t WLWH DS_N/WR_N t I2HI1X t WHWH RW_N/RD_N 004aaa384 Fig 29. ISP1583 register access timing: multiplexed address/data bus (A0 function and Freescale mode) DIOR, DIOW (1) 36 ns (min) EOT(1) DREQ t h1 004aaa926 (1) Programmable polarity: shown as active LOW. Remark: EOT must be valid for 36 ns (minimum) when DIOR or DIOW is active. Fig 30. EOT timing in split bus mode ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 79 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 12.2 DMA timing 12.2.1 PIO mode Remark: In the following subsections, RW_N/RD_N, DS_N/WR_N, READY/IORDY and ALE/A0 refer to the ISP1583 pin. Table 106. PIO mode timing parameters VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Tcy1(min) read or write cycle time Conditions Mode 0 Mode 1 Mode 2 Mode 3 Mode 4 Unit [1] 600 383 240 180 120 ns 70 50 30 30 25 ns tsu1(min) address to DIOR or DIOW on set-up time tw1(min) DIOR or DIOW pulse width [1] 165 125 100 80 70 ns tw2(min) DIOR or DIOW recovery time [1] - - - 70 25 ns tsu2(min) data set-up time before DIOW off 60 45 30 30 20 ns th2(min) data hold time after DIOW off 30 20 15 10 10 ns tsu3(min) data set-up time before DIOR on 50 35 20 20 20 ns th3(min) data hold time after DIOR off 5 5 5 5 5 ns 30 30 30 30 30 ns 20 15 10 10 10 ns [2] td2(max) data to 3-state delay after DIOR off th1(min) address hold time after DIOR or DIOW off tsu4(min) READY/IORDY after DIOR or DIOW on set-up time [3] 35 35 35 35 35 ns tsu5(min) read data to READY/IORDY HIGH set-up time [3] 0 0 0 0 0 ns tw3(max) READY/IORDY LOW pulse width 1250 1250 1250 1250 1250 ns [1] Tcy1 is the total cycle time, consisting of command active time tw1 and command recovery (inactive) time tw2, that is, Tcy1 = tw1 + tw2. Minimum timing requirements for Tcy1, tw1 and tw2 must all be met. As Tcy1(min) is greater than the sum of tw1(min) and tw2(min), a host implementation must lengthen tw1 and/or tw2 to ensure that Tcy1 is equal to or greater than the value reported in the IDENTIFY DEVICE data. A device implementation shall support any legal host implementation. [2] td2 specifies the time after DIOR is negated, when the data bus is no longer driven by the device (3-state). [3] If READY/IORDY is LOW at tsu4, the host waits until READY/IORDY is made HIGH before the PIO cycle is completed. In that case, tsu5 must be met for reading (tsu3 does not apply). When READY/IORDY is HIGH at tsu4, tsu3 must be met for reading (tsu5 does not apply). ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 80 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller T cy1 device(1) address valid t h1 t su1 DIOR, DIOW (4) t w1 t w2 (write) DATA [7:0] (2) t su2 t h2 (read) DATA [7:0] (2) t su3 READY/IORDY (3a) HIGH t h3(min) t d2 t su4 READY/IORDY (3b) t su5 READY/IORDY (3c) 004aaa921 t su4 t w3 (1) The device address consists of signals CS1_N, CS0_N, DA2, DA1 and DA0. (2) The data bus width depends on the PIO access command used. The Task File register access uses 8 bits (DATA[7:0]), except for Task File register 1F0 that uses 16 bits (DATA[15:0]). DMA commands 04h and 05h also use a 16-bit data bus. (3) The device can negate READY/IORDY to extend the PIO cycle with wait states. The host determines whether or not to extend the current cycle after tsu4, following the assertion of DIOR or DIOW. The following three cases are distinguished: a) Device keeps READY/IORDY released (high-impedance): no wait state is generated. b) Device negates READY/IORDY during tsu4, but re-asserts READY/IORDY before tsu4 expires: no wait state is generated. c) Device negates READY/IORDY during tsu4 and keeps READY/IORDY negated for at least 5 ns after tsu4 expires: a wait state is generated. The cycle is completed as soon as READY/IORDY is re-asserted. For extended read cycles (DIOR asserted), the read data on lines DATAn must be valid at td1 before READY/IORDY is asserted. (4) DIOR and DIOW have a programmable polarity: shown here as active LOW signals. Fig 31. PIO mode timing ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 81 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 12.2.2 GDMA slave mode * Bits MODE[1:0] = 00: data strobes DIOR (read) and DIOW (write); see Figure 32 * Bits MODE[1:0] = 01: data strobes DIOR (read) and DACK (write); see Figure 33 * Bits MODE[1:0] = 10: data strobes DACK (read and write); see Figure 34 Table 107. GDMA slave mode timing parameters VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Min Typ Max Unit Tcy1 Symbol Parameter read or write cycle time Conditions 75 - - ns tsu1 DREQ set-up time before first DACK on 10 - - ns td1 DREQ on delay after last strobe off 33.33 - - ns th1 DREQ hold time after last strobe on 0 - 53 ns tw1 DIOR or DIOW pulse width 39 - 600 ns tw2 DIOR or DIOW recovery time 36 - - ns td2 read data valid delay after strobe on - - 20 ns th2 read data hold time after strobe off - - 5 ns th3 write data hold time after strobe off 1 - - ns tsu2 write data set-up time before strobe off 10 - - ns tsu3 DACK set-up time before DIOR or DIOW assertion 0 - - ns ta1 DACK de-assertion after DIOR or DIOW de-assertion 0 - 30 ns DREQ(2) t su1 t w1 Tcy1 t h1 DACK (1) t d1 t su3 DIOR or DIOW (1) tw2 t h2 t d2 ta1 (read) DATA [15:0] t su2 t h3 (write) DATA [15:0] mgt500 DREQ is continuously asserted, until the last transfer is done or the FIFO is full. Data strobes: DIOR (read), DIOW (write). (1) Programmable polarity: shown as active LOW. (2) Programmable polarity: shown as active HIGH. Fig 32. GDMA slave mode timing: DIOR (master) and DIOW (slave) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 82 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller DREQ(2) tsu3 tw1 tsu1 Tcy1 td1 th1 DACK(1) td2 ta1 DIOR or DIOW(1) th2 (read) DATA[15:0] th3 tsu2 (write) DATA[15:0] mgt502 DREQ is asserted for every transfer. Data strobes: DIOR (read), DACK (write). (1) Programmable polarity: shown as active LOW. (2) Programmable polarity: shown as active HIGH. Fig 33. GDMA slave mode timing: DIOR (master) or DACK (slave) DREQ(2) tsu1 tw1 Tcy1 th1 DACK(1) tw2 td2 DIOR or DIOW(1) td1 HIGH th2 (read) DATA[15:0] tsu2 th3 (write) DATA[15:0] mgt501 DREQ is continuously asserted, until the last transfer is done or the FIFO is full. Data strobe: DACK (read/write). (1) Programmable polarity: shown as active LOW. (2) Programmable polarity: shown as active HIGH. Fig 34. GDMA slave mode timing: DACK (master and slave) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 83 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 12.2.3 MDMA mode Table 108. MDMA mode timing parameters VCC(I/O) = 1.65 V to 3.6 V; VCC(3V3) = 3.3 V; VGND = 0 V; Tamb = -40 C to +85 C. Symbol Parameter Conditions Mode 0 Mode 1 Mode 2 Unit 480 150 120 ns 215 80 70 ns Tcy1(min) read/write cycle time [1] tw1(min) DIOR or DIOW pulse width [1] td1(max) data valid delay after DIOR on 150 60 50 ns th3(min) data hold time after DIOR off 5 5 5 ns tsu2(min) data set-up time before DIOR or DIOW off 100 30 20 ns th2(min) data hold time after DIOW off 20 15 10 ns tsu1(min) DACK set-up time before DIOR or DIOW on 0 0 0 ns th1(min) DACK hold time after DIOR or DIOW off tw2(min) td2(max) td3(max) [1] 20 5 5 ns DIOR recovery time [1] 50 50 25 ns DIOW recovery time [1] 215 50 25 ns DIOR on to DREQ off delay 120 40 35 ns DIOW on to DREQ off delay 40 40 35 ns DACK off to data lines 3-state delay 20 25 25 ns Tcy1 is the total cycle time, consisting of command active time tw1 and command recovery (inactive) time tw2, that is, Tcy1 = tw1 + tw2. Minimum timing requirements for Tcy1, tw1 and tw2 must all be met. As Tcy1(min) is greater than the sum of tw1(min) and tw2(min), a host implementation must lengthen tw1 and/or tw2 to ensure that Tcy1 is equal to or greater than the value reported in the IDENTIFY DEVICE data. A device implementation shall support any legal host implementation. DREQ(2) Tcy1 DACK(1) tsu1 tw2 tw1 td2 th1 DIOR or DIOW(1) td3 td1 (write) DATA[15:0] th3 (read) DATA[15:0] tsu2 th2 mgt506 tsu2 (1) Programmable polarity: shown as active LOW. (2) Programmable polarity: shown as active HIGH. Fig 35. MDMA master mode timing ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 84 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 13. Application information ISP1583 address 8 data 16 AD[7:0] ALE/A0 DATA[15:0] CPU read strobe RW_N/RD_N write strobe DS_N/WR_N chip select CS_N 004aaa273 Fig 36. Typical interface connections for generic processor mode DATA [15:0] DREQ DMA ISP1583 DACK DIOW DIOR ALE/A0 address latch enable ALE RW_N/RD_N INT interrupt INTn_N DS_N/WR_N write strobe read strobe RD_N WR_N 8051 MICROCONTROLLER AD[7:0] 8 address or data P0.7/AD7 to P0.0/AD0 004aaa274 Fig 37. Typical interface connections for split bus mode (slave mode) 14. Test information The dynamic characteristics of analog I/O ports DP and DM are determined using the circuit shown in Figure 38. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 85 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller test point DUT 15 k CL 50 pF mgt495 In full-speed mode, an internal 1.5 k pull-up resistor is connected to pin DP. Fig 38. Load impedance for the DP and DM pins (full-speed mode) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 86 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 15. Package outline HVQFN64: plastic thermal enhanced very thin quad flat package; no leads; 64 terminals; body 9 x 9 x 0.85 mm SOT804-1 B D D1 A terminal 1 index area A A4 E1 E c A1 detail X C e1 e y1 C v M C A B w M C b 1/2 e 17 y 32 L 33 16 e e2 Eh 1/2 e 1 terminal 1 index area 48 49 64 X Dh 0 5 10 mm scale DIMENSIONS (mm are the original dimensions) UNIT A max. A1 A4 b c D D1 Dh E E1 Eh e e1 e2 L v w y y1 mm 1 0.05 0.00 0.80 0.65 0.30 0.18 0.2 9.05 8.95 8.95 8.55 4.85 4.55 9.05 8.95 8.95 8.55 4.85 4.55 0.5 7.5 7.5 0.5 0.3 0.1 0.05 0.05 0.1 REFERENCES OUTLINE VERSION IEC JEDEC JEITA SOT804-1 --- MO-220 --- EUROPEAN PROJECTION ISSUE DATE 03-03-26 Fig 39. Package outline SOT804-1 (HVQFN64) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 87 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller TFBGA64: plastic thin fine-pitch ball grid array package; 64 balls; body 6 x 6 x 0.8 mm D SOT543-1 A B ball A1 index area A A2 E A1 detail X C e1 e 1/2 e v M C A B b y y1 C w M C K J H e G F e2 E 1/2 e D C B A ball A1 index area 1 2 3 4 5 6 7 8 9 10 X 0 2.5 5 mm scale DIMENSIONS (mm are the original dimensions) UNIT mm A max. A1 A2 b D E e e1 e2 v w y y1 1.1 0.25 0.15 0.85 0.75 0.35 0.25 6.1 5.9 6.1 5.9 0.5 4.5 4.5 0.15 0.05 0.08 0.1 REFERENCES OUTLINE VERSION IEC JEDEC JEITA SOT543-1 --- MO-195 --- EUROPEAN PROJECTION ISSUE DATE 00-11-22 02-04-09 Fig 40. Package outline SOT543-1 (TFBGA64) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 88 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller TFBGA64: plastic thin fine-pitch ball grid array package; 64 balls; body 4 x 4 x 0.8 mm A B D SOT969-1 ball A1 index area A E A2 A1 detail X e1 1/2 e v w b e C C A B C M M y y1 C H G F e E e2 D C 1/2 e B A ball A1 index area 1 2 3 4 5 6 7 8 X 0 2.5 5 mm scale DIMENSIONS (mm are the original dimensions) UNIT A max A1 A2 b D E e e1 e2 v w y y1 mm 1.1 0.25 0.15 0.85 0.75 0.3 0.2 4.1 3.9 4.1 3.9 0.4 2.8 2.8 0.15 0.05 0.08 0.1 REFERENCES OUTLINE VERSION IEC JEDEC JEITA SOT969-1 --- --- --- EUROPEAN PROJECTION ISSUE DATE 06-09-22 06-09-27 Fig 41. Package outline SOT969-1 (TFBGA64) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 89 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 16. Soldering This text provides a very brief insight into a complex technology. A more in-depth account of soldering ICs can be found in Application Note AN10365 "Surface mount reflow soldering description". 16.1 Introduction to soldering Soldering is one of the most common methods through which packages are attached to Printed Circuit Boards (PCBs), to form electrical circuits. The soldered joint provides both the mechanical and the electrical connection. There is no single soldering method that is ideal for all IC packages. Wave soldering is often preferred when through-hole and Surface Mount Devices (SMDs) are mixed on one printed wiring board; however, it is not suitable for fine pitch SMDs. Reflow soldering is ideal for the small pitches and high densities that come with increased miniaturization. 16.2 Wave and reflow soldering Wave soldering is a joining technology in which the joints are made by solder coming from a standing wave of liquid solder. The wave soldering process is suitable for the following: * Through-hole components * Leaded or leadless SMDs, which are glued to the surface of the printed circuit board Not all SMDs can be wave soldered. Packages with solder balls, and some leadless packages which have solder lands underneath the body, cannot be wave soldered. Also, leaded SMDs with leads having a pitch smaller than ~0.6 mm cannot be wave soldered, due to an increased probability of bridging. The reflow soldering process involves applying solder paste to a board, followed by component placement and exposure to a temperature profile. Leaded packages, packages with solder balls, and leadless packages are all reflow solderable. Key characteristics in both wave and reflow soldering are: * * * * * * Board specifications, including the board finish, solder masks and vias Package footprints, including solder thieves and orientation The moisture sensitivity level of the packages Package placement Inspection and repair Lead-free soldering versus PbSn soldering 16.3 Wave soldering Key characteristics in wave soldering are: * Process issues, such as application of adhesive and flux, clinching of leads, board transport, the solder wave parameters, and the time during which components are exposed to the wave * Solder bath specifications, including temperature and impurities ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 90 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 16.4 Reflow soldering Key characteristics in reflow soldering are: * Lead-free versus SnPb soldering; note that a lead-free reflow process usually leads to higher minimum peak temperatures (see Figure 42) than a PbSn process, thus reducing the process window * Solder paste printing issues including smearing, release, and adjusting the process window for a mix of large and small components on one board * Reflow temperature profile; this profile includes preheat, reflow (in which the board is heated to the peak temperature) and cooling down. It is imperative that the peak temperature is high enough for the solder to make reliable solder joints (a solder paste characteristic). In addition, the peak temperature must be low enough that the packages and/or boards are not damaged. The peak temperature of the package depends on package thickness and volume and is classified in accordance with Table 109 and 110 Table 109. SnPb eutectic process (from J-STD-020C) Package thickness (mm) Package reflow temperature (C) Volume (mm3) < 350 350 < 2.5 235 220 2.5 220 220 Table 110. Lead-free process (from J-STD-020C) Package thickness (mm) Package reflow temperature (C) Volume (mm3) < 350 350 to 2000 > 2000 < 1.6 260 260 260 1.6 to 2.5 260 250 245 > 2.5 250 245 245 Moisture sensitivity precautions, as indicated on the packing, must be respected at all times. Studies have shown that small packages reach higher temperatures during reflow soldering, see Figure 42. ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 91 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller maximum peak temperature = MSL limit, damage level temperature minimum peak temperature = minimum soldering temperature peak temperature time 001aac844 MSL: Moisture Sensitivity Level Fig 42. Temperature profiles for large and small components For further information on temperature profiles, refer to Application Note AN10365 "Surface mount reflow soldering description". 17. Abbreviations Table 111. Abbreviations Acronym Description ACPI Advanced Configuration and Power Interface ASIC Application-Specific Integrated Circuit ATA Advanced Technology Attachment ATAPI Advanced Technology Attachment Peripheral Interface CRC Cyclic Redundancy Code DMA Direct Memory Access EMI ElectroMagnetic Interference ESR Equivalent Series Resistance FS Full-Speed GDMA Generic DMA HS High-Speed IDE Integrated Development Environment MDMA Multi-word DMA MMU Memory Management Unit MO Magneto-Optical NRZI Non-Return-to-Zero Inverted OTG On-The-Go PCB Printed-Circuit Board PDA Personal Digital Assistant ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 92 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 111. Abbreviations ...continued Acronym Description PID Packet IDentifier PIE Parallel Interface Engine PIO Parallel Input/Output PLL Phase-Locked Loop PHY Physical POR Power-On Reset SE0 Single-Ended Zero SIE Serial Interface Engine SRP Session Request Protocol TTL Transistor-Transistor Logic USB Universal Serial Bus 18. References [1] Universal Serial Bus Specification Rev. 2.0 [2] On-The-Go Supplement to the USB Specification Rev. 1.2 [3] ISP1581/2/3 Frequently Asked Questions (AN10046) [4] AT Attachment with Packet Interface Extension (ATA/ATAPI-4), ANSI INCITS 317-1998 (R2003) [5] ISP1582/83 and ISP1761 clearing an IN buffer (AN10045) ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 93 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 19. Revision history Table 112. Revision history Document ID Release date Data sheet status Change notice Supersedes ISP1583_6 20070820 Product data sheet - ISP1583_5 Modifications: * * * * * * * * * * * ISP1583_5 Added the ISP1583ET1 package. Figure 1 "Block diagram": updated the figure note. Updated Section 7.9 "Clear buffer" on page 16. Added Section 7.10 "Reconfiguring endpoints" on page 17. Figure 7 "Resistor and electrolytic or tantalum capacitor needed for VBUS sensing": added the figure note. Section 8.3.1 "Endpoint Index register (address: 2Ch)": added two remarks. Section 8.3.2 "Control Function register (address: 28h)": updated the DSEN bit. Section 8.3.3 "Data Port register (address: 20h)": added two remarks. Table 36 "Control Function register: bit description": updated bit 4 description. Table 38 "Data Port register: bit description": updated the bit description. Section 18 "References": updated the list. 20070209 Product data sheet - ISP1583-04 ISP1583-04 20050104 (9397 750 14335) Product data 200412038 ISP1583-03 ISP1583-03 20040712 (9397 750 13461) Product data - ISP1583-02 ISP1583-02 20040503 (9397 750 12978) Product data - ISP1583-01 ISP1583-01 20040225 (9397 750 11497) Preliminary data - - ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 94 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 20. Legal information 20.1 Data sheet status Document status[1][2] Product status[3] Definition Objective [short] data sheet Development This document contains data from the objective specification for product development. Preliminary [short] data sheet Qualification This document contains data from the preliminary specification. Product [short] data sheet Production This document contains the product specification. [1] Please consult the most recently issued document before initiating or completing a design. [2] The term `short data sheet' is explained in section "Definitions". [3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL http://www.nxp.com. 20.2 Definitions Draft -- The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information. Short data sheet -- A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail. 20.3 Disclaimers General -- Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. Right to make changes -- NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof. Suitability for use -- NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in medical, military, aircraft, space or life support equipment, nor in applications where failure or malfunction of a NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk. Applications -- Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification. Limiting values -- Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) may cause permanent damage to the device. Limiting values are stress ratings only and operation of the device at these or any other conditions above those given in the Characteristics sections of this document is not implied. Exposure to limiting values for extended periods may affect device reliability. Terms and conditions of sale -- NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at http://www.nxp.com/profile/terms, including those pertaining to warranty, intellectual property rights infringement and limitation of liability, unless explicitly otherwise agreed to in writing by NXP Semiconductors. In case of any inconsistency or conflict between information in this document and such terms and conditions, the latter will prevail. No offer to sell or license -- Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights. 20.4 Trademarks Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners. SoftConnect -- is a trademark of NXP B.V. 21. Contact information For additional information, please visit: http://www.nxp.com For sales office addresses, send an email to: salesaddresses@nxp.com ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 95 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 22. Tables Table 1. Table 2. Table 3. Table 4. Table 5. Table 6. Table 7. Table 8. Table 9. Table 10. Table 11. Table 12. Table 13. Table 14. Table 15. Table 16. Table 17. Table 18. Table 19. Table 20. Table 21. Table 22. Table 23. Table 24. Table 25. Table 26. Table 27. Table 28. Table 29. Table 30. Table 31. Table 32. Table 33. Table 34. Table 35. Table 36. Table 37. Table 38. Table 39. Table 40. Table 41. Table 42. Ordering information . . . . . . . . . . . . . . . . . . . . .3 Pin description . . . . . . . . . . . . . . . . . . . . . . . . . .6 Bus configuration modes . . . . . . . . . . . . . . . . .17 ISP1583 pin status . . . . . . . . . . . . . . . . . . . . . .18 ISP1583 output pin status . . . . . . . . . . . . . . . .18 Power modes . . . . . . . . . . . . . . . . . . . . . . . . . .24 Operation truth table for SoftConnect . . . . . . .26 Operation truth table for clock off during suspend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .26 Operation truth table for back voltage compliance . . . . . . . . . . . . . . . . . . . . . . . . . . . .26 Operation truth table for OTG . . . . . . . . . . . . .26 Operation truth table for SoftConnect . . . . . . .27 Operation truth table for clock off during suspend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .27 Operation truth table for back voltage compliance . . . . . . . . . . . . . . . . . . . . . . . . . . . .27 Operation truth table for OTG . . . . . . . . . . . . .28 Operation truth table for SoftConnect . . . . . . .28 Operation truth table for clock off during suspend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .28 Operation truth table for back voltage compliance . . . . . . . . . . . . . . . . . . . . . . . . . . . .29 Operation truth table for OTG . . . . . . . . . . . . .29 Register overview . . . . . . . . . . . . . . . . . . . . . .30 Address register: bit allocation . . . . . . . . . . . .32 Address register: bit description . . . . . . . . . . .32 Mode register: bit allocation . . . . . . . . . . . . . . .33 Mode register: bit description . . . . . . . . . . . . .33 Status of the chip . . . . . . . . . . . . . . . . . . . . . . .34 Interrupt Configuration register: bit allocation .35 Interrupt Configuration register: bit description 35 Debug mode settings . . . . . . . . . . . . . . . . . . . .35 OTG register: bit allocation . . . . . . . . . . . . . . .35 OTG register: bit description . . . . . . . . . . . . . .36 Interrupt Enable register: bit allocation . . . . . .38 Interrupt Enable register: bit description . . . . .38 Endpoint Index register: bit allocation . . . . . . .39 Endpoint Index register: bit description . . . . . .40 Addressing of endpoint buffers . . . . . . . . . . . .40 Control Function register: bit allocation . . . . . .40 Control Function register: bit description . . . . .41 Data Port register: bit allocation . . . . . . . . . . .42 Data Port register: bit description . . . . . . . . . .42 Buffer Length register: bit allocation . . . . . . . .43 Buffer Length register: bit description . . . . . . .43 Buffer Status register: bit allocation . . . . . . . . .44 Buffer Status register: bit description . . . . . . . .44 Table 43. Endpoint MaxPacketSize register: bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Table 44. Endpoint MaxPacketSize register: bit description . . . . . . . . . . . . . . . . . . . . . . . . . 45 Table 45. Endpoint Type register: bit allocation . . . . . . . 45 Table 46. Endpoint Type register: bit description . . . . . . 46 Table 47. Control bits for Generic DMA transfers . . . . . . 47 Table 48. Control bits for IDE-specified DMA transfers . . 48 Table 49. DMA Command register: bit allocation . . . . . . 48 Table 50. DMA Command register: bit description . . . . . 48 Table 51. DMA commands . . . . . . . . . . . . . . . . . . . . . . . 49 Table 52. DMA Transfer Counter register: bit allocation . 50 Table 53. DMA Transfer Counter register: bit description 51 Table 54. DMA Configuration register: bit allocation . . . . 51 Table 55. DMA Configuration register: bit description . . . 52 Table 56. DMA Hardware register: bit allocation . . . . . . . 53 Table 57. DMA Hardware register: bit description . . . . . 53 Table 58. Task File register functions . . . . . . . . . . . . . . . 54 Table 59. ATAPI peripheral register addressing . . . . . . . 54 Table 60. Task File 1F0 register (address: 40h): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 Table 61. Task File 1F1 register (address: 48h): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Table 62. Task File 1F2 register (address: 49h): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Table 63. Task File 1F3 register (address: 4Ah): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Table 64. Task File 1F4 register (address: 4Bh): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Table 65. Task File 1F5 register (address: 4Ch): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Table 66. Task File 1F6 register (address: 4Dh): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 Table 67. Task File 1F7 register (address: 44h): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 Table 68. Task File 3F6 register (address: 4Eh): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 Table 69. Task File 3F7 register (address: 4Fh): bit allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 Table 70. DMA Interrupt Reason register: bit allocation . 57 Table 71. DMA Interrupt Reason register: bit description 57 Table 72. Internal EOT-functional relation with DMA_XFER_OK bit . . . . . . . . . . . . . . . . . . . . . 58 Table 73. DMA Interrupt Enable register: bit allocation . . 58 Table 74. DMA Endpoint register: bit allocation . . . . . . . 58 Table 75. DMA Endpoint register: bit description . . . . . . 59 Table 76. DMA Strobe Timing register: bit allocation . . . 59 Table 77. DMA Strobe Timing register: bit description . . 59 continued >> ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 96 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller Table 78. Table 79. Table 80. Table 81. Table 82. Table 83. Table 84. Table 85. Table 86. Table 87. Table 88. Table 89. Table 90. Table 91. Table 92. Table 93. Table 94. Table 95. Table 96. Table 97. DMA Burst Counter register: bit allocation . . .60 DMA Burst Counter register: bit description . .60 Interrupt register: bit allocation . . . . . . . . . . . .60 Interrupt register: bit description . . . . . . . . . . .61 Chip ID register: bit allocation . . . . . . . . . . . . .62 Chip ID register: bit description . . . . . . . . . . . .62 Frame Number register: bit allocation . . . . . . .63 Frame Number register: bit description . . . . . .63 Scratch register: bit allocation . . . . . . . . . . . . .63 Scratch register: bit description . . . . . . . . . . . .63 Unlock Device register: bit allocation . . . . . . . .64 Unlock Device register: bit description . . . . . . .64 Test Mode register: bit allocation . . . . . . . . . . .64 Test Mode register: bit description . . . . . . . . . .65 Limiting values . . . . . . . . . . . . . . . . . . . . . . . . .66 Recommended operating conditions . . . . . . . .66 Static characteristics: supply pins . . . . . . . . . .66 Static characteristics: digital pins . . . . . . . . . . .67 Static characteristics: OTG detection . . . . . . .67 Static characteristics: analog I/O pins DP and DM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .67 Table 98. Dynamic characteristics . . . . . . . . . . . . . . . . . .68 Table 99. Dynamic characteristics: analog I/O pins DP and DM . . . . . . . . . . . . . . . . . . . . . . . . . . .68 Table 100.ISP1583 register access timing parameters: separate address and data buses . . . . . . . . . .70 Table 101.ISP1583 register access timing parameters: separate address and data buses . . . . . . . . . .72 Table 102.ISP1583 register access timing parameters: multiplexed address/data bus . . . . . . . . . . . . .74 Table 103.ISP1583 register access timing parameters: multiplexed address/data bus . . . . . . . . . . . . .75 Table 104.ISP1583 register access timing parameters: multiplexed address/data bus . . . . . . . . . . . . .76 Table 105.ISP1583 register access timing parameters: multiplexed address/data bus . . . . . . . . . . . . .77 Table 106.PIO mode timing parameters . . . . . . . . . . . . . .80 Table 107.GDMA slave mode timing parameters . . . . . . .82 Table 108.MDMA mode timing parameters . . . . . . . . . . .84 Table 109.SnPb eutectic process (from J-STD-020C) . . .91 Table 110.Lead-free process (from J-STD-020C) . . . . . .91 Table 111.Abbreviations . . . . . . . . . . . . . . . . . . . . . . . . . .92 Table 112.Revision history . . . . . . . . . . . . . . . . . . . . . . . .94 continued >> ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 97 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 23. Figures Fig 1. Fig 2. Fig 3. Fig 4. Fig 5. Fig 6. Fig 7. Fig 8. Fig 9. Fig 10. Fig 11. Fig 12. Fig 13. Fig 14. Fig 15. Fig 16. Fig 17. Fig 18. Fig 19. Fig 20. Fig 21. Fig 22. Fig 23. Fig 24. Fig 25. Fig 26. Fig 27. Fig 28. Fig 29. Fig 30. Fig 31. Fig 32. Fig 33. Fig 34. Block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . .4 Pin configuration ISP1583BS (top view) . . . . . . . .5 Pin configuration ISP1583ET (top view) . . . . . . . .5 Pin configuration ISP1583ET1 (top view) . . . . . . .6 Interrupt logic . . . . . . . . . . . . . . . . . . . . . . . . . . . .20 Behavior of bit GLINTENA . . . . . . . . . . . . . . . . . .21 Resistor and electrolytic or tantalum capacitor needed for VBUS sensing . . . . . . . . . . . . . . . . . . .22 Oscilloscope reading: no resistor and capacitor in the network . . . . . . . . . . . . . . . . . . . .22 Oscilloscope reading: with resistor and capacitor in the network . . . . . . . . . . . . . . . . . . . .22 POR timing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .23 Clock with respect to the external POR . . . . . . . .23 ISP1583 with a 3.3 V supply . . . . . . . . . . . . . . . .24 Power-sharing mode . . . . . . . . . . . . . . . . . . . . . .25 Interrupt pin status during power off in power-sharing mode . . . . . . . . . . . . . . . . . . . . . .25 Self-powered mode . . . . . . . . . . . . . . . . . . . . . . .27 Bus-powered mode . . . . . . . . . . . . . . . . . . . . . . .28 Programmable strobe timing . . . . . . . . . . . . . . . .59 Source differential data-to-EOP transition skew and EOP width . . . . . . . . . . . . . . . . . . . . . .69 Receiver differential data jitter . . . . . . . . . . . . . . .70 Receiver SE0 width tolerance . . . . . . . . . . . . . . .70 ISP1583 register access timing: separate address and data buses (8051 mode) . . . . . . . . .71 ISP1583 ready signal timing . . . . . . . . . . . . . . . .72 ISP1583 register access timing: separate address and data buses (Freescale mode) . . . . .73 ISP1583 ready signal timing . . . . . . . . . . . . . . . .73 EOT timing in generic processor mode . . . . . . . .74 ISP1583 register access timing: multiplexed address/data bus (8051 mode) . . . . . . . . . . . . . .75 ISP1583 register access timing: multiplexed address/data bus (Freescale mode) . . . . . . . . . .76 ISP1583 register access timing: multiplexed address/data bus (A0 function and 8051 mode) .77 ISP1583 register access timing: multiplexed address/data bus (A0 function and Freescale mode). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .79 EOT timing in split bus mode . . . . . . . . . . . . . . . .79 PIO mode timing . . . . . . . . . . . . . . . . . . . . . . . . .81 GDMA slave mode timing: DIOR (master) and DIOW (slave) . . . . . . . . . . . . . . . . . . . . . . . . . . . .82 GDMA slave mode timing: DIOR (master) or DACK (slave) . . . . . . . . . . . . . . . . . . . . . . . . . . . .83 GDMA slave mode timing: DACK (master and slave) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 Fig 35. MDMA master mode timing. . . . . . . . . . . . . . . . . 84 Fig 36. Typical interface connections for generic processor mode. . . . . . . . . . . . . . . . . . . . . . . . . . 85 Fig 37. Typical interface connections for split bus mode (slave mode) . . . . . . . . . . . . . . . . . . . . . . . 85 Fig 38. Load impedance for the DP and DM pins (full-speed mode) . . . . . . . . . . . . . . . . . . . . . . . . 86 Fig 39. Package outline SOT804-1 (HVQFN64) . . . . . . . 87 Fig 40. Package outline SOT543-1 (TFBGA64) . . . . . . . 88 Fig 41. Package outline SOT969-1 (TFBGA64) . . . . . . . 89 Fig 42. Temperature profiles for large and small components. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 continued >> ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 98 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 24. Contents 1 2 3 4 5 6 6.1 6.2 7 7.1 7.2 7.3 7.4 7.5 7.6 7.6.1 7.6.2 7.6.3 7.6.4 7.7 7.8 7.9 7.10 7.11 7.12 7.13 7.14 7.14.1 7.14.2 7.15 7.16 7.17 7.17.1 7.17.2 7.17.3 8 8.1 8.2 8.2.1 8.2.2 8.2.3 8.2.4 8.2.4.1 8.2.5 General description . . . . . . . . . . . . . . . . . . . . . . 1 Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Ordering information . . . . . . . . . . . . . . . . . . . . . 3 Block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . 4 Pinning information . . . . . . . . . . . . . . . . . . . . . . 5 Pinning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 Pin description . . . . . . . . . . . . . . . . . . . . . . . . . 6 Functional description . . . . . . . . . . . . . . . . . . 13 DMA interface, DMA handler and DMA registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Hi-Speed USB transceiver . . . . . . . . . . . . . . . 14 MMU and integrated RAM . . . . . . . . . . . . . . . 14 Microcontroller interface and microcontroller handler . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 OTG SRP module . . . . . . . . . . . . . . . . . . . . . . 15 NXP high-speed transceiver . . . . . . . . . . . . . . 15 NXP Parallel Interface Engine (PIE) . . . . . . . . 15 Peripheral circuit . . . . . . . . . . . . . . . . . . . . . . . 15 HS detection . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Isolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 NXP Serial Interface Engine (SIE) . . . . . . . . . 16 SoftConnect . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Clear buffer . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Reconfiguring endpoints . . . . . . . . . . . . . . . . . 17 System controller . . . . . . . . . . . . . . . . . . . . . . 17 Modes of operation . . . . . . . . . . . . . . . . . . . . . 17 Pins status . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Interrupt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Interrupt output pin . . . . . . . . . . . . . . . . . . . . . 18 Interrupt control . . . . . . . . . . . . . . . . . . . . . . . 21 VBUS sensing . . . . . . . . . . . . . . . . . . . . . . . . . 21 Power-on reset . . . . . . . . . . . . . . . . . . . . . . . . 23 Power supply . . . . . . . . . . . . . . . . . . . . . . . . . 24 Power-sharing mode. . . . . . . . . . . . . . . . . . . . 25 Self-powered mode. . . . . . . . . . . . . . . . . . . . . 27 Bus-powered mode. . . . . . . . . . . . . . . . . . . . . 28 Register description . . . . . . . . . . . . . . . . . . . . 30 Register access . . . . . . . . . . . . . . . . . . . . . . . 31 Initialization registers . . . . . . . . . . . . . . . . . . . 32 Address register (address: 00h) . . . . . . . . . . . 32 Mode register (address: 0Ch) . . . . . . . . . . . . . 32 Interrupt Configuration register (address: 10h) 34 OTG register (address: 12h) . . . . . . . . . . . . . . 35 Session Request Protocol (SRP) . . . . . . . . . . 37 Interrupt Enable register (address: 14h) . . . . . 37 8.3 8.3.1 8.3.2 8.3.3 8.3.4 8.3.5 8.3.6 Data flow registers . . . . . . . . . . . . . . . . . . . . . Endpoint Index register (address: 2Ch) . . . . . Control Function register (address: 28h) . . . . Data Port register (address: 20h) . . . . . . . . . . Buffer Length register (address: 1Ch) . . . . . . Buffer Status register (address: 1Eh) . . . . . . . Endpoint MaxPacketSize register (address: 04h) . . . . . . . . . . . . . . . . . . . . . . . . 8.3.7 Endpoint Type register (address: 08h) . . . . . . 8.4 DMA registers . . . . . . . . . . . . . . . . . . . . . . . . 8.4.1 DMA Command register (address: 30h) . . . . 8.4.2 DMA Transfer Counter register (address: 34h) 8.4.3 DMA Configuration register (address: 38h) . . 8.4.4 DMA Hardware register (address: 3Ch) . . . . . 8.4.5 Task File registers (addresses: 40h to 4Fh) . . 8.4.6 DMA Interrupt Reason register (address: 50h) 8.4.7 DMA Interrupt Enable register (address: 54h) 8.4.8 DMA Endpoint register (address: 58h). . . . . . 8.4.9 DMA Strobe Timing register (address: 60h). . 8.4.10 DMA Burst Counter register (address: 64h). . 8.5 General registers . . . . . . . . . . . . . . . . . . . . . . 8.5.1 Interrupt register (address: 18h). . . . . . . . . . . 8.5.2 Chip ID register (address: 70h) . . . . . . . . . . . 8.5.3 Frame Number register (address: 74h) . . . . . 8.5.4 Scratch register (address: 78h) . . . . . . . . . . . 8.5.5 Unlock Device register (address: 7Ch). . . . . . 8.5.6 Test Mode register (address: 84h) . . . . . . . . . 9 Limiting values . . . . . . . . . . . . . . . . . . . . . . . . 10 Recommended operating conditions . . . . . . 11 Static characteristics . . . . . . . . . . . . . . . . . . . 12 Dynamic characteristics . . . . . . . . . . . . . . . . . 12.1 Register access timing . . . . . . . . . . . . . . . . . . 12.1.1 Generic processor mode . . . . . . . . . . . . . . . . 12.1.1.1 8051 mode . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.1.1.2 Freescale mode . . . . . . . . . . . . . . . . . . . . . . . 12.1.2 Split bus mode . . . . . . . . . . . . . . . . . . . . . . . . 12.1.2.1 ALE function. . . . . . . . . . . . . . . . . . . . . . . . . . 12.1.2.2 A0 function . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.2 DMA timing. . . . . . . . . . . . . . . . . . . . . . . . . . . 12.2.1 PIO mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12.2.2 GDMA slave mode . . . . . . . . . . . . . . . . . . . . . 12.2.3 MDMA mode . . . . . . . . . . . . . . . . . . . . . . . . . 13 Application information . . . . . . . . . . . . . . . . . 14 Test information. . . . . . . . . . . . . . . . . . . . . . . . 15 Package outline . . . . . . . . . . . . . . . . . . . . . . . . 16 Soldering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 39 40 41 42 43 44 45 46 48 50 51 52 54 56 58 58 59 59 60 60 62 62 63 64 64 66 66 66 68 70 70 70 72 74 74 76 80 80 82 84 85 85 87 90 continued >> ISP1583_6 Product data sheet (c) NXP B.V. 2007. All rights reserved. Rev. 06 -- 20 August 2007 99 of 100 ISP1583 NXP Semiconductors Hi-Speed USB Peripheral Controller 16.1 16.2 16.3 16.4 17 18 19 20 20.1 20.2 20.3 20.4 21 22 23 24 Introduction to soldering . . . . . . . . . . . . . . . . . Wave and reflow soldering . . . . . . . . . . . . . . . Wave soldering . . . . . . . . . . . . . . . . . . . . . . . . Reflow soldering . . . . . . . . . . . . . . . . . . . . . . . Abbreviations . . . . . . . . . . . . . . . . . . . . . . . . . . References . . . . . . . . . . . . . . . . . . . . . . . . . . . . Revision history . . . . . . . . . . . . . . . . . . . . . . . . Legal information. . . . . . . . . . . . . . . . . . . . . . . Data sheet status . . . . . . . . . . . . . . . . . . . . . . Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . Disclaimers . . . . . . . . . . . . . . . . . . . . . . . . . . . Trademarks . . . . . . . . . . . . . . . . . . . . . . . . . . . Contact information. . . . . . . . . . . . . . . . . . . . . Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Figures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Contents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90 90 90 91 92 93 94 95 95 95 95 95 95 96 98 99 Please be aware that important notices concerning this document and the product(s) described herein, have been included in section `Legal information'. (c) NXP B.V. 2007. All rights reserved. For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com Date of release: 20 August 2007 Document identifier: ISP1583_6