

# **PSoC<sup>™</sup> 4 interrupts**

### About this document

#### Scope and purpose

This application note explains the interrupt architecture in PSoC<sup>™</sup> 4 and its configuration in ModusToolbox<sup>™</sup> software environment and PSoC<sup>™</sup> Creator. This document serves as a guide in developing interrupt-based projects. Advanced interrupt concepts such as latency, vector selection, interrupt code optimization, and debug techniques are also explained.

#### **Intended audience**

This document is intended for anyone using interrupts with the PSoC<sup>™</sup> 4 family.



### Introduction

## **Table of contents**

| Abou         | t this document                                          | 1  |
|--------------|----------------------------------------------------------|----|
| Table        | of contents                                              | 2  |
| 1            | Introduction                                             | 4  |
| 2            | PSoC <sup>™</sup> 4 interrupt architecture               | 5  |
| 2.1          | Interrupt sources                                        | .6 |
| 2.2          | Level- and edge-triggered interrupts                     | .8 |
| 3            | ModusToolbox™ interrupt support                          | LO |
| 3.1          | Enabling interrupt sources                               | 11 |
| 3.2          | Enabling interrupt sources using PDL                     | 12 |
| 3.3          | Configuring interrupts using PDL                         | 12 |
| 3.3.1        | Interrupt API functions                                  |    |
| 3.3.2        | Critical section control functions                       |    |
| 3.3.3        | Setting up an interrupt                                  | 13 |
| 4            | PSoC <sup>™</sup> Creator interrupt support              | 12 |
| 4.1          | Interrupt component configuration                        |    |
| 4.1.1        | Sticky bits                                              |    |
| 4.2          | Interrupt priority configuration                         |    |
| 4.3          | Interrupt API functions                                  |    |
| 4.3.1        | Critical section control functions                       |    |
| 4.4          | Writing interrupt service routine (ISR)                  |    |
| 4.5          | Using auto-generated ISR                                 |    |
| 4.5.1        | Using extern keyword                                     |    |
| 4.6          | Using the callback function                              |    |
| 4.7<br>4.7.1 | Creating a custom ISR                                    |    |
|              | Significance of the keyword CY_ISR                       |    |
| 5            | ModusToolbox <sup>™</sup> related code examples          |    |
| 6<br>7       | PSoC <sup>™</sup> Creator related code examples          |    |
| 7            | Debugging tips                                           |    |
| <b>8</b>     | Advanced interrupt topics                                |    |
| 8.1<br>8.1.1 | Exceptions<br>ModusToolbox™ exceptions                   |    |
| 8.1.2        | PSoC <sup>™</sup> Creator exceptions                     |    |
| 8.2          | Interrupt latency                                        |    |
| 8.3          | Optimizing the interrupt code                            |    |
| 8.4          | PSoC <sup>™</sup> Creator components internal interrupts |    |
| 8.5          | PSoC <sup>™</sup> Creator forcing interrupt vector num   |    |
| 8.6          | ModusToolbox™ SysTick timer                              |    |
| 8.7          | PSoC <sup>™</sup> Creator SysTick timer                  |    |
| 8.8          | Nested interrupts                                        |    |
| 8.9          | PSoC™ Creator GlobalSignal component                     | 36 |
| 8.9.1        | Combined port interrupt                                  |    |
| 8.10         | Use of volatile for global variables                     |    |
| 9            | Summary                                                  | 39 |
| Appe         | ndix A - Interrupt sources and vector numbers            | 40 |
| Refer        | ences                                                    | 44 |



### Introduction

| Revision history | 45 |
|------------------|----|
| Disclaimer       | 46 |



### Introduction

# 1 Introduction

Interrupts are an important part of any embedded application. An interrupt frees the CPU from having to continuously poll for the occurrence of an event; it notifies the CPU only when that event occurs. In system-on-chip (SoC) architectures such as PSoC<sup>™</sup>, interrupts are frequently used to communicate the status of on-chip peripherals to the CPU.

PSoC<sup>™</sup> 4 devices are supported in both the ModusToolbox<sup>™</sup> software environment and PSoC<sup>™</sup> Creator; this document covers both IDEs. ModusToolbox<sup>™</sup> supports only a limited number of devices. To check whether a device is supported, start ModusToolbox<sup>™</sup>, choose **New Application** > **PSoC<sup>™</sup> 4 BSPs**, and under PSoC<sup>™</sup> 4 BSPs is a list of supported PSoC<sup>™</sup> 4 devices.

The document begins with an explanation of PSoC<sup>™</sup> 4 interrupt architecture. If you want to learn about the interrupt support in ModusToolbox<sup>™</sup>, skip to ModusToolbox<sup>™</sup> interrupt support. For the PSoC<sup>™</sup> Creator IDE, skip to the PSoC<sup>™</sup> Creator interrupt support. For sample code examples, see ModusToolbox<sup>™</sup> related code examples and PSoC<sup>™</sup> Creator related code examples. If you are debugging an interrupt project, go to Debugging tips, which provides guidance on finding and resolving interrupt issues.

This application note assumes that you are familiar with PSoC<sup>™</sup>, and the ModusToolbox<sup>™</sup> or PSoC<sup>™</sup> Creator IDE. If you are new to PSoC<sup>™</sup>, you can find an introduction in the application note AN79953 - Getting started with PSoC<sup>™</sup> 4 MCU or visit the ModusToolbox<sup>™</sup> software or PSoC<sup>™</sup> Creator home page.



# 2 PSoC<sup>™</sup> 4 interrupt architecture

Figure 1 shows a simplified block diagram of the interrupt architecture in PSoC<sup>™</sup> 4.



#### Figure 1 PSoC<sup>™</sup> 4 interrupt architecture

There are up to 32 interrupt lines – IRQ[0] to IRQ[31] – each with four priority levels, 0 to 3. Each interrupt line is assigned an interrupt vector address. The CPU branches to this address after receiving an interrupt request, where a special function called an interrupt service routine (ISR) is executed.

Interrupt signals are received by the nested vectored interrupt controller (NVIC). When an interrupt signal becomes active, the NVIC sends the interrupt vector address to the processor core along with the interrupt request signal. In return, the processor core sends an acknowledgment when the ISR is entered and exited. The NVIC is responsible for enabling/disabling an interrupt based on the user configuration. It also resolves interrupt priority when multiple requests occur at the same time, and supports nested interrupts to allow a higher-priority interrupt to be serviced leaving a low-priority ISR.

The wakeup interrupt controller (WIC) block allows the device to wake up from low-power modes – Sleep, Deep Sleep, and Hibernate – using interrupts. The WIC block remains active while the NVIC, processor core, and other device peripherals are shut down. When an interrupt triggers, the WIC activates the power management system, which restores the NVIC and the processor core along with other peripherals. The NVIC then takes over and the processor core executes the ISR. There are several sources in the PSoC<sup>™</sup> 4 device that can wake up the device. For example, Figure 1 shows IRQ[0] and IRQ[1] routed to the WIC along with the NVIC. These are the interrupt lines from GPIOs.

Note: Only sources that can wakeup the device from Sleep, Deep Sleep, or Hibernate are routed to the WIC while all interrupt sources are routed to the NVIC.

PSoC<sup>™</sup> 4 provides the following interrupt features:

- **Configurable interrupt vector address**: CPU execution can be directly branched to any ISR code when the interrupt occurs.
- Flexible interrupt sources: In traditional microcontrollers, the interrupt source is hard-wired to each interrupt line. PSoC<sup>™</sup> gives you the flexibility to choose the interrupt source for each interrupt line. This flexible architecture enables any digital signal to be configured as an interrupt source.



### 2.1 Interrupt sources

PSoC<sup>™</sup> 4 interrupt sources are of two types:

- 1. Fixed-function interrupt sources: These are a predefined set of interrupt sources from on-chip peripherals.
- 2. Universal digital block (UDB) interrupt sources (available in PSoC<sup>™</sup> 4200, 4200 Bluetooth<sup>®</sup> low-energy (LE), 4200DS, 4200M, and 4200L product lines): UDBs are building blocks for different digital functions such as timer, PWM, UART, SPI, and many more. A UDB consists of programmable logic (PLDs), datapath, and flexible routing. In contrast to fixed-function interrupt sources, any digital signal generated in a UDB can trigger an interrupt. The signals are routed to the interrupt controller through a routing fabric called the digital system interconnect (DSI). See the PSoC<sup>™</sup> 4 reference manual for more information.

Note: ModusToolbox<sup>™</sup> does not currently support UDBs.

Table 1 shows the interrupt sources. Interrupt sources mentioned in the table are available in all PSoC<sup>™</sup> 4 parts unless noted otherwise. For details on each interrupt source, see the PSoC<sup>™</sup> Creator Component datasheets or peripheral driver library (PDL) listed in Table 1. Appendix A shows the complete list of interrupt sources depending on the device.

Note:  $PSoC^{TM} 4 PDL$  is currently in Alpha and not all peripherals are supported.

| ModusToolbox™<br>PDL                | PSoC™<br>Creator<br>component<br>datasheets | Details                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIOs                               | GPIOs                                       | <ul> <li>Each port consists of eight pins. Each pin can generate an interrupt, but the vector address is common for all pins in a port. Firmware must identify the pin that caused the interrupt.</li> <li>PSoC<sup>™</sup> 4 enables an interrupt trigger on the rising edge, falling edge, or both edges of the GPIO signal. This interrupt can wake the device from Sleep, Deep Sleep, and Hibernate modes.</li> </ul> |
| Low Power<br>Comparator<br>(LPCOMP) | Low Power<br>Comparator<br>(LPCOMP)         | Like GPIOs, an interrupt can be triggered on the rising edge, falling edge,<br>or both edges of the comparator output signal. The LPCOMP can also<br>wake the device from Sleep, Deep Sleep, and Hibernate modes. LPCOMP<br>is not available in PSoC <sup>™</sup> 4000.                                                                                                                                                   |
| WDT                                 | WDT                                         | The watchdog timer (WDT) is a timer that can reset the device or<br>generate an interrupt. PSoC <sup>™</sup> 4000, 4000S, 4100S, 4100S Plus, and<br>4100PS devices have a 16-bit free-running WDT, whereas other PSoC <sup>™</sup> 4<br>parts have two 16-bit WDTs and one 32-bit WDT. The WDT can wake the<br>device from Sleep and Deep Sleep modes.                                                                    |
| SCB                                 | SCB                                         | PSoC <sup>™</sup> 4 has up to five serial communication blocks (SCB), which can be configured as I <sup>2</sup> C, SPI, or UART. The exact number of SCB blocks depends on the device family.                                                                                                                                                                                                                             |
|                                     |                                             | I <sup>2</sup> CThe following events generate an interrupt: arbitration lost,<br>slave address match, start/stop detect, bus error, byte/word<br>transfer complete, TX FIFO not full, TX/RX FIFO empty, RX FIFO<br>not empty, RX FIFO overrun, and RX FIFO full. The slave address                                                                                                                                        |

#### Table 1PSoC<sup>™</sup> 4 interrupt sources



| ModusToolbox™<br>PDL                                       | PSoC™<br>Creator<br>component<br>datasheets                  | Details                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            |                                                              | match event can wake the device from Sleep and Deep Sleep modes.                                                                                                                                                                                                                                                                                                                           |
|                                                            |                                                              | SPI The following events generate an interrupt: transfer done, idle,<br>TX FIFO not full, TX/RX FIFO empty, byte/Word transfer<br>complete, RX FIFO is not empty, attempt to write to a full RX<br>FIFO, and RX FIFO full.                                                                                                                                                                 |
|                                                            |                                                              | UART The following events generate an interrupt: transmission done,<br>UART TX received a NACK in SmartCard mode, UART arbitration<br>lost in LIN or SmartCard mode, frame error, parity error, LIN<br>baud rate detection complete, and LIN successful break<br>detection. It can also wake up the device from low-power<br>modes <sup>1</sup> .                                          |
| SysTick                                                    | SysTick                                                      | SysTick is a 24-bit timer built into the Arm <sup>®</sup> Cortex <sup>®</sup> -M0/Cortex <sup>®</sup> M0+<br>processor. It is generally used by real-time operating systems (RTOS) as a<br>tick timer. However, it can be used as a general-purpose timer. See the<br>ModusToolbox <sup>™</sup> SysTick timer and PSoC <sup>™</sup> Creator SysTick timer section<br>for more information. |
| SAR ADC                                                    | SAR ADC                                                      | The successive approximation register analog-to-digital converter (SAR ADC) can generate interrupts on end of conversion, data overflow, scan collision, data saturation, and data over-range events.                                                                                                                                                                                      |
| CAPSENSE™<br>(CSD)                                         | CAPSENSE <sup>™</sup><br>(CSD)                               | CSD, used for touch applications, generates an interrupt when the sensor scan is complete.                                                                                                                                                                                                                                                                                                 |
| Timer, Counter,<br>and Pulse Width<br>Modulator<br>(TCPWM) | Timer,<br>Counter and<br>Pulse Width<br>Modulator<br>(TCPWM) | The TCPWM block can be configured to work as a 16-bit timer, counter,<br>or PWM. It can generate interrupts on terminal count, input capture<br>signal, or a "compare true" event.                                                                                                                                                                                                         |
| CAN with<br>Flexible Data-<br>Rate (CAN FD)                | Controller<br>Area Network<br>(CAN)                          | PSoC <sup>™</sup> 4200M and PSoC <sup>™</sup> 4200L devices have two CAN blocks. PSoC <sup>™</sup> 4100S Plus device has one CAN block. The CAN block can generate interrupts on events such as message received, message sent, and various error events. See the CAN chapter of the reference manual for more information.                                                                |
| Direct Memory<br>Access<br>Controller<br>(DMAC)            | Direct<br>Memory<br>Access (DMA)                             | PSoC <sup>™</sup> 4100M/4200M, PSoC <sup>™</sup> 4200L, PSoC <sup>™</sup> 4100S Plus, and PSoC <sup>™</sup> 4100PS devices have DMA to transfer data between peripherals. An interrupt can be generated when the data transfer is completed.                                                                                                                                               |
| Not currently<br>supported in<br>ModusToolbox™             | Universal<br>Digital Block<br>(UDB)                          | UDB implementations such as timer, PWM, counter, UART, and so on can generate interrupts on different events similar to their fixed-function                                                                                                                                                                                                                                               |

<sup>&</sup>lt;sup>1</sup> There are pin limitations; not all ports have dedicated interrupts. If the UART selected pins do not have dedicated port interrupt, it cannot wake up the device. See the "Interrupts" chapter in device *Architecture reference manual* to learn about ports that have dedicated interrupts.



| ModusToolbox™<br>PDL             | PSoC <sup>™</sup><br>Creator<br>component<br>datasheets | Details                                                                                                                                 |
|----------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
|                                  |                                                         | counterparts. UDBs are available in PSoC <sup>™</sup> 4200, 4200 BLE, 4200DS, 4200M, and 4200L product lines.                           |
| USB Full-Speed<br>device (USBFS) | Full Speed<br>USB (USBFS)                               | PSoC <sup>™</sup> 4200L has USB with start-of-frame interrupt and interrupt on completion of the communication over data endpoints.     |
| In Progress                      | CTB/CTBm                                                | Provides continuous time analog functionality. It generates interrupts on event such as comparator triggers.                            |
| In Progress                      | WCO<br>WDT/WCO                                          | PSoC <sup>™</sup> 41000S and PSoC <sup>™</sup> 4100S Plus have timers that can be clocked by WCO. These timers can generate interrupts. |

### 2.2 Level- and edge-triggered interrupts

PSoC<sup>™</sup> 4 supports level and edge triggering for interrupts. Figure 2 shows the logic to select the trigger type. This logic is present for each interrupt line supported by NVIC. Note that the fixed-function interrupt can only be configured to level, but for the DSI sources, which include the UDB, the interrupt can be rising-edge triggered as well as level-triggered. The rising-edge detect block generates a pulse at every rising edge of the DSI interrupt signal. See the timing diagrams (Figure 3 and Figure 4) to know how the NVIC responds to leveland edge-configured interrupts.

Currently, ModusToolbox<sup>™</sup> does not support digital signal interconnect (DSI) or universal digital blocks (UDBs), this means that the only interrupts supported are fixed-function interrupts. PSoC<sup>™</sup> Creator does support both fixed function interrupts and UDB based interrupts.



### Figure 2 Level trigger and edge trigger





### **PSoC<sup>™</sup> 4 interrupts**



## PSoC<sup>™</sup> 4 interrupt architecture



### Figure 4 Edge-triggered interrupts

Note: The GPIO interrupt logic has additional circuitry to support interrupts on the rising edge, falling edge, and both edges. See the PSoC<sup>™</sup> 4 reference manual for more information.



# 3 ModusToolbox<sup>™</sup> interrupt support

ModusToolbox<sup>™</sup> software environment does not use Components as in PSoC<sup>™</sup> Creator, but uses a Device Configurator tool. The Device Configurator is used to enable and configure device peripherals such as clocks and pins, as well as standard MCU peripherals that do not require their own tool.

As there is currently no DSI or UDB support in ModusToolbox<sup>™</sup>, an interrupt can only be connected through a dedicated route. To open the Device Configurator, go to the **Quick Panel** and select the Device Configurator, as shown in Figure 5.

| Quick Panel (*) Variables 🍕 Expressions 💁 Breakpoints |   |
|-------------------------------------------------------|---|
| Eclipse IDE for<br>ModusToolbox®                      | ^ |
| - Start                                               |   |
| Vew Application                                       |   |
|                                                       |   |
| Search Online for Libraries and BSPs                  |   |
| Kefresh Quick Panel                                   |   |
| GPIO_Interrupt (CY8CKIT-149)                          |   |
| Suild GPIO_Interrupt Application                      |   |
| Clean GPIO_Interrupt Application                      |   |
|                                                       |   |
| 体 GPIO_Interrupt Debug (JLink)                        |   |
| GPIO_Interrupt Debug (KitProg3_MiniProg4)             |   |
| GPIO_Interrupt Program (JLink)                        |   |
| GPIO_Interrupt Program (KitProg3_MiniProg4)           |   |
| Senerate Launches for GPIO_Interrupt                  |   |
|                                                       |   |
| Library Manager 1.2                                   |   |
| Pevice Configurator 2.20                              |   |
| Device Firmware Update Tool 1.30                      |   |
| Smart I/O Configurator 2.20                           |   |
| → Documentation                                       | ~ |
| <                                                     | > |

Figure 5

**Device Configurator quick start** 



## 3.1 Enabling interrupt sources

As mentioned previously, all the interrupts are fixed function, and fixed function interrupts route directly to the NVIC. A peripheral that has an interrupt source has options to enable that interrupt from inside the Device Configurator. For example, the GPIO has a fixed function interrupt that can be configured as shown in Figure 6. The interrupt source parameters vary based on the peripheral.

| · · · · · · · · · · · · · · · · · · ·      |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 | _ |                             |
|--------------------------------------------|-------------|--------------------|---------------|----------|-------|--------|-------|-------|-------|-------|-------|------|--------------------------------------------------|-----------------------------------|-----------------|---|-----------------------------|
| C:/Users/nrsh/Desktop/test5/Hel            | lo_World/de | sign.modus* - Devi | ce Configurat | or 2.20  |       |        |       |       |       |       |       |      |                                                  | -                                 | $\Box$ $\times$ |   |                             |
| <u>File Edit View H</u> elp                |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 |   |                             |
| Peripherals Pins Analog-Routing            | System      | Peripheral-Clocks  |               |          |       |        |       |       |       |       |       |      | [0] (Pin) - Parameters                           |                                   | Ø               |   |                             |
| Enter filter text                          |             |                    |               |          |       |        |       |       | 7 E E | * 🖻 🖻 | 3 5 2 | Ent  | ter filter text                                  |                                   | ζυ 🖻 🛛          | Đ |                             |
| Resource Name(s)                           |             |                    |               |          |       |        |       |       |       |       | -     | Nar  |                                                  | Value                             |                 | - |                             |
| Port 0                                     |             |                    | 32            | 31       | 3     | 28     | 26    | 25    |       |       |       | •    | Peripheral Documentation ⑦ Configuration Help    | Open GPIO Documentation           |                 |   |                             |
| ▼ Port 1                                   |             |                    |               |          |       | a 0    | 0     | _     |       |       |       | -    | General                                          | Open GPIO Documentation           |                 |   |                             |
|                                            |             | •                  | P1[3]         | P1[2]    | P1[0] | VSSA   | VSSD  | VCCD  |       |       |       |      | ⑦ Drive Mode                                     | Resistive Pull-Up. Input buffer o | n               |   |                             |
| P1[1] ioss_0_port_1_pin_1                  |             |                    | ۵.            | <u> </u> | . 🕰   | > ~    | >     | >     |       |       |       |      | <li>Initial Drive State</li>                     | High (1)                          |                 |   | Peripheral<br>parameters    |
| P1[2] ioss_0_port_1_pin_2                  |             |                    |               |          |       |        |       |       |       |       |       | -    | Input                                            |                                   |                 |   | hat configure               |
| P1[3] ioss_0_port_1_pin_3                  |             |                    |               |          |       |        |       |       |       |       |       |      | ⑦ Threshold                                      | CMOS                              | ,               |   | ind enable                  |
| P1[7] ioss_0_port_1_pin_7                  |             |                    |               |          |       |        |       |       |       |       |       |      | Interrupt Trigger Type                           | e Falling Edge                    |                 |   | nterrupt<br>ource           |
| <ul> <li>Port 2</li> <li>Port 3</li> </ul> | 1           | P1[7]              |               |          |       |        |       |       |       | XRES  | 24    |      | Output                                           |                                   |                 |   |                             |
| Port 4                                     |             |                    |               |          |       |        |       |       |       | -     |       |      | Internal Connection<br>Advanced                  |                                   |                 | • |                             |
|                                            | 2           | P2[0]              |               |          |       |        |       |       |       | P0[6] | 23    | 4    |                                                  |                                   | Þ               |   |                             |
|                                            | 3           | P2[1]              |               |          |       |        |       |       |       | P0[5] | 22    |      | de Preview<br>ndif                               |                                   | Ø               | × |                             |
|                                            |             |                    |               |          |       |        |       |       |       | 0[3]  | 22    | #de  | efine Pin HSIOM ioss (                           |                                   |                 | Î |                             |
|                                            | 4           | P2[2]              |               |          |       |        |       |       |       | P0[4] | 21    |      | efine Pin_IRQ ioss_int<br>f defined (CY USING H  |                                   |                 |   | ienerated<br>Aacro defining |
|                                            |             |                    | CY8C4         | 1024/    | AXI-S | 6412 ( | 32-1  | [QFP] | )     |       |       |      | #define Pin_HAL_POR                              | P PIN P1 0                        |                 |   | he dedicated                |
|                                            | 5           | P2[3]              |               |          |       |        |       |       |       | P0[3] | 20    |      | ndif //defined (CY_US)<br>f defined (CY_USING HJ |                                   |                 |   | nterrupt                    |
|                                            | 6           | P2[5]              |               |          |       |        |       |       |       | P0[2] | 19    |      | #define Pin P1_0<br>ndif //defined (CY US)       |                                   |                 |   | ource for the<br>eripheral  |
|                                            |             |                    |               |          |       |        |       |       |       | -1-1  |       |      | f defined (CY_USING_H                            | AL)                               |                 | Ľ |                             |
|                                            | 7           | P2[6]              |               |          |       |        |       |       |       | P0[1] | 18    | ‡e:  | #define Pin_HAL_IRQ<br>ndif //defined (CY_US)    | CYHAL_GPIO_IRQ_FALL<br>ING HAL)   |                 |   |                             |
|                                            | 8           | P2[7]              |               |          |       |        |       |       |       | P0[0] | 17    | \$1; | f defined (CY_USING_H                            | AL) -<br>CYHAL GPIO DIR BIDIRECTI | ONINT           |   |                             |
|                                            | 8           | P2[7]              |               |          |       |        |       |       |       | PU[U] | 17    |      | ndif //defined (CY_US)                           | ING_HAL)                          | ONALD           |   |                             |
|                                            |             |                    |               |          |       |        |       |       |       |       |       | #1:  | f defined (CY_USING_H)<br>#define Pin HAL DRI    | AL)<br>VEMODE CYHAL GPIO DRIVE P  | ULLUP           |   |                             |
|                                            |             |                    |               |          |       |        |       |       |       |       |       | \$es | ndif //defined (CY_US                            | ING_HAL)                          |                 |   |                             |
|                                            |             |                    |               |          |       |        |       |       |       |       |       | cos  | nst cy_stc_gpio_pin_co                           | onfig_t Pin_config =              |                 |   |                             |
|                                            |             |                    | P3[0]         | P3[1]    | P3[3] | P4[0]  | P4[2] | P4[3] |       |       |       | 1    | .outVal = 1,<br>.driveMode = CY GPIC             |                                   |                 |   | Generated by                |
|                                            |             |                    | ě.            |          | . 6   | d d    | ď     | d.    |       |       |       |      | hsion = Pin_HSTOM,                               |                                   |                 |   | nterrupt<br>Trigger Type    |
|                                            |             |                    | 0             | 11       | 12    | 13     | 15    | 16    |       |       |       |      | .intEdge = CY GPIO :<br>.vtrip = CY GPIO VT      |                                   |                 |   | arameter                    |
|                                            |             |                    |               |          |       |        |       | -     |       |       |       |      | .slewRate = CY_GPIO                              | SLEW_FAST,                        |                 | - |                             |
| •                                          |             |                    |               |          |       |        |       |       |       |       | *     | •    |                                                  |                                   | ×               | _ |                             |
| Notice List                                |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   | Ø               | × |                             |
| 😢 0 Errors 🥂 0 Warnings 🧮                  | 0 Tasks     | 0 Infos            |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 |   |                             |
| Fix Tescription                            |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   | Location        |   |                             |
|                                            |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 |   |                             |
|                                            |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 |   |                             |
| Ready                                      |             |                    |               |          |       |        |       |       |       |       |       |      |                                                  |                                   |                 |   |                             |

Figure 6 TCPWM fixed function interrupt configuration

Currently the only interrupts that can be used in ModusToolbox<sup>™</sup> are fixed-function interrupts, this means that all interrupt types are level driven. Some peripherals have added hardware that can be configured so that an interrupt can be triggered on a rising edge.

An interrupt source does need to be configured in the Device Configurator but can be configured in software through the peripheral driver library (PDL). The peripheral that supplies the interrupt source includes API to enable and disable interrupts. An example of this can be seen in Enabling interrupt sources using PDL.

Based on the configuration, ModusToolbox<sup>™</sup> generates the 'C' code to achieve the desired configuration. The code generated can be viewed in the Code Preview pane; it is added to relevant cycfg\_xxx.c/h files found under <ApplicationName>/libs/TARGET\_<TargetName>/COMPONENT\_BSP\_DESIGN\_MODUS/GeneratedSource folder in the ModusToolbox<sup>™</sup> project workspace window. The generated code includes macros defining the interrupt source numbers and any peripheral configuration that is necessary to set up and enable the interrupt source. This simplifies the process of searching for the dedicated interrupt numbers in the device header file. The user application only needs to enable the interrupt vector on the CPU and assign an interrupt handler function as described in Setting up an interrupt.



### 3.2 Enabling interrupt sources using PDL

An interrupt source does not need to be enabled from the Device Configurator but can be enabled using the peripheral driver library (PDL). The peripheral that supplies the interrupt source has API functions that allow the interrupt source to be enabled/disabled, set/cleared, and allows the status to be read from the peripheral's hardware. An example using GPIO shows how to enable an interrupt source, see Figure 7. This can be done for any peripheral that has a fixed function interrupt.

| <pre>{     /* Set the interrupt trigger type to falling edge for P1.0 */     Cy_GPI0_SetInterruptEdge(P1_0_PORT, P1_0_NUM, CY_GPI0_INTR_FALLING); }</pre> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|

#### Figure 7 TCPWM enabling interrupt

## 3.3 Configuring interrupts using PDL

The peripheral driver library (PDL) is a software development kit (SDK) that enables firmware development for PSoC<sup>™</sup> 4 MCU devices. PDL API function calls are used to configure, initialize, enable, and use a peripheral driver. One such driver is system interrupts (SysInt). SysInt provides structures and functions to configure and enable interrupt functionality. PDL also supports the Interrupts and Exceptions (NVIC) functions used for interrupt configuration.

### 3.3.1 Interrupt API functions

ModusToolbox<sup>™</sup> generates an API –.*c* and .*h* files – for each peripheral in the project. These APIs include functions to configure and use each peripheral. The following API functions are associated with an interrupt:

### • Cy\_SysInt\_Init (const cy\_stc\_sysint\_t \*config, cy\_israddress userIsr)

Initializes the referenced interrupt by setting the priority and the interrupt vector. Use the Cortex<sup>®</sup> microcontroller system interface standard (CMSIS – Library is supplied by Cypress and is retrieved automatically when required) core function NVIC\_EnableIRQ(config.intrSrc) to enable the interrupt.

### Cy\_SysInt\_SetVector (IRQn\_Type IRQn, cy\_israddress userIsr)

Changes the ISR vector for the interrupt. This function relies on the assumption that the vector table is relocated to \_\_RAM\_VECTOR\_TABLE[RAM\_VECTORS\_SIZE] in SRAM. Otherwise, it returns the address of the default ISR location in the flash vector table.

### Cy\_SysInt\_GetVector (IRQn\_Type IRQn)

Gets the address of the current ISR vector for the interrupt. This function relies on the assumption that the vector table is relocated to \_\_\_RAM\_VECTOR\_TABLE[RAM\_VECTORS\_SIZE] in SRAM. Otherwise, it returns the address of the default ISR location in the flash vector table.



### 3.3.2 Critical section control functions

ModusToolbox<sup>TM</sup> also provides a set of generic interrupt functions in the *cy\_syslib.h* and *cy\_syslib.c* files. The important ones are *Cy\_SysLib\_EnterCriticalSection* and *Cy\_SysLib\_ExitCriticalSection*. These two functions are used to avoid the corruption of firmware variables and hardware registers. *Cy\_SysLib\_EnterCriticalSection* disables interrupts and returns an interrupt state value. *Cy\_SysLib\_ExitCriticalSection* restores the interrupt state.

To see how this works, consider an example of writing to a timer control register:

TCPWM BLOCK CONTROL REG |= TCPWM MASK;

The following sequence of operations occurs while executing the statement above:

- 1. The CPU reads the control register of the TCPWM and stores it in a temporary register.
- 2. The CPU executes a logical OR operation of the temporary register with its mask value.
- 3. The CPU loads the OR result back to the control register.

Between steps 1 and 2, an interrupt may occur, and its ISR may load a new value into the same control register. After executing the ISR, when the CPU resumes executing step 2, it uses the stale control register value, which was in the temporary register– this leads to data corruption.

To avoid this issue, add the following code:

```
uint32_t InterruptState;
InterruptState=Cy_SysLib_EnterCriticalSection();
TCPWM_BLOCK_CONTROL_REG |= TCPWM_MASK;
Cy SysLib ExitCriticalSection(InterruptState);
```

The *Cy\_SysLib\_EnterCriticalSection* and *Cy\_SysLib\_ExitCriticalSection* functions solve the problem by disabling interrupts while the control register is being written. Use these functions when a shared variable or register is being written.

### 3.3.3 Setting up an interrupt

These steps use PDL and NVIC APIs to set up an interrupt to trigger on a signal from a peripheral.

- 1. Configure the peripheral to generate the interrupt. For example, for a GPIO, configure the drive mode (pull up or pull down), interrupt signal generation on falling or rising edge, and unmask the interrupt. Refer to the PDL API reference documentation for your peripheral for this information.
- Configure the interrupt using the structure provided by the SysInt API.
   The structure is defined in the PDL SysInt driver file cy\_sysint.h, as shown in Code Listing 1.

```
/**
 * Initialization configuration structure for a single interrupt channel
 */
typedef struct {
    IRQn_Type intrSrc; /**< Interrupt source */
    uint32_t intrPriority; /**< Interrupt priority number (Refer to
    NVIC_PRIO_BITS) */
} cy_stc_sysint_t;
</pre>
```



- a) Interrupt Source (intrSrc)
  - These are the dedicated interrupt numbers as defined under the drivers header file (*cy\_sysint.h*).
  - Each number represents an interrupt that routes from a peripheral to the NVIC.
- b) Interrupt Priority (intrPriority)
  - Sets the priority of the interrupt. PSoC<sup>™</sup> 4 supports priorities 0 to 3.
- 3. Call Cy\_SysInt\_Init(&SysInt\_SW\_cfg\_1, ISR\_1\_handler).

Here, SysInt\_SW\_cfg\_1 is the name of the configured structure from step 2. ISR\_1\_handler is the name of the interrupt handler that executes when the interrupt triggers. This function applies the routing and priority configuration of the interrupt but does not enable it.

- 4. Call NVIC\_ClearPendingIRQ(SysInt\_SW\_cfg\_1.intrSrc) to clear any pending interrupts.
- 5. Call NVIC\_EnableIRQ(SysInt\_SW\_cfg\_1.intrSrc) to enable the interrupt.
- 6. Call the \_\_enable\_irq() function to enable global interrupts. This is safe to perform as the first step, as individual CPU interrupts have not been enabled yet. You can also perform this later, but interrupts are disabled at startup until this is called.



# **4 PSoC<sup>™</sup>** Creator interrupt support

In PSoC<sup>™</sup> Creator, properties of interrupts such as the level or edge trigger, vector address, and interrupt priority must be configured using the PSoC<sup>™</sup> Creator Interrupt Component. This Component is available under the System tab in the Component Catalog window, as shown in Figure 8.

Each instance of the Interrupt Component uses one interrupt line out of the 32 lines that go to NVIC. In the example shown in Figure 8, the end-of-conversion (eoc) signal from the SAR ADC is connected to the Interrupt Component "isr\_1." The SAR ADC has an allotted vector line of the NVIC (see Appendix A). For example, in PSoC<sup>™</sup> 4200, IRQ14 is allotted for SAR ADC interrupt. Thus, the Interrupt Component "isr\_1" wires the eoc signal to the IRQ14 line through the MUX logic shown in Figure 2.



Figure 8 PSoC<sup>™</sup> Creator interrupt component

## 4.1 Interrupt component configuration

Figure 9 shows the interrupt component configuration dialog. There are three options in the Component: DERIVED, RISING\_EDGE, and LEVEL.

| Configure 'cy_isr'                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Basic Built-in 4 b<br>Parameter Value                                                                                                                                                                           |
| InterruptType DERIVED                                                                                                                                                                                           |
| Parameter Information Interrupt Type: DERIVED - infers the interrupt type based on the signal source. RISING_EDGE - selects the source connection to the ISR component as a rising edge connection via the DSI. |
| Datasheet OK Apply Cancel                                                                                                                                                                                       |

Figure 9 Interrupt component configuration

This setting configures the multiplexers shown in Figure 2. The selection of a particular option depends on the interrupt source (fixed-function or UDB/DSI) and the application requirements.

**Fixed-function blocks:** The interrupt line from the fixed-function block is always routed through the "dedicated route" as shown by the red line in Figure 10. When configured to this path, the interrupt is level-triggered and the vector number is determined based on the hardware block being used. The Interrupt

Application note



Component (isr\_1) connected to the interrupt line can only be configured as level-triggered. Setting the interrupt to RISING\_EDGE trigger results in a build error. When configured to DERIVED, the tool selects Level interrupt only.

In PSoC<sup>™</sup> 4 devices with DSI, other output signals from the fixed-function block can be routed for interrupts. This allows the RISING\_EDGE option as shown by the blue line in Figure 10 for the "line" output of a PWM Component. The Interrupt Component (isr\_2) connected to the output of the PWM can be configured to Level or RISING\_EDGE. When the DERIVED option is selected, the tool selects the level trigger configuration. Level trigger in such cases is usually not useful as it causes the ISR to be repeatedly executed as long as the signal is HIGH, and so in most cases, RISING\_EDGE is used.



Figure 10 Interrupt routing for fixed-function blocks

**UDBs:** For UDBs, the DSI is used to route the signal (from the interrupt line of the UDB Component or any output) to the MUX logic as shown in Figure 11. Thus, both LEVEL and RISING\_EDGE options are available for any signal from the UDB. When the DERIVED option is selected in the Interrupt Component (isr\_1 or isr\_2), the RISING\_EDGE option is configured. This is in contrast to the case of the DSI signal routing for fixed-function block outputs.



Figure 11 Interrupt routing for UDBs



Note: PSoC<sup>™</sup> 4 Bluetooth<sup>®</sup> LE, PSoC<sup>™</sup> 4200M, and PSoC<sup>™</sup> 4200L parts have eight DSI channels with each channel demultiplexed to **4** to spread across 32 **(8x4)** interrupt lines for the Arm Cortex<sup>®</sup>-M0/M0+ processor. Thus, the maximum number of DSI interrupts is limited to **eight** in a design.

Table 2 provides guidelines for setting the InterruptType parameter in the Interrupt Component.

| Interrupt<br>source | Signal       | Interrupt component configuration                                                                                                    |
|---------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Fixed-function      | Interrupt    | Select LEVEL or DERIVED. RISING_EDGE is not allowed.                                                                                 |
|                     | Block output | Select RISING_EDGE; otherwise, the interrupt is repeatedly triggered for the duration of the logic HIGH signal state.                |
| UDB function        | Interrupt    | Select RISING_EDGE or DERIVED.                                                                                                       |
|                     | Block output | Select RISING_EDGE; selecting LEVEL causes the interrupt to be repeatedly triggered for the duration of the logic HIGH signal state. |

Table 2 Interrupt component configuration

### 4.1.1 Sticky bits

An interrupt signal may be "sticky", which means that the interrupt line remains active (HIGH) until it is read or cleared. In this case, if the Interrupt Component is configured to RISING\_EDGE, the ISR is executed once. If the Interrupt Component is configured to LEVEL, the ISR is executed repeatedly. To handle this, clear the interrupt source by using the API function provided by the Component. See the Component datasheet of the interrupt source. You can also refer to the section, which provides an example using the timer interrupt.

Note that when the output lines of a fixed-function block or the UDB (for example, the "pwm" line of a PWM Component as shown in Figure 12) are connected to the Interrupt Component instead of the) sectioninterrupt line, there is no need to clear the interrupt. However, the ISR is repeatedly executed as long as the signal is HIGH, if the interrupt Component is configured to LEVEL.



Figure 12 Sticky signal



## 4.2 Interrupt priority configuration

The design-wide resources window (*project\_name.cydwr*) of the PSoC<sup>™</sup> Creator project has an Interrupts tab, which displays the Interrupt Component instance names, their priorities, and vector numbers, as Figure 13 shows. isr\_1, isr\_2, and isr\_3 are the Interrupt components used in the design.



Figure 13 Interrupt tab in *cydwr* window

Use the *cydwr* window to change the priority of an interrupt. Note that 0 is the highest priority; and 3, the lowest priority. The Cortex<sup>®</sup>-M0/M0+ CPU supports interrupt nesting; see <u>Nested interrupts</u> for details.

The interrupt vector number for each Interrupt Component is automatically assigned by PSoC<sup>™</sup> Creator when the project is built, but can be manually changed. See PSoC<sup>™</sup> Creator forcing interrupt vector num for details. Also, note that the vector number is shown with an offset in the *.cydwr* window. Vector number 0 corresponds to exception number 16 in Cortex<sup>®</sup>-M0/Cortex<sup>®</sup> M0+. See Exceptions for an overview of Cortex<sup>®</sup>-M0/Cortex<sup>®</sup> M0+ exceptions.

### 4.3 Interrupt API functions

PSoC<sup>™</sup> Creator generates an API –.*c* and .*h* files – for each Component in the project. These APIs include functions to configure and use the hardware corresponding to the Component. The following API functions are associated with an Interrupt Component:

• <instance\_name> Start() and <instance\_name>\_Stop()

Start() enables the interrupt, sets its vector to the default ISR, and sets the interrupt priority.

- Stop() disables the interrupt.
- <instance\_name>\_StartEx()
  Similar to Start(); the only difference is that this function takes a vector address as an input, enabling
  you to write a custom ISR rather than using the default ISR generated by the Component.
- <instance\_name> Enable() and <instance\_name>\_Disable()
  These functions are called internally by Start() and Stop() to enable and disable the interrupt. These
  functions can be called to dynamically enable and disable an interrupt.
- <instance\_name> SetVector() and <instance\_name> SetPriority()



These functions are called internally by Start() and Stop() to set the interrupt vector address and the interrupt priority. These functions can also be called to dynamically set the vector and the priority. Make sure that the interrupt is disabled before calling these functions.

- <instance\_name> SetPending() Makes the interrupt pending without an interrupt request, that is, under firmware control.
- <instance\_name> ClearPending()

Clears the pending status of the interrupt so that it is not serviced. This function does not have any effect on the interrupt source signal; it only clears the pending status bit of the interrupt line in the NVIC.

See the Interrupt component datasheet for a detailed explanation of the API.

## 4.3.1 Critical section control functions

PSoC<sup>™</sup> Creator also provides a set of generic interrupt functions in the *CyLib.h and CyLib.c* files. These files are generated when the project is built. The important ones are CyEnterCriticalSection and CyExitCriticalSection. These two functions are used to avoid the corruption of firmware variables and hardware registers. CyEnterCriticalSection disables interrupts and returns an interrupt state value. CyExitCriticalSection restores the interrupt state.

To see how this works, consider an example of writing to a timer control register:

TCPWM\_BLOCK\_CONTROL\_REG |= TCPWM\_MASK;

The following sequence of operations occurs while executing the statement above:

- 1. The CPU reads the control register of the TCPWM and stores it in a temporary register.
- 2. The CPU executes a logical OR operation of the temporary register with its mask value.
- 3. The CPU loads the OR result back to the control register.

Between steps 1 and 2, an interrupt may occur, and its ISR may load a new value into the same control register. After executing the ISR, when the CPU resumes executing step 2, it uses the stale control register value, which was in the temporary register– this leads to data corruption.

To avoid this issue, add the following code:

```
InterruptState = CyEnterCriticalSection();
TCPWM_BLOCK_CONTROL_REG |= TCPWM_MASK;
CyExitCriticalSection(InterruptState);
```

The CyEnterCriticalSection and CyExitCriticalSection functions solve the problem by disabling interrupts while the control register is being written. Use these functions when a shared variable or register is being written.

For details on these functions, see the System reference guide (also available under the PSoC<sup>™</sup> Creator menu **Help** > **Documentation**).



## 4.4 Writing interrupt service routine (ISR)

To understand how to write an ISR, consider a timer interrupt as an example. The Interrupt Component "isr\_1" is connected to the interrupt terminal of Timer\_1, as shown in Figure 14.

After building the project, PSoC<sup>™</sup> Creator generates the files associated with all the Components as shown in Figure 15. *isr\_1.c* and *isr\_1.h* are the files generated for the Interrupt Component isr\_1. These files provide the API for configuring and using the Component, including the ISR.



#### Figure 14 Timer interrupt example



Figure 15 Files generated for interrupt components

There are two ways to write an ISR – using the PSoC<sup>™</sup> Creator auto-generated ISR, and creating a custom ISR function.



### 4.5 Using auto-generated ISR

The following is an ISR generated by default in *isr\_1.c.* The ISR function name is in the format-CY\_ISR (<isr\_name>\_interrupt).

```
CY_ISR(isr_1_Interrupt)
{
    #ifdef isr_1_INTERRUPT_INTERRUPT_CALLBACK
        isr_1_Interrupt_InterruptCallback();
    #endif /* isr_1_INTERRUPT_INTERRUPT_CALLBACK */
    /* Place your Interrupt code here. */
    /* `#START isr_1_Interrupt` */
    /* `#END` */
}
```



There are two parts in this function: one to invoke a callback function and another a placeholder for the handler code. The callback function is explained in the next section. You can write the handler code in this auto-generated ISR between the #START and #END markers. Note that code written outside these markers is deleted when the project files are re-generated.

To enable the interrupt, start the isr Component. Code Listing 3 is the *main.c* code to start the interrupt source, that is, the timer and the Interrupt Component.

### **Code Listing 3**

```
int main()
{
    /* Start the timer component */
    Timer_1_Start();
    /* Start the interrupt component */
    isr_1_Start();
    /* Enable global interrupt */
    CyGlobalIntEnable;
    for(;;)
    {
        /* Place your application code here. */
    }
}
```

Note that in addition to enabling the Interrupt Component, you must enable the global interrupt using the CyGlobalIntEnable macro. Inside the ISR, clear the interrupts as explained in Sticky bits. In this example, the Timer interrupt is cleared using the following API function:

void Timer 1 ClearInterrupt(uint32 interruptMask)

The interruptMask parameter can be the Timer Component's terminal count interrupt mask or compare/capture count interrupt mask – see the Timer Component datasheet or the *timer\_1.h* file. See other Component datasheets to learn about the API and the interrupt mask that clears the interrupt from a particular component.

### 4.5.1 Using extern keyword

Many times, in the auto-generated ISR, it is required to access variables and call functions defined in user source files. But to use the variables and the function calls in the auto-generated ISR, it needs to be declared in the isr\_1 file. An "extern" keyword is used for variable declaration.

Look out for Code Listing 4 in the beginning of the file.



### **Code Listing 4**

/\* `#END` \*/

You can either declare the variables and functions between the #START and #END markers directly or just include the header file containing the declarations. An example is shown with a variable and a function declaration.

### Code Listing 5

### 4.6 Using the callback function

Instead of writing the handler code in the auto-generated ISR, you can invoke your own function from the ISR. This helps to keep a separation between the user code and generated code.

The auto-generated ISR has a code with conditional compilation, controlled by macros, for invoking the callback function.

```
CY_ISR(isr_1_Interrupt)
{
    #ifdef isr_1_INTERRUPT_INTERRUPT_CALLBACK
        isr_1_Interrupt_InterruptCallback();
    #endif /* isr_1_INTERRUPT_INTERRUPT_CALLBACK */
    /* Place your Interrupt code here. */
    /* `#START isr_1_Interrupt` */
    /* `#END` */
}
```



By default, the  $isr_1\_INTERRUPT\_INTERRUPT\_CALLBACK$  macro is not defined, thereby disabling the call to  $isr_1\_Interrupt\_InterruptCallback()$ . This is the callback function that you need to write in the source file.

Enable the callback function. To do this, define isr\_1\_INTERRUPT\_INTERRUPT\_CALLBACK in the *cyapicallbacks.h* file, which is located under "Header Files" of the project. Also, declare the callback function in the same file as Code Listing 7.

Code Listing 7

```
#ifndef CYAPICALLBACKS_H
#define CYAPICALLBACKS_H
/*Define your macro callbacks here */
/*For more information, refer to the Writing Code topic in PSoC<sup>TM</sup>Creator Help.*/
#define isr_1_INTERRUPT_INTERRUPT_CALLBACK
void isr_1_Interrupt_InterruptCallback(void);
#endif /* CYAPICALLBACKS H */
```

Notice that the function call is enabled in the auto-generated ISR.

Write the callback function in your source file like any other function.

## 4.7 Creating a custom ISR

The ISR can also be written completely in your own source file instead of modifying the auto-generated code. This method has a benefit of saving time in the function call which occurs in the case of callback function. To make your own function, for example MyCustomISR, to be the ISR for an Interrupt Component *isr\_1*, do the following:

1. Declare the custom function using the  $\ensuremath{\texttt{CY\_ISR\_PROTO}}$  macro:

```
CY_ISR_PROTO(MyCustomISR);
```

2. Define the custom function using the CY\_ISR macro:

```
CY_ISR(MyCustomISR)
{
    /* ISR code goes here */
}
```

3. In the startup code of your *main.c* file, add a call to the <code>isr\_1\_StartEx()</code> API function instead of <code>isr\_1\_Start()</code>. The <code>isr\_1\_StartEx()</code> API function is similar to <code>isr\_1\_Start()</code> except that <code>isr\_1\_StartEx()</code> has a parameter for your ISR function: <code>isr\_1\_StartEx(MyCustomISR)</code>;



### **Code Listing 8**

```
CY ISR PROTO (MyCustomISR);
                  *****
 Function Name: MyCustomISR
CY ISR (MyCustomISR)
{
    /* Add code here */
}
int main()
{
    /* Start the timer component */
    Timer 1 Start();
    /* Set the custom ISR */
    isr_1_StartEx(MyCustomISR);
    /* Enable global interrupt */
    CyGlobalIntEnable;
    for(;;)
    {
       /* Place your application code here. */
    }
```

## 4.7.1 Significance of the keyword CY\_ISR

The interrupt source file defines the ISR function using the CY\_ISR macro. This macro is defined in the autogenerated *cytypes.h* file. It is used for compatibility and easy code porting to other PSoC<sup>™</sup> device families such as PSoC<sup>™</sup> 3 or PSoC<sup>™</sup> 5LP.

Similarly, the macro CY\_ISR\_PROTO declares an ISR function prototype. The declaration is in the header file of the Interrupt Component. For example, the *isr\_1* Interrupt Component has the following function prototype declaration in the header file *isr\_1.h*:

```
CY_ISR_PROTO(isr_1_Interrupt);
```



#### ModusToolbox<sup>™</sup> related code examples

# 5 ModusToolbox<sup>™</sup> related code examples

Table 3 provides the list of code examples that use the interrupt feature. For more code examples, visit Github.

Note:  $PSoC^{M} 4 PDL$  is currently in Alpha and many features are in progress.

#### Table 3 ModusToolbox™ interrupt code examples

| Code Example                                                            | Interrupt Source |
|-------------------------------------------------------------------------|------------------|
| CE230654 - PSoC <sup>™</sup> 4: GPIO interrupt                          | GPIO             |
| CE230664 – PSoC <sup>™</sup> 4: Periodic interrupt using TCPWM          | ТСРѠМ            |
| CE230603 - PSoC <sup>™</sup> 4: I2C slave using callbacks               | 12C              |
| CE231429 - PSoC <sup>™</sup> 4: SCB UART transmit and receive with DMAv | UART             |
| CE230653 - PSoC <sup>™</sup> 4: Watchdog timer interrupt and reset      | WDT              |
| CE231432 - PSoC <sup>™</sup> 4: Watchdog counter interrupts             | WDC              |

#### All ModusToolbox<sup>™</sup> Code Examples

To see all currently released code examples select **New Application** in the ModusToolbox<sup>™</sup> **Quick Panel.** A list of board support packages (BSP) are available to choose from, see Figure 16. The BSP corresponds to the specific device that is being used. When a BSP is selected, a list of code examples that correspond with that BSP can be chosen, as shown in Figure 17.

| Service Creator 1.2 - Choose Board Support Package (BSP)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                |               | ×   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------|-----|
| <u>S</u> ettings <u>H</u> elp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                  |               |     |
| Enter filter text                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CY8C4548AZI-S485                                                                                                                 |               |     |
| Kit Name         MCU         Connectivity           * PSoC4 BSPs         CV8C4548A2I-S485         CV8C4548A2I-S485         cnone>           CV8CK17-041-41XX         CV8C4146A2I-S433         cnone>           CV8CK17-041-41XX         CV8C4146A2I-S433         cnone>           CV8CK17-145-40XX         CV8C4146A2I-S433         cnone>           CV8CK17-145-40XX         CV8C4147A2I-S475         cnone>           CV3CK17-149         CV8C4147A2I-S475         cnone>           PSOC4-GENERIC         CV8C4548AZI-S485         cnone>           PSOC6         BSPs         WICED Bluetooth BSPs | CYBC4548AZI-5485 device.<br>CYBC4548AZI-5485 device.                                                                             |               |     |
| <ul> <li>D*CY8CKTI-149* of Board *CY8CKIT-149* was already found in one<br/>this manifest will be ignored.</li> <li>Found unknown item sensor-motion-bme680 commit latest+v1.X, relet</li> <li>Found unknown item PSVP-M33X1-256K commit latest+v1.X, release-1.1</li> <li>Found unknown item PSVP-Player28 commit latest+v1.X, release-1.1</li> <li>Found unknown item CY8CKTI-149 commit latest+v1.X in the dependence</li> </ul>                                                                                                                                                                   | ease-v1.0.0 in the dependency manifest data.<br>=-v1.0.0 in the dependency manifest data.<br>.0 in the dependency manifest data. | IT-149" from  | n 🌲 |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <u>N</u> ext >                                                                                                                   | <u>C</u> losi | e   |

Figure 16 BSP selection wizard



### ModusToolbox<sup>™</sup> related code examples



Figure 17 Code example selection



PSoC<sup>™</sup> Creator related code examples

# 6 PSoC<sup>™</sup> Creator related code examples

Table 4 provides the list of code examples that use the interrupt feature.

#### Table 4Interrupt code examples

| Code Example                                                                             | Interrupt Source |
|------------------------------------------------------------------------------------------|------------------|
| CE210558 – PSoC <sup>™</sup> 4 GPIO interrupt                                            | GPIO             |
| CE95915 – Implementing an RTC with PSoC <sup>™</sup> 4100/PSoC <sup>™</sup> 4200 Devices | ТСРШМ            |
| CE95333 – Low Power Comparator with PSoC <sup>™</sup> 4                                  | LPCOMP           |
| CE95321 – Hibernate and Stop Power Modes with PSoC <sup>™</sup> 4                        | LPCOMP, GPIO     |
| CE95400 – Watchdog Timer Reset and Interrupt for PSoC <sup>™</sup><br>41xx/42xx Devices  | WDT              |
| CE95275 – Sequencing SAR ADC and Die temperature sensor<br>with PSoC <sup>™</sup> 4      | SAR ADC          |
| CE97089 – PSoC <sup>™</sup> 4 ADC to Memory Buffer DMA Transfer                          | DMA              |
| CE210741 – UART Full Duplex and printf Support with PSoC <sup>™</sup>                    | UART             |

#### All PSoC<sup>™</sup> Creator code examples

To see all currently released code examples select **Find Code Example** in the **Start Page**, see Figure 18. This opens a code example selection menu that can be filtered by device or by Component.

| B PSoC Creator 4.3        |                                                                            | - 🗆 X                                                                                         |
|---------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| <u>File Edit View Pro</u> | oject <u>B</u> uild <u>D</u> ebug <u>T</u> ools <u>W</u> indow <u>H</u> el | lp                                                                                            |
| 8 🔁 👌 🚔 🗔 🖉               | BLADEX 90, M.                                                              |                                                                                               |
| im - 🖂 🕸 📬 👹              |                                                                            |                                                                                               |
| Workspace Ex 👻 🛱 🗙        | Start Page                                                                 | - 4 Þ 🗙 👔                                                                                     |
| <b>-</b>                  | Learn                                                                      | Res                                                                                           |
| No workspace open         | Getting Acquainted                                                         | PSoC Creator News and Information                                                             |
|                           | New in 4.3                                                                 | e Me                                                                                          |
|                           | News and Information                                                       | PSoC Creator News and Information                                                             |
|                           | Start                                                                      |                                                                                               |
|                           | Create New Project                                                         | PSoC Creator 4.3 Available Now                                                                |
|                           | Open Existing Project<br>Find Code Example                                 | We just released PSoC Creator 4.3. It is available for download from our web site now and our |
|                           | No Kit Packages Installed                                                  | update messages should be popping up on your screen at any moment. But don't wait - go ge     |
|                           | Recent                                                                     | PSoC Creator 4.3 adds support for the exciting new PSoC                                       |
|                           | CE224821.cywrk                                                             | Posted on 02/21/2020                                                                          |
|                           | CE225691.cywrk                                                             |                                                                                               |
|                           | CE224625.cywrk                                                             | Read More                                                                                     |
|                           | CE225691.cywrk<br>CE224625.cywrk                                           |                                                                                               |
|                           |                                                                            | PSoC Creator 4.3 BETA Available Now!                                                          |
|                           |                                                                            | Cypress uses cookies to enhance the user                                                      |
|                           |                                                                            | experience and collect visitor statistics. When you Accept and Close                          |
|                           |                                                                            | use this website, you are accepting our use of                                                |
|                           |                                                                            | cookies. Read Our Cookie                                                                      |
|                           |                                                                            | Policy                                                                                        |
|                           |                                                                            | <                                                                                             |
|                           | Output                                                                     | + 4 X                                                                                         |
|                           | Show output from: All 🔹 🐳                                                  |                                                                                               |
|                           |                                                                            | cated at: C:\Users\nrsh\AppData\Local\Temp\PSoC Creator-000.log                               |
|                           |                                                                            |                                                                                               |
|                           |                                                                            |                                                                                               |
|                           |                                                                            |                                                                                               |
|                           |                                                                            |                                                                                               |
|                           |                                                                            |                                                                                               |
|                           | Output Notice List                                                         |                                                                                               |
| Ready                     |                                                                            | 0 Errors 0 Warnings 0 Notes:                                                                  |

### Figure 18 Code example Quick Start



### **Debugging tips**

# 7 Debugging tips

This section provides tips on debugging interrupt projects. The following are some of the frequently encountered cases:

#### 1. Interrupt does not get triggered

- Ensure that the interrupt source and global interrupt are enabled.
- Check whether the vector is set to the correct ISR. See Writing interrupt service routine (ISR) or Setting up an interrupt for more details on how to write and assign the handler for an interrupt source.
- Check whether there are other interrupt sources that are getting repeatedly triggered, thus consuming the entire CPU bandwidth.
- Check whether the interrupt is getting triggered only once. This happens if the Interrupt Component is configured to rising edge and the interrupt source is not cleared.

#### 2. Interrupt is triggered repeatedly

This can happen in multiple cases:

- The interrupt line from the source Component is connected to the Interrupt Component configured to level type. Clear the interrupt source to resolve this behavior.
- A digital output from the Component (not the interrupt line) is connected to the Interrupt Component configured to level type. Configure the Interrupt Component to rising edge to get one interrupt per rising edge.

See Sticky bits for more details.

#### 3. Interrupt is triggered only once

The interrupt line from the source Component is connected to the Interrupt Component configured to rising edge type. Clear the interrupt source to allow the interrupt to be triggered for every rising edge. See Sticky bits for more details.

### 4. Execution of the interrupt service routine (ISR) is taking longer time than expected

This can happen if other high-priority interrupts are being triggered during the execution of the ISR. Increase the priority of the interrupt relative to other interrupt sources.

PSoC<sup>™</sup> 4 devices have an on-chip debug capability that uses the serial wire debug (SWD) interface. It allows you to add breakpoints, evaluate and edit variables, view CPU registers, observe assembler instructions, and read and write memory. The debug mode is useful for checking interrupts as given below:

- To check whether the interrupts are getting executed, add a breakpoint in one of the instructions of the ISR.
- Use the Call Stack window of the debugger to locate when an interrupt is getting executed. You can also use it to check whether a high-priority interrupt occurred during the execution of a low-priority ISR.
- Use Breakpoint Hit Count to detect the number of times an interrupt is being triggered. This is particularly useful to check if the interrupt signal has glitches causing the interrupt to trigger multiple times.

For more details on how to use the Debugger, see the "Using the Debugger" section in PSoC<sup>™</sup> Creator help. To access the document, press **F1** or use the **Help** > **Topics** menu in PSoC<sup>™</sup> Creator.

As an alternative to the debugger, you can also bit bang a pin to do the following:

- Check whether the CPU is entering the ISR.
- Measure the ISR execution time. This can be done by setting the pin in the beginning of the ISR and resetting the pin at the end.



#### **Advanced interrupt topics** 8

#### 8.1 **Exceptions**

Exceptions are events that cause the processor to suspend the currently executing code and branch to a handler. Interrupts are a subset of exceptions. Besides interrupts, exceptions exist for operating system applications and fault handling, as shown in Table 5.

| able 5 Exce                       |                  |                       |                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|-----------------------------------|------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Exception                         | Exception number | Interrupt<br>priority | Description                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Reset                             | 1                | –3 (Highest)          | Triggered on power-on-reset or external reset.                                                                                                                  |  |  |  |  |  |  |  |  |
| Hard fault                        | 3                | -1                    | Generated on fault conditions such as the detection of undefined opcode.                                                                                        |  |  |  |  |  |  |  |  |
| SVCall (Supervisor<br>call)       | 11               | Programmable          | Triggered on a supervisory call (execution of the SVC instruction). It is normally used in operating system applications.                                       |  |  |  |  |  |  |  |  |
| PendSV (pendable<br>service call) | 14               | Programmable          | Similar to SVCall, but the branching to the handler is done only after all high-priority tasks are completed.                                                   |  |  |  |  |  |  |  |  |
| SysTick                           | 15               | Programmable          | SysTick is a 24-bit down-counting timer present in Cortex <sup>®</sup><br>M0/M0+. It generates periodic interrupts for use in<br>operating system applications. |  |  |  |  |  |  |  |  |
| IRQ0 to IRQ31                     | 16–47            | Programmable          | External (Pins) or internal peripheral interrupts.                                                                                                              |  |  |  |  |  |  |  |  |

Exceptions in Arm® Cortex® M0 Table 5

#### **ModusToolbox™ exceptions** 8.1.1

Note that the exception numbers are defined by Arm<sup>®</sup>. In ModusToolbox<sup>™</sup> software environment, interrupt vector numbers are shown in the device header file (example: cy8c4024axi\_s402.h). For example, interrupt vector 0 is exception number 16 (IRQ0).

Reset is the highest-priority exception in the device followed by Hard Fault. These have a fixed priority, whereas others have programmable priorities. ModusToolbox<sup>™</sup> provides a default handler for all exceptions. For reset, the default handler is Reset Handler () in the startup\_psocXXXX.c file. This function is executed first on startup. For all other exceptions, the Defualt Handler() function is the default handler provided in the *startup\_psocXXXX.c* file. However, vector addresses of exceptions that are used including interrupts (defined by the PSoC<sup>™</sup> Creator Components or by the user) are loaded into the vector table during program execution. Unused exceptions still use the default handler.

#### 8.1.2 **PSoC<sup>™</sup>** Creator exceptions

Note that the exception numbers are defined by Arm<sup>®</sup>. In PSoC<sup>™</sup> Creator interrupt vector numbers are shown in the interrupt tab of the *.cydwr* window in the PSoC<sup>™</sup> Creator project, include an exception offset. For example, interrupt vector 0 is exception number 16 (IRQ0).

Reset is the highest-priority exception in the device followed by Hard Fault. These have a fixed priority, whereas others have programmable priorities. PSoC<sup>™</sup> Creator provides a default handler for all exceptions. For reset, the default handler is Reset () in the CmOStart.c file. This function is executed first on startup. For all other exceptions, the IntDefaultHandler() function is the default handler provided in the CmOStart.c file. However, vector addresses of exceptions that are used including interrupts (defined by the PSoC<sup>™</sup> Creator Application note 30 001-90799 Rev. \*G



Components or by the user) are loaded into the vector table during program execution. Unused exceptions still use the default handler.

To identify the exception currently being handled, read the Interrupt Program Status Register (IPSR). This is particularly useful when the default handler is under execution.

For more details on exceptions, see ARM<sup>®</sup> developer.

### 8.2 Interrupt latency

Interrupt latency is defined as the time delay between the assertion of an interrupt and the execution of the first instruction in its ISR. The Arm<sup>®</sup> Cortex<sup>®</sup>-M0 or Arm<sup>®</sup> Cortex<sup>®</sup>-M0+ processor in PSoC<sup>™</sup> 4 devices has a latency of 16 and 15 CPU clock cycles (worst-case) respectively with additional CPU cycles because of the synchronizer between peripherals and Cortex<sup>®</sup>-M0/ Cortex<sup>®</sup> M0+ interrupt lines. Table 6 provides the synchronizer CPU clock cycle delays in different PSoC<sup>™</sup> 4 families for DSI and fixed-function source interrupts.

| Device                                          | DSI<br>Interrupt | Fixed-function interrupt                                                          |  |  |  |  |  |  |
|-------------------------------------------------|------------------|-----------------------------------------------------------------------------------|--|--|--|--|--|--|
| PSoC <sup>™</sup> 4000                          | NA               | Depends on the peripheral:                                                        |  |  |  |  |  |  |
|                                                 |                  | SCB-I2C, GPIO, WDT: 3 CPU cycles                                                  |  |  |  |  |  |  |
|                                                 |                  | SPC, CSD, TCPWM: 0 CPU cycles                                                     |  |  |  |  |  |  |
| PSoC <sup>™</sup> 4200 / PSoC <sup>™</sup> 4100 | 0 CPU<br>cycles  | 3 CPU Cycles                                                                      |  |  |  |  |  |  |
| PSoC <sup>™</sup> 42x7 BLE / PSoC <sup>™</sup>  | 3 CPU            | Depends on the peripheral:                                                        |  |  |  |  |  |  |
| 41x7 BLE                                        | cycles           | SCB-I2C, GPIO, WDT, CTBm, LPCOMP, BLE, LVD: 3 CPU cycles                          |  |  |  |  |  |  |
|                                                 |                  | SPC, CSD, TCPWM, SAR: 0 CPU cycles                                                |  |  |  |  |  |  |
| PSoC <sup>™</sup> 4200M / PSoC <sup>™</sup>     | 3 CPU            | Depends on the peripheral:                                                        |  |  |  |  |  |  |
| 4100M / PSoC™ 4200L                             | cycles           | SCB-I2C, GPIO, WDT, CTBm, LPCOMP, LVD: 3 CPU cycles                               |  |  |  |  |  |  |
|                                                 |                  | SPC, CSD, TCPWM, SAR, DMA, CAN, USB (only available in PSoC™ 4200L): 0 CPU cycles |  |  |  |  |  |  |
| PSoC <sup>™</sup> 4000S / PSoC <sup>™</sup>     | NA               | Depends on the peripheral:                                                        |  |  |  |  |  |  |
| 4100S / PSoC™ 4100PS                            |                  | SCB, GPIO, WDT, CTBm/CTB, LPCOMP: 2 CPU cycles                                    |  |  |  |  |  |  |
|                                                 |                  | CSD, TCPWM, SAR: 0 CPU cycles                                                     |  |  |  |  |  |  |
| PSoC™ 4100S Plus                                | NA               | Depends on the peripheral:                                                        |  |  |  |  |  |  |
|                                                 |                  | SCB, GPIO, WDT, CTBm/CTB, LPCOMP: 2 CPU cycles                                    |  |  |  |  |  |  |
|                                                 |                  | CSD, Crypto, CAN, SAR: 0 CPU cycles                                               |  |  |  |  |  |  |

| Table 6 | Synchronizer clock cycle delays for DSI and fixed-function source interrupts |
|---------|------------------------------------------------------------------------------|
|---------|------------------------------------------------------------------------------|

During the 16-cycles latency in Cortex<sup>®</sup> M0 or 15-cycles latency in Cortex<sup>®</sup> M0+, the following actions take place:

- 1. The processor pushes the current Program Counter (PC), Link Register (LR), Program Status Register (PSR), and some of the general-purpose registers to the stack.
- 2. The processor reads the vector address from the NVIC and updates it to the PC.
- 3. The processor updates the NVIC registers.

Thus, the latency differs from 16 cycles in Cortex<sup>®</sup> M0 and 15 cycles in Cortex<sup>®</sup> M0+ when an ISR is currently in execution or about to begin. To make the process efficient, the Cortex<sup>®</sup>-M0/ Cortex<sup>®</sup> M0+ processor implements the following two schemes:



- 1. *Tail Chaining:* If an interrupt is in the pending state while the processor is executing another interrupt handler, unstacking is skipped when the execution ends for the first interrupt and the handler for the pending interrupt is immediately executed. This saves the time of restoring the registers from the stack and pushing the same registers again to stack. This is useful for reducing the latency of low-priority interrupts.
- 2. *Late Arrival:* If a higher-priority interrupt occurs during the stacking process of a lower-priority interrupt, the processor jumps to the higher-priority interrupt handler instead of a lower-priority one. The processor reads the vector address of the higher-priority interrupt at the end of the stacking process. Once the higher-priority interrupt handler execution is completed, the vector address for the pending lower-priority interrupt handler is fetched and executed. This reduces the latency for a higher-priority interrupt by eliminating the delay caused by entering the lower-priority ISR and pushing the register values to the stack.

Note that the current instruction in execution when the interrupt is triggered causes an additional delay in the execution of the ISR. In the case of a device wakeup from an interrupt, an additional delay is caused by the voltage stabilization after the power-up sequence. See the device datasheet for specifications.

## 8.3 Optimizing the interrupt code

One of the important performance requirements in interrupt-based applications is the ISR code execution time. In some applications, the critical code in the ISR must be executed within a particular time of receiving the interrupt request. Also, interrupt execution should not take too much time and stall the main code execution or other interrupts. To meet these requirements, use the following guidelines:

• Avoid calls to lengthy functions in the ISR. Functions such as Character LCD display routines take a long time to execute, and thus block the execution of other low-priority interrupts.

The recommended technique is to move noncritical function calls to the main code and just set a flag variable in the ISR. The main code periodically checks the flag and if set, clears it and calls the function.

• Assign proper priority to interrupts. In applications with multiple interrupts, give a higher priority to more time-critical interrupts.

## 8.4 PSoC<sup>™</sup> Creator components internal interrupts

Many PSoC<sup>™</sup> Creator Components have an Interrupt Component internally as part of their implementation. Examples include CAPSENSE<sup>™</sup>, SAR ADC, EZI2C, and Segment LCD.

Similar to Interrupt Components, internal ISRs in these Components provide a placeholder region for writing user code. See the respective Component datasheets and associated code examples provided in PSoC<sup>™</sup> Creator to understand the interrupt usage in these Components. Interrupt usage can also be seen in the *cydwr* window as shown in Figure 19.

## 8.5 PSoC<sup>™</sup> Creator forcing interrupt vector num

PSoC<sup>™</sup> Creator automatically assigns the vector numbers for Interrupt Components in a project. After building the project, you can view the assigned vector numbers in the Interrupts tab of the *cydwr* window, as shown in Figure 19. You can also select a particular vector number for an interrupt signal when it is routed through the DSI. This section provides a step-by-step procedure to do this.



| TopDesign.cysch | test.cydv   | vr   | <b>→</b> 4 Þ <b>×</b>                                |  |  |  |  |  |  |
|-----------------|-------------|------|------------------------------------------------------|--|--|--|--|--|--|
| Instance Name   | Priority    | - X. | Vector                                               |  |  |  |  |  |  |
| isr_1           | Default <3> | •    | 0                                                    |  |  |  |  |  |  |
| UART_1_SCB_IRQ  | Default <3> | •    | 10                                                   |  |  |  |  |  |  |
| EZI2C_1_SCB_IRQ | Default <3> | •    | 11                                                   |  |  |  |  |  |  |
|                 |             |      |                                                      |  |  |  |  |  |  |
|                 |             |      |                                                      |  |  |  |  |  |  |
| Pins M          | Analog 🕑 🤇  | lock | s 🖋 Interrupts 🐶 System 🖺 Directives 🧃 Flash Sec 4 🕨 |  |  |  |  |  |  |

Figure 19 Interrupt vector numbers in *cydwr* Window

To override the vector numbers assigned by PSoC<sup>™</sup> Creator and manually assign a vector number, a *Control File* is used. Follow the steps given below:

- 1. Click the **Components** tab of the Workspace Explorer window.
- 2. Right-click the **TopDesign** Component and select **Add Component Item...**. The Add Component Item dialog opens.
- 3. Scroll down to the **Misc** group, select **Control File**, and click **Create New**, as shown in Figure 20.

| Add Component Item                 | S                                                                 |
|------------------------------------|-------------------------------------------------------------------|
| Symbol                             | ▲                                                                 |
| M Empty Symbol                     | Creates a blank symbol.                                           |
| Symbol Wizard                      | Creates a symbol using a wizard.                                  |
| <ul> <li>Implementation</li> </ul> |                                                                   |
| Schematic                          | Creates a blank schematic.                                        |
| Schematic Macro                    | Creates a blank Schematic Macro                                   |
| UDB document                       | Creates a new file to add/configure UDB elements.                 |
| Verilog File                       | Creates an empty verilog file.                                    |
| □ API                              |                                                                   |
| 8051 Keil Assembly File            | Creates an empty 8051 Keil assembly file.                         |
| h API Header File                  | Creates an empty API C File.<br>Creates an empty API header file. |
| GNU ARM Assembly File              | Creates an empty GNU ARM assembly file.                           |
|                                    | e Creates an empty RealView ARM (RVDS/MDK) assembly file.         |
| Misc                               | e creates an empty near new Artin (not simply assenting inc.      |
| C# Customizer File                 | Creates a C# customizer file.                                     |
| Control File                       | Creates an empty control file.                                    |
| Target                             |                                                                   |
| Generic Device                     |                                                                   |
| Architecture:                      | Item name: component01.ctl                                        |
| Family:                            | Component name: component01                                       |
| Device:                            | Destination:     test                                             |
|                                    | Create New  Cancel                                                |

Figure 20 Adding the Control File

A *TopDesign.ctl* file is created and added to the Workspace Explorer window.

4. Double-click the *TopDesign.ctl* file to open it for editing. The *attribute* keyword is used in the control file to specify the interrupt vector number for each Interrupt Component. The method of specifying the interrupt vector number depends on whether you have placed the Interrupt Component on the example schematic or the Interrupt Component is used internally in a PSoC<sup>™</sup> Creator Component in the schematic. The two methods are as follows:

### a) For Interrupt Components that you have placed on the schematic, the syntax is:

```
attribute placement_force of instance_name : label is "Intr(0,
DesiredVectorNumber)";
```



Here, instance\_name refers to the name of the Interrupt Component in the schematic and DesiredVectorNumber is the vector number (0 to 31). For example, to assign vector 17 to the Interrupt Component *isr\_1*:

attribute placement force of isr 1 : label is "Intr(0, 17)";

b) For Components that use interrupts internally such as EZI2C, the syntax is:

```
attribute placement_force of \top_instance_name : InternalInterruptName\: label
is "Intr(0, DesiredVectorNumber)";
```

Here, top\_instance\_name refers to the name of the Component that uses the interrupt internally. InternalInterruptName refers to the name assigned for the internal interrupt in the Component. This can be found from the Interrupts tab of the *cydwr* window, where the interrupt name is appended to the top Component instance name. In Figure 19, *SCB\_IRQ* is the internal interrupt name for the EZI2C Component and the UART Component. The following statement assigns the vector for EZI2C Component to 11.

attribute placement force of \EZI2C 1:SCB IRQ\ : label is "Intr(0,11)"

- 5. After assigning the interrupt vector numbers, click **Save** to save the changes made to the control file.
- 6. **Clean and Build** the example for the new interrupt vector assignments to take effect. The **Interrupts** tab in the *cydwr* window now shows the modified interrupt vector number assignments.

### 8.6 ModusToolbox<sup>™</sup> SysTick timer

SysTick is a 24-bit down-counting timer. Its interrupt is generally used for task switching in a real-time system. It uses the Cortex<sup>®</sup>-M0/ Cortex<sup>®</sup> M0+ internal clock for counting. SysTick is configured using the APIs given below:

1. Setting interrupt handler

Cy SysInt SetVector(SysTick IRQn, SysTick ISR);

SysTick\_IRQN is the exception number for the SysTick interrupt, which is 15 for Cortex<sup>®</sup>-MO. SysTick ISR is the interrupt handler.

2. Configuring interrupt period

```
Cy_SysTick_Init(CY_SYSTICK_CLOCK_SOURCE_CLK_CPU,
CLOCK_FREQ/INTERRUPT_FREQ);
```

CLOCK\_FREQ is the CPU clock frequency. INTERRUPT\_FREQ is the derived interrupt rate from SysTick.



Code Listing 9 is the code snippet for SysTick timer usage.

#### Code Listing 9

```
/* clock and interrupt rates, in Hz */
#define CLOCK FREQ
                       2400000u
#define INTERRUPT FREQ 2u
void SysTick ISR(void)
{
    /* Interrupt Handler */
}
int main()
{
   /* Point the Systick vector to the ISR */
   CyIntSetSysVector(SysTick IRQn, SysTick ISR);
     /* Set the number of ticks between interrupts */
   Cy SysTick Init (CY SYSTICK CLOCK SOURCE CLK CPU, CLOCK FREQ/INTERRUPT FREQ);
   /* Enable Global Interrupts */
    enable irq();
    for(;;)
    {
    }
```

### 8.7 PSoC<sup>™</sup> Creator SysTick timer

SysTick is a 24-bit down-counting timer. Its interrupt is generally used for task switching in a real-time system. It uses the Cortex<sup>®</sup>-M0/Cortex<sup>®</sup> M0+ internal clock for counting. SysTick is configured using the APIs given below:

1. Setting interrupt handler

```
CyIntSetSysVector(SYSTICK VECTOR NUMBER, SysTick ISR);
```

SYSTICK\_VECTOR\_NUMBER is the exception number for the SysTick interrupt, which is 15 for Cortex<sup>®</sup>-M0. SysTick ISR is the interrupt handler.

2. Configuring interrupt period

```
(void) SysTick_Config(CLOCK_FREQ / INTERRUPT_FREQ);
```

CLOCK\_FREQ is the CPU clock frequency. INTERRUPT\_FREQ is the derived interrupt rate from SysTick.



The following is the code snippet for SysTick timer usage.

### Code Listing 10

```
#define SYSTICK INTERRUPT VECTOR NUMBER 15u /* Cortex®-M0/M0+ hard vector */
/* clock and interrupt rates, in Hz */
#define CLOCK FREQ
                       2400000u
#define INTERRUPT FREQ 2u
CY ISR (SysTick ISR)
{
    /* Interrupt Handler */
}
int main()
{
    /* Point the Systick vector to the ISR */
   CyIntSetSysVector(SYSTICK INTERRUPT VECTOR NUMBER, SysTick ISR);
      /* Set the number of ticks between interrupts */
    (void)SysTick Config(CLOCK FREQ / INTERRUPT FREQ);
      /* Enable Global Interrupt */
    CyGlobalIntEnable;
    for(;;)
    {
    }
```

### 8.8 Nested interrupts

NVIC automatically handles nested interrupts without any software overhead. If a higher-priority interrupt is asserted during the execution of a lower-priority interrupt handler, some of the general-purpose registers are pushed to stack, the processor core reads the vector address from NVIC and jumps to the higher-priority interrupt handler. After the execution is completed, the processor restores the register values and execution resumes for the lower-priority interrupt.

### 8.9 PSoC<sup>™</sup> Creator GlobalSignal component

The GlobalSignal Component helps access interrupt signals from various resources in the system. Some of the interrupt signals accessed are watchdog timer interrupt, combined port interrupt, combined low-power comparator interrupt, System Performance Controller Interface (SPCIF) timer (used in the case of flash write operations), and so on. For details on available interrupt signals, see the Component datasheet. The combined port interrupt is explained below.

## 8.9.1 Combined port interrupt

In most PSoC<sup>™</sup> 4 devices, not all ports have a dedicated interrupt vector (see Table 7). In such a case, it is recommended to use the combined port interrupt feature in the GlobalSignal component. The combined port interrupt uses OR logic to combine port interrupt signals.



For example, if you want to generate an interrupt from a signal on pin P5[0], which doesn't have a dedicated interrupt, in the PSoC<sup>™</sup> 4100PS device, do the following:

- 1. Place a digital input pin component and set it to P5[0].
- 2. Configure the pin interrupt. Ensure that dedicated interrupt is unchecked, see Figure 21.

| Configure 'Pin_1'                                                                                                                                                                                                                             | 2 ×             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Pins     Mapping     Clocking     Bullt-in       Number of pins:     1     X     X     4       [All pins]     Image: Clocking     Image: Clocking     Image: Clocking       Image: Clocking     Ping 1_0     The clocking     Image: Clocking |                 |
| Datasheet                                                                                                                                                                                                                                     | OK Apply Cancel |

Figure 21 Pin properties for combined interrupt

3. Place a GlobalSignal Component and set it to "Combined port interrupt (AllPortInt)", see Figure 22.

| Configure | re 'GlobalSignal_1'                                   | x   |
|-----------|-------------------------------------------------------|-----|
| Name:     | GlobalSignal_1                                        |     |
| Ba        | Basic Built-in                                        | 4 Þ |
| Global    | al signal name: Combined port interrupt (AllPortInt)  | •   |
|           | Triggers when any pin or port generates an interrupt. |     |
|           |                                                       |     |
|           |                                                       |     |
| Da        | atasheet OK Apply Cance                               |     |

Figure 22 Placing a GlobalSignal component

Connect an interrupt Component to the GlobalSignal Component, see Figure 23.

| Pin_1                           |  |
|---------------------------------|--|
| GlobalSignal_1<br>Global Signal |  |
| AllPortIntisr_1                 |  |

Figure 23 Connecting an interrupt component to GlobalSignal component

The ISR can now be written for the isr\_1 Component. Note that if multiple port pins are enabled with interrupt, you should check the GPIO\_PRTx\_INTR register to identify the port pin that triggered the interrupt. See the *Register Reference Manual* of the device for details on the register.



## 8.10 Use of volatile for global variables

In interrupts, a common case is to use a variable as a flag that is set in the interrupt handler and polled in the main loop. In such cases, the compiler may optimize out the variable by assuming that there is no code present in the program flow to update the flag; this results in error during run time. To avoid this problem, always declare the global variables that are accessed in both the ISR and the main loop as volatile.



### Summary

# 9 Summary

Interrupts are commonly used in embedded applications. For system-on-chip architectures such as PSoC<sup>™</sup> 4, interrupts play the critical role of communicating the status of on-chip peripherals to the CPU. This application note has provided the information needed to understand the infrastructure available and create interrupt-based projects.

40

001-90799 Rev. \*G 2024-03-06

# Appendix A - Interrupt sources and vector numbers

Table 7 lists the interrupt sources for the 32 interrupt vectors in PSoC<sup>™</sup> 4.

### Table 7 PSoC<sup>™</sup> 4 interrupt sources ('-' Indicates function not available)

| Fixed function<br>interrupt source           | DSI interrupt                                                                    | Interrupt vector |                                    |                |              |             |                |                |                        |                 |                                |                       |                 |                |                            |
|----------------------------------------------|----------------------------------------------------------------------------------|------------------|------------------------------------|----------------|--------------|-------------|----------------|----------------|------------------------|-----------------|--------------------------------|-----------------------|-----------------|----------------|----------------------------|
|                                              | source<br>(not for PSoC™<br>4000/4000S/<br>4100S/4100S<br>Plus/<br>PSoC™ 4100PS) | PSoC™<br>4000    | PSoC <sup>™</sup><br>4100/<br>4200 | PSoC™<br>4 BLE | PSoC™<br>4 M | PSoC™4<br>L | PSoC™<br>4000S | PSoC™<br>4100S | PSoC™<br>4100S<br>Plus | PSoC™<br>4100PS | PSoC™<br>4100S<br>Plus<br>256k | PSoC™<br>4100S<br>Max | PSoC™<br>4200DS | PSoC™<br>4500S | PSoC <sup>™</sup><br>4700S |
| GPIO Interrupt –<br>Port 0                   | DSI                                                                              | IRQ0             | IRQ0                               | IRQ0           | IRQ0         | IRQ0        | IRQ0           | IRQ0           | IRQ0                   | IRQ0            | IRQ0                           | IRQ0                  | IRQ0            | IRQ0           | IRQ0                       |
| GPIO Interrupt –<br>Port 1                   | DSI                                                                              | IRQ1             | IRQ1                               | IRQ1           | IRQ1         | IRQ1        | IRQ1           | IRQ1           | IRQ1                   | IRQ1            | IRQ1                           | IRQ1                  | IRQ1            | IRQ1           | IRQ1                       |
| GPIO Interrupt –<br>Port 2                   | DSI                                                                              | IRQ2             | IRQ2                               | IRQ2           | IRQ2         | IRQ2        | IRQ2           | IRQ2           | IRQ2                   | IRQ2            | IRQ2                           | IRQ2                  | IRQ2            | IRQ2           | IRQ2                       |
| GPIO Interrupt –<br>Port 3                   | DSI                                                                              | IRQ3             | IRQ3                               | IRQ3           | IRQ3         | IRQ3        | IRQ3           | IRQ3           | IRQ3                   | IRQ3            | IRQ3                           | IRQ3                  | IRQ3            | IRQ3           | IRQ3                       |
| GPIO Interrupt –<br>Port 4                   | DSI                                                                              | -                | IRQ4                               | IRQ4           | IRQ4         | IRQ4        | -              | -              | -                      | -               | -                              | -                     | -               | -              | -                          |
| GPIO Interrupt –<br>Port 5                   | DSI                                                                              | _                | -                                  | IRQ5           | -            | -           | -              | -              | _                      | -               | _                              | -                     | -               | _              | -                          |
| GPIO Interrupt –<br>Port 13 (USB<br>Wake up) | DSI                                                                              | -                | -                                  | -              | -            | IRQ5        | -              | -              | -                      | -               | -                              | -                     | -               | -              | -                          |
| GPIO Interrupt –<br>All Port*                | DSI                                                                              | -                | -                                  | IRQ6           | IRQ5         | IRQ6        | IRQ4           | IRQ4           | IRQ4                   | IRQ4            | IRQ4                           | IRQ4                  | IRQ4            | IRQ4           | IRQ4                       |
| _                                            | DSI                                                                              | -                | IRQ5                               | -              | -            | -           | -              | -              | -                      | -               | -                              | -                     | -               | -              | -                          |
| _                                            | DSI                                                                              | -                | IRQ6                               | -              | -            | -           | -              | -              | -                      | -               | -                              | -                     | -               | -              | -                          |
| -                                            | DSI                                                                              | -                | IRQ7                               | -              | -            | -           | -              | -              | -                      | -               | -                              | -                     | -               | -              | -                          |
| LPCOMP (low-<br>power<br>comparator)         | DSI                                                                              | -                | IRQ8                               | IRQ7           | IRQ6         | IRQ7        | IRQ5           | IRQ5           | IRQ5                   | IRQ5            | IRQ5                           | IRQ5                  | IRQ5            | IRQ5           | IRQ5                       |
| WDT (Watchdog<br>timer)                      | DSI                                                                              | IRQ4             | IRQ9                               | IRQ8           | IRQ7         | IRQ8        | IRQ6           | IRQ6           | IRQ6                   | IRQ7            | IRQ6                           | IRQ6                  | IRQ6            | IRQ6           | IRQ6                       |
| SCB0 (Serial<br>Communication<br>Block 0)    | DSI                                                                              | IRQ5             | IRQ10                              | IRQ9           | IRQ8         | IRQ9        | IRQ7           | IRQ7           | IRQ7                   | IRQ8            | IRQ7                           | IRQ7                  | IRQ7            | IRQ7           | IRQ7                       |

Appendix A - Interrupt sources and vector numbers

Infineon

| Fixed function<br>interrupt source            | DSI interrupt<br>source<br>(not for PSoC <sup>™</sup><br>4000/4000S/<br>4100S/4100S<br>Plus/<br>PSoC <sup>™</sup> 4100PS) | Interrupt vector |                        |                |              |              |                |                |                        |                 |                                |                       |                 |                |                |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|----------------|--------------|--------------|----------------|----------------|------------------------|-----------------|--------------------------------|-----------------------|-----------------|----------------|----------------|
|                                               |                                                                                                                           | PSoC™<br>4000    | PSoC™<br>4100/<br>4200 | PSoC™<br>4 BLE | PSoC™<br>4 M | PSoC™ 4<br>L | PSoC™<br>4000S | PSoC™<br>4100S | PSoC™<br>4100S<br>Plus | PSoC™<br>4100PS | PSoC™<br>4100S<br>Plus<br>256k | PSoC™<br>4100S<br>Max | PSoC™<br>4200DS | PSoC™<br>4500S | PSoC™<br>4700S |
| SCB1 (Serial<br>Communication<br>Block 1)     | DSI                                                                                                                       | -                | IRQ11                  | IRQ10          | IRQ9         | IRQ10        | IRQ8           | IRQ8           | IRQ8                   | IRQ9            | IRQ8                           | IRQ8                  | IRQ8            | IRQ8           | IRQ8           |
| SCB2 (Serial<br>Communication<br>Block 2)     | DSI                                                                                                                       | -                | -                      | -              | IRQ10        | IRQ11        | -              | IRQ9           | IRQ9                   | IRQ10           | IRQ9                           | IRQ9                  | IRQ9            | IRQ9           | -              |
| SCB3 (Serial<br>Communication<br>Block 3)     | DSI                                                                                                                       | -                | -                      | -              | IRQ11        | IRQ12        | -              | -              | IRQ10                  | -               | IRQ10                          | IRQ10                 | -               | IRQ10          | -              |
| SCB3 (Serial<br>Communication<br>Block 4)     | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | IRQ11                  | -               | IRQ11                          | IRQ11                 | -               | IRQ11          | -              |
| CTBm0<br>Interrupt (all<br>CTBm0s)            | DSI                                                                                                                       | -                | -                      | IRQ11          | IRQ12        | IRQ13        | -              | IRQ10          | IRQ12                  | IRQ6            | IRQ12                          | IRQ12                 | -               | IRQ12          | -              |
| CTBm1<br>Interrupt (all<br>CTBm1s)            | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | IRQ13                          | -                     | -               | IRQ13          | -              |
| Bluetooth LE<br>Subsystem<br>Interrupt        | DSI                                                                                                                       | -                | -                      | IRQ12          | -            | -            | -              | -              | -                      | -               | -                              | -                     | -               | -              | -              |
| DMA Interrupt                                 | DSI                                                                                                                       | -                | -                      | -              | IRQ13        | IRQ14        | -              | -              | IRQ14                  | IRQ12           | IRQ15                          | IRQ14                 | IRQ10           | IRQ15          | -              |
| SPCIF Interrupt                               | DSI                                                                                                                       | IRQ6             | IRQ12                  | IRQ13          | IRQ14        | IRQ15        | IRQ9           | IRQ10          | IRQ15                  | IRQ13           | IRQ16                          | IRQ15                 | IRQ11           | IRQ16          | IRQ9           |
| SRSS LVD<br>Interrupt                         | DSI                                                                                                                       | -                | IRQ13                  | IRQ14          | IRQ15        | IRQ16        | -              | -              | -                      | -               | -                              | -                     | -               | -              | -              |
| SAR 0<br>(Successive<br>Approximation<br>ADC) | DSI                                                                                                                       | -                | IRQ14                  | IRQ15          | IRQ16        | IRQ17        | -              | IRQ19          | IRQ25                  | IRQ15           | IRQ26                          | IRQ25                 | -               | IRQ26          | -              |
| SAR 1<br>(Successive<br>Approximation<br>ADC) | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | IRQ27                          | -                     | -               | IRQ27          | -              |
| CSD0<br>(CAPSENSE™)                           | DSI                                                                                                                       | IRQ7             | IRQ15                  | IRQ16          | IRQ17        | IRQ18        | IRQ10          | IRQ13          | IRQ16                  | IRQ14           | IRQ17                          | IRQ16                 | -               | IRQ17          | IRQ10          |
| CSD1<br>(CAPSENSE™)                           | DSI                                                                                                                       | -                | -                      | -              | IRQ18        | IRQ19        | -              | -              | -                      | -               | -                              | IRQ29                 | -               | -              | -              |

41

PSoC<sup>™</sup> 4 interrupts

Appendix A - Interrupt sources and vector numbers



| Fixed function<br>interrupt source  | DSI interrupt<br>source<br>(not for PSoC <sup>™</sup><br>4000/4000S/<br>4100S/4100S<br>Plus/<br>PSoC <sup>™</sup> 4100PS) | Interrupt vector |                        |                |              |              |                |                |                        |                 |                                |                       |                 |                |                |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|----------------|--------------|--------------|----------------|----------------|------------------------|-----------------|--------------------------------|-----------------------|-----------------|----------------|----------------|
|                                     |                                                                                                                           | PSoC™<br>4000    | PSoC™<br>4100/<br>4200 | PSoC™<br>4 BLE | PSoC™<br>4 M | PSoC™ 4<br>L | PSoC™<br>4000S | PSoC™<br>4100S | PSoC™<br>4100S<br>Plus | PSoC™<br>4100PS | PSoC™<br>4100S<br>Plus<br>256k | PSoC™<br>4100S<br>Max | PSoC™<br>4200DS | PSoC™<br>4500S | PSoC™<br>4700S |
| VDAC Interrupt<br>(Both VDACs)      | -                                                                                                                         | -                | -                      | -              | -            | -            | -              | _              | -                      | IRQ16           | _                              | _                     | -               | -              | -              |
| TCPWM0<br>(Timer/Counter/<br>PWM 0) | DSI                                                                                                                       | IRQ8             | IRQ16                  | IRQ17          | IRQ19        | IRQ20        | IRQ11          | IRQ14          | IRQ17                  | IRQ17           | IRQ18                          | IRQ17                 | IRQ12           | IRQ18          | IRQ11          |
| TCPWM1<br>(Timer/Counter/<br>PWM 1) | DSI                                                                                                                       | -                | IRQ17                  | IRQ18          | IRQ20        | IRQ21        | IRQ12          | IRQ15          | IRQ18                  | IRQ18           | IRQ19                          | IRQ18                 | IRQ13           | IRQ19          | IRQ12          |
| TCPWM2<br>(Timer/Counter/<br>PWM 2) | DSI                                                                                                                       | -                | IRQ18                  | IRQ19          | IRQ21        | IRQ22        | IRQ13          | IRQ16          | IRQ19                  | IRQ19           | IRQ20                          | IRQ19                 | IRQ14           | IRQ20          | IRQ13          |
| TCPWM3<br>(Timer/Counter/<br>PWM 3) | DSI                                                                                                                       | -                | IRQ19                  | IRQ20          | IRQ22        | IRQ23        | IRQ14          | IRQ17          | IRQ20                  | IRQ20           | IRQ21                          | IRQ20                 | IRQ15           | IRQ21          | IRQ14          |
| TCPWM4<br>(Timer/Counter/<br>PWM 4) | DSI                                                                                                                       | -                | -                      | _              | IRQ23        | IRQ24        | IRQ15          | IRQ18          | IRQ21                  | IRQ21           | IRQ22                          | IRQ21                 | -               | IRQ22          | IRQ15          |
| TCPWM5<br>(Timer/Counter/<br>PWM 5) | DSI                                                                                                                       | -                | -                      | _              | IRQ24        | IRQ25        | -              | -              | IRQ22                  | IRQ22           | IRQ23                          | IRQ22                 | -               | IRQ23          | -              |
| TCPWM6<br>(Timer/Counter/<br>PWM 6) | DSI                                                                                                                       | -                | -                      | _              | IRQ25        | IRQ26        | -              | -              | IRQ23                  | IRQ23           | IRQ24                          | IRQ23                 | -               | IRQ24          | -              |
| TCPWM7<br>(Timer/Counter/<br>PWM 7) | DSI                                                                                                                       | -                | -                      | -              | IRQ26        | IRQ27        | -              | -              | IRQ24                  | IRQ24           | IRQ25                          | IRQ24                 | -               | IRQ25          | -              |
| CAN0 Interrupt                      | DSI                                                                                                                       | -                | -                      | -              | IRQ27        | IRQ28        | -              | -              | IRQ26                  | -               | -                              | IRQ26                 | -               | -              | -              |
| CAN1 Interrupt                      | DSI                                                                                                                       | -                | -                      | -              | IRQ28        | IRQ29        | -              | -              | -                      | -               | -                              | IRQ27                 | -               | -              | -              |
| USB Start of<br>Frame               | DSI                                                                                                                       | -                | -                      | -              | -            | IRQ30        | -              | -              | -                      | -               | -                              | -                     | -               | -              | -              |
| USB EP1-EP8<br>Data                 | DSI                                                                                                                       | -                | -                      | -              | -            | IRQ31        | -              | -              | -                      | -               | -                              | _                     | -               | -              | -              |
| Crypto Interrupt                    | -                                                                                                                         | -                | -                      | -              | -            | -            | -              | -              | IRQ27                  | -               | -                              | IRQ28                 | -               | -              | -              |
| WCO/WDT<br>Interrupt                | -                                                                                                                         | -                | -                      | -              | -            | -            | -              | -              | IRQ13                  | IRQ11           | IRQ14                          | IRQ13                 | -               | IRQ14          | -              |
| EXCO Interrupt                      | -                                                                                                                         | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | IRQ28                          | IRQ30                 | -               | IRQ28          | -              |
| 125                                 | _                                                                                                                         | -                | -                      | -              | _            | -            | -              | -              | -                      | -               | _                              | IRQ31                 | -               | -              | -              |

42

Appendix A - Interrupt sources and vector numbers



| Fixed function<br>interrupt source | DSI interrupt<br>source<br>(not for PSoC <sup>™</sup><br>4000/4000S/<br>4100S/4100S<br>Plus/<br>PSoC <sup>™</sup> 4100PS) | Interrupt vector |                        |                |              |              |                |                |                        |                 |                                |                       |                 |                |                |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|----------------|--------------|--------------|----------------|----------------|------------------------|-----------------|--------------------------------|-----------------------|-----------------|----------------|----------------|
|                                    |                                                                                                                           | PSoC™<br>4000    | PSoC™<br>4100/<br>4200 | PSoC™<br>4 BLE | PSoC™<br>4 M | PSoC™ 4<br>L | PSoC™<br>4000S | PSoC™<br>4100S | PSoC™<br>4100S<br>Plus | PSoC™<br>4100PS | PSoC™<br>4100S<br>Plus<br>256k | PSoC™<br>4100S<br>Max | PSoC™<br>4200DS | PSoC™<br>4500S | PSoC™<br>4700S |
| -                                  | DSI                                                                                                                       | -                | IRQ20                  | IRQ21          | IRQ29        | -            | -              | -              | -                      | -               | IRQ29                          | -                     | IRQ16           | IRQ29          | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ21                  | IRQ22          | IRQ30        | -            | -              | -              | -                      | -               | IRQ30                          | -                     | IRQ17           | IRQ30          | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ22                  | IRQ23          | IRQ31        | -            | -              | -              | -                      | -               | IRQ31                          | -                     | IRQ18           | IRQ31          | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ23                  | IRQ24          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ19           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ24                  | IRQ25          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ20           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ25                  | IRQ26          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ21           | -              | -              |
| _                                  | DSI                                                                                                                       | -                | IRQ26                  | IRQ27          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ22           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ27                  | IRQ28          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ23           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ28                  | IRQ29          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ24           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ29                  | IRQ30          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ25           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ30                  | IRQ31          | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ26           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | IRQ31                  | -              | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ27           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ28           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ29           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ30           | -              | -              |
| -                                  | DSI                                                                                                                       | -                | -                      | -              | -            | -            | -              | -              | -                      | -               | -                              | -                     | IRQ31           | -              | -              |

Appendix A - Interrupt sources and vector numbers





#### References

### References

The wealth of information available on the Infineon webpage can help you select the right PSoC<sup>™</sup> device and, additionally, integrate the device into your designs efficiently and effectively. The following is an abbreviated list for PSoC<sup>™</sup> 4:

- Overview: PSoC<sup>™</sup> portfolio
- Product selectors: PSoC<sup>™</sup> 4. In addition, PSoC<sup>™</sup> Creator includes a device selection tool.
- Datasheets describe and provide electrical specifications for each family.
- Application notes cover a broad range of topics, from basic to advanced level, and include the following:
  - AN88619: PSoC<sup>™</sup> 4 MCU hardware design considerations
  - AN73854: PSoC<sup>™</sup> Creator Introduction to bootloaders
  - AN89610: PSoC<sup>™</sup> Arm<sup>®</sup> Cortex<sup>®</sup> code optimization
  - AN86233: PSoC<sup>™</sup> 4 low-power modes and power reduction techniques
  - AN57821: PSoC<sup>™</sup> 3, PSoC<sup>™</sup> 4, and PSoC<sup>™</sup> 5LP mixed-signal circuit board layout considerations
  - AN89056: PSoC<sup>™</sup> 4 IEC 60730 class B and IEC 61508 SIL safety software library
  - AN64846: Getting started with CAPSENSE<sup>™</sup>
  - AN85951: PSoC<sup>™</sup> 4 and PSoC<sup>™</sup> 6 MCU CAPSENSE<sup>™</sup> design guide
- Code examples demonstrate product features and usage.
- Reference manuals provide detailed descriptions of the architecture and registers in each PSoC<sup>™</sup> 4 device family.
- PSoC<sup>™</sup> 4 programming specification provides the information necessary to program PSoC<sup>™</sup> 4 nonvolatile memory.
- Development tools:
  - CY8CKIT-040, CY8CKIT-042, CY8CKIT-044, CY8CKIT-046, CY8CKIT-042-BLE-A, CY8CKIT-045S, and CY8CKIT-041S-MAX PSoC<sup>™</sup> 4 pioneer kits are easy-to-use and inexpensive development platforms. These include connectors for Arduino-compatible shields and Digilent Pmod daughter cards.
  - CY8CKIT-043, CY8CKIT-145-40XX, CY8CKIT-147, and CY8CKIT-149 are very low-cost prototyping platforms for sampling PSoC<sup>™</sup> 4 devices.
  - CY8CKIT-040T is a low-cost evaluation kit showing the low power CAPSENSE<sup>™</sup>, low power wake on touch and liquid tolerant features of the PSoC<sup>™</sup> 4000T device.
  - The MiniProg3 (CY8CKIT-002) or MiniProg4 (CY8CKIT-005) kit provides an interface for flash programming and debug.
  - Integrated development environment (IDE): There are two development platforms that can be used for application development with PSoC<sup>™</sup> 4 – ModusToolbox<sup>™</sup> software and PSoC<sup>™</sup> Creator.
  - PSoC<sup>™</sup> 4 CAD libraries provide footprint and schematic support for common tools. IBIS models are also available.
- Training videos are available in infineon website on a wide range of topics including the PSoC<sup>™</sup> MCUs.
- Infineon community enables connection with fellow PSoC<sup>™</sup> developers around the world, 24 hours a day, 7 days a week, and hosts a dedicated PSoC<sup>™</sup> 4 MCU community.

### **Other resources:**

- ModusToolbox<sup>™</sup> software
- ModusToolbox<sup>™</sup> software help on GitHub

### **Revision history**

# **Revision history**

| Document<br>Revision | Date       | Description of changes         New Application note                                                    |  |  |  |  |  |  |  |
|----------------------|------------|--------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| **                   | 2014-05-22 |                                                                                                        |  |  |  |  |  |  |  |
| *A                   |            | Updated for PSoC <sup>™</sup> 4 Bluetooth <sup>®</sup> LE and PSoC <sup>™</sup> 4 M                    |  |  |  |  |  |  |  |
|                      |            | Added section on Writing interrupt handlers                                                            |  |  |  |  |  |  |  |
|                      | 2015-05-14 | Added details on interrupts latency                                                                    |  |  |  |  |  |  |  |
|                      |            | Provided links for PSoC <sup>™</sup> Creator code examples                                             |  |  |  |  |  |  |  |
|                      |            | Updated projects with PSoC <sup>™</sup> Creator 3.2                                                    |  |  |  |  |  |  |  |
|                      |            | Updated Appendix B with development kits                                                               |  |  |  |  |  |  |  |
|                      |            | Added information on CyEnterCriticalSection and CyExitCriticalSection APIs                             |  |  |  |  |  |  |  |
|                      |            | Updated template                                                                                       |  |  |  |  |  |  |  |
|                      |            | Updated for PSoC <sup>™</sup> 4200L.                                                                   |  |  |  |  |  |  |  |
|                      |            | Added Exceptions and Debugging tips.                                                                   |  |  |  |  |  |  |  |
| *В                   | 2016-02-02 | Updated Introduction, PSoC <sup>™</sup> 4 interrupt architecture and Interrupt priority configuration. |  |  |  |  |  |  |  |
|                      |            | Removed projects from the application note and moved to code examples CE210557 and CE210558.           |  |  |  |  |  |  |  |
| *C                   | 2017-04-19 | Updated logo and copyright                                                                             |  |  |  |  |  |  |  |
| *D                   | 2017-12-13 | Updated for PSoC <sup>™</sup> 4000S, 4100S, PSoC <sup>™</sup> 4100S Plus, and PSoC <sup>™</sup> Analog |  |  |  |  |  |  |  |
|                      |            | Coprocessor.                                                                                           |  |  |  |  |  |  |  |
|                      |            | Updated Table 1, Table 3, Table 5, and Table 6.                                                        |  |  |  |  |  |  |  |
|                      | 2018-09-14 | Updated for PSoC <sup>™</sup> 4100PS.                                                                  |  |  |  |  |  |  |  |
| * –                  |            | Added Using extern keyword, Using the callback function, PSoC™ Creator                                 |  |  |  |  |  |  |  |
| *E                   |            | GlobalSignal component and Use of volatile for global variables.                                       |  |  |  |  |  |  |  |
|                      |            | Updated Using auto-generated ISR.                                                                      |  |  |  |  |  |  |  |
|                      |            | Updated to Infineon template                                                                           |  |  |  |  |  |  |  |
|                      |            | Updated document to support ModusToolbox™ software environment and PDL                                 |  |  |  |  |  |  |  |
|                      |            | Created new sections:                                                                                  |  |  |  |  |  |  |  |
|                      |            | 3 ModusToolbox™ interrupt support                                                                      |  |  |  |  |  |  |  |
|                      |            | 3.1 Enabling interrupt sources                                                                         |  |  |  |  |  |  |  |
| *F                   |            | 3.2 Enabling interrupt sources using PDL                                                               |  |  |  |  |  |  |  |
|                      | 2021-03-23 | 3.3 Configuring interrupts using PDL                                                                   |  |  |  |  |  |  |  |
|                      |            | 3.3.1 Interrupt API functions                                                                          |  |  |  |  |  |  |  |
|                      |            | 3.3.2 Critical section control functions                                                               |  |  |  |  |  |  |  |
|                      |            | 3.3.3 Setting up an interrupt                                                                          |  |  |  |  |  |  |  |
|                      |            | 5 ModusToolbox™ related code examples                                                                  |  |  |  |  |  |  |  |
|                      |            | 8.1.1 ModusToolbox™ exceptions                                                                         |  |  |  |  |  |  |  |
|                      |            | 8.6 ModusToolbox™ SysTick timer                                                                        |  |  |  |  |  |  |  |
|                      |            | Updated Appendix A for new PSoC <sup>™</sup> 4 devices                                                 |  |  |  |  |  |  |  |
| * C                  | 2024.02.00 | Fixed broken links.                                                                                    |  |  |  |  |  |  |  |
| *G                   | 2024-03-06 | Updated References section.                                                                            |  |  |  |  |  |  |  |



#### Trademarks

All referenced product or service names and trademarks are the property of their respective owners. The Bluetooth<sup>®</sup> word mark and logos are registered trademarks owned by Bluetooth SIG, Inc., and any use of such marks by Infineon is under license.

Edition 2024-03-06 Published by

Infineon Technologies AG 81726 Munich, Germany

© 2024 Infineon Technologies AG. All Rights Reserved.

Do you have a question about this document? Email: erratum@infineon.com

Document reference 001-90799 Rev. \*G

#### Important notice

The information contained in this application note is given as a hint for the implementation of the product only and shall in no event be regarded as a description or warranty of a certain functionality, condition or quality of the product. Before implementation of the product, the recipient of this application note must verify any function and other technical information given herein in the real application. Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind (including without limitation warranties of non-infringement of intellectual property rights of any third party) with respect to any and all information given in this application note.

The data contained in this document is exclusively intended for technically trained staff. It is the responsibility of customer's technical departments to evaluate the suitability of the product for the intended application and the completeness of the product information given in this document with respect to such application.

#### Warnings

Due to technical requirements products may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies office.

Except as otherwise explicitly approved by Infineon Technologies in a written document signed by authorized representatives of Infineon Technologies, Infineon Technologies' products may not be used in any applications where a failure of the product or any consequences of the use thereof can reasonably be expected to result in personal injury.