赞
踩
ps:此文章可以接在第一篇文章后面看,这篇文章主要写了一个利用指针位操作去控制某个寄存器的函数,以及对于这个函数的发散思考。
之前在研究指针的时候萌发了这个想法,起因是想写一个可以操作一个地址里面任意一个bit位的函数,于是突然想到,如果能写这么一个函数,那肯定也能用这样的方法直接去操作寄存器的某一位了,那样的速度更快。我们看一下代码。
形参非常的简单,输入寄存器地址和要改变的位置,就能直接改变某一位的值,我们方便看现象我就拿led灯GPIOB->ODR的地址测试了一下,灯被点亮了。
- int main()
- {
- LED_init();
-
- //0X40010C0C
-
- bit_reset_left(5,(uint32_t*)0X40010C0C);
-
- }
- void bit_reset_left(int n,uint32_t* arr)
- {
- uint32_t left = 0x0<<n;
- uint32_t* p = arr;
- *p &= left;
- }
-
- void bit_set_left(int n,uint32_t* arr)
- {
- uint32_t left = 0x1<<n;
- uint32_t* p = arr;
- *p |= left;
- }
另外这个函数一开始我是用来操作一个数组里面的某一位的值的,我们来看一下原函数。大家可以猜一下结果是多少。
- #include <stdio.h>
-
- unsigned int num[2]={0};
-
- void bit_set(int n,unsigned int* arr)
- {
- unsigned int mask = (0x1<<((n-1)%32));
- unsigned int* p = arr + (n/32);
- *p |= mask;
- }
-
- int main()
- {
- bit_set(1,num);
- bit_set(33,num);
- printf("num[0]=%d\n",num[0]);
- printf("num[1]=%d\n",num[1]);
- }
代码的意思是num数组的第一位和第三十二位set 1,就是num[0]的第一位,num[1]的第二位。
因为一个地址的大小是四个字节也就是32个bit,所以我们用n%32和n/32的操作,可以操作把n的范围控制在1-64,然后代表这个数组里面所有的位,很方便,我们还可以更改改变位的方向,可以右移改变。
我们这样就用数组来更巧妙形象的记录数据了,然后可以写一个读取bit位的函数.....之后还能干嘛就看大家怎么用了。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。