2.6 Advanced Interrupt Controller (AIC)

Controls the Interrupt Lines (nIRQ and nFIQ) of an ARM Processor

  • 128 Individually Maskable and Vectored Interrupt Sources
  • Source 0 is reserved for the fast interrupt input (FIQ)
  • Programmable edge-triggered or level-sensitive internal sources
  • Programmable rising/falling edge-triggered or high/low level-sensitive external sources
  • 8-level Priority Controller
    • Drives the normal interrupt of the processor
    • Handles priority of the interrupt sources 1 to 127
    • Higher priority interrupts can be served during service of lower priority interrupt
  • Vectoring
    • Optimizes interrupt service routine branch and execution
    • One 32-bit vector register for all interrupt sources
    • Interrupt vector register reads the corresponding current interrupt vector
  • General Interrupt Mask
    • Provides processor synchronization on events without triggering an interrupt
    • Register Write Protection

Using The Library

The AIC peripheral library initializes interrupt controller as configured by the user in the MCC. User can launch the AIC configurator using the "Tools" drop down in MCC menu bar. Using the AIC configurator, user can enable interrupt, configure priority, interrupt type and interrupt vector name.

Note: Only the interrupts of type non secure can be configured. Software routing of interrupts between secure and non-secure domains are not supported.

Library Interface

Advanced Interrupt Controller peripheral library provides the following interfaces:

Functions

NameDescription
AIC_INT_InitializeInitializes Advanced Interrupt Controller (AIC) peripheral library
AIC_INT_IrqEnableEnable Processor interrupt
AIC_INT_IrqDisableDisable Processor interrupt
AIC_INT_IrqRestoreRestore processor interrupt state
Note: Not all APIs maybe implemented. See the specific device family section for available APIs.