stm32f103c8t6寄存器点灯法

今天我们来讲一下不用别人写好的库函数来点灯,我们需要用到的参考资料有stm32f103参考手册

我先展示代码吧

c 复制代码
void delay(int d)
{
	while(d--);
}
int main()
{
	unsigned int *pReg;
	pReg=(unsigned int *)(0x40021000+0x18);
	*pReg|=0x04;
	
	pReg=(unsigned int *)(0x40010800+0x00);
	*pReg|=0x02;
	
	pReg=(unsigned int *)(0x40010800+0x0C);
	while(1)
	{
		*pReg |=0x01;
		delay(100000);
		*pReg&= ~(0x01);
		delay(100000);
		
	}
}

想要进行点灯,我们需要使能我们相关GPIO口的总线,然后配置端口的模式(输入还是输出),最后修改端口寄存器的值来实现高低电平的变化

1.先设置我们的指针变量方便我们访问寄存器

unsigned int *pReg;

2.使能相关总线

我们需要查看数据手册

我们看到RCC地址空间的起始地址为0x40021000

并且GPIOA是挂载在APB2总线上的,于是我们就需要找到APB2在RCC中的偏移量才能找到控制APB2的寄存器

我们可以看到APB2外设时钟使能寄存器便宜地址为0x18,所以我们让我们的指针指向(0x40021000+0x18),并且GPIOA的使能是第二位控制的,于是进行*pReg|=0x04的操作(我们这里使用的是16进制,所以是与上0x04),那么现在我们的GPIOA的时钟就打开好了

3.配置端口的模式

由于GPIOA端口的基地址是0x40010800,我们要找到相关寄存器的偏移地址才能进行赋值控制

可以看到偏低地址为0x00,所以我们让 pReg=(unsigned int *)(0x40010800+0x00);,然后由于我们使用的是GPIOA0这个端口,于是我们让 *pReg|=0x01 表示输出模式并且最大速度为10MHz

4.修改端口0寄存器的数值来控制高低电平的变化

这里的偏移地址为0C,于是我们让 pReg=(unsigned int *)(0x40010800+0x0C);然后进行while循环来使得灯不停的亮灭亮灭

c 复制代码
while(1)
{
	*pReg |=0x01;
	delay(100000);
	*pReg&= ~(0x01);
	delay(100000);
	
}

这里的操作逻辑不过多解释,就是让第0位为1后延迟一段时间然后让第0位为0,实现灯的闪烁

相关推荐
VekiSon7 小时前
Linux内核驱动——杂项设备驱动与内核模块编译
linux·c语言·arm开发·嵌入式硬件
来自晴朗的明天8 小时前
14、光耦隔离电路(EL3H7)
单片机·嵌入式硬件·硬件工程
G***技8 小时前
杰和IB3-272:以低功耗高性能打造新一代工业智能交互核心
单片机·嵌入式硬件·物联网
czhaii9 小时前
STC AI8052U单片机特点
单片机
MAR-Sky9 小时前
keil5中数据的不同定义和单片机(以stc8为例)里的对应关系(idata,xdata,data,code)
单片机·嵌入式硬件
项目題供诗11 小时前
51单片机入门(八)
单片机·嵌入式硬件·51单片机
羽获飞11 小时前
从零开始学嵌入式之STM32——9.STM32的时钟系统
stm32·单片机·嵌入式硬件
飞睿科技12 小时前
乐鑫智能开关方案解析:基于ESP32-C系列的低功耗、高集成设计
嵌入式硬件·物联网·esp32·智能家居·乐鑫科技
来自晴朗的明天13 小时前
13、NMOS 电源防反接电路
单片机·嵌入式硬件·硬件工程
17(无规则自律)14 小时前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件