

# **Program your GPIO pins**

Written by Ishita Gupta

# **Program your GPIO pins**

**A guide to the user manual :)**



Say we have  
this LED



We can turn it  
on by  
connecting it  
to the ground  
and power  
pins



But what if we wanted to turn it on and off on demand? Using our computers?



Thats when all  
these pins  
come in



# Decide which pin you want to connect to



Find its ID. The ID for this pin is PBO. This will be useful when we are telling the computer to turn this pin on.



Now connect  
the LED.



Now we have  
to program  
the computer  
to turn it on.

To program the pins, we have to do two things:

To program the pins, we have to do two things:

1. Tell the computer that we want the PBO pin to be an output pin

To program the pins, we have to do two things:

1. Tell the computer that we want the PBO pin to be an output pin
2. Tell the computer we want PBO to be on

# This is the D1-H User manual



# It's a MASSIVE document



# It's a MASSIVE document



Today we are using only one section

d1-h\_user\_manual\_v1.0.pdf 1093 / 1390 | - 64% + | ⌂ ⌃ ⌁

1091

1092

ALLWINNER

ALLWINNER

ALLWINNER

The ALLWINNER logo is stamped diagonally across the three pages of the user manual.

**9.7.4 Register List**

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

  

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |
| PD_CFG1       | 0x0094 | PD Configure Register 1     |
| PD_CFG2       | 0x0098 | PD Configure Register 2     |
| PD_DAT        | 0x00A0 | PD Data Register            |
| PD_DRV0       | 0x00A4 | PD Multi_Driving Register 0 |
| PD_DRV1       | 0x00A8 | PD Multi_Driving Register 1 |
| PD_DRV2       | 0x00AC | PD Multi_Driving Register 2 |
| PD_PULL0      | 0x00B4 | PD Pull Register 0          |
| PD_PULL1      | 0x00B8 | PD Pull Register 1          |

Confidential

ALLWINNER

ALLWINNER

ALLWINNER

# Turn to this page



d1-h\_user\_manual\_v1.0.pdf    1093 / 1390    64%

1091

1092

ALLWINNER

Confidential

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |
| PD_CFG1       | 0x0094 | PD Configure Register 1     |
| PD_CFG2       | 0x0098 | PD Configure Register 2     |
| PD_DAT        | 0x00A0 | PD Data Register            |
| PD_DRV0       | 0x00A4 | PD Multi_Driving Register 0 |
| PD_DRV1       | 0x00A8 | PD Multi_Driving Register 1 |
| PD_DRV2       | 0x00AC | PD Multi_Driving Register 2 |
| PD_PULL0      | 0x00B4 | PD Pull Register 0          |
| PD_PULL1      | 0x00B8 | PD Pull Register 1          |

ALLWINNER

Or click on this image :)



## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

# Confused?

## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

# Let's break it down!

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG        | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

## Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |



| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG        | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DPA        | 0x0040 | PB Data Register A          |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

This is the base address for the GPIO module

## Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |



| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG        | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

If all the GPIO pins were houses, this would be the starting number of the houses

9.7.4

## Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |



| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG        | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

It looks like we are in the right place. Lets try to find the specific address we want to write to

But wait, why are we writing to addresses?

But wait, why are we writing to addresses? Recall we have to:

But wait, why are we writing to addresses? Recall we have to:

1. Tell the computer that we want the PBO pin to be an output pin
2. Tell the computer we want PBO to be on

To ‘tell’ the computer anything, we have to just put a message, a certain pattern of bits in the right location in the computer’s memory. The datasheet is telling us all the different locations in the memory.

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x01000000   |

This section contains information about the addresses of the PB pins in memory

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

Lets start with we step 1!

1. **Tell the computer that we want the PBO pin to be an output pin**
2. Tell the computer we want PBO to be on

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x2E000000   |

**1. We can use the configure register to tell the computer we want PBO to be an output**

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

## 9.7.5 Register Description

### 9.7.5.1 0x0030 PB Configure Register 0 (Default Value: 0xFFFF\_FFFF)

The 4 bit number 0001 signifies output

| Offset: 0x0030 |            |             | Register Name: PB_CFG0                                                                                                      |                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |                                                                                                                             |
| 31:28          | R/W        | 0xF         | PB7_SELECT<br>PB7 Select<br>0000:Input<br>0010:LCD0-D17<br>0100:TWI3-SDA<br>0110:LCD0-D23<br>1000:CPUBIST1<br>1110:PB-EINT7 | <p>0001:Output</p> <p>0011:I2S2-MCLK</p> <p>0101:IR-RX</p> <p>0111:UART3-RX</p> <p>1001:Reserved</p> <p>1111:IO Disable</p> |

## 9.7.5 Register Description

### 9.7.5.1 0x0030 PB Configure Register 0 (Default Value: 0xFFFF\_FFFF)

We need to put this number in the right place for PBO in the configure register

| Offset: 0x0030 |            |             | Register Name: PB_CFG0                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                 |
| 31:28          | R/W        | 0xF         | <p>PB7_SELECT<br/>PB7 Select<br/>0000:Input<br/>0010:LCD0-D17<br/>0100:TWI3-SDA<br/>0110:LCD0-D23<br/>1000:CPUBIST1<br/>1110:PB-EINT7</p> <p>0001:Output<br/>0011:I2S2-MCLK<br/>0101:IR-RX<br/>0111:UART3-RX<br/>1001:Reserved<br/>1111:IO Disable</p>  |

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

**2. We can use the data register to tell the computer to turn that specific pin on**

| Register Name | Offset        | Description                 |
|---------------|---------------|-----------------------------|
| PB_CFG0       | 0x0030        | PB Configure Register 0     |
| PB_CFG1       | 0x0034        | PB Configure Register 1     |
| <b>PB_DAT</b> | <b>0x0040</b> | <b>PB Data Register</b>     |
| PB_DRV0       | 0x0044        | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048        | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054        | PB Pull Register 0          |
| PC_CFG0       | 0x0060        | PC Configure Register 0     |
| PC_DAT        | 0x0070        | PC Data Register            |
| PC_DRV0       | 0x0074        | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084        | PC Pull Register 0          |
| PD_CFG0       | 0x0090        | PD Configure Register 0     |

## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

You will learn about the other registers later

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

Underneath are PC registers, which we dont need to look since we did not choose to connect to a PC pin.

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

**Similarly if we had connected to a PD pin,  
we could look down here, and so on.**

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |

9.7.4

## Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description             |
|---------------|--------|-------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0 |
| PB_CFG1       | 0x0034 | PB Configure Register 1 |
| PB_DAT        | 0x0040 | PB Data Register        |

|          |        |                             |
|----------|--------|-----------------------------|
| PB_DRV0  | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1  | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0 | 0x0054 | PB Pull Register 0          |
| PC_CFG0  | 0x0060 | PC Configure Register 0     |
| PC_DAT   | 0x0070 | PC Data Register            |
| PC_DRV0  | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0 | 0x0084 | PC Pull Register 0          |
| PD_CFG0  | 0x0090 | PD Configure Register 0     |

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description             |
|---------------|--------|-------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0 |
| PB_CFG1       | 0x0034 | PB Configure Register 1 |
| PB_DAT        | 0x0040 | PB Data Register        |

|          |        |                             |
|----------|--------|-----------------------------|
| PB_DRV0  | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1  | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0 | 0x0054 | PB Pull Register 0          |
| PC_CFG0  | 0x0060 | PC Configure Register 0     |
| PC_DAT   | 0x0070 | PC Data Register            |
| PC_DRV0  | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0 | 0x0084 | PC Pull Register 0          |
| PD_CFG0  | 0x0090 | PD Configure Register 0     |

These are all offsets

9.7.4

## Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description             |
|---------------|--------|-------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0 |
| PB_CFG1       | 0x0034 | PB Configure Register 1 |
| PB_DAT        | 0x0040 | PB Data Register        |

|          |        |                             |
|----------|--------|-----------------------------|
| PB_DRV0  | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1  | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0 | 0x0054 | PB Pull Register 0          |
| PC_CFG0  | 0x0058 | PC Configure Register 0     |
| PC_DRV0  | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0 | 0x0084 | PC Pull Register 0          |
| PD_CFG0  | 0x0090 | PD Configure Register 0     |

You add the offset to the base address to access the address that you need

## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description             |
|---------------|--------|-------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0 |
| PB_CFG1       | 0x0034 | PB Configure Register 1 |

|          |        |                             |
|----------|--------|-----------------------------|
| PB_DAT   | 0x0040 | PB Data Register            |
| PB_DRV0  | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1  | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0 | 0x0054 | PB Pull Register 0          |

|          |        |                             |
|----------|--------|-----------------------------|
| PC_CFG0  | 0x0060 | PC Configure Register 0     |
| PC_DAT   | 0x0070 | PC Data Register            |
| PC_DRV0  | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0 | 0x0084 | PC Pull Register 0          |

|          |        |                             |
|----------|--------|-----------------------------|
| PD_CFG0  | 0x0090 | PD Configure Register 0     |
| PD_DAT   | 0x00A0 | PD Data Register            |
| PD_DRV0  | 0x00A4 | PD Multi_Driving Register 0 |
| PD_PULL0 | 0x00B4 | PD Pull Register 0          |

Lets look at 0x2000030 and 0x2000034, the two configure registers for the PB group

# 0x2000030



# 0x2000034



# 0x2000030



# 0x2000034



**Here it is! Each box can store a 0 or a 1 bit**

# 0x2000030



# 0x2000034



Here is how the space is allocated. 4 bits for each pin.

# 0x2000030



# 0x2000034



Here is how the space is allocated. 4 bits for each pin. This makes sense, Recall:

# 0x2000030



# 0x2000034



## 9.7.5 Register Description

### 9.7.5.1 0x0030 PB Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0030 |            |             | Register Name: PB_CFG0                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:28          | R/W        | 0xF         | PB7_SELECT<br>PB7 Select<br>0000:Input<br>0010:LCD0-D17<br>0100:TWI3-SDA<br>0110:LCD0-D23<br>1000:CPUBIST1<br>1110:PB-EINT7 |
|                |            |             | 0001:Output<br>0011:I2S2-MCLK<br>0101:IR-RX<br>0111:UART3-RX<br>1001:Reserved<br>1111:IO Disable                            |

Here is how the space is allocated. 4 bits for each pin. This makes sense, Recall:

# 0x2000030



# 0x2000034



Since there are only 12 PB pins, some space is unused

# 0x2000030



# 0x2000034



**Because we want PBO to be an output, we can put that 0001 in the right place.**

# 0x2000030



# 0x2000034



Because we want PBO to be an output, we can put that 0001 in the right place.

# 0x2000030



# 0x2000034



## Here it is!

0x2000030



0x2000034



If we had picked PB3, we would have done this

Now we know how to do step 1!

1. ~~Tell the computer that we want the PBO pin to be an output pin~~
2. Tell the computer we want PBO to be on

Lets do step 2:

1. Tell the computer that we want the PBO pin to be an output pin
2. **Tell the computer we want PBO to be on**

#### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

**2. We can use the data register to tell the computer to turn that specific pin on**

| Register Name | Offset        | Description                 |
|---------------|---------------|-----------------------------|
| PB_CFG0       | 0x0030        | PB Configure Register 0     |
| PB_CFG1       | 0x0034        | PB Configure Register 1     |
| <b>PB_DAT</b> | <b>0x0040</b> | <b>PB Data Register</b>     |
| PB_DRV0       | 0x0044        | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048        | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054        | PB Pull Register 0          |
| PC_CFG0       | 0x0060        | PC Configure Register 0     |
| PC_DAT        | 0x0070        | PC Data Register            |
| PC_DRV0       | 0x0074        | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084        | PC Pull Register 0          |
| PD_CFG0       | 0x0090        | PD Configure Register 0     |

## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset        | Description                 |
|---------------|---------------|-----------------------------|
| PB_CFG0       | 0x0030        | PB Configure Register 0     |
| PB_CFG1       | 0x0034        | PB Configure Register 1     |
| <b>PB_DAT</b> | <b>0x0040</b> | <b>PB Data Register</b>     |
| PB_DRV0       | 0x0044        | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048        | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054        | PB Pull Register 0          |
| PC_CFG0       | 0x0060        | PC Configure Register 0     |
| PC_DAT        | 0x0070        | PC Data Register            |
| PC_DRV0       | 0x0074        | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084        | PC Pull Register 0          |
| PD_CFG0       | 0x0090        | PD Configure Register 0     |

**Add the offset to the base address, to go to the data register**

## 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset        | Description                 |
|---------------|---------------|-----------------------------|
| PB_CFG0       | 0x0030        | PB Configure Register 0     |
| PB_CFG1       | 0x0034        | PB Configure Register 1     |
| <b>PB_DAT</b> | <b>0x0040</b> | <b>PB Data Register</b>     |
| PB_DRV0       | 0x0044        | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048        | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054        | PB Pull Register 0          |
| PC_CFG0       | 0x0060        | PC Configure Register 0     |
| PC_DAT        | 0x0071        | PC Data Register            |
| PC_DRV0       | 0x0074        | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084        | PC Pull Register 0          |
| PD_CFG0       | 0x0090        | PD Configure Register 0     |

Lets go to 0x02000040

# 0x2000040



**Space is allocated a bit differently here**

# 0x2000040



We only need one bit to say whether the pin  
needs to be on or off

# 0x2000040



**So we only use these 13 bits for the 12 PB pins**

# 0x2000040



Lets take a closer look

# 0x2000040



One bit for each pin!

# 0x2000040



Just add 1 to the location at PBO!

# 0x2000040



Just add 1 to the location at PBO!



And we are  
done!



Now you understand how to use the datasheet to program GPIO pins!