

# IO Port Configuration Example

Embedded Software Essentials

# Peripherals [S1a]

- **Peripherals**: External to CPU specialized support hardware
- Similar process to configure peripherals
  - Pointers
  - Memory Reads/Writes
  - Use of Bit Manipulation



# Peripherals [S1b]

- **Peripherals**: External to CPU specialized support hardware
- Similar process to configure peripherals
  - Pointers
  - Memory Reads/Writes
  - Use of Bit Manipulation
- GPIO - General Purpose Input/Output



# Input Output Systems [S2a]

- **Input/Output:** method to get data in/out of microcontroller
  - GIO
  - IO
  - GPIO (General Purpose IO)



# Input Output Systems [S2b]

- **Input/Output:** method to get data in/out of microcontroller
  - GIO
  - IO
  - GPIO (General Purpose IO)



# Input Output Systems [S2c]

- **Input/Output:** method to get data in/out of microcontroller
  - GIO
  - IO
  - GPIO (General Purpose IO)
- Pin - physical connection to microcontroller
- Port - combination of pins



# MSP432 Ports [S3a]



# MSP432 Ports [S3b]



# 10 Ports

# MSP432 Ports [S3c]



10 Ports



|                       |                          |    |
|-----------------------|--------------------------|----|
| P1.0/UCA0STE          | <input type="checkbox"/> | 4  |
| P1.1/UCA0CLK          | <input type="checkbox"/> | 5  |
| P1.2/UCA0RXD/UCA0SOMI | <input type="checkbox"/> | 6  |
| P1.3/UCA0TXD/UCA0SIMO | <input type="checkbox"/> | 7  |
| P1.4/UCB0STE          | <input type="checkbox"/> | 8  |
| P1.5/UCB0CLK          | <input type="checkbox"/> | 9  |
| P1.6/UCB0SIMO/UCB0SDA | <input type="checkbox"/> | 10 |
| P1.7/UCB0SOMI/UCB0SCL | <input type="checkbox"/> | 11 |

Port 1 - 8 Pins

GPIO / Primary / Secondary

Port 1 Pin 0 = P1.0

Primary Mode = SPI Chip Select

Port 1 Pin 7 = P1.7

Primary Mode = SPI Slave-Out-Master-In Data (**UCB0SOMI**)

Secondary Mode = I<sup>2</sup>C Clock (**UCB0SCL**)

# MSP432 Ports [S4a]



# MSP432 Ports [S4b]

**LaunchPad Schematic:  
Microcontroller  
Connections**

**P1.0 Red LED Circuit**



# MSP432 Ports [S4a]



P1.0 Red LED Circuit



LED Schematic for P1.0

# MSP432 Launchpad Schematic [S5a]



# MSP432 Launchpad Schematic [S5b]

## MSP432 Port 1



Launchpad Schematic: MSP432 Pinout

|                    |    |                       |
|--------------------|----|-----------------------|
| P1.0_LFD1          | 4  | P1.0/UCA0STE          |
| D1.1_BUTTON04      | 5  | P1.1/UCA0CLK          |
| P1.2_BCL_UART_RXD  | 6  | P1.2/UCA0RXD/UCA0SIMO |
| P1.3_BCL_UART_TXD  | 7  | P1.3/UCA0TXD/UCA0SIMO |
| P1.4_BUTTON02      | 8  | P1.4/UCB0STE          |
| P1.5_SPICLK_J1.7   | 9  | P1.5/UCB0CLK          |
| P1.6_SPIMOSI_J2.15 | 10 | P1.6/UCB0SIMO/UCB0SDA |
| P1.7_SPIMISO_J2.14 | 11 | P1.7/UCB0SOMI/UCB0SCL |

Schematic Label for P1.0: P1.0\_LED1



RED LED Schematic

# MSP432 Launchpad Schematic [S5c]

## MSP432 Pinout Port 1

|                   |    |                       |
|-------------------|----|-----------------------|
| P1.0_LFD1         | 4  | P1.0/UCA0STE          |
| P1.1_BUTTON1      | 5  | P1.1/UCA0CLK          |
| P1.2_BCI_UART_RXD | 6  | P1.2/UCA0RXD/UCA0SOMI |
| P1.3_BCI_UART_TXD | 7  | P1.3/UCA0TXD/UCA0SIMO |
| P1.4_BUTTON2      | 8  | P1.4/UCB0STE          |
| P1.5_SPICLK_J1.7  | 9  | P1.5/UCB0CLK          |
| P1.6_SPMOSI_J2.15 | 10 | P1.6/UCB0SIMO/UCB0SDA |
| P1.7_SPMISO_J2.14 | 11 | P1.7/UCB0SOMI/UCB0SCL |

Pin Number      Pin Modes

## MSP432 Pin Descriptions

Table 6-32. Port P1 (P1.0 to P1.7) Pin Functions

| PIN NAME (P1.x)       | x | FUNCTION         | CONTROL BITS OR SIGNALS <sup>(1)</sup> |          |          |
|-----------------------|---|------------------|----------------------------------------|----------|----------|
|                       |   |                  | P1DIR.x                                | P1SEL1.x | P1SEL0.x |
| P1.0/UCA0STE          | 0 | P1.0 (I/O)       | I: 0; O: 1                             | 0        | 0        |
|                       |   | UCA0STE          | X <sup>(2)</sup>                       | 0        | 1        |
|                       |   | N/A              | 0                                      | 1        | 0        |
|                       |   | DVSS             | 1                                      |          |          |
|                       |   | N/A              | 0                                      | 1        | 1        |
|                       |   | DVSS             | 1                                      |          |          |
| P1.1/UCA0CLK          | 1 | P1.1 (I/O)       | I: 0; O: 1                             | 0        | 0        |
|                       |   | UCA0CLK          | X <sup>(2)</sup>                       | 0        | 1        |
|                       |   | N/A              | 0                                      | 1        | 0        |
|                       |   | DVSS             | 1                                      |          |          |
|                       |   | N/A              | 0                                      | 1        | 1        |
|                       |   | DVSS             | 1                                      |          |          |
| P1.2/UCA0RXD/UCA0SOMI | 2 | P1.2 (I/O)       | I: 0; O: 1                             | 0        | 0        |
|                       |   | UCA0RXD/UCA0SOMI | X <sup>(2)</sup>                       | 0        | 1        |
|                       |   | N/A              | 0                                      | 1        | 0        |
|                       |   | DVSS             | 1                                      |          |          |
|                       |   | N/A              | 0                                      | 1        | 1        |
|                       |   | DVSS             | 1                                      |          |          |

# MSP432 Launchpad Schematic [S5d]

## MSP432 Pinout Port 1

|                   |    |                       |
|-------------------|----|-----------------------|
| P1.0_LFD1         | 4  | P1.0/UCA0STE          |
| P1.1_BUTTON1      | 5  | P1.1/UCA0CLK          |
| P1.2_BCI_UART_RXD | 6  | P1.2/UCA0RXD/UCA0SOMI |
| P1.3_BCI_UART_TXD | 7  | P1.3/UCA0TXD/UCA0SIMO |
| P1.4_BUTTON2      | 8  | P1.4/UCB0STE          |
| P1.5_SPICLK_J1.7  | 9  | P1.5/UCB0CLK          |
| P1.6_SPMOSI_J2.15 | 10 | P1.6/UCB0SIMO/UCB0SDA |
| P1.7_SPMISO_J2.14 | 11 | P1.7/UCB0SOMI/UCB0SCL |

Pin Number      Pin Modes

## MSP432 Pin Descriptions

| Table 6-32. Port P1 (P1.0 to P1.7) Pin Functions |   |                             |                  |
|--------------------------------------------------|---|-----------------------------|------------------|
| PIN NAME (P1.x)                                  | x | CONTROL BITS OR SIGNALS (*) |                  |
|                                                  |   | P1DIR.x                     | P1SEL1.x         |
| P1.0/UCA0STE                                     | 0 | P1.0 (I/O)                  | I: 0; O: 1       |
|                                                  |   | UCA0STE                     | X <sup>(2)</sup> |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |
| P1.1/UCA0CLK                                     | 1 | P1.1 (I/O)                  | I: 0; O: 1       |
|                                                  |   | UCA0CLK                     | X <sup>(2)</sup> |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |
| P1.2/UCA0RXD/UCA0SOMI                            | 2 | P1.2 (I/O)                  | I: 0; O: 1       |
|                                                  |   | UCA0RXD/UCA0SOMI            | X <sup>(2)</sup> |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |
|                                                  |   | N/A                         | 0                |
|                                                  |   | DVSS                        | 1                |

Port P1Sel0.x /P1Sel1.x registers  
Select Mode for each Pin in Port

# Configuring the LED [S6a]

- To configure LED on P1.0<sup>1</sup>



<sup>1</sup>Also Required to Set Pin to I/O Mode (P1SELx). This is set by default



# Configuring the LED [S6b]

- To configure LED on P1.0<sup>1</sup>
  - Set direction to output  
**(P1DIR)**



<sup>1</sup>Also Required to Set Pin to I/O Mode (P1SELx). This is set by default



# Configuring the LED [S6c]

- To configure LED on P1.0<sup>1</sup>
  - Set direction to output (**P1DIR**)
  - Set P1.0 output to high (**P1OUT**)



<sup>1</sup>Also Required to Set Pin to I/O Mode (P1SELx). This is set by default



# Configuring the LED [S6d]

- To configure LED on P1.0<sup>1</sup>
  - Set direction to output (**P1DIR**)
  - Set P1.0 output to high (**P1OUT**)
- To turn on LED, **P1.0\_LED1** voltage needs to be a Logical HIGH  $\sqsubseteq$  VCC(3.3v)

<sup>1</sup>Also Required to Set Pin to I/O Mode (P1SELx). This is set by default



Figure 6-17. Py.x/USCI Pin Schematic



# Configuring the LED [S6e]

- To configure LED on P1.0<sup>1</sup>
  - Set direction to output (**P1DIR**)
  - Set P1.0 output to high (**P1OUT**)
- To turn on LED, **P1.0\_LED1** voltage needs to be a Logical HIGH  $\sqsubseteq$  VCC(3.3v)

<sup>1</sup>Also Required to Set Pin to I/O Mode (**P1SELx**). This is set by default



Figure 6-17. Py.x/USCI Pin Schematic



# Configuring IO Port [S7a]

- Technical reference manual provides configuration steps
- Digital IO has own section
  - Important to read through this

www.ti.com

Digital I/O Introduction

## 10.1 Digital I/O Introduction

The digital I/O features include:

- Independently programmable individual I/Os
- Any combination of input or output
- Individually configurable interrupts for ports (available for certain ports only)
- Independent input and output data registers
- Individually configurable pullup or pulldown resistors
- Wake-up capability from ultra-low-power modes (available for certain ports only)
- Individually configurable high drive I/Os (available for certain I/Os only)

Devices within the family may have up to eleven digital I/O ports implemented (P1 to P10 and PJ). Most ports contain eight I/O lines; however, some ports may contain less (see the device-specific data sheet for ports available). Each I/O line is individually configurable for input or output direction, and each can be individually read or written. Each I/O line is individually configurable for pullup or pulldown resistors.

Certain ports have interrupt and wakeup capability from ultra-low-power modes (see device specific data sheet for ports with interrupt and wakeup capability). Each interrupt can be individually enabled and configured to provide an interrupt on a rising or falling edge of an input signal. All interrupts are fed into an encoded Interrupt Vector register, allowing the application to determine which sub-pin of a port has generated the event.

Individual ports can be accessed as byte-wide ports or can be combined into half-word-wide ports. Port pairs P1 and P2, P3 and P4, P5 and P6, P7 and P8, and so on, are associated with the names PA, PB, PC, PD, and so on, respectively. All port registers are handled in this manner with this naming convention. The main exception are the interrupt vector registers, for example, interrupts for ports P1 and P2 must be handled through P1IV and P2IV, PAIV does not exist.

When writing to port PA with half-word operations, all 16 bits are written to the port. When writing to the lower byte of port PA using byte operations, the upper byte remains unchanged. Similarly, writing to the upper byte of port PA using byte instructions leaves the lower byte unchanged. When writing to a port that contains less than the maximum number of bits possible, the unused bits are don't care. Ports PB, PC, PD, PE, and PF behave similarly.

Reading port PA using half-word operations causes all 16 bits to be transferred to the destination. Reading the lower or upper byte of port PA (P1 or P2) and storing to memory using byte operations causes only the lower or upper byte to be transferred to the destination, respectively. When reading from ports that contain fewer than the maximum bits possible, unused bits are read as zeros (similarly for port PJ).

# Configuring IO Port [S7b]

- Two important registers
  - IO Direction Register (**P1DIR**)
  - IO Output Register (**P1OUT**)
- Register section provides the software configuration steps using Bit Manipulation

Table 10-3. Digital I/O Registers

| Offset | Acronym               | Register Name                | Section         |
|--------|-----------------------|------------------------------|-----------------|
| 0Eh    | P1IV                  | Port 1 Interrupt Vector      | Section 10.4.1  |
| 1Eh    | P2IV                  | Port 2 Interrupt Vector      | Section 10.4.1  |
| 2Eh    | P3IV                  | Port 3 Interrupt Vector      | Section 10.4.1  |
| 3Eh    | P4IV                  | Port 4 Interrupt Vector      | Section 10.4.1  |
| 4Eh    | P5IV                  | Port 5 Interrupt Vector      | Section 10.4.1  |
| 5Eh    | P6IV                  | Port 6 Interrupt Vector      | Section 10.4.1  |
| 6Eh    | P7IV                  | Port 7 Interrupt Vector      | Section 10.4.1  |
| 7Eh    | P8IV                  | Port 8 Interrupt Vector      | Section 10.4.1  |
| 8Eh    | P9IV                  | Port 9 Interrupt Vector      | Section 10.4.1  |
| 9Eh    | P10IV                 | Port 10 Interrupt Vector     | Section 10.4.1  |
| 00h    | P1IN                  | Port 1 Input                 | Section 10.4.2  |
| PAIN_L |                       |                              |                 |
| 02h    | P1OUT<br>or PAOUT_L   | Port 1 Output                | Section 10.4.3  |
| 04h    | P1DIR<br>or PADIR_L   | Port 1 Direction             | Section 10.4.4  |
| 06h    | P1REN<br>or PAREN_L   | Port 1 Resistor Enable       | Section 10.4.5  |
| 08h    | P1DS<br>or PADS_L     | Port 1 Drive Strength        | Section 10.4.6  |
| 0Ah    | P1SEL0<br>or PASEL0_L | Port 1 Select 0              | Section 10.4.7  |
| 0Ch    | P1SEL1<br>or PASEL1_L | Port 1 Select 1              | Section 10.4.8  |
| 16h    | P1SELC<br>or PASELC_L | Port 1 Complement Selection  | Section 10.4.9  |
| 18h    | P1IES<br>or PAIES_L   | Port 1 Interrupt Edge Select | Section 10.4.10 |
| 1Ah    | P1IE<br>or PAIE_L     | Port 1 Interrupt Enable      | Section 10.4.11 |
| 1Ch    | P1IFG<br>or PAIFG_L   | Port 1 Interrupt Flag        | Section 10.4.12 |

# Configuring IO Port [S7c]

- Two important registers
  - IO Direction Register (**PxDIR**)
  - IO Output Register (**PxOUT**)
- PxOUT, PxDIR
  - X = Port Number
- Examples:
  - P2OUT
  - P1DIR

## 10.4.4 PxDIR Register

Port X Direction Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-4. PxDIR Register



Table 10-7. PxDIR Register Description

| Bit | Field | Type | Reset | Description                                                                          |
|-----|-------|------|-------|--------------------------------------------------------------------------------------|
| 7-0 | PxDIR | RW   | 0h    | Port X direction.<br>0b = Port configured as input<br>1b = Port configured as output |

## 10.4.3 PxOUT Register

Port X Output Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-3. PxOUT Register



Table 10-6. PxOUT Register Description

| Bit | Field | Type | Reset     | Description                                                                                                                                                                                                                |
|-----|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | PxOUT | RW   | Undefined | Port X output.<br>When I/O configured to output mode:<br>0b = Output is low.<br>1b = Output is high.<br>When I/O configured to input mode and pullups/pulldowns enabled:<br>0b = Pulldown selected<br>1b = Pullup selected |

# P1DIR Register [S8a]

- Port Direction Register sets pin to:
  - 0: an input
  - 1: an output

## 10.4.4 PxDIR Register

Port X Direction Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-4. PxDIR Register

| 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|
| PxDIR |      |      |      |      |      |      |      |
| rw-0  | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 |

Table 10-7. PxDIR Register Description

| Bit | Field | Type | Reset | Description                                                                          |
|-----|-------|------|-------|--------------------------------------------------------------------------------------|
| 7-0 | PxDIR | RW   | 0h    | Port X direction.<br>0b = Port configured as input<br>1b = Port configured as output |

# P1DIR Register [S8b]

- Port Direction Register sets pin to:
  - 0: an input
  - 1: an output

```
/* Configure P1.0 output */  
P1->DIR |= BIT0;
```

## 10.4.4 PxDIR Register

Port X Direction Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-4. PxDIR Register

| 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|
| PxDIR |      |      |      |      |      |      |      |
| rw-0  | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 | rw-0 |

Table 10-7. PxDIR Register Description

| Bit | Field | Type | Reset | Description                                                                          |
|-----|-------|------|-------|--------------------------------------------------------------------------------------|
| 7-0 | PxDIR | RW   | 0h    | Port X direction.<br>0b = Port configured as input<br>1b = Port configured as output |

# P1DIR Register [S8a]

- Port Direction Register sets pin to:
  - 0: an input
  - 1: an output

```
/* Configure P1.0 output */  
P1->DIR |= BIT0;
```

**rw-0: Bit is  
Read/Write &  
defaults to 0**

## 10.4.4 PxDIR Register

Port X Direction Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-4. PxDIR Register



Table 10-7. PxDIR Register Description

| Bit | Field | Type | Reset | Description                                                                          |
|-----|-------|------|-------|--------------------------------------------------------------------------------------|
| 7-0 | PxDIR | RW   | 0h    | Port X direction.<br>0b = Port configured as input<br>1b = Port configured as output |

# P1OUT Register [S9a]

- Port Output Register sets output to:
  - 0: Output set to LOW (GND)
  - 1: Output set to HIGH (VCC)

## 10.4.3 PxOUT Register

Port X Output Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)

Figure 10-3. PxOUT Register

| 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|
| PxOUT |    |    |    |    |    |    |    |
| rw    | rw | rw | rw | rw | rw | rw | rw |

Table 10-6. PxOUT Register Description

| Bit | Field | Type | Reset     | Description                                                                                                                                                                                                                |
|-----|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | PxOUT | RW   | Undefined | Port X output.<br>When I/O configured to output mode:<br>0b = Output is low.<br>1b = Output is high.<br>When I/O configured to input mode and pullups/pulldowns enabled:<br>0b = Pulldown selected<br>1b = Pullup selected |

# P1OUT Register [S9b]

- Port Output Register sets output to:
  - 0: Output set to LOW (GND)
  - 1: Output set to HIGH (VCC)

```
/* Configure P1.0
output */
P1->DIR |= BIT0;

/* Set P1.0 HIGH */
P1->OUT |= BIT0;
```

## 10.4.3 PxOUT Register

Port X Output Register (X = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 or J)



Table 10-6. PxOUT Register Description

| Bit | Field | Type | Reset     | Description                                                                                                                                                                                                                |
|-----|-------|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0 | PxOUT | RW   | Undefined | Port X output.<br>When I/O configured to output mode:<br>0b = Output is low.<br>1b = Output is high.<br>When I/O configured to input mode and pullups/pulldowns enabled:<br>0b = Pulldown selected<br>1b = Pullup selected |