STM32之Bit-Banding

用了不少芯片,就只有51有位操作,这个特性很喜欢,赋值简单、效率又高且节省内存,不必为了一个bool去分配一个uint8.

发现stm32有Bit-Banding,就试了一下,用MDK-ARM环境下的汇编代码做了一些比较。

操作,清零USART1的SR寄存器的TC位:

方法一:

//利用USART_TypeDef这个结构寻到SR的地址,再赋值
USART1->SR &= ~(1<<6);

其汇编代码(-level 0)如下:

用了7条指令。

方法二:

直接用SR的地址操作:

*(__IO uint32_t *) 0x40013800 &= ~(1<<6);

汇编如下:

可以看到代码跟方法一是一样的,所以以后没有必要用这个方法了,一点效率提升都没有,代码还难读。

方法三:

位域

//下面两个宏的汇编代码是一样的
#define  USART1_TC_ResetBit_BB()    \
          (*(__IO uint32_t *) (PERIPH_BB_BASE | ((USART1_BASE + 0x00 - PERIPH_BASE) << 5) | ((6) << 2)) = 0)
#define  USART1_TC_ResetBit_BB2() (*(__IO uint32_t *) 0x42270018 = 0)

这个位域的代码只需要3个指令,而且可定义看到,这个位域不像51那样是位寻址,有专业的位操作指令。上面这3条还是通用的指令,也是在4G空间线性寻址。

执行完之后的效果,可以看到TC被清除了:

 

综上所述,Bit-Banding确实可以提高代码效率,但是说到写程序的方便程度,如果用C语言的话,还是一样的,因为那些代码都可以用宏定义或者函数来封装。

转载于:https://www.cnblogs.com/TrueElement/archive/2012/09/16/2687212.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值