当前位置:   article > 正文

stm32学习之单独操作寄存器的某一个位_寄存器怎么取出其中位

寄存器怎么取出其中位

ps:此文章可以接在第一篇文章后面看,这篇文章主要写了一个利用指针位操作去控制某个寄存器的函数,以及对于这个函数的发散思考。

之前在研究指针的时候萌发了这个想法,起因是想写一个可以操作一个地址里面任意一个bit位的函数,于是突然想到,如果能写这么一个函数,那肯定也能用这样的方法直接去操作寄存器的某一位了,那样的速度更快。我们看一下代码。

 形参非常的简单,输入寄存器地址和要改变的位置,就能直接改变某一位的值,我们方便看现象我就拿led灯GPIOB->ODR的地址测试了一下,灯被点亮了。

  1. int main()
  2. {
  3. LED_init();
  4. //0X40010C0C
  5. bit_reset_left(5,(uint32_t*)0X40010C0C);
  6. }
  1. void bit_reset_left(int n,uint32_t* arr)
  2. {
  3. uint32_t left = 0x0<<n;
  4. uint32_t* p = arr;
  5. *p &= left;
  6. }
  7. void bit_set_left(int n,uint32_t* arr)
  8. {
  9. uint32_t left = 0x1<<n;
  10. uint32_t* p = arr;
  11. *p |= left;
  12. }

另外这个函数一开始我是用来操作一个数组里面的某一位的值的,我们来看一下原函数。大家可以猜一下结果是多少。

  1. #include <stdio.h>
  2. unsigned int num[2]={0};
  3. void bit_set(int n,unsigned int* arr)
  4. {
  5. unsigned int mask = (0x1<<((n-1)%32));
  6. unsigned int* p = arr + (n/32);
  7. *p |= mask;
  8. }
  9. int main()
  10. {
  11. bit_set(1,num);
  12. bit_set(33,num);
  13. printf("num[0]=%d\n",num[0]);
  14. printf("num[1]=%d\n",num[1]);
  15. }

 代码的意思是num数组的第一位和第三十二位set 1,就是num[0]的第一位,num[1]的第二位。

因为一个地址的大小是四个字节也就是32个bit,所以我们用n%32和n/32的操作,可以操作把n的范围控制在1-64,然后代表这个数组里面所有的位,很方便,我们还可以更改改变位的方向,可以右移改变。

 我们这样就用数组来更巧妙形象的记录数据了,然后可以写一个读取bit位的函数.....之后还能干嘛就看大家怎么用了。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/565897
推荐阅读
相关标签
  

闽ICP备14008679号