

主讲: 叶剑

电话: 13728639620

Email: yejian@hit.edu.cn

### 第六讲: GPIO端口

- 1、GPIO端口概述
- 2、GPIO原理框图
- 3、寄存器
- 4、例子

◆F2833x芯片提供了多达88个多功能引脚,每个引脚都可以配置成数字I/O工作模式或外设I/O工作模式,可以通过功能切换寄存器(GPxMUX1/2)进行切换。



◆当不使用片内外设时,可以将其配置成数字I/O工作模式,通过方向控制寄存器(GPxDIR)控制数字I/O的输入输出方向。



◆可以通过输入限定(GPxQSEL1/2)对输入信号进行限定, 从而消除外部噪声信号。



◆88个引脚被分为A、B、C三个端口,其中A端口包括GPIO0~GPIO31,B端口包括GPIO32~GPIO63,C端口包括GPIO64~GPIO87。



## F2833x GPI0管脚示意图



### 第六讲: GPIO端口

- 1、GPIO端口概述
- 2、GPIO原理框图
- 3、寄存器
- 4、例子

### **GPIO0** to **GPIO27** Multiplexing Diagram



### **GPIO28 to GPIO31 Multiplexing Diagram**

### (Peripheral 2 and Peripheral 3 Outputs Merged)



### **GPIO32, GPIO33 Multiplexing Diagram**



# GPIO34 to GPIO63 Multiplexing Diagram (Peripheral 2 and Peripheral 3 Outputs Merged)



# **GPIO64 to GPIO79 Multiplexing Diagram** (Minimal GPIOs Without Qualification)



### 第六讲: GPIO端口

- 1、GPIO端口概述
- 2、GPIO原理框图
- 3、寄存器
- 4、例子

|                          | Default at Reset<br>Primary I/O Function | Peripheral Selection | Peripheral Selection 2  | Peripheral Selection 3  |  |
|--------------------------|------------------------------------------|----------------------|-------------------------|-------------------------|--|
| GPAMUX1 Register<br>Bits | (GPAMUX1 bits = 00)                      | (GPAMUX1 bits = 01)  | (GPAMUX1 bits = 10)     | (GPAMUX1 bits = 11)     |  |
| 1-0                      | GPI00                                    | EPWM1A (O)           | Reserved <sup>(1)</sup> | Reserved <sup>(1)</sup> |  |
| 3-2                      | GPIO1                                    | EPWM1B (O)           | ECAP6 (I/O)             | MFSRB (I/O)(1)          |  |
| 5-4                      | GPIO2                                    | EPWM2A (O)           | Reserved <sup>(1)</sup> | Reserved <sup>(1)</sup> |  |
| 7-6                      | GPIO3                                    | EPWM2B (O)           | ECAP5 (I/O)             | MCLKRB (I/O)(1)         |  |
| 9-8                      | GPIO4                                    | EPWM3A (O)           | Reserved <sup>(1)</sup> | Reserved <sup>(1)</sup> |  |
| 11-10                    | GPIO5                                    | EPWM3B (O)           | MFSRA (I/O)             | ECAP1 (I/O)             |  |
| 13-12                    | GPIO6                                    | EPWM4A (O)           | EPWMSYNCI (I)           | EPWMSYNCO (O)           |  |
| 15-14                    | GPI07                                    | EPWM4B (O)           | MCLKRA (I/O)            | ECAP2 (I/O)             |  |
| 17-16                    | GPIO8                                    | EPWM5A (O)           | CANTXB (O)              | ADCSOCAO (O)            |  |
| 19-18                    | GPIO9                                    | EPWM5B (O)           | SCITXDB (O)             | ECAP3 (I/O)             |  |
| 21-20                    | GPIO10                                   | EPWM6A (O)           | CANRXB (I)              | ADCSOCBO (O)            |  |
| 23-22                    | GPIO11                                   | EPWM6B (O)           | SCIRXDB (I)             | ECAP4 (I/O)             |  |
| 25-24                    | GPIO12                                   | TZ1 (I)              | CANTXB (O)              | MDXB (O)                |  |
| 27-26                    | GPIO13                                   | TZ2 (I)              | CANRXB (I)              | MDRB (I)                |  |
| 29-28                    | GPIO14                                   | TZ3/XHOLD (I)        | SCITXDB (O)             | MCLKXB (I/O)            |  |
| 31-30                    | GPIO15                                   | TZ4/XHOLDA (O)       | SCIRXDB (I)             | MFSXB (I/O)             |  |

| GPAMUX2 Register<br>Bits | (GPAMUX2 bits = 00) | (GPAMUX2 bits = 01) | (GPAMUX2 bits = 10) | (GPAMUX2 bits = 11) |
|--------------------------|---------------------|---------------------|---------------------|---------------------|
| 1-0                      | GPIO16              | SPISIMOA (I/O)      | CANTXB (O)          | TZ5 (I)             |
| 3-2                      | GPIO17              | SPISOMIA (I/O)      | CANRXB (I)          | TZ6 (I)             |
| 5-4                      | GPIO18              | SPICLKA (I/O)       | SCITXDB (O)         | CANRXA (I)          |
| 7-6                      | GPIO19              | SPISTEA (I/O)       | SCIRXDB (I)         | CANTXA (O)          |
| 9-8                      | GPIO20              | EQEP1A (I)          | MDXA (O)            | CANTXB (O)          |
| 11-10                    | GPIO21              | EQEP1B (I)          | MDRA (I)            | CANRXB (I)          |
| 13-12                    | GPIO22              | EQEP1S (I/O)        | MCLKXA (I/O)        | SCITXDB (O)         |
| 15-14                    | GPIO23              | EQEP1I (I/O)        | MFSXA (I/O)         | SCIRXDB (I)         |
| 17-16                    | GPIO24              | ECAP1 (I/O)         | EQEP2A (I)          | MDXB (O)            |
| 19-18                    | GPIO25              | ECAP2 (I/O)         | EQEP2B (I)          | MDRB (I)            |
| 21-20                    | GPIO26              | ECAP3 (I/O)         | EQEP2I (I/O)        | MCLKXB (I/O)        |
| 23-22                    | GPIO27              | ECAP4 (I/O)         | EQEP2S (I/O)        | MFSXB (I/O)         |
| 25-24                    | GPIO28              | SCIRXDA (I)         | XZCS6 (O)           | XZCS6 (O)           |
| 27-26                    | GPIO29              | SCITXDA (O)         | XA19 (O)            | XA19 (O)            |
| 29-28                    | GPIO30              | CANRXA (I)          | XA18 (O)            | XA18 (O)            |
| 31-30                    | GPIO31              | CANTXA (O)          | XA17 (O)            | XA17 (O)            |

|                          | Default at Reset<br>Primary I/O Function | Peripheral Selection 1 | Peripheral Selection 2 | Peripheral Selection 3 |  |
|--------------------------|------------------------------------------|------------------------|------------------------|------------------------|--|
| GPBMUX1 Register<br>Bits | (GPBMUX1 bits = 00)                      | (GPBMUX1 bits = 01)    | (GPBMUX1 bits = 10)    | (GPBMUX1 bits = 11)    |  |
| 1,0                      | GPIO32 (I/O)                             | SDAA (I/OC)            | EPWMSYNCI (I)          | ADCSOCAO (O)           |  |
| 3,2                      | GPIO33 (I/O)                             | SCLA (I/OC)            | EPWMSYNCO (O)          | ADCSOCBO (O)           |  |
| 5,4                      | GPIO34 (I/O)                             | ECAP1 (I/O)            | XREADY (I)             | XREADY (I)             |  |
| 7,6                      | GPIO35 (I/O)                             | SCITXDA (O)            | XR/W (O)               | XR/W (O)               |  |
| 9,8                      | GPIO36 (I/O)                             | SCIRXDA (I)            | XZCS0 (O)              | XZCS0 (O)              |  |
| 11,10                    | GPIO37 (I/O)                             | ECAP2 (I/O)            | XZCS7 (O)              | XZCS7 (O)              |  |
| 13,12                    | GPIO38 (I/O)                             | Reserved               | XWE0 (O)               | XWE0 (O)               |  |
| 15,14                    | GPIO39 (I/O)                             | Reserved               | XA16 (O)               | XA16 (O)               |  |
| 17,16                    | GPIO40 (I/O)                             | Reserved               | XA0/XWE1 (O)           | XA0/XWE1 (O)           |  |
| 19,18                    | GPIO41 (I/O)                             | Reserved               | XA1 (O)                | XA1 (O)                |  |
| 21,20                    | GPIO42 (I/O)                             | Reserved               | XA2 (O)                | XA2 (O)                |  |
| 23,22                    | GPIO43 (I/O)                             | Reserved               | XA3 (O)                | XA3 (O)                |  |
| 25,24                    | GPIO44 (I/O)                             | Reserved               | XA4 (O)                | XA4 (O)                |  |
| 27,26                    | GPIO45 (I/O)                             | Reserved               | XA5 (O)                | XA5 (O)                |  |
| 29,28                    | GPIO46 (I/O)                             | Reserved               | XA6 (O)                | XA6 (O)                |  |
| 31,30                    | GPIO47 (I/O)                             | Reserved               | XA7 (O)                | XA7 (O)                |  |

| GPBMUX2 Register<br>Bits | (GPBMUX2 bits = 00) | (GPBMUX2 bits = 01) | (GPBMUX2 bits = 10 or 11) |  |  |
|--------------------------|---------------------|---------------------|---------------------------|--|--|
| 1,0                      | GPIO48 (I/O)        | ECAP5 (I/O)         | XD31 (I/O)                |  |  |
| 3,2                      | GPIO49 (I/O)        | ECAP6 (I/O)         | XD30 (I/O)                |  |  |
| 5,4                      | GPIO50 (I/O)        | EQEP1A (I)          | XD29 (I/O)                |  |  |
| 7,6                      | GPIO51 (I/O)        | EQEP1B (I)          | XD28 (I/O)                |  |  |
| 9,8                      | GPIO52 (I/O)        | EQEP1S (I/O)        | XD27 (I/O)                |  |  |
| 11,10                    | GPIO53 (I/O)        | EQEP1I (I/O)        | XD26 (I/O)                |  |  |
| 13,12                    | GPIO54 (I/O)        | SPISIMOA (I/O)      | XD25 (I/O)                |  |  |
| 15,14                    | GPIO55 (I/O)        | SPISOMIA (I/O)      | XD24 (I/O)                |  |  |
| 17,16                    | GPIO56 (I/O)        | SPICLKA (I/O)       | XD23 (I/O)                |  |  |
| 19,18                    | GPIO57 (I/O)        | SPISTEA (I/O)       | XD22 (I/O)                |  |  |
| 21,20                    | GPIO58 (I/O)        | MCLKRA (I/O)        | XD21 (I/O)                |  |  |
| 23,22                    | GPIO59 (I/O)        | MFSRA (I/O)         | XD20 (I/O)                |  |  |
| 25,24                    | GPIO60 (I/O)        | MCLKRB (I/O)        | XD19 (I/O)                |  |  |
| 27,26                    | GPIO61 (I/O)        | MFSRB (I/O)         | XD18 (I/O)                |  |  |
| 29,28                    | GPIO62 (I/O)        | SCIRXDC (I)         | XD17 (I/O)                |  |  |
| 31,30                    | GPIO63 (I/O)        | SCITXDC (O)         | XD16 (I/O)                |  |  |

|                       | Default at Reset<br>Primary I/O Function | Peripheral Selection 2 or 3 |
|-----------------------|------------------------------------------|-----------------------------|
| GPCMUX1 Register Bits | (GPCMUX1 bits = 00 or 01)                | (GPCMUX1 bits = 10 or 11)   |
| 1,0                   | GPIO64 (I/O)                             | XD15 (I/O)                  |
| 3,2                   | GPIO65 (I/O)                             | XD14 (I/O)                  |
| 5,4                   | GPIO66 (I/O)                             | XD13 (I/O)                  |
| 7,6                   | GPIO67 (I/O)                             | XD12 (I/O)                  |
| 9,8                   | GPIO68 (I/O)                             | XD11 (I/O)                  |
| 11,10                 | GPIO69 (I/O)                             | XD10 (I/O)                  |
| 13,12                 | GPIO70 (I/O)                             | XD9 (I/O)                   |
| 15,14                 | GPI071 (I/O)                             | XD8 (I/O)                   |
| 17,16                 | GPIO72 (I/O)                             | XD7 (I/O)                   |
| 19,18                 | GPIO73 (I/O)                             | XD6 (I/O)                   |
| 21,20                 | GPI074 (I/O)                             | XD5 (I/O)                   |
| 23,22                 | GPIO75 (I/O)                             | XD4 (I/O)                   |
| 25,24                 | GPIO76 (I/O)                             | XD3 (I/O)                   |
| 27,26                 | GPI077 (I/O)                             | XD2 (I/O)                   |
| 29,28                 | GPIO78 (I/O)                             | XD1 (I/O)                   |
| 31,30                 | GPIO79 (I/O)                             | XD0 (I/O)                   |
| GPCMUX2 Register Bits | GPCMUX2 bits = 00 or 01                  | GPCMUX2 bits = 10 or 11     |
| 1,0                   | GPIO80 (I/O)                             | XA8 (O)                     |
| 3,2                   | GPIO81 (I/O)                             | XA9 (O)                     |
| 5,4                   | GPIO82 (I/O)                             | XA10 (O)                    |
| 7,6                   | GPIO83 (I/O)                             | XA11 (O)                    |
| 9,8                   | GPIO84 (I/O)                             | XA12 (O)                    |
| 11,10                 | GPIO85 (I/O)                             | XA13 (O)                    |
| 13,12                 | GPIO86 (I/O)                             | XA14 (O)                    |
| 15,14                 | GPI087 (I/O)                             | XA15 (O)                    |
| 16 – 31               | Reserved                                 | Reserved                    |

### **GPxDIR**

### GPIO Port A Direction (GPADIR) Register

| 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     |
|--------|--------|--------|--------|--------|--------|--------|--------|
| GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO27 | GPIO26 | GPIO25 | GPIO24 |
| R/W-0  |
| 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| GPIO23 | GPIO22 | GPIO21 | GPIO20 | GPIO19 | GPIO18 | GPIO17 | GPIO16 |
| R/W-0  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| GPIO15 | GPIO14 | GPIO13 | GPIO12 | GPIO11 | GPIO10 | GPIO9  | GPIO8  |
| R/W-0  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| GPI07  | GPIO6  | GPIO5  | GPIO4  | GPIO3  | GPIO2  | GPIO1  | GPI00  |
| R/W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### **GPIO Port A Direction (GPADIR) Register Field Descriptions**

| Bits | Field        | Value | Description (1)                                                                                                                                                                                              |
|------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO0 |       | Controls direction of GPIO Port A pins when the specified pin is configured as a GPIO in the appropriate GPAMUX1 or GPAMUX2 register.                                                                        |
|      |              | 0     | Configures the GPIO pin as an input. (default)                                                                                                                                                               |
|      |              | 1     | Configures the GPIO pin as an output                                                                                                                                                                         |
|      |              |       | The value currently in the GPADAT output latch is driven on the pin. To initialize the GPADAT latch prior to changing the pin from an input to an output, use the GPASET, GPACLEAR, and GPATOGGLE registers. |

### **GPxDIR**

### GPIO Port B Direction (GPBDIR) Register

| 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     |
|--------|--------|--------|--------|--------|--------|--------|--------|
| GPIO63 | GPIO62 | GPIO61 | GPIO60 | GPIO59 | GPIO58 | GPIO57 | GPIO56 |
| R/W-0  |
| 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| GPIO55 | GPIO54 | GPIO53 | GPIO52 | GPIO51 | GPIO50 | GPIO49 | GPIO48 |
| R/W-0  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| GPIO47 | GPIO46 | GPIO45 | GPIO44 | GPIO43 | GPIO42 | GPIO41 | GPIO40 |
| R/W-0  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| GPIO39 | GPIO38 | GPIO37 | GPIO36 | GPIO35 | GPIO34 | GPIO33 | GPIO32 |
| R/W-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### GPIO Port B Direction (GPBDIR) Register Field Descriptions

| Bits | Field         | Value | Description (1)                                                                                                                   |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO63-GPIO32 |       | Controls direction of GPIO pin when GPIO mode is selected. Reading the register returns the current value of the register setting |
|      |               | 0     | Configures the GPIO pin as an input. (default)                                                                                    |
|      |               | 1     | Configures the GPIO pin as an output                                                                                              |

### **GPxDIR**

### GPIO Port C Direction (GPCDIR) Register

| 31     |          |        |        |        |        |        | 24     |  |  |
|--------|----------|--------|--------|--------|--------|--------|--------|--|--|
|        | Reserved |        |        |        |        |        |        |  |  |
| R/W-0  | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |  |  |
| 23     | 22       | 21     | 20     | 19     | 18     | 17     | 16     |  |  |
| GPIO87 | GPIO86   | GPIO85 | GPIO84 | GPIO83 | GPIO82 | GPIO81 | GPIO80 |  |  |
| R/W-0  | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |  |  |
| 15     | 14       | 13     | 12     | 11     | 10     | 9      | 8      |  |  |
| GPIO79 | GPIO78   | GPIO77 | GPIO76 | GPIO75 | GPIO74 | GPIO73 | GPIO72 |  |  |
| R/W-0  | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |  |  |
| 7      | 6        | 5      | 4      | 3      | 2      | 1      | 0      |  |  |
| GPIO71 | GPIO70   | GPIO69 | GPIO68 | GPIO67 | GPIO66 | GPIO65 | GPIO64 |  |  |
| R/W-0  | R/W-0    | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### **GPIO Port C Direction (GPCDIR) Register Field Descriptions**

| Bits | Field         | Value | Description (1)                                                                                                                   |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPI087-GPI064 |       | Controls direction of GPIO pin when GPIO mode is selected. Reading the register returns the current value of the register setting |
|      |               | 0     | Configures the GPIO pin as an input. (default)                                                                                    |
|      |               | 1     | Configures the GPIO pin as an output                                                                                              |

### GPIO XINTn

#### GPIO XINTn, XNMI Interrupt Select (GPIOXINTnSEL, GPIOXNMISEL) Registers

| 15 | 5        | 5 | 4 |              | 0 |
|----|----------|---|---|--------------|---|
|    | Reserved |   |   | GPIOXINTnSEL |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

R-0

#### GPIO XINT1/XINT2 Interrupt Select (GPIOXINTnSEL) Register Field Descriptions

R/W-0

| Bits | Field        | Value | Description (2)                                                                                                                                                                                                                                                                                                                                     |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5 | Reserved     |       | Reserved                                                                                                                                                                                                                                                                                                                                            |
| 4-0  | GPIOXINTnSEL |       | Select the port A GPIO signal (GPIO0 - GPIO31) that will be used as the XINT1 or XINT2 interrupt source. In addition, you can configure the interrupt in the XINT1CR or XINT2CR registers described in Section 8.6.  To use XINT2 as ADC start of conversion, enable it in the ADCTRL2 register. The ADCSOC signal is always rising edge sensitive. |
|      |              | 00000 | Select the GPIO0 pin as the XINTn interrupt source (default)                                                                                                                                                                                                                                                                                        |
|      |              | 00001 | Select the GPIO1 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                  |
|      |              |       |                                                                                                                                                                                                                                                                                                                                                     |
|      |              | 11110 | Select the GPIO30 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                 |
|      |              | 11111 | Select the GPIO31 pin as the XINTn interrupt source                                                                                                                                                                                                                                                                                                 |

#### **XINT1/XINT2** Interrupt Select and Configuration Registers

| n | Interrupt | Interrupt Select Register | Configuration Register |
|---|-----------|---------------------------|------------------------|
| 1 | XINT1     | GPIOXINT1SEL              | XINT1CR                |
| 2 | XINT2     | GPIOXINT2SEL              | XINT2CR                |

### GPIO XINTn

### GPIO XINT3 - XINT7 Interrupt Select (GPIOXINTnSEL) Register Field Descriptions

| Bits | Field        | Value | Description (2)                                                                                                                                                                                 |
|------|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5 | Reserved     |       | Reserved                                                                                                                                                                                        |
| 4-0  | GPIOXINTnSEL |       | Select the port B GPIO signal (GPIO32 - GPIO63) that will be used as the XINTn interrupt source. In addition, you can configure the interrupt in the XINTnCR register described in Section 8.6. |
|      |              | 00000 | Select the GPIO32 pin as the XINTn interrupt source (default)                                                                                                                                   |
|      |              | 00001 | Select the GPIO33 pin as the XINTn interrupt source                                                                                                                                             |
|      |              |       |                                                                                                                                                                                                 |
|      |              | 11110 | Select the GPIO62 pin as the XINTn interrupt source                                                                                                                                             |
|      |              | 11111 | Select the GPIO63 pin as the XINTn interrupt source                                                                                                                                             |

#### **XINT3 - XINT7 Interrupt Select and Configuration Registers**

| n | Interrupt | Interrupt Select Register | Configuration Register |
|---|-----------|---------------------------|------------------------|
| 3 | XINT3     | GPIOXINT3SEL              | XINT3CR                |
| 4 | XINT4     | GPIOXINT4SEL              | XINT4CR                |
| 5 | XINT5     | GPIOXINT5SEL              | XINT5CR                |
| 6 | XINT6     | GPIOXINT6SEL              | XINT6CR                |
| 7 | XINT7     | GPIOXINT7SEL              | XINT7CR                |

### GPIO XNMI

### **GPIO XNMI Interrupt Select (GPIOXNMISEL) Register Field Descriptions**

| Bits | Field    | Value | Description (1)                                                                                                                                                                          |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-5 | Reserved |       | Reserved                                                                                                                                                                                 |
| 4-0  | GPIOSEL  |       | Select which port A GPIO signal (GPIO0 - GPIO31) will be used as the XNMI interrupt source. In addition you can configure the interrupt in the XNMICR register described in Section 8.6. |
|      |          | 00000 | Select the GPIO0 pin as the XNMI interrupt source (default)                                                                                                                              |
|      |          | 00001 | Select the GPIO1 pin as the XNMI interrupt source                                                                                                                                        |
|      |          |       |                                                                                                                                                                                          |
|      |          | 11110 | Select the GPIO30 pin as the XNMI interrupt source                                                                                                                                       |
|      |          | 11111 | Select the GPIO31 pin as the XNMI interrupt source                                                                                                                                       |

## Input Qualification

- ◆异步输入: 只允许工作在外设I/0模式, 数字I/0模式下无效。
- ◆仅与SYSCLKOUT同步: 所有引脚复位时默认此模式,产生一个SYSCLKOUT周期延时。
- ◆采用采样窗口限定:外设I/0模式和数字I/0模式均有效; 采样周期和采样窗长度配置。



## Input Qualification采样周期

#### **GPIO Port A Qualification Control (GPACTRL) Register Field Descriptions**

| Bits  | Field    | Value | Description <sup>(1)</sup>                               |
|-------|----------|-------|----------------------------------------------------------|
| 31-24 | QUALPRD3 |       | Specifies the sampling period for pins GPIO24 to GPIO31. |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)             |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |
| 23-16 | QUALPRD2 |       | Specifies the sampling period for pins GPIO16 to GPIO23. |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)             |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |
| 15-8  | QUALPRD1 |       | Specifies the sampling period for pins GPIO8 to GPIO15.  |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)             |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSOLKOUT</sub>           |
| 7-0   | QUALPRD0 |       | Specifies the sampling period for pins GPIO0 to GPIO7.   |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)             |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>             |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>             |
|       |          |       |                                                          |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>           |

## Input Qualification采样周期

#### **GPIO Port B Qualification Control (GPBCTRL) Register Field Descriptions**

| Bits  | Field    | Value | Description (1)                                         |
|-------|----------|-------|---------------------------------------------------------|
| 31-24 | QUALPRD3 |       | Specifies the sampling period for pins GPIO56 to GPIO63 |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)            |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>            |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>            |
|       |          |       |                                                         |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>          |
| 23-16 | QUALPRD2 |       | Specifies the sampling period for pins GPIO48 to GPIO55 |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)            |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>            |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>            |
|       |          |       |                                                         |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>          |
| 15-8  | QUALPRD1 |       | Specifies the sampling period for pins GPIO40 to GPIO47 |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)            |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>            |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>            |
|       |          |       |                                                         |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>          |
| 7-0   | QUALPRD0 |       | Specifies the sampling period for pins GPIO32 to GPIO39 |
|       |          | 0x00  | Sampling Period = T <sub>SYSCLKOUT</sub> (2)            |
|       |          | 0x01  | Sampling Period = 2 × T <sub>SYSCLKOUT</sub>            |
|       |          | 0x02  | Sampling Period = 4 × T <sub>SYSCLKOUT</sub>            |
|       |          |       |                                                         |
|       |          | 0xFF  | Sampling Period = 510 × T <sub>SYSCLKOUT</sub>          |

## Input Qualification采样窗长度

#### **GPIO Port A Qualification Select 1 (GPAQSEL1) Register Field Descriptions**

| Bits | Field        | Value | Description (1)                                                                                                                                                                                                             |
|------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO15-GPIO0 |       | Select input qualification type for GPIO0 to GPIO15. The input qualification of each GPIO input is controlled by two bits as shown in Figure 55.                                                                            |
|      |              | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|      |              | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |              | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |              | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

#### **GPIO Port A Qualification Select 2 (GPAQSEL2) Register Field Descriptions**

| Bits | Field         | Value | Description (1)                                                                                                                                                                                                             |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO31-GPIO16 |       | Select input qualification type for GPIO16 to GPIO31. The input qualification of each GPIO input is controlled by two bits as shown in Figure 56.                                                                           |
|      |               | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|      |               | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

## Input Qualification采样窗长度

#### **GPIO Port B Qualification Select 1 (GPBQSEL1) Register Field Descriptions**

| Bits | Field         | Value | Description (1)                                                                                                                                                                                                             |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO47-GPIO32 |       | Select input qualification type for GPIO32 to GPIO47. The input qualification of each GPIO input is controlled by two bits as shown in Figure 55.                                                                           |
|      |               | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|      |               | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

#### **GPIO Port B Qualification Select 2 (GPBQSEL2) Register Field Descriptions**

| Bits | Field         | Value | Description (1)                                                                                                                                                                                                             |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | GPIO63-GPIO48 |       | Select input qualification type for GPIO48 to GPIO63. The input qualification of each GPIO input is controlled by two bits as shown in Figure 56.                                                                           |
|      |               | 00    | Synchronize to SYSCLKOUT only. Valid for both peripheral and GPIO pins.                                                                                                                                                     |
|      |               | 01    | Qualification using 3 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 10    | Qualification using 6 samples. Valid for pins configured as GPIO or a peripheral function. The time between samples is specified in the GPACTRL register.                                                                   |
|      |               | 11    | Asynchronous. (no synchronization or qualification). This option applies to pins configured as peripherals only. If the pin is configured as a GPIO input, then this option is the same as 0,0 or synchronize to SYSCLKOUT. |

### Example Qualification Window

- GPxQSEL1/2 = 1,0. This indicates a six-sample qualification.
- GPxCTRL[QUALPRDn] = 1. The sampling period is  $t_w(SP) = 2 \times GPxCTRL[QUALPRDn] \times T_{SYSCLKOUT}$ .

#### This configuration results in the following:

- · The width of the sampling window is: .
  - $t_w(IQSW) = 5 \times t_w(SP) = 5 \times 2 \times GPxCTRL[QUALPRDn] \times T_{SYSCLKOUT}$  or  $5 \times 2 \times T_{SYSCLKOUT}$
- If, for example, T<sub>SYSCLKOUT</sub> = 6.67 ns, then the duration of the sampling window is:

$$t_w(IQSW) = 5 \times 2 \times 6.67 \text{ ns} = 67 \text{ ns}.$$

 To account for the asynchronous nature of the input relative to the sampling period and SYSCLKOUT, up to an additional sampling period, t<sub>w</sub>(SP), + T<sub>SYSCLKOUT</sub> may be required to detect a change in the input signal. For this example:

$$t_w(SP) + T_{SYSCLKOUT} = 13.34 \text{ ns} + 6.67 \text{ ns} = 20 \text{ ns}$$



## GPxDAT/GPxSET/GPxCLEAR/GPxTOGGLE

- ◆GPxDAT: 写时可能改变同端口其他引脚状态出现不可预知错误; 读时不会出现类似错误。
- ◆GPxSET: 置位寄存器在不影响其他引脚状态的情况下将相应的引脚驱动到高电平。
- ◆GPxCLEAR: 清零寄存器在不影响其他引脚状态的情况下将相应的引脚驱动到低电平。
- ◆GPxTOGGLE: 状态翻转寄存器在不影响其他引脚状态的情况下将相应的引脚状态进行翻转。

### 第六讲: GPIO端口

- 1、GPIO端口概述
- 2、GPIO原理框图
- 3、寄存器

4、例子

检测GPIO0引脚上的电平信号,当其为高电平时,驱动GPIO32引脚为高电平,当其为低电平时,驱动GPIO32引脚为低电平。

```
void main(void)
InitSysCtrl(); //系统初始化
  DINT://关闭全局中断
  InitPieCtrl()://初始化中断控制寄存器
  IER = 0x0000;//关闭CPU中断
  IFR = 0x0000;//清除CPU中断信号
InitPieVectTable()://初始化中断向量表
  Gpio_setup1();
  while(1)
  //方案1:采用GPBDAT寄存器实现
  if(GpioDataRegs.GPADAT.bit.GPIO0==1) //读GPIO0引脚的状态
          GpioDataRegs.GPBDAT.bit.GPIO32=1; //写GPIO32引脚的状态
           else
          { GpioDataRegs.GPBDAT.bit.GPIO32=0; }
 //方案2:采用GPBSET、GPBCLEAR寄存器实现
  if(GpioDataRegs.GPADAT.bit.GPIO0==1)
          GpioDataRegs.GPBSET.bit.GPIO32=1;
           else
          { GpioDataRegs.GPBCLEAR.bit.GPIO32=1; }
  */
```

