28.3.5 Interrupts

The peripheral has ten interrupt sources. These are split between two interrupt vectors, the transaction complete (TRNCOMPL) interrupt and the bus event (BUSEVENT) interrupt. An interrupt group is enabled by setting its interrupt level (INTLVL), while different interrupt sources are enabled individually or in groups.

The table below summarizes the interrupts and event sources for the USB peripheral and shows how they are enabled.

Table 28-2. Available Interrupt Vectors and Sources
NameVector DescriptionInterrupt FlagConditions
TRNCOMPLTransaction Complete interruptSETUPIF
TRNIF
BUSEVENTBus Event interruptSOFIF
SUSPENDIF
RESUMEIF

When an interrupt condition occurs, the corresponding interrupt flag is set in the peripheral’s Interrupt Flags (peripheral.INTFLAGS) register.

An interrupt source is enabled or disabled by writing to the corresponding enable bit in the peripheral’s Interrupt Control (peripheral.INTCTRL) register.

An interrupt request is generated when the corresponding interrupt source is enabled, and the interrupt flag is set. The interrupt request remains active until the interrupt flag is cleared. See the peripheral’s INTFLAGS register for details on how to clear interrupt flags.

Transaction Complete Interrupt

The transaction complete interrupt is generated per endpoint. When an interrupt occurs, the associated endpoint number is registered and optionally added to the FIFO. The following two interrupt sources use the interrupt vector:

Table 28-3. Transaction complete interrupt sources.
Interrupt SourceDescription
Transfer complete (TRNIF)An IN or OUT transaction is completed
Setup complete (SETUPIF)A SETUP transaction is completed

Bus Event Interrupt

The bus event (BUSEVENT) interrupt is used for all interrupts that signal various types of USB line events or error conditions. These interrupts are related to the USB lines and are generated for the USB peripheral and per endpoint. The following eight interrupts use the interrupt vector:

Table 28-4. Bus Event Interrupt Sources
Interrupt SourceDescription
Start of frame (SOFIF)A SOF token has been received
Suspend (SUSPENDIF)The bus has been idle for 3 ms
Resume (RESUMEIF)A non-idle state is detected when the bus is suspended. The interrupt is asynchronous and can wake the device from all sleep modes.
Reset (RSTIF)A reset condition has been detected on the bus
Isochronous CRC error (CRCIF)A CRC error or a bit-stuff error has been detected in an incoming packet to an isochronous endpoint
Underflow (UNFIF)An endpoint is unable to return data to the host
Overflow (OVFIF)An endpoint is unable to accept data from the host
STALL (STALLIF)A STALL handshake has been returned to the host