cortex-A7核UART总线实验

uart.h:

cpp 复制代码
#ifndef __UART4_H__
#define __UART4_H__

#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_uart.h"

//RCC/GPIO/UART4章节初始化
void hal_uart4_init();

//发送一个字符函数
void hal_put_char(const char str);

//发送一个字符串函数
void hal_put_string(const char* string);

//接收一个字符函数
char hal_get_char();

//接收一个字符串函数
char* hal_get_string();

#endif

uart.c:

cpp 复制代码
#include "uart4.h"
extern void delay_ms(int ms);

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

	//GPIO章节初始化
	//1.设置PB2引脚为复用功能 MODER[5:4] = 10
	GPIOB->MODER &= (~(0x3 << 4));
	GPIOB->MODER |= (0x1 << 5);
	//2.设置PB2引脚复用功能为UART4_RX AFRL[11:8] = 1000
	GPIOB->AFRL &= (~(0xf << 8));
	GPIOB->AFRL |= (0x1 << 11);

	//1.设置PG11引脚为复用功能 MODER[23:22] = 10	
	GPIOG->MODER &= (~(0x3 << 22));
	GPIOG->MODER |= (0x1 << 23);
	//2.设置PG11引脚复用功能为UART4_TX AFRH[15:12] = 0110
	GPIOG->AFRH &= (~(0xf << 12));
	GPIOG->AFRH |= (0x3 << 13);

	//UART4章节初始化
	//8N1 115200 使能 
	//0.设置UE=0 判断 
	if(USART4->CR1 & (0x1 << 0))
	{
		delay_ms(500);
		//禁止UE位
		USART4->CR1 &= (~(0x1 << 0));
	}
	
	//1.设置UART4串口1位起始位,8位数据位 CR1[28][12] = 00
	USART4->CR1 &= (~(0x1 << 12));
	USART4->CR1 &= (~(0x1 << 28));
	//2.设置UART4串口没有校验位 CR1[10] = 0
	USART4->CR1 &= (~(0x1 << 10));
	//3.设置UART4串口1位停止位 CR2[13:12] = 00
	USART4->CR2 &= (~(0x3 << 12));
	//4.设置UART4串口16倍采样率 CR1[15] = 0
	USART4->CR1 &= (~(0x1 << 15));
	//5.设置UART4串口不分频 PRESC[3:0] = 0000
	USART4->PRESC &= (~(0xf << 0));
	//6.设置UART4串口波特率为115200 BRR = 0x22B
	USART4->BRR |= 0x22B;
	//7.设置UART4串口发送器使能 CR1[3] = 1
	USART4->CR1 |= (0x1 << 3);
	//8.设置UART4串口接收器使能 CR1[2] = 1
	USART4->CR1 |= (0x1 << 2);
	//9.设置UART4串口使能 CR1[0] = 1
	USART4->CR1 |= (0x1 << 0);
}

//发送一个字符函数
void hal_put_char(const char str)
{
	//1.判断发送数据寄存器是否为空 ISR[7]
	//读0:发送数据寄存器满,需要等待
	//读1:发送数据寄存器为空,可以发送数据
	while(!(USART4->ISR & (0x1 << 7)));
	//2.将要发送的数据,赋值给发送数据寄存器中
	USART4->TDR = str;
	//4.判断一帧数据是否发送完成 ISR[6]
	//读0:一帧数据没有发送完成,需要等待
	//读1:一帧数据发送完成
	while(!(USART4->ISR & (0x1 << 6)));	
}

//发送一个字符串函数
void hal_put_string(const char* string)
{
	//判断是否为'\0'
	//一个一个字符进行发送就可以
	while(*string)
	{
		hal_put_char(*string++);
	}
	hal_put_char('\n');
	hal_put_char('\r');
}

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

char buffer[50] = {0};
//接收一个字符串函数
char* hal_get_string()
{
	//循环
	//enter = '\r'
	unsigned int i;
	for(i=0;i<49;i++)
	{
		//接收一个字符
		buffer[i] = hal_get_char();
		//发送一个字符 回显串口工具
		hal_put_char(buffer[i]);
		//判断键盘enter是否按下 enter = '\r'
		if(buffer[i] == '\r')
			break;
	}
	buffer[i] = '\0';
	hal_put_char('\n');
	return buffer;
}

main.c:

cpp 复制代码
#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();
	hal_put_string("this is DC23051\n");
	while(1)
	{
	//	hal_put_char(hal_get_char()+1);
		hal_put_string(hal_get_string());
	}
	return 0;
}
相关推荐
-Springer-3 小时前
STM32 学习 —— 个人学习笔记11-1(SPI 通信协议及 W25Q64 简介 & 软件 SPI 读写 W25Q64)
笔记·stm32·学习
yrx0203074 小时前
串口空闲中断+DMA接收+环形缓冲区 && 串口DMA发送+环形缓冲区
stm32·单片机
LCG元5 小时前
STM32实战:基于STM32F103的4G模块(EC20)HTTP通信
stm32·嵌入式硬件·http
送外卖的CV工程师6 小时前
STM32+Makefile编译+OpenOCD 烧录调试
stm32·单片机·嵌入式硬件·makefile·调试·烧录·openocd
豆包公子6 小时前
程序流监控:AUTOSAR CP 功能安全在裸机 MCU 上的实现(理论篇)
运维·单片机·嵌入式硬件·安全·车载系统·autosar
编程之升级打怪6 小时前
单片机SPI硬件接口的要点
嵌入式硬件
Aaron_dw8 小时前
PHY Eye Monitor 全栈技术说明书
嵌入式硬件
NQBJT10 小时前
嵌入式从零开始(第十二篇):调试与工具链 —— 从 IDE 到逻辑分析仪
ide·stm32·单片机·嵌入式硬件·c#
广州灵眸科技有限公司11 小时前
瑞芯微(EASY EAI)RV1126B 网络摄像头方案
开发语言·网络·科技·嵌入式硬件·物联网
豆包公子11 小时前
程序流监控 —— AUTOSAR CP 功能安全在裸机 MCU 上的实现:实践篇
单片机·嵌入式硬件·学习