10 i2c interrupt vector register (icivr), Section 3.10 – Texas Instruments TMS320C642X User Manual
Page 36
Registers
www.ti.com
3.10 I2C Interrupt Vector Register (ICIVR)
The I2C interrupt vector register (ICIVR) is used by the CPU to determine which event generated the I2C
interrupt. Reading ICIVR clears the interrupt flag; if other interrupts are pending, a new interrupt is
generated. If there are more than one interrupt flag, reading ICIVR clears the highest priority interrupt flag.
Note that you must read (clear) ICIVR before doing another start; otherwise, ICIVR could contain an
incorrect (old interrupt flags) value.
The I2C interrupt vector register (ICIVR) is shown in
and described in
Figure 24. I2C Interrupt Vector Register (ICIVR)
31
16
Reserved
R-0
15
2
0
Reserved
INTCODE
R-0
R-0
LEGEND: R= Read only; -n = value after reset
Table 17. I2C Interrupt Vector Register (ICIVR) Field Descriptions
Bit
Field
Value
Description
31-3
Reserved
0
These reserved bit locations are always read as zeros. A value written to this field has no effect.
2-0
INTCODE
0-7h
Interrupt code bits. The binary code in INTCODE indicates which event generated an I2C interrupt.
0
None
1h
Arbitration-lost interrupt (AL). Highest priority if multiple I2C interrupts are pending.
2h
No-acknowledgment interrupt (NACK)
3h
Register-access-ready interrupt (ARDY)
4h
Receive-data-ready interrupt (ICRRDY)
5h
Transmit-data-ready interrupt (ICXRDY)
6h
Stop condition detected interrupt (SCD)
7h
Address-as-slave interrupt (AAS). Lowest priority if multiple I2C interrupts are pending.
36
Inter-Integrated Circuit (I2C) Peripheral
SPRUEN0D – March 2011
© 2011, Texas Instruments Incorporated