STM32开发中的位运算以及位带操作

电子说

1.3w人已加入

描述

STM32开发中的位运算以及位带操作 

位运算是计算机中常用的一种操作方式,特别适用于对数据的单个或多个位进行操作。在STM32开发中,位运算常被用于对寄存器的位进行设置或清除,以及对数据的位进行操作。同时,STM32还提供了位带操作,使得对单个位进行操作更加方便。本文将详细介绍STM32开发中的位运算和位带操作。

1. 位运算

位运算是一种通过位的逻辑操作对二进制数据进行操作的方法,它包括与(&)、或(|)、异或(^)、取反(~)等操作。在STM32开发中,位运算常被用于对寄存器的位进行设置或清除,以控制硬件设备的工作状态。

以GPIO寄存器为例,每个GPIO口都有一个对应的寄存器,用于控制该GPIO口的输入、输出状态。设置或清除寄存器中某一位的方法如下:

- 设置寄存器中某一位为1:先将寄存器中对应的位设置为0,然后再将该位设置为1。
- 清除寄存器中某一位为0:先将寄存器中对应的位设置为1,然后再将该位设置为0。

以设置GPIOA的第5位为1为例,代码如下:

```c
GPIOA->CRL &= ~(0b11 << 20); // 先将第5位设置为0
GPIOA->CRL |= (0b01 << 20); // 再将第5位设置为1
```

在上述代码中,`GPIOA->CRL`表示GPIOA寄存器的低8位,通过与运算 `&` 和或运算 `|` 将对应的位设置为0或1。

2. 位带操作

位带操作是指将某一位映射到一个特定的内存地址上,以方便对该位进行直接的读写操作。STM32提供了位带操作的相关特性。

在STM32中,每个位的地址都可以通过位带区域的地址计算得到。位带操作通过STM32提供的特殊地址将位操作转换为对特定地址的读写操作,从而实现对单个位的直接读写。这种方式可以大大简化对单个位的操作,提高代码可读性和代码执行效率。

以位带操作设置GPIOA的第5位为1为例,代码如下:

```c
#define BITBAND_SRAM(address, bit) ((uint32_t*)((BITBAND_SRAM_BASE + ((address) - SRAM_BASE) * 32 + (bit) * 4)))
#define BITBAND_PERIPH(address, bit) ((uint32_t*)((BITBAND_PERIPH_BASE + ((address) - PERIPH_BASE) * 32 + (bit) * 4)))

volatile uint32_t* GPIOA_PIN5 = BITBAND_PERIPH(&GPIOA->ODR, 5);

// 设置GPIOA的第5位为1
*GPIOA_PIN5 = 1;
```

在上述代码中,`BITBAND_PERIPH` 定义了位带操作的宏,通过计算得到对应位的地址。`GPIOA_PIN5` 即为第5位的地址,通过给该地址赋值为1,即可将第5位设置为1。

3. 位运算与位带操作的比较

位运算和位带操作都可以用于对单个位进行操作,但是在一些情况下,位带操作比位运算更加高效:

- 可读性:位带操作使得代码更加直观和易读,能够清晰地看出对哪个位进行操作。
- 代码量:位带操作可以通过宏定义简化代码,减少了位运算的操作和代码量。
- 高效性:位带操作直接对位进行操作,避免了对整个寄存器的读取和写入,提高了代码执行效率。

然而,位带操作也存在一些限制:

- 只能对每个字节(byte)的某个位进行操作。
- 位带区域的内存资源有限,一般情况下只能直接对GPIO寄存器的每个位进行位带操作,对其他寄存器的位进行位带操作可能无效。

因此,在实际开发中,根据需要选择合适的方法进行位操作。

结论:

本文详细介绍了STM32开发中的位运算和位带操作。位运算通过与运算和或运算对寄存器的位进行设置和清除,用于控制硬件设备的工作状态。位带操作通过将位映射到特定的地址上,实现对单个位的直接读写操作,提高了代码的可读性和执行效率。在选择位操作方法时,需要考虑可读性、代码量和效率等因素。
 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分