

GPIO –
General
Purpose
Input/Output



8 Dec 2024

### **OUTLINE**



- 1. Polling and interrupt
- 2. Modules overview
- 3. Port module Interrupt Configuration
- 4. Configuration

## 1. Polling and interrupt



| Criteria      | Polling                                                                               | Interrupt                                                                                 |
|---------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| Concept       | Continuously checking device status                                                   | Notifying when an event occurs                                                            |
| Operation     | The microcontroller runs a loop to check status                                       | The microcontroller pauses the current program and executes the ISR                       |
| Advantages    | <ul><li>Simple and easy to implement</li><li>Easy to understand and control</li></ul> | <ul><li>More efficient CPU usage</li><li>Frees up CPU resources for other tasks</li></ul> |
| Disadvantages | <ul><li>Time-consuming and resource</li><li>Can reduce system performance</li></ul>   | <ul><li>More complex management</li><li>Potential for interrupt conflicts</li></ul>       |
| Use Cases     | When requirements are simple or real-<br>time is not critical                         | When fast response and high performance are needed                                        |



### 2. Modules overview





## 3. Port module - Interrupt Configuration



#### Pin Control Register n (PORT\_PCRn)



| 19–16 | Interrupt Configuration                                                                                                                                     |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| IRQC  | The pin interrupt configuration is valid in all digital pin muxing modes. The corresponding pin is configured to generate interrupt/DMA request as follows: |  |  |
|       | 0000 Interrupt Status Flag (ISF) is disabled.                                                                                                               |  |  |
|       | 0001 ISF flag and DMA request on rising edge.                                                                                                               |  |  |
|       | 0010 ISF flag and DMA request on falling edge.                                                                                                              |  |  |
|       | 0011 ISF flag and DMA request on either edge.                                                                                                               |  |  |
|       | 0100 Reserved.                                                                                                                                              |  |  |
|       | 0101 Reserved.                                                                                                                                              |  |  |
|       | 0110 Reserved.                                                                                                                                              |  |  |
|       | 0111 Reserved.                                                                                                                                              |  |  |
|       | 1000 ISF flag and Interrupt when logic 0.                                                                                                                   |  |  |
|       | 1001 ISF flag and Interrupt on rising-edge.                                                                                                                 |  |  |
|       | 1010 ISF flag and Interrupt on falling-edge.                                                                                                                |  |  |
|       | 1011 ISF flag and Interrupt on either edge.                                                                                                                 |  |  |
|       | 1100 ISF flag and Interrupt when logic 1.                                                                                                                   |  |  |
|       | 1101 Reserved.                                                                                                                                              |  |  |
|       | 1110 Reserved.                                                                                                                                              |  |  |
|       | 1111 Reserved.                                                                                                                                              |  |  |

## 3. Port module – Interrupt Configuration





## 3. Port module - Interrupt Configuration



#### Pin Control Register n (PORT\_PCRn)



| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31–25<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 24<br>ISF         | Interrupt Status Flag  The pin interrupt configuration is valid in all digital pin muxing modes.  Configured interrupt is not detected.  Configured interrupt is detected. If the pin is configured to generate a DMA request, then the corresponding flag will be cleared automatically at the completion of the requested DMA transfer. Otherwise, the flag remains set until a logic 1 is written to the flag. If the pin is configured for a level sensitive interrupt and the pin remains asserted, then the flag is set again immediately after it is cleared. |  |

### 4. Configuration





## 4.1. ISR (Interrupt Service Routine)



- ISR (Interrupt Service Routine) is a function or code segment that is executed when an interrupt occurs.
- When an interrupt occurs, the microcontroller temporarily pauses the current program execution and switches to executing the ISR to handle the related event.

#### The main characteristics of an ISR:

- Quick execution: The ISR should execute quickly to avoid long interruptions of the main process.
- ❖ Interrupts disabled: Interrupts are typically disabled during ISR execution to prevent conflicts.
- ❖ Interrupt status flag: After processing, the interrupt status flag is usually cleared to ensure the interrupt is not handled again immediately.

## 4.1. ISR (Interrupt Service Routine)



 The ISR (Interrupt Service Routine) for external interrupts is declared in the file startup\_S32K144.S

| No. | EXTIX   | Name ISR         |
|-----|---------|------------------|
| 1   | PORTA_x | PORTA_IRQHandler |
| 2   | PORTB_x | PORTB_IRQHandler |
| 3   | PORTC_x | PORTC_IRQHandler |
| 4   | PORTD_x | PORTD_IRQHandler |
| 5   | PORTE_x | PORTE_IRQHandler |

# 4.2. Assignment





