GPIO即通用输入/输出 (General Purpose Input Output)
包括:
两个32位的配置寄存器 GPIOx->CRL,GPIOx->CRH
两个32位的数据寄存器 GPIOx->IDR,GPIOx->ODR
一个32位的 set/reset 寄存器 GPIOx->BSRR
一位16位的 reset 寄存器 GPIOx->BRR
一位32位的锁定寄存器 GPIOx->LCKR
端口的模式包括:
浮空输入(Input floating)—— 即没有上拉电阻和下拉电阻,电压呈不确定性,一般用来做ADC输入用,这样可以减少上下拉电阻对结果的影响
上拉输入(Input pull-up)
下拉输入(Input-pull-down)
模拟输入(Analog)
开漏输出(Output open-drain)—— 输出逻辑0,则N-MOS激活; 输出逻辑1,端口处于高阻(电阻非常大,但不是断路,此外,P-MOS从未激活)
推挽输出(Output push-pull)—— 输出逻辑0,则N-MOS激活;输出逻辑1,P-MOS激活
复用功能推挽输出(Alternate function push-pull)——片内外设功能(I2C的SCL,SDA)
复用功能开漏输出(Alternate function open-drain)——片内外设功能(USART的TX1,SPI的MOSI,MISO,SCK,SS)
复用开漏输出、复用推挽输出:可以理解为GPIO口被用作第二功能时的配置情况(即并非作为通用IO口使用)
注意:I / O端口寄存器被访问为32位字(半字或字节存取是不允许的)
其余具体的可以查看stm3210x 手册
GPIOx->CRL 低位(0-7)端口配置寄存器(x = A~ G,该寄存器偏移地址为:0x00):
GPIOx->CRH 高位(8-15)端口配置寄存器(x = A~ G,该寄存器偏移地址为:0x04):
GPIOx->IDR 端口数据输入寄存器(x = A~ G,该寄存器偏移地址为:0x08):只读,可以读取IO口输入的值
GPIOx->ODR 端口数据输出寄存器(x = A~ G,该寄存器偏移地址为:0x0C):可写可读,可以设置IO口输出的值
GPIOx->BSRR 低位端口配置寄存器(x = A~ G,该寄存器偏移地址为:0x10):0-15位——为1时,可以使ODRx相应的位置1,为0时,无变化 。15-31位——为1时,可以使ODRx相应的位清零,为0时,无变化(注:当set和reset都设置了,则set优先级高)
GPIOx->BSR 低位端口配置寄存器(x = A~ G,该寄存器偏移地址为:0x14): 0-15位——为1时,可以使ODRx相应的位清零,为0时,无变化
注:用BSRR和BRR去改变管脚状态的时候,没有被中断打断的风险,也就不需要关闭中断
GPIOx->LCKR 端口配置锁定寄存器(x = A~ G,该寄存器偏移地址为:0x18):用来锁定对应位的端口位配置,当端口被锁定时,不再有可能修改它的值,直到系统复位。每一个锁都冻结相应的4位控制寄存器(CRL,CRH)
例子:
1 /*
2 根据高8位的输入电平来决定低8位的输出电平
3 */
4
5 GPIOA->CRL = 0x33333333; //GPIOA.0-GPIO0.7 output push-pull 50MHz
6 GPIOA->CRH = 0x44444444; //GPIOA.8-GPIOA.15 input floating
7
8 while(1)
9 {
10 if(GPIOA->IDR & 0xff00)
11 GPIOA->ODR = (GPIOA->IDR >> 8) & 0xff;
12 else
13 GPIOA->ODR = 0;
14 }
上一篇:STM32学习笔记之GPIO(二)
下一篇:stm32 gpio 工作方式及 mos管的认识
推荐阅读最新更新时间:2024-11-08 12:23
设计资源 培训 开发板 精华推荐
- ADR433A 3 Vout 超低噪声 XFET 电压基准的典型应用,具有灌电流和拉电流能力
- 用于 SMPS 的 L6566B 多模式控制器的典型(全功能、QR 操作)应用
- 【训练营】牧云电子狗
- LTC2337-18、18 位、500ksps、全差分输入 ADC 的典型应用
- Maker10
- LTC1867LIGN 用于单端输入的微功率、3V、16 位、8 通道、175ksps ADC 的典型应用电路
- 平衡小车主控板_12.16
- ADP1043A 有源钳位正向转换器,从 -34 V 至 -60 VDC 输入提供 18 V/6A DC 输出
- 用于仪表的 16 位 1 通道 DAC
- FT232R+485