

GPIO –
General
Purpose
Input/Output



#### **OUTLINE**



- 1. Introduction GPIO
  - 1.1. GPIO Features
  - 1.2. Schematic
  - 1.3. Assignment
- 2. Modules overview
  - 2.1. Peripheral Clock Controller (PCC)
  - 2.2. PORT module
  - 2.3. GPIO module
  - **2.4. GPIO Pad**
  - 2.5. Configure GPIO pin to output
  - 2.6. Configure GPIO pin to input

# 1. Introduction GPIO



#### **General Purpose Input/Output**



# 1. Introduction GPIO





| PORT   | S32K144 |
|--------|---------|
| PORT A | 18      |
| PORT B | 18      |
| PORT C | 18      |
| PORT D | 18      |
| PORT E | 17      |

- ❖ 5 GPIO ports:
  A, B, C, D, E
- Up to 32 pins in each port



#### 1.1. GPIO Features



#### **GPIO** typically used for:

- Reading digital signal
- Generating triggers for external components
- Issuing interrupts
- Waking up the processor



# 1.2. Schematic







# 1.3. Assignment



# Blink Red Led

#### 2. Modules overview





The clock signal is used to maintain the synchronicity and result validity between blocks(CPU, GPIO, Port). Allow Core(CPU) able to be access to the registers of GPIO.

# 2.1. Peripheral Clock Controller (PCC)





**PCC Block Diagram** 

# 2.1. Peripheral Clock Controller (PCC)



#### PCC PORTx Register (PCC\_PORTx)





| Field | Function                                                                                                                                                                                                         |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 30    | Clock Gate Control                                                                                                                                                                                               |  |  |
| CGC   | This read/write bit enables the interface clock for the peripheral, allowing access to the module's registers. It also controls whether the clock selection and divider options can be modified.                 |  |  |
|       | Ob - Clock disabled. The current clock selection and divider options are not locked and can be modified.  1b - Clock enabled. The current clock selection and divider options are locked and cannot be modified. |  |  |



#### Port Control and Interrupts (PORT) features:

- Port control
  - > Pullup or pulldown enable
  - ➤ Drive strength
  - > Passive input filter enable
  - ➤ Pin Muxing mode
- Digital input filter
- Pin interrupt
  - > Asynchronous wake-up in low-power modes
  - Support for edge sensitive (rising, falling, both)



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



| Field | Description                                                                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10–8  | Pin Mux Control                                                                                                                                               |
| MUX   | Not all pins support all pin muxing slots. Unimplemented pin muxing slots are reserved and may result in configuring the pin for a different pin muxing slot. |
|       | The corresponding pin is configured in the following pin muxing slot as follows:                                                                              |
|       | 000 Pin disabled (Alternative 0) (analog).                                                                                                                    |
|       | 001 Alternative 1 (GPIO).                                                                                                                                     |
|       | 010 Alternative 2 (chip-specific).                                                                                                                            |
|       | 011 Alternative 3 (chip-specific).                                                                                                                            |
|       | 100 Alternative 4 (chip-specific).                                                                                                                            |
|       | 101 Alternative 5 (chip-specific).                                                                                                                            |
|       | 110 Alternative 6 (chip-specific).                                                                                                                            |
|       | 111 Alternative 7 (chip-specific).                                                                                                                            |



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



| 6   | Drive Strength Enable                                                                                                                                                |  |  |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| DSE | Drive strength configuration is valid in all digital pin muxing modes.                                                                                               |  |  |  |
|     | Low drive strength is configured on the corresponding pin, if pin is configured as a digital output.                                                                 |  |  |  |
|     | 1 High drive strength is configured on the corresponding pin, if pin is configured as a digital output.                                                              |  |  |  |
| 4   | Passive Filter Enable                                                                                                                                                |  |  |  |
| PFE | Passive filter configuration is valid in all digital pin muxing modes.                                                                                               |  |  |  |
|     | Passive input filter is disabled on the corresponding pin.                                                                                                           |  |  |  |
|     | Passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input. Refer<br>to the device data sheet for filter characteristics. |  |  |  |
|     | +                                                                                                                                                                    |  |  |  |



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



| 1<br>PE | Pull Enable                                                                                                              |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ""      | Pull configuration is valid in all digital pin muxing modes.                                                             |  |  |  |
|         | Internal pullup or pulldown resistor is not enabled on the corresponding pin.                                            |  |  |  |
|         | 1 Internal pullup or pulldown resistor is enabled on the corresponding pin, if the pin is configured as a digital input. |  |  |  |
| 0       | Pull Select                                                                                                              |  |  |  |
| PS      | Pull configuration is valid in all digital pin muxing modes.                                                             |  |  |  |
|         | 0 Internal pulldown resistor is enabled on the corresponding pin, if the corresponding PE field is set.                  |  |  |  |
|         | Internal pullup resistor is enabled on the corresponding pin, if the corresponding PE field is set.                      |  |  |  |

# 2.3. GPIO module



#### **GPIO** module features:

- Port Data Input register visible in all digital
- Port Data Output register with corresponding set/clear/toggle registers
- Port Data Direction register

# 2.3. GPIO module









| Signal name | Direction | Description                                                                                            |
|-------------|-----------|--------------------------------------------------------------------------------------------------------|
| pad         | I/O       | I/O to external world                                                                                  |
| do          | I         | Data coming from the core into the pad                                                                 |
| obe         | I         | Enable output driver                                                                                   |
| pue         | I         | 0: Disable internal pullup or pulldown resistor<br>1: Enable internal pullup or pulldown resistor      |
| pus         | I         | 0: Enable internal pulldown resistor if pue is set<br>1: Enable internal pullup resistor if pue is set |
| ibe         | I         | Enable input receiver                                                                                  |
| ind         | 0         | Data coming out of the pad into the core                                                               |

| obe | do  | pad | Description                                                   |
|-----|-----|-----|---------------------------------------------------------------|
| 0   | X   | Z   | Output buffer disabled, pad hi-Z (If not configured as input) |
| 1   | 0/1 | 0/1 | Output buffer enable, pad = do                                |

| pue | pus | pad | Description                                    |
|-----|-----|-----|------------------------------------------------|
| 0   | Χ   | Z   | Weak pull disabled. Pad retains previous state |
| 1   | 0   | 0   | Weak pull down enabled                         |
| 1   | 1   | 1   | Weak pull up enabled                           |

| ibe | pad | ind | Description                         |
|-----|-----|-----|-------------------------------------|
| 0   | Χ   | 0   | Input buffer disabled, ind gets low |
| 1   | 0/1 | 0/1 | Input buffer enabled, ind = pad     |

#### **Truth table**



#### Registers configure for ode and ibe:



**GPIO** pad representation

#### **Port Data Direction Register (PDDR)**

→ The PDDR configures the individual port pins for input or output.

| Field | Function                                                                                                                                                                                                                                                                             |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31-0  | Port Data Direction                                                                                                                                                                                                                                                                  |  |  |
| PDD   | Configures individual port pins for input or output.  Öb - Pin is configured as general-purpose input, for the GPIO function. The pin will be high-Z if the port input is disabled in GPIOx_PIDR register.  1b - Pin is configured as general-purpose output, for the GPIO function. |  |  |



#### Registers configure for do:



**GPIO** pad representation

#### **Port Data Output Register (PDOR)**

| Field | Function                                                                                                                                                                                                                                                       |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-0  | Port Data Output                                                                                                                                                                                                                                               |  |
| PDO   | Register bits for unbonded pins return an undefined value when read.  0b - Logic level 0 is driven on pin, provided pin is configured for general-purpose output.  1b - Logic level 1 is driven on pin, provided pin is configured for general-purpose output. |  |

#### Port Set Output Register (PSOR)

| Field | Function                                                                                                                                                                                             |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-0  | Port Set Output                                                                                                                                                                                      |  |
| PTSO  | Writing to this register updates the contents of the corresponding bit in the PDOR as follows:  0b - Corresponding bit in PDORn does not change.  1b - Corresponding bit in PDORn is set to logic 1. |  |

#### **Port Clear Output Register (PCOR)**

| Field | Function                                                                                                                                                                                                                             |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-0  | Port Clear Output                                                                                                                                                                                                                    |  |
| PTCO  | Writing to this register updates the contents of the corresponding bit in the Port Data Output Register (PDOR) as follows:  0b - Corresponding bit in PDORn does not change.  1b - Corresponding bit in PDORn is cleared to logic 0. |  |

#### **Port Toggle Output Register (PTOR)**

| Field | Function                                                                                                                                                                                                                             |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-0  | Port Toggle Output                                                                                                                                                                                                                   |  |
| PTTO  | Writing to this register updates the contents of the corresponding bit in the PDOR as follows:  0b - Corresponding bit in PDORn does not change.  1b - Corresponding bit in PDORn is set to the inverse of its existing logic state. |  |



#### Registers configure for pue and pus:



**GPIO** pad representation

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

→ This register configures Pullup or pulldown enable

| Field   | Description                                                                                                                                                                                                                            |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1<br>PE | Pull Enable                                                                                                                                                                                                                            |  |  |
|         | Pull configuration is valid in all digital pin muxing modes.                                                                                                                                                                           |  |  |
|         | Internal pullup or pulldown resistor is not enabled on the corresponding pin.                                                                                                                                                          |  |  |
|         | Internal pullup or pulldown resistor is enabled on the corresponding pin, if the pin is configured as a digital input.                                                                                                                 |  |  |
| 0       | Pull Select                                                                                                                                                                                                                            |  |  |
| PS      | Pull configuration is valid in all digital pin muxing modes.                                                                                                                                                                           |  |  |
|         | <ul> <li>Internal pulldown resistor is enabled on the corresponding pin, if the corresponding PE field is set.</li> <li>Internal pullup resistor is enabled on the corresponding pin, if the corresponding PE field is set.</li> </ul> |  |  |

Pull-Up: Small internal resistor to Vcc

Pull-Down: Small internal resistor to Gnd



#### Registers configure for ind:



**GPIO** pad representation

#### Port Data Input Register (PDIR)

→ This register captures the logic levels that are driven into each general-purpose input pin.

| Field | Function                                                                                                                                                                                                                                                                                                                                               |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31-0  | Port Data Input                                                                                                                                                                                                                                                                                                                                        |  |
| PDI   | Reads 0 at the unimplemented pins for a particular device. Pins that are not configured for a digital function read 0. If the Port Control and Interrupt module is disabled, then the corresponding bit in PDIR does not update.  0b - Pin logic level is logic 0, or is not configured for use by digital function.  1b - Pin logic level is logic 1. |  |

# 2.5. Configure GPIO pin to output





# 2.5.1. Finding address register



| No. | Register    | Address |
|-----|-------------|---------|
| 1   | PCC_PORTD   |         |
| 2   | PORT_PCR15  |         |
| 3   | GPIOD.PDDR  |         |
| 4   | GPIOD. PDOR |         |

#### 2.5.2. Practice



# Blink Red Led

# 2.6. Configure GPIO pin to input





# 2.6.1. Finding address register



| No. | Register   | Address |
|-----|------------|---------|
| 1   | PCC_PORTC  |         |
| 2   | PORT_PCR13 |         |
| 3   | GPIOC.PDDR |         |
| 4   | GPIOC.PDIR |         |



# Read state SW3 (PTC13)

