Datasheet
PIC18F47J53 FAMILY
DS39964B-page 394 Preliminary 2010 Microchip Technology Inc.
23.5 USB Interrupts
The USB module can generate multiple interrupt con-
ditions. To accommodate all of these interrupt sources,
the module is provided with its own interrupt logic
structure, similar to that of the microcontroller. USB
interrupts are enabled with one set of control registers
and trapped with a separate set of flag registers. All
sources are funneled into a single USB interrupt
request, USBIF (PIR2<4>), in the microcontroller’s
interrupt logic.
Figure 23-7 provides the interrupt logic for the USB
module. There are two layers of interrupt registers in
the USB module. The top level consists of overall USB
status interrupts; these are enabled and flagged in the
UIE and UIR registers, respectively. The second level
consists of USB error conditions, which are enabled
and flagged in the UEIR and UEIE registers. An
interrupt condition in any of these triggers a USB Error
Interrupt Flag (UERRIF) in the top level.
Interrupts may be used to trap routine events in a USB
transaction. Figure 23-8 provides some common
events within a USB frame and its corresponding
interrupts.
FIGURE 23-7: USB INTERRUPT LOGIC FUNNEL
FIGURE 23-8: EXAMPLE OF A USB TRANSACTION AND INTERRUPT EVENTS
BTSEF
BTSEE
BTOEF
BTOEE
DFN8EF
DFN8EE
CRC16EF
CRC16EE
CRC5EF
CRC5EE
PIDEF
PIDEE
SOFIF
SOFIE
TRNIF
TRNIE
IDLEIF
IDLEIE
STALLIF
STALLIE
ACTVIF
ACTVIE
URSTIF
URSTIE
UERRIF
UERRIE
USBIF
Second Level USB Interrupts
(USB Error Conditions)
UEIR (Flag) and UEIE (Enable) Registers
Top Level USB Interrupts
(USB Status Interrupts)
UIR (Flag) and UIE (Enable) Registers
USB Reset
SOFRESET SETUP DATA STATUS
SOF
SETUP Token Data ACK
OUT Token Empty Data ACK
Start-of-Frame (SOF)
IN Token Data ACK
SOFIF
URSTIF
1 ms Frame
Differential Data
From Host From Host
To Ho s t
From Host To Host From Host
From Host
From Host
To H os t
Transaction
Control Transfer
(1)
Transaction
Complete
Note 1: The control transfer shown here is only an example showing events that can occur for every transaction. Typical
control transfers will spread across multiple frames.
Set TRNIF
Set TRNIF
Set TRNIF