位带的计算,不知道我的理解对吗,希望大家一块交流啊。

2019-07-21 04:50发布

       今天我看来看关于位带的操作啊,自己有了点想法。其它低处理器里面没有位带操作。而STM32里有。而关于位带的计算我看了一会刚开始也是很迷不知道怎么计算。后来自信想想终于明白了。所以就给大家分享一下。        大家不要被它那复杂的计算公式给迷惑了。按步骤的理解理解就可以了。       首先它固定支持位带操作的区:        支持位带操作的两个内存区的范围是:0x2000_0000‐0x200F_FFFF(SRAM区中的最顶1MB)和0x4000_0000‐0x400F_FFFF(片上外设区中的最低1MB)      它的位带思路就是把这2个区里边的每一位,也就是每一比特用一个32位的字给重新表示出来,其实给映射差不都。只不过是一个比特映射一个字。你只要把这一点给记住了。理解计算方法就很是简单了。  别名地址=0x2200000+((A-0x20000000)*8+n)*4= 0x22000000+ (A0x20000000)*32 + n*4 咱就来一步一步的分析它怎么得来的。 A-0x20000000:获得与0x20000000的字节偏移量。 (A-0x20000000)*8:表示该位在的字节前与0x20000000的第一个位之间有多少位。 (A-0x20000000)*8+n:到这里就算出来与0x20000000的第一位总共偏移的位。 ((A-0x20000000)*8+n)*4:以为每一位映射到新的地址空间的时候被作为一个字了。所以他的地址不能单纯的把位的个数当成字节数,而是当成了字数,要想当成字节那就要乘以4,因为每个字里面有4个字节。 0x2200000+((A-0x20000000)*8+n)*4:加上映射过去的首地址,不就是该位映射过去的新的字地址了吗。
我也不知道我理解的对不对希望我们共同交流啊。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
2条回答
正点原子
1楼-- · 2019-07-21 05:46
谢谢分享....
一通无阻
2楼-- · 2019-07-21 08:48
其实我在写这个的时候想了想位带的使用。费这么大的劲到底给我的编程带来那些好处呢?
如果你要是用过51你就知道了。我们在操作51的时候对每个引脚是不是能直接操作。比如P0^1.但是我们在STM32里面的端口如果没有用位带比如我们仍要操作B10的输出ODR。我们要这么做:为1时GPIOB_ODR |=1<<10,为0时GPIOB_ODR &= ~(1<<10);
但是如果我们用了位带我们可以这样做:
#defined led Bout(10)
    led = 1;  //赋值为1
led = 0;  //赋值为0
简单多了吧。这就是原因。


代码跟踪:
PBout(10)<--PBout(n)   BIT_ADDR(GPIOB_ODR_Addr,n):
BIT_ADDR是位带:BIT_ADDR(addr, bitnum)   MEM_ADDR(BITBAND(addr, bitnum))
MEM_ADDR(addr)  *((volatile unsigned long  *)(addr));BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
所以可以看出来BIT_ADDR的作用是把addr字节地址里面的bitnum(表示的一个为0-7)用一个32位的字来重新表示。
④GPIOB_ODR_Addr<---- GPIOB_ODR_Addr    (GPIOB_BASE+12) //0x40010C0C
表示的是B口的ODR寄存器的地址。
所以上面那个PBout(10)就代表把B口的ODR寄存器的第10位给位带操作了。

一周热门 更多>