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位的函数.....之后还能干嘛就看大家怎么用了。