C语言 cortex-A7核UART总线实验

news2025/1/15 6:25:49

一、C

1)uart4.h

#ifndef __UART4_H__                       
#define __UART4_H__                       
                                          
#include "stm32mp1xx_rcc.h"               
#include "stm32mp1xx_gpio.h"              
#include "stm32mp1xx_uart.h"              
                                          
//PB2 ---> UART4_RX                       
//PG11 ---> UART4_TX                      
                                          
//RCC/GPIO/UART4章节初始化                
void hal_uart4_init();                    
//发送一个字符                            
void hal_put_char(const char ch);         
//发送一个字符串                          
void hal_put_string(const char* string);  
//接收一个字符                            
char hal_get_char();                      
//接收一个字符串                          
char* hal_get_string();                   
                                                                           
#endif

2)uart.c

#include "uart4.h"

//RCC/GPIO/UART4章节初始化
void hal_uart4_init()
{
	//RCC章节初始化
	//1.使能GPIOB组控制器  MP_AHB4ENSETR[1] = 1  0x50000A28[1]
	RCC->MP_AHB4ENSETR |= (0X1 << 1);
	//2.使能GPIOG组控制器  MP_AHB4ENSETR[6] = 1  0x50000a28[6]
	RCC->MP_AHB4ENSETR |= (0X1 << 6);
	//3.使能UART4组控制器  MP_AHB4ENSETR[11] = 1 PB2 PG11---> 0x500000A00[16] 
	RCC->MP_APB1ENSETR |= (0X1 << 16);

	//GPIO章节初始化
	//1.设置PB2引脚为复用功能模式 MODER[5:4] = 10
	GPIOB->MODER &= (~(0x1 << 4));
	GPIOB->MODER |= (0x1 << 5);
	//2.设置PB2引脚复用功能为UART4_RX功能 AFRL[11:8] = 1000
	GPIOB->AFRL &= (~(0xf << 8));
	GPIOB->AFRL |= (0x1 << 11);
	//设置PG11引脚为复用功能模式 MODER[23:22] = 10
	GPIOG->MODER &= (~(0x1 << 22));
	GPIOG->MODER |= (0x1 << 23);
	//设置PG11引脚复用功能为UART4_TX功能 AFRH[15:12] = 0110
	GPIOG->AFRH &= (~(0xf << 12));
	GPIOG->AFRH |= (0x6 << 12);

	//UART4章节初始化
	//8N1 115200 使能位 代码编写逻辑
	//0.设置串口UE=0 CR1[0] = 0
	USART4->CR1 &= (~(0x1 << 0));
	//1.设置1位起始位,8位数据位 CR1[28][12] = 00
	USART4->CR1 &= (~(0x1 << 12));
	USART4->CR1 &= (~(0x1 << 28));
	//2.设置串口1位停止位 CR2[13:12] = 00
	USART4->CR2 &= (~(0x3 << 12))	;
	//3.设置串口无校验位 CR1[10] = 0
	USART4->CR1 &= (~(0x1 << 10));
	//4.设置串口16倍采样率 CR1[15] = 0
	USART4->CR1 &= (~(0x1 << 15));
	//5.设置串口不分频 PRESC[3:0] = 0000
	USART4->PRESC &= (~(0xf << 0));
	//6.设置串口波特率为115200 BRR = 0X22b
	USART4->BRR &= (~(0xffff));
	USART4->BRR |= (0x22b);
	//7.设置串口发送位使能 CR1[3] = 1
	USART4->CR1 |= (0x1 << 3);
	//8.设置串口接受位使能 CR1[2] = 1
	USART4->CR1 |= (0x1 << 2);
	//9.设置串口使能 CR1[0] = 1
	USART4->CR1 |= (0x1 << 0);
}
//发送一个字符
void hal_put_char(const char ch)
{
	//1.判断发送数据寄存器是否为空 ISR[7]
	//读0:发送数据寄存器满,需要等待 for while
	//读1:发送数据寄存器空,可以发送数据
	while(!(USART4->ISR & (0X1 << 7)));
	//2.将参数ch传递过来的内容,赋值给TDR寄存器
	USART4->TDR = (volatile unsigned int)ch;	
	//3.判断一帧数据是否发送完成 ISR[6]
	while(!(USART4->ISR & (0x1 << 6)));
}

//发送一个字符串
void hal_put_string(const char* string)
{
	//判断字符串是否为'\0'
	int i=0;
	while(string[i] != '\0')
	{
		//一个字符一个字符进行发送
		hal_put_char(string[i]);
		i++;
	}
}

//接收一个字符
char hal_get_char()
{
	char ch;
	//1.判断接收数据寄存器是否不为空 ISR[5]
	//读0:没有接收到数据,需要等待 for while
	//读1:接收到数据,可以将数据读出
	while(!(USART4->ISR & (0x1 << 5)));
	//2.将接收数据寄存器中RDR,读出来
	ch = (char)USART4->RDR;
	return ch;
}


char buffer[50] = {0};
//接收一个字符串
char* hal_get_string()
{
	for(int i=0;buffer[i]!='\0'; i++)
	{
		buffer[i]='\0';
	}
	//判断键盘enter是否按下'\r'
	int i = 0;
	char ch;
	while(1)
	{
		ch = hal_get_char();
		hal_put_char(ch);
		buffer[i] = ch;
		i++;
		if(ch == '\r')
		{
			hal_put_char('\n');	
			break;			
		}
	}
	buffer[i] = '\n';
	return buffer;
}

3)main.c

#include "uart4.h"                                                    
extern void printf(const char *fmt, ...);                             
void delay_ms(int ms)                                                 
{                                                                     
    int i,j;                                                          
    for(i = 0; i < ms;i++)                                            
        for (j = 0; j < 1800; j++);                                   
}                                                                     
                                                                      
int main()                                                            
{                                                                     
    hal_uart4_init();                                                 
    while(1)                                                          
    {                                                                 
        //单个字符                                                    
        //hal_put_char(hal_get_char() + 1);                           
        //字符串                                                      
        hal_put_string(hal_get_string());                             
    }                                                                 
    return 0;                                                         
}                                                                    

4)效果

实验一:收发字符

实验二:收发字符串

二、函数实现

1)uart4.h

2)uart.c

3)main.c

4)效果

实验一:收发字符

实验二:收发字符串

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1029878.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

maven清理本地仓库。删除_remote.repositories文件和删除失败的jar包

1.图预览 .bat文件要和仓库在同一平级目录 REPOSITORY_PATH要改成你自己仓库的地址 2、删除.lastUpdated文件(失败的jar包) 使用.bat文件 注明&#xff1a;REPOSITORY_PATHD:\software\Java\maven\repository 改成你仓库的地址 set REPOSITORY_PATHD:\software\Java\maven\rep…

nvm下载安装教程

前言 nvm 官网地址&#xff1a;https://nvm.uihtm.com 一、nvm 下载 进入 nvm github 地址&#xff0c;下载最新版本&#xff1a;https://github.com/coreybutler/nvm-windows/releases 点击选择当前最新版本。 滑动到底部&#xff0c;点击 nvm-setup.exe 下载安装文件。 接…

【C++ 番外】【指针】数组类型的指针,指向数组的指针,数组的元素是指针,这个视频说明白。数组和指针

from&#xff1a; https://www.bilibili.com/video/BV1H34y1K7AM/ 指向数组第一个元素的指针 数组类型指针 数组的类型都是指针 超级混合版本&#xff0c;加深理解

Spring-AOP+入门案例(注解)+AOP切入点语法+AOP通知类型

一、简介工作流程。 简介 SpringAop实际上就是代理模式 工作流程 二、导入依赖 1.spring-aop包 该包是在spring-context依赖下的子包&#xff0c;所以有context就有aop <dependency><groupId>org.springframework</groupId><artifactId>spring-con…

​消费盲返:消费者和商家都受益的消费返利

消费盲返是什么&#xff1f;它是一种新型的消费返利模式&#xff0c;它的核心思想是&#xff1a;消费者在平台购买商品后&#xff0c;可以获得后续一定数量的订单的部分利润作为奖励。这样&#xff0c;消费者不仅可以享受商品的优惠&#xff0c;还有可能赚取更多的钱。这种模式…

第七章 查找 六、平衡二叉树

目录 一、定义 二、最小不平衡子树 1、平衡方法 2、查找效率 三、插入、删除操作 平衡二叉树的插入操作&#xff1a; 平衡二叉树的删除操作&#xff1a; 1、例子1 &#xff08;1&#xff09;若我们要删除9 &#xff08;2&#xff09;若我们要删除55 2、例子2 ​编辑…

高云FPGA系列教程(10):letter-shell移植

文章目录 letter-shell简介letter-shell源码获取letter-shell移植函数和变量应用示例 本文是高云FPGA系列教程的第10篇文章。 shell&#xff0c;中文是外壳的意思&#xff0c;就是操作系统的外壳。通过shell命令可以操作和控制操作系统&#xff0c;比如Linux中的Shell命令就包括…

2023-09-21 LeetCode每日一题(收集树中金币)

2023-09-21每日一题 一、题目编号 2603. 收集树中金币二、题目链接 点击跳转到题目位置 三、题目描述 给你一个 n 个节点的无向无根树&#xff0c;节点编号从 0 到 n - 1 。给你整数 n 和一个长度为 n - 1 的二维整数数组 edges &#xff0c;其中 edges[i] [ai, bi] 表示…

Redis学习笔记--001

Redis快速入门 文章目录 Redis快速入门一、初识Redis1.1、NoSQL数据库1.2、Redis介绍1.3、[Redis](https://redis.io/)的安装 二、Redis常见命令2.1、Redis默认启动2.2、指定配置启动2.3、Redis开机自启设置 三、Redis客户端3.1、Redis命令行客户端3.2、图形化桌面客户端 四、r…

Python Opencv实践 - 人脸识别CascadeClassifier

参考资料&#xff1a; 【PythonOpenCV 人脸检测—CascadeClassifier 级联分类器实现】_LPY。的博客-CSDN博客 ‘cv::CascadeClassifier::detectMultiScale‘_只要思想不滑坡办法总比困难多--小鱼干的博客-CSDN博客 import cv2 as cv import matplotlib.pyplot as plt import nu…

陆拾捌- 如何通过数据影响决策(三)

一、如何正确的引导别人&#xff1f; 引导与误导的区别是什么&#xff1f; 看下面这广告图 单看上面大字的结果&#xff0c;感觉好像真的使用过的人均觉得有好处 可如果我们看下面的细字 对111位连续14天食用&#xff08;本产品&#xff09;的燕麦片非重度使用者所做调研… 从…

Linux 系统移植(二)--系统调试

文章目录 一、 编译文件系统1.1 下载资源安装包1.2 配置模板ARM64目标平台1.3 配置交叉编译器1.4 配置登录用户名和密码1.5 配置Linux 控制台1.6 配置文件系统格式1.7 编译buildroot文件系统 二、编译ARM64 Linux三、启动 Qemu Linux系统参考链接&#xff1a; 一、 编译文件系统…

React(react18)中组件通信05——react-redux

React&#xff08;react18&#xff09;中组件通信05——react-redux 1. 前言1.1 React中组件通信的其他方式1.2 介绍React-Redux1.2.1 简单介绍React-Redux1.2.2 官网 1.3 安装react-redux 2. 简单改写redux的例子2.1 提供store2.2 连接 Components UI组件修改2.2.1 连接 Comp…

Dubbo 3.x源码(11)—Dubbo服务的发布与引用的入口

基于Dubbo 3.1&#xff0c;详细介绍了Dubbo服务的发布与引用的入口的源码。 此前我们学习了Dubbo配置的加载与覆盖的一系列源码&#xff1a; Dubbo 3.x源码(7)—Dubbo配置的加载入口源码Dubbo 3.x源码(8)—Dubbo配置中心的加载与优先级源码Dubbo 3.x源码(9)—Dubbo启动元数据中…

通过 Helm Chart 部署 Easysearch

Easysearch 可以通过 Helm 快速部署了&#xff0c;快来看看吧&#xff01; Easysearch 的 Chart 仓库地址在这里 https://helm.infinilabs.com。 使用 Helm 部署 Easysearch 有两个前提条件&#xff1a; cert-managerlocal-path 我们先按照 Chart 仓库的说明来快速部署一下…

OpenCV之九宫格图像

将一张图像均等分成九份&#xff0c;然后将这九个小块按一定间隔&#xff08;九宫格效果&#xff09;拷贝到新画布上。效果如下图所示&#xff1a; 源码&#xff1a; #include<iostream> #include<opencv2/opencv.hpp> using namespace std; using namespace cv;i…

基于矩阵分解算法的智能Steam游戏AI推荐系统——深度学习算法应用(含python、ipynb工程源码)+数据集(二)

目录 前言总体设计系统整体结构图系统流程图 运行环境模块实现1. 数据预处理2. 模型构建1&#xff09;定义模型结构2&#xff09;优化损失函数 3. 模型训练及保存1&#xff09;模型训练2&#xff09;模型保存 相关其它博客工程源代码下载其它资料下载 前言 本项目采用了矩阵分…

优维低代码实践:图片和搜索

优维低代码技术专栏&#xff0c;是一个全新的、技术为主的专栏&#xff0c;由优维技术委员会成员执笔&#xff0c;基于优维7年低代码技术研发及运维成果&#xff0c;主要介绍低代码相关的技术原理及架构逻辑&#xff0c;目的是给广大运维人提供一个技术交流与学习的平台。 优维…

Unity中Shader模板测试使用到的二进制

文章目录 前言&#xff08;接上一篇文章&#xff09;一、模板测试公式1、简化版(在ReadMask默认值的情况下)2、完整版 二、二进制的值1、0 和 1组成2、符号3、二进制的与运算4、二进制和十进制转化 三、在Shader中的实际操作 前言&#xff08;接上一篇文章&#xff09; Unity中…

JimuReport积木报表 v1.6.2 版本正式发布—开源免费的低代码报表

项目介绍 一款免费的数据可视化报表&#xff0c;含报表和大屏设计&#xff0c;像搭建积木一样在线设计报表&#xff01;功能涵盖&#xff0c;数据报表、打印设计、图表报表、大屏设计等&#xff01; Web 版报表设计器&#xff0c;类似于excel操作风格&#xff0c;通过拖拽完成报…