STM点滴一
就就是你用BSRR和BRR去改变管脚状态的时候,没有被中断打断的风险。也就不需要关闭中断。
This way, there is no risk that an IRQ occurs between the read and the modify access.”
用ODR操作GPIO的伪代码如下:
disable_irq()
save_gpio_pin_sate = read_gpio_pin_state();
save_gpio_pin_sate = xxxx;
chang_gpio_pin_state(save_gpio_pin_sate);
enable_irq();
关闭中断明显会延迟或丢失一事件的捕获,所以控制GPIO的状态最好还是用SBRR和BRR
对于问题 2 ------- 个人经验判断意法半导体仅仅是为了程序员操作方便估计做么做的。
因为SBRR的 低 16bsts 恰好是set操作,而高16bit是 reset 操作
而BRR 低 16bits 是reset 操作
用stm32 的配置GPIO 来控制LED 显示状态,可用ODR,BSRR,BRR 直接来控制引脚输出状态.
ODR寄存器可读可写:既能控制管脚为高电平,也能控制管脚为低电平。管脚对于位写1 gpio 管脚为高电平,写 0 为低电平
BSRR 只写寄存器:既能控制管脚为高电平,也能控制管脚为低电平。对寄存器高 16bit 写1 对应管脚为低电平,对寄存器低16bit写1对应管脚为高电平。写 0 ,无动作
BRR 只写寄存器:只能改变管脚状态为低电平,对寄存器 管脚对于位写 1 相应管脚会为低电平。写 0 无动作。
=========================================================================
PIOx_CRL/GPIOx_CRH (x:A~F)寄存器用来对GPIO进行端口设置,如:设置GPIO为输入模式或输出模式。每个寄存器含有32位,每4位用来设置1个GPIO引脚功能。GPIOx_CRL/GPIOx_CRH 两个寄存器共含有64位,因此可完成对GPIO0~15的设定。其中GPIOx_CRL用于设置GPIO0~7引脚,GPIOx_CRH用于设置GPIO8~15引脚。
例如设置PB11引脚为开漏输出模式,输出频率为10MHz:
步骤:
- 因PB11属于GPIO8~15之间,所以,需通过GPIOB_CRH寄存器才能实现对PB11的设置。
- 因GPIOB_CRH寄存器中每4位决定一个GPIO工作模式,所以,需通过设置GPIOB_CRH的第12~15位。
- 因PB11引脚“输出模式”,从图中②可以看出须把GPIOB_CRH寄存器的MODE11[1:0]设置为01。
- 根据MODE[1:0]的值为01可知,CNF11[1:0]需要选择“在输出模式(MODE[1:0]>00)”中选择需要设置的值。
- 因PB11须设置为“通用开漏模式”,故CNF11[1:0]需设置为01。
- 最终设置指令为:
GPIOB->CRH&=0XFFFF0FFF; //清除GPIOB->CRH的第12~15位。
GPIOB->CRH|=3<<12; //设置GPIOB->CRH的第12~15位为0101(10MHz开漏输出模式)。
如图是一张stm32的内存映射图,其中代码区是从0x0800 0000开始的,他的结束地址是0x0800 0000加上实际芯片的flash大小,他的ram的起始地址是0x2000 0000,然后结束地址依然是加上芯片实际的ram大小。
数据手册F103x8B上的图为: