点灯案例练习(基于寄存器)

2024-08-20 15:44
文章标签 练习 案例 寄存器 点灯

本文主要是介绍点灯案例练习(基于寄存器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、需求描述

二、工程创建

二、硬件电路设计

三、软件设计

1、main.c

1、开启时钟

 2、配置GPIOA的工作模式

3、设置PA1、PA8端口低电平

4、给死循环保持状态

2、最终代码如下

 四、实验现象

前面,我们耗费大量时间,终于点亮了STM32板子上的第一个LED-1的黄灯,实验现象如下

那么,根据前面的思路,我们按理说也可以点亮其他两个LED灯(这里有三个LED灯,分别叫LED-1 LED-2 LED-3,对应黄蓝绿),接下来我们就开始练习点亮另外两盏灯。

一、需求描述

基于寄存器开发,在第一个点灯案例基础上继续点亮LED-2、LED-3两个灯 

二、工程创建

基于前面的点灯案例进行扩展练习,故直接在原来的工程上进行修改,不需重新创建

二、硬件电路设计

 

由原理图可知:
LED-2连接PA1端口, LED-3连接PA8端口 

同样是给端口低电平即可点亮

三、软件设计

1、main.c

1、开启时钟

和前面同理,我们要先开启时钟,此处和前面使用的寄存器相同,都是RCC_APB2ENR,且使用的都是GPIOA的端口,所以开启时钟方式相同,即寄存器地址值为0x40021000+0x18,给的数据二进制第二位是1,其他都是0。

// 开启时钟
*(uint32_t *)(0x40021000+0x18) = 4;

 2、配置GPIOA的工作模式

GPIOA时钟开启后,就要设置GPIOA的工作模式。和前面一样,要使端口输出高低电平,就要让连接LED灯的端口PA1和PA8处于输出模式。

同样,找到GPIOA的寄存器的地址值 0x40010800+0x00。有下图手册可知,给寄存器的数据是二进制第6、7位给00,4、5位给11即可让链接LED-2灯的端口PA1处于最大速度的推挽输出模式。给的数据就是00110000,即0x30

// 设置GPIOA的工作模式
*(uint32_t *)(0x40010800+0x00) = 0x30;  // PA1

同时,我们还要设置连接LED-3的端口PA8的工作模式,但是我们发现,这个端口配置低寄存器只有PA0-PA7端口的配置。所以我们要找相应的端口配置高寄存器去进行同理操作。

由上图可知,配置PA8端口的寄存器是GPIOx_CRH,偏移地址值是0x04,所以对应的寄存器地址值为 0x40010800+0x04,要使PA8端口处于最大速度推挽输出模式,则要给的数据就是0011,也就是3(或16进制表示 0x03)

// 设置GPIOA的工作模式
*(uint32_t *)(0x40010800+0x04) = 0x03;  // PA8

3、设置PA1、PA8端口低电平

 工作模式变为输出模式后,接下来就是找到控制端口高低电平的端口输出寄存器,查阅技术手册

由图可知,输出寄存器和前面一样,地址值为 0x40010800 + 0x0C。只要给PA1和PA8端口低电平(0)即可点亮,所以给寄存器的数据二进制位的第1位和第8位都是0,其余为1即可,也就是1111111011111101,即0xfefd

// 设置PA1、PA8为低电平
*(uint32_t *)(0x40010800+0x0C) = 0xfefd;  

4、给死循环保持状态

 最后,只需加一个死循环,保持灯点亮的状态就好啦

while(1){}

2、最终代码如下

#include<stdint.h>
// 查手册 找基地址和偏移地址等
int main(void)
{
    // 1. RCC寄存器 GPIO A时钟配置  节能 告诉节拍节奏,模块较多,运行频率不同,所以单独配置
    *(uint32_t *)(0x40021000 + 0x18) = 4;
    
    // 2. GPIO工作模式的配置  输出模式 端口配置寄存器 00110000
    *(uint32_t *)(0x40010800 + 0x00) = 0x30;  //PA1
    *(uint32_t *)(0x40010800 + 0x04) = 0x03;  //PA8 0011
    
    // 3. 通用数据输出寄存器 PA1、PA8 输出低电平
    *(uint32_t *)(0x40010800 + 0x0c) = 0xfefd;   
    
    // 4. 死循环保持状态
    while(1){}
}
 

 四、实验现象

如果前面关于Keil和st_Link的相关配置都配置完毕的话,那么现在只需点击编译、运行、然后下载程序即可观察到LED-2、LED-3(蓝灯、绿灯)被点亮的现象啦

 现象如下,除了电源指示灯,蓝灯绿灯都亮啦

 

至此,关于点灯案例的小练习就完成啦,其实还可以试着将三个灯都点亮,或者点亮一个灯撒活动都可以试试哦,实际上原理都是差不多的,也就这些步骤,查查技术手册就OK啦

加油加油 

这篇关于点灯案例练习(基于寄存器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1090487

相关文章

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

MySQL不使用子查询的原因及优化案例

《MySQL不使用子查询的原因及优化案例》对于mysql,不推荐使用子查询,效率太差,执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响,本文给大家... 目录不推荐使用子查询和JOIN的原因解决方案优化案例案例1:查询所有有库存的商品信息案例2:使用EX

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD