# **Lecture 4: Interrupts (Part 2)**

Cristinel Ababei

Dept. of Electrical and Computer Engineering, Marquette University

#### 1. LPC17xx MCU Overview

The LPC1700 series of low power cost-effective Cortex-M3 microcontrollers feature best-in-class peripheral support such as Ethernet, USB 2.0 Host/OTG/Device, and CAN 2.0B. Operating at speeds up to 120 MHz, they have up to 512 KB of FLASH, up to 64 KB of SRAM, 12-bit A/D and 10-bit D/A converters as well as an internal RC oscillator.

Block diagram shown in Fig.2 [1].



Figure 1 LPC17xx block diagram.

Simplified block diagrams of LPC1768 MCU are shown in Fig.3,4 [2].



Figure 2 Simplified block diagram of LPC1768 MCU.



Figure 3 LPC1768 block diagram, CPU, and buses.

### 2. Exception and Interrupts: Nested Vectored Interrupt Controller (NVIC)

- --Nested Vectored Interrupt Controller that is an integral part of the ARM Cortex-M3
- -- Tightly coupled interrupt controller provides low interrupt latency
- -- Controls system exceptions and peripheral interrupts
- -- In the LPC17xx, the NVIC supports 35 vectored interrupts
- --32 programmable interrupt priority levels, with hardware priority level masking
- --Relocatable vector table
- --Non-Maskable Interrupt
- --Software interrupt generation

Table 50 from User Manual [2] lists the interrupt sources for each peripheral function. Each peripheral device may have one or more interrupt lines to the Vectored Interrupt Controller. Each line may represent more than one interrupt source, as noted.

Exception numbers relate to where entries are stored in the exception vector table. Interrupt numbers are used in some other contexts, such as software interrupts.

Table 50. Connection of interrupt sources to the Vectored Interrupt Controller

| Table 50.       | Connection of interrupt sources to the Vectored Interrupt Controller |                  |                   |                                        |
|-----------------|----------------------------------------------------------------------|------------------|-------------------|----------------------------------------|
| Interrupt<br>ID | Exception<br>Number                                                  | Vector<br>Offset | Function          | Flag(s)                                |
| 0               | 16                                                                   | 0x40             | WDT               | Watchdog Interrupt (WDINT)             |
| 1               | 17                                                                   | 0x44             | Timer 0           | Match 0 - 1 (MR0, MR1)                 |
|                 |                                                                      |                  |                   | Capture 0 - 1 (CR0, CR1)               |
| 2               | 18                                                                   | 0x48             | Timer 1           | Match 0 - 2 (MR0, MR1, MR2)            |
|                 |                                                                      |                  |                   | Capture 0 - 1 (CR0, CR1)               |
| 3               | 19                                                                   | 0x4C             | Timer 2           | Match 0-3                              |
|                 |                                                                      |                  |                   | Capture 0-1                            |
| 4               | 20                                                                   | 0x50             | Timer 3           | Match 0-3                              |
|                 |                                                                      |                  |                   | Capture 0-1                            |
| 5               | 21                                                                   | 0x54             | UART0             | Rx Line Status (RLS)                   |
|                 |                                                                      |                  |                   | Transmit Holding Register Empty (THRE) |
|                 |                                                                      |                  |                   | Rx Data Available (RDA)                |
|                 |                                                                      |                  |                   | Character Time-out Indicator (CTI)     |
|                 |                                                                      |                  |                   | End of Auto-Baud (ABEO)                |
|                 |                                                                      |                  |                   | Auto-Baud Time-Out (ABTO)              |
| 6               | 22                                                                   | 0x58             | UART1             | Rx Line Status (RLS)                   |
|                 |                                                                      |                  |                   | Transmit Holding Register Empty (THRE) |
|                 |                                                                      |                  |                   | Rx Data Available (RDA)                |
|                 |                                                                      |                  |                   | Character Time-out Indicator (CTI)     |
|                 |                                                                      |                  |                   | Modern Control Change                  |
|                 |                                                                      |                  |                   | End of Auto-Baud (ABEO)                |
|                 |                                                                      |                  |                   | Auto-Baud Time-Out (ABTO)              |
| 7               | 23                                                                   | 0x5C             | UART 2            | Rx Line Status (RLS)                   |
|                 |                                                                      |                  |                   | Transmit Holding Register Empty (THRE) |
|                 |                                                                      |                  |                   | Rx Data Available (RDA)                |
|                 |                                                                      |                  |                   | Character Time-out Indicator (CTI)     |
|                 |                                                                      |                  |                   | End of Auto-Baud (ABEO)                |
|                 |                                                                      |                  |                   | Auto-Baud Time-Out (ABTO)              |
| 8               | 24                                                                   | 0x60             | UART 3            | Rx Line Status (RLS)                   |
|                 |                                                                      |                  |                   | Transmit Holding Register Empty (THRE) |
|                 |                                                                      |                  |                   | Rx Data Available (RDA)                |
|                 |                                                                      |                  |                   | Character Time-out Indicator (CTI)     |
|                 |                                                                      |                  |                   | End of Auto-Baud (ABEO)                |
|                 |                                                                      |                  |                   | Auto-Baud Time-Out (ABTO)              |
| 9               | 25                                                                   | 0x64             | PWM1              | Match 0 - 6 of PWM1                    |
|                 |                                                                      |                  |                   | Capture 0-1 of PWM1                    |
| 10              | 26                                                                   | 0x68             | I <sup>2</sup> C0 | SI (state change)                      |
| 11              | 27                                                                   | 0x6C             | I <sup>2</sup> C1 | SI (state change)                      |
| 12              | 28                                                                   | 0x70             | I <sup>2</sup> C2 | SI (state change)                      |
| 13              | 29                                                                   | 0x74             | SPI               | SPI Interrupt Flag (SPIF)              |
|                 |                                                                      |                  |                   | Mode Fault (MODF)                      |
|                 |                                                                      |                  |                   |                                        |

| Interrupt<br>ID | Exception<br>Number | Vector<br>Offset | Function                      | Flag(s)                                                                                                                                     |  |
|-----------------|---------------------|------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| 14              | 30                  | 0x78             | SSP0                          | Tx FIFO half empty of SSP0                                                                                                                  |  |
|                 |                     |                  |                               | Rx FIFO half full of SSP0                                                                                                                   |  |
|                 |                     |                  |                               | Rx Timeout of SSP0                                                                                                                          |  |
|                 |                     |                  |                               | Rx Overrun of SSP0                                                                                                                          |  |
| 15              | 31                  | 0x7C             | SSP 1                         | Tx FIFO half empty                                                                                                                          |  |
|                 |                     |                  |                               | Rx FIFO half full                                                                                                                           |  |
|                 |                     |                  |                               | Rx Timeout                                                                                                                                  |  |
|                 |                     |                  |                               | Rx Overrun                                                                                                                                  |  |
| 16              | 32                  | 0x80             | PLL0 (Main PLL)               | PLL0 Lock (PLOCK0)                                                                                                                          |  |
| 17              | 33                  | 0x84             | RTC                           | Counter Increment (RTCCIF)                                                                                                                  |  |
|                 |                     |                  |                               | Alarm (RTCALF)                                                                                                                              |  |
| 18              | 34                  | 0x88             | External Interrupt            | External Interrupt 0 (EINT0)                                                                                                                |  |
| 19              | 35                  | 0x8C             | External Interrupt            | External Interrupt 1 (EINT1)                                                                                                                |  |
| 20              | 36                  | 0x90             | External Interrupt            | External Interrupt 2 (EINT2)                                                                                                                |  |
| 21              | 37                  | 0x94             | External Interrupt            | External Interrupt 3 (EINT3).                                                                                                               |  |
|                 |                     |                  |                               | Note: EINT3 channel is shared with GPIO interrupts                                                                                          |  |
| 22              | 38                  | 0x98             | ADC                           | A/D Converter end of conversion                                                                                                             |  |
| 23              | 39                  | 0x9C             | BOD                           | Brown Out detect                                                                                                                            |  |
| 24              | 40                  | 0xA0             | USB                           | USB_INT_REQ_LP, USB_INT_REQ_HP, USB_INT_REQ_DMA                                                                                             |  |
| 25              | 41                  | 0xA4             | CAN                           | CAN Common, CAN 0 Tx, CAN 0 Rx, CAN 1 Tx, CAN 1 Rx                                                                                          |  |
| 26              | 42                  | 0xA8             | GPDMA                         | IntStatus of DMA channel 0, IntStatus of DMA channel 1                                                                                      |  |
| 27              | 43                  | 0xAC             | I2S                           | irq, dmareq1, dmareq2                                                                                                                       |  |
| 28              | 44                  | 0xB0             | Ethernet                      | Wakeupint, Softint, TxDoneint, TxFinishedint, TxErrorint,<br>TxUnderrunint, RxDoneint, RxFinishedint, RxErrorint,<br>RxOverrunint.          |  |
| 29              | 45                  | 0xB4             | Repetitive Interrupt<br>Timer | RITINT                                                                                                                                      |  |
| 30              | 46                  | 0xB8             | Motor Control PWM             | IPER[2:0], IPW[2:0], ICAP[2:0], FES                                                                                                         |  |
| 31              | 47                  | 0xBC             | Quadrature Encoder            | INX_int, TIM_int, VELC_int, DIR_int, ERR_int, ENCLK_int,<br>POS0_int, POS1_int, POS2_int, REV_int, POS0REV_int,<br>POS1REV_int, POS2REV_int |  |
| 32              | 48                  | 0xC0             | PLL1 (USB PLL)                | PLL1 Lock (PLOCK1)                                                                                                                          |  |
| 33              | 49                  | 0xC4             | USB Activity Interrupt        | USB_NEED_CLK                                                                                                                                |  |
| 34              | 50                  | 0xC8             | CAN Activity Interrupt        | CAN1WAKE, CAN2WAKE                                                                                                                          |  |

As we can see, the LPC1768 microprocessor can have many sources of interrupts. Selected GPIO pins can also be set to generate interrupts.

# 3. Input/Output Ports

Detailed information on this topic can be found in Chapters 7,8, and 9 of the LPC17xx user manual [2].

### a) Pin function:

The LPC1768 microprocessor has 100 pins. Fig.5 [3] shows the functionality of most of these pins. **Most pins can have more than one function.** For example, pin number 73, named as P2.2, can take four different roles as indicated by P2.2/PWM1.3/CTS1/TRACEDATA3.



Figure 4 Pins of LPC1768 MCU.

Many pins of LPC1768 can have up to four different functionalities. For each pin there is a two-bit field in a register named **PINSELx which controls the functionality of the pin**.

**There are ten PINSEL** (pin select) registers. One of them, PINSEL4, is used for pins connected to LEDs (connected to pins P2.7..P2:0) on the LandTiger board. The PINSEL4 register (at address 0x4002 C010 in the memory address space) controls the functions of the lower half of Port 2.

For example, the table on the next page, from the user manual, shows the functions of many of the Port 2 pins. For more information refer to tables 79-86 of the LPC17xx user manual.

Many times though we'll define the pins we'll work with as GPIO (general purpose input output) – the default functionality. We saw an example of using a pin as a GPIO in the Blinky examples of lab#2.

### 8.5.5 Pin Function Select Register 4 (PINSEL4 - 0x4002 C010)

The PINSEL4 register controls the functions of the lower half of Port 2. The direction control bit in the FIO2DIR register is effective only when the GPIO function is selected for a pin. For other functions, direction is controlled automatically.

Table 84. Pin function select register 4 (PINSEL4 - address 0x4002 C010) bit description

| PINSEL4 | Pin<br>name | Function when<br>00 | Function when 01 | Function<br>when 10 | Function when | Reset |
|---------|-------------|---------------------|------------------|---------------------|---------------|-------|
| 1:0     | P2.0        | GPIO Port 2.0       | PWM1.1           | TXD1                | Reserved      | 00    |
| 3:2     | P2.1        | GPIO Port 2.1       | PWM1.2           | RXD1                | Reserved      | 00    |
| 5:4     | P2.2        | GPIO Port 2.2       | PWM1.3           | CTS1                | Reserved 🗵    | 00    |
| 7:6     | P2.3        | GPIO Port 2.3       | PWM1.4           | DCD1                | Reserved 2    | 00    |
| 9:8     | P2.4        | GPIO Port 2.4       | PWM1.5           | DSR1                | Reserved 🗵    | 00    |
| 11:10   | P2.5        | GPIO Port 2.5       | PWM1.6           | DTR1                | Reserved 2    | 00    |
| 13:12   | P2.6        | GPIO Port 2.6       | PCAP1.0          | RII                 | Reserved 🗵    | 00    |
| 15:14   | P2.7        | GPIO Port 2.7       | RD2              | RTS1                | Reserved      | 00    |
| 17:16   | P2.8        | GPIO Port 2.8       | TD2              | TXD2                | ENET_MDC      | 00    |
| 19:18   | P2.9        | GPIO Port 2.9       | USB_CONNECT      | RXD2                | ENET_MDIO     | 00    |
| 21:20   | P2.10       | GPIO Port 2.10      | EINT0            | NMI                 | Reserved      | 00    |
| 23:22   | P2.11[1]    | GPIO Port 2.11      | EINT1            | Reserved            | I2STX_CLK     | 00    |
| 25:24   | P2.12[1]    | GPIO Port 2.12      | EINT2            | Reserved            | I2STX_WS      | 00    |
| 27:26   | P2.13[1]    | GPIO Port 2.13      | EINT3            | Reserved            | I2STX_SDA     | 00    |
| 31:28   |             | Reserved            | Reserved         | Reserved            | Reserved      | 0     |

# b) Pin mode (direction):

Each GPIO pin can be either input or output and can be configured to use a pull-up resistor, a pull-down resistor, or no resistor at all. "Fig.35" below, taken from NXP's LPC17xx datasheet, shows the general structure for a GPIO pin.



Fig 35. Standard I/O pin configuration with analog input

For configuration as output, the pull-up "resistor" can generate a "high" (or logic 1) state, while the pull-down "resistor" can generate a "low" (or logic 0) state.

There is a two bit field in the register named **PINMODEx** that determines the GPIO pin configuration. The PINMODE registers control the input mode or direction of all ports. This includes the use of the on-chip pull-up/pull-down resistor feature and a special open-drain operating mode. The on-chip pull-up/pull-down resistor can be selected for every port pin regardless of the function on this pin with the exception of the I2C pins for the I2C0 interface and the USB pins. The next table shows how the configuration is done.

Table 76. Pin Mode Select register Bits

| PINMODE0 to<br>PINMODE9 Values | Function                                                | Value after<br>Reset |
|--------------------------------|---------------------------------------------------------|----------------------|
| 00                             | Pin has an on-chip pull-up resistor enabled.            | 00                   |
| 01                             | Repeater mode (see text below).                         |                      |
| 10                             | Pin has neither pull-up nor pull-down resistor enabled. |                      |
| 11                             | Pin has an on-chip pull-down resistor enabled.          |                      |

For more information, refer to tables 87-93 of the LPC17xx User manual.

## c) Using the GPIO:

The following table lists the registers associated with GPIOs. When using a given pin as I/O we write and read from these registers' individual bits.

Table 101. GPIO register map (local bus accessible registers - enhanced GPIO features)

| Generic<br>Name | Description                                                                                                                                                                                                                                                                                                                                                                                     | Access |   | PORTn Register<br>Name & Address                                                                                               |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|--------------------------------------------------------------------------------------------------------------------------------|
| FIODIR          | Fast GPIO Port Direction control register. This register individually controls the direction of each port pin.                                                                                                                                                                                                                                                                                  | R/W    | 0 | FIODDIR - 0x2009 C000<br>FIO1DIR - 0x2009 C020<br>FIO2DIR - 0x2009 C040<br>FIO3DIR - 0x2009 C080<br>FIO4DIR - 0x2009 C080      |
| FIOMASK         | Fast Mask register for port. Writes, sets, clears, and reads to port (done via writes to FIOPIN, FIOSET, and FIOCLR, and reads of FIOPIN) alter or return only the bits enabled by zeros in this register.                                                                                                                                                                                      | R/W    | 0 | FIO0MASK - 0x2009 C010<br>FIO1MASK - 0x2009 C030<br>FIO2MASK - 0x2009 C050<br>FIO3MASK - 0x2009 C070<br>FIO4MASK - 0x2009 C090 |
| FIOPIN          | Fast Port Pin value register using FIOMASK. The current state of digital port pins can be read from this register, regardless of pin direction or alternate function selection (as long as pins are not configured as an input to ADC). The value read is masked by ANDing with inverted FIOMASK. Writing to this register places corresponding values in all bits enabled by zeros in FIOMASK. | R/W    | 0 | FIO0PIN - 0x2009 C014<br>FIO1PIN - 0x2009 C034<br>FIO2PIN - 0x2009 C054<br>FIO3PIN - 0x2009 C074<br>FIO4PIN - 0x2009 C094      |
|                 | Important: if an FIOPIN register is read, its bit(s) masked with 1 in the FIOMASK register will be read as 0 regardless of the physical pin state.                                                                                                                                                                                                                                              |        |   |                                                                                                                                |
| FIOSET          | Fast Port Output Set register using FIOMASK. This register controls the state of output pins. Writing 1s produces highs at the corresponding port pins. Writing 0s has no effect. Reading this register returns the current contents of the port output register. Only bits enabled by 0 in FIOMASK can be altered.                                                                             | R/W    | 0 | FIO0SET - 0x2009 C018<br>FIO1SET - 0x2009 C038<br>FIO2SET - 0x2009 C058<br>FIO3SET - 0x2009 C078<br>FIO4SET - 0x2009 C098      |
| FIOCLR          | Fast Port Output Clear register using FIOMASK. This register controls the state of output pins. Writing 1s produces lows at the corresponding port pins. Writing 0s has no effect. Only bits enabled by 0 in FIOMASK can be altered.                                                                                                                                                            | WO     | 0 | FIOOCLR - 0x2009 C01C<br>FIO1CLR - 0x2009 C03C<br>FIO2CLR - 0x2009 C05C<br>FIO3CLR - 0x2009 C07C<br>FIO4CLR - 0x2009 C09C      |

<sup>[1]</sup> Reset value reflects the data stored in used bits only. It does not include reserved bits content.

**Selected GPIO pins can also be set to generate interrupts.** The push button labeled INT0 on the LandTiger board is connected to pin P2.10 of the LPC1768 microcontroller. This pin **can be** a source of external interrupts to the MCU. The table below shows different functionalities that can be assigned to P2.10 pin.

Table E.1 - Pin functions for P2.10

| Bits 21:20 of PINSEL4 | Function                 | Value after reset |  |
|-----------------------|--------------------------|-------------------|--|
| 00                    | GPIO P2.10 pin (default) |                   |  |
| 01                    | EINT0                    | 00                |  |
| 10                    | NMI                      | 00                |  |
| 11                    | Reserved                 |                   |  |

If you plan to use P2.10 as GPIO, then **you should also enable this source of interrupt** as described in Section 9.5.6 of the LPC17xx user manual. Note that you can set the P2.10 pin to be sensitive to either the rising edge or the falling edge. More information on clearing the interrupt pending bit can be found in Table 123 of the user manual.

#### 4. Polling vs. Interrupts

"Polling is like picking up your phone every few seconds to see if you have a call."

Polling the device usually means reading its status register every so often until the device's status changes to indicate that it has completed some request. It takes CPU time even when no requests are pending. However, it can be efficient if events arrive rapidly.

**Interrupts are an alternative to polling.** Each device is given a wire (interrupt line) that it can use to signal the processor. When an interrupt is signaled, the processor executes a routine called an interrupt handler to deal with the interrupt. This approach has no overhead when no requests are pending.



A **nonmaskable interrupt (NMI)** is an interrupt that cannot be ignored by standard interrupt masking techniques in the system. It is typically used to signal attention for non-recoverable hardware errors. On receipt of an NMI request, immediate execution of the NMI handler is guaranteed unless the system is completely locked up. **NMI is very important for many safety-critical applications.** 

#### 5. References

[1] Cortex-M3 based microcontrollers with Ethernet, USB, CAN and 12-bit ADC;

http://www.nxp.com/documents/leaflet/75016846.pdf

[2] LPC17xx User Manual;

http://www.nxp.com/documents/user manual/UM10360.pdf

[3] Schematic Diagram for the LandTiger 2.0 board;

http://www.haoyuelectronics.com/Attachment/HY-LandTiger/HY-LandTiger\_SCH.pdf