34.6.4 DMA, Interrupts and Events

Each interrupt source has its own interrupt flag. The interrupt flag in the Interrupt Flag Status and Clear register (INTFLAG) is set when the interrupt condition is met. Each interrupt can be individually enabled by writing ‘1’ to the corresponding bit in the Interrupt Enable Set register (INTENSET) and disabled by writing ‘1’ to the corresponding bit in the Interrupt Enable Clear register (INTENCLR). An interrupt request is generated when the interrupt flag is set and the corresponding interrupt is enabled. The interrupt request is active until the interrupt flag is cleared, the interrupt is disabled or the I2C is reset. See the INTFLAG (Client) or INTFLAG (Host) register from Related Links for details on how to clear interrupt flags.

Table 34-2. Module Request for SERCOM I2C Client
ConditionRequest
DMA Interrupt Event
Data needed for transmit (TX) (Client transmit mode)Yes

(request cleared when data is written)

NA
Data received (RX) (Client receive mode)Yes

(request cleared when data is read)

Data Ready (DRDY)Yes
Address Match (AMATCH)Yes
Stop received (PREC)Yes
Error (ERROR)Yes
Table 34-3. Module Request for SERCOM I2C Host
ConditionRequest
DMA Interrupt Event
Data needed for transmit (TX) (Host transmit mode)Yes

(request cleared when data is written)

NA
Data needed for transmit (RX) (Host transmit mode)Yes

(request cleared when data is read)

Host on Bus (MB)Yes
Stop received (SB)Yes
Error (ERROR)Yes