INT12
MUX
INT11
INT2
INT1
CPU
(Enable)
(Flag)
INTx
INTx.8
PIEIERx(8:1)
PIEIFRx(8:1)
MUX
INTx.7
INTx.6
INTx.5
INTx.4
INTx.3
INTx.2
INTx.1
From
Peripherals or
External
Interrupts
(Enable)
(Flag)
IER(12:1)
IFR(12:1)
Global
Enable
INTM
1
0
PIEACKx
(Enable/Flag)
Exceptions and Interrupts Control
102
SPRUHE8E – October 2012 – Revised November 2019
Copyright © 2012–2019, Texas Instruments Incorporated
System Control and Interrupts
dedicated RAM block that is modifiable. The CPU, upon servicing the interrupt, automatically fetches the
appropriate interrupt vector. It takes nine CPU clock cycles to fetch the vector and save critical CPU
registers. Therefore, the CPU can respond quickly to interrupt events. Prioritization of interrupts is
controlled in hardware and software. Each individual interrupt can be enabled/disabled within the PIE
block.
By default on power-up or on reset (any reset which can reset the control subsystem CPU), the PIE is
disabled and none of the peripheral interrupts are enabled. However, an NMI and ITRAP exceptions are
enabled by default on power up and a reset occur. When the PIE is disabled, any NMI and ITRAP
exception will use the handlers registered in the ROM vector table, and when the PIE is enabled, an NMI
and ITRAP exceptions will use the handler's registers in the PIE vector table, which is located in PIE RAM.
More details are explained in the following sections.
1.5.4.1
Overview of the PIE Controller
The 28x CPU supports one nonmaskable interrupt (NMI) and 16 maskable prioritized interrupt requests
(INT1-INT14, RTOSINT, and DLOGINT) at the CPU level. The 28x devices have many peripherals and
each peripheral is capable of generating one or more interrupts in response to many events at the
peripheral level. Because the CPU does not have sufficient capacity to handle all peripheral interrupt
requests at the CPU level, a centralized peripheral interrupt expansion (PIE) controller is required to
arbitrate the interrupt requests from various sources such as peripherals and other external pins. The PIE
vector table is used to store the address (vector) of each interrupt service routine (ISR) within the system.
There is one vector per interrupt source including all MUXed and nonMUXed interrupts. The user
populates the vector table during device initialization and updates it during operation.
1.5.4.1.1 Interrupt Operation Sequence
shows an overview of the interrupt operation sequence for all multiplexed PIE interrupts.
Interrupt sources that are not multiplexed are fed directly to the CPU.
Figure 1-4. PIE Interrupts Multiplexing