通过串口收发一个字符、字符串

2023-05-16

1.通过串口收发一个字符

2.通过串口收发一个字符串

uart4.h文件

#ifndef __UART4_H__
#define __UART4_H__
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_uart.h"

//1.初始化函数
void uart4_init();
//2.发送一个字符
void put_char(const char str);
//3.接收一个字符
char get_char();
//4.发送一个字符串
void put_string(const char* str);
//5.接收一个字符串
char* get_string();

#endif

uart4.c文件

#include "uart4.h"
extern void delay_ms(int ms);
//1.初始化函数
void uart4_init()
{
	/***************RCC章节****************/
	//1.GPIOB控制器使能 
	RCC->MP_AHB4ENSETR |= (0x1<<1);	
	//2.GPIOG控制器使能
	RCC->MP_AHB4ENSETR |= (0x1<<6);	
	//3.UART4控制器使能
	RCC->MP_APB1ENSETR |= (0x1<<16);

	/***********GPIO章节******************/
	//1.GPIOB引脚2设置成复用功能[5:4]=10,AF=[11-8]=1000  RX
	GPIOB->MODER &= (~(0x3<<4));
	GPIOB->MODER |= (0x2<<4);
	GPIOB->AFRL &= (~(0xf<<8));
	GPIOB->AFRL |= (0x8<<8);
	//2.GPIOG引脚11设置成复用功能[23:22]=10,AF=[15-12]=0110  TX
	GPIOG->MODER &= (~(0x3<<22));
	GPIOG->MODER |= (0x2<<22);
	GPIOG->AFRH &= (~(0xf<<12));
	GPIOG->AFRH |= (0x6<<12);
	
	/*******UART章节,串口信息初始化*******/
	//CR1寄存器第0位(UE)置0才能配置串口信息	
	delay_ms(500);//先让发送寄存器原有的数据发送完在配置
	USART4->CR1 &= (~(0x1<<0));
	//1.设置8位数据位CR1[28][12]=00
	USART4->CR1 &= (~(0x1<<28));
	USART4->CR1 &= (~(0x1<<12));
	//2.设置无奇偶校验位R1[10]=0
	USART4->CR1 &= (~(0x1<<10));
	//3.设置一位停止位R2[13:12]=00
	USART4->CR2 &= (~(0x3<<12));
	//4.设置16倍采样率R1[15]=0
	USART4->CR1 &= (~(0x1<<15));
	//5.设置不分频PRESC[4-0]=0000
	USART4->PRESC &= (~(0xf<<0));
	//5.设置波特率为115200
	USART4->BRR = 0x22B;
	//6.设置发送器使能CR1[3]=1
	USART4->CR1 |= (0x1<<3);
	//7.设置接收器使能CR1[2]=1
	USART4->CR1 |= (0x1<<2);
	//8.配置完成,串口使能UE即CR1[0]=1
	USART4->CR1 |= (0x1<<0);
}
//2.发送一个字符
void put_char(const char str)
{
	//1.判断发送数据寄存器中是否有数据ISR[7]
	//读0:有数据,需要等待数据发送完成
	//读1:没有数据,可以发送下一个数据
	while(!(USART4->ISR & (0x1<<7)));
	
	//2.将要发送的字符写到发送数据寄存器中
	USART4->TDR = str;

	//3.判断数据是否发送完成ISR[6]
	//读0:未完成,等待
	//读1:已完成,可以发送下一个数据
	while(!(USART4->ISR & (0x1<<6)));
}
//3.接收一个字符
char get_char()
{
	char ch;
	//1.判断接收寄存器是否有数据可读
	//读0:没有数据可读,需要等待
	//读1:有数据可读
	while(!(USART4->ISR & (0x1<<5)));
	
	//2.将接收寄存器中的内容读出来
	ch = USART4->RDR;
	return ch;
}
//4.发送一个字符串
void put_string( const char* str)
{
	int i = 0;
	//1.判断是否为'\0',是则发送完成,不是则一个一个字符发送
	while(str[i] != '\0')
	{
		put_char(str[i]);
		i++;
	}
	//3.发送完成换行,光标回到首位
	put_char('\n');
	put_char('\r');
}
//5.接收一个字符串
//1.定义一个数组接收字符串
char buff[128] = {0};
char* get_string()
{
	//2.循环实现:接收一个字符后,发送一个字符
	//当键盘按下回车(光标回到首位),表示字符串接收结束
	int i=0;
	while((buff[i]=get_char()) != '\r')
		{
			put_char(buff[i]);
			i++;
		}
	//3.字符串补0
	buff[i] = '\0';
	//4.输入完成,换行
	put_char('\n');
	put_char('\r');
	return buff;
}

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()
{
    //串口初始化
	uart4_init();
	while(1)
	{
        //发送一个字符,如a接收字符b(a+1)
		//put_char(get_char()+1);
        //发送一个字符串
		put_string(get_string());
	}
	return 0;
}

测试结果:

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

通过串口收发一个字符、字符串 的相关文章

  • Qt学习笔记之类继承关系图

  • C++:头文件递归包含问题(互相包含问题)

    目录 引言初始版本头文件守卫递归包含会怎么样为什么会出错前置声明是什么如何解决递归包含问题参考 引言 最近正在疯狂补技术债 xff0c 以及疯狂赶项目 大一大二摸的鱼终归是要还的 xff0c 也奉劝大家少摸鱼 xff0c 不然临近找工作可能
  • 拓展:示波器使用_波形分析

    这里主要对上一个练习中的波形图来拓展 xff0c 讲讲怎么在示波器输出的波形图中 xff0c 对该界面上的一些功能的使用 01 关于适应全屏 放大 缩小 对于输出波形 xff0c 经常要用到的即是适应屏幕 xff0c 以及放大缩小 xff0
  • 【已解决】element-ui组件嵌套太多层,导致内部el-input和el-select 等组件无法正常输入解决方案

    如果 element ui 组件嵌套太多层 xff0c 可能会导致内部的 el input 和 el select 等组件无法正常输入 出现这种问题通常是由于 z index 属性设置不正确导致的 解决这个问题的方法是调整组件的 z ind
  • 两个半天一刷Ubuntu入门指令

    目录 两个半天一刷Ubuntu入门指令 一 Ubuntu初次体验 二 设备驱动 三 Ubuntu用户组及其权限分配 四 压缩解压 五 Linux连接文件 六 vim编辑器 七 Linux下C编程 八 gcc和make及其Makefile的引
  • ENV环境配置及其下载网络组件包问题

    准备工作 Env 工具包含了 RT Thread 源代码开发编译环境和软件包管理系统 从 RT Thread 官网下载 Env 工具 在电脑上装好 git xff0c 软件包管理功能需要 git 的支持 git 的下载地址为https gi
  • 芯片flash保护(解锁)

    报错结果 Error while accessing a target resource The resource is perhaps notavailable 就是无法下载程序 解决办法 1 下载ST LINK Utility 链接 x
  • 2.RTT-点灯大师的修炼

    1 创建工程模板 相信大家通过学习上一篇文章 1 RTT 环境搭建 现在能熟练的创建一个标准模板了 xff0c 如果不会就跳回去学习一下吧 链接 xff1a 1 RTT 环境搭建 嵌入式路上的流浪的博客 CSDN博客 建立好的工程模板编译并
  • 4.RTT-UART-中断接收及轮询发送

    本期博客开始分享RTT的UART xff0c 利用战舰V3的uart2来输入输出一些字符串 UART xff08 Universal Asynchronous Receiver Transmitter xff09 通用异步收发传输器 xff
  • 12.RTT-IIC设备-AHT10温湿度传感器

    本系列博客更新结束啦 xff01 完结啦 xff01 xff01 xff01 撒花 xff01 xff01 xff01 关于RTT的设备和驱动专题更新完毕啦 xff0c 本期是最后一期 一段学习旅途的结束意味着下一段学习冒险的开始 虽然本系
  • RTduino+sht31温湿度传感器

    本次博客使用的是STM32F103C8T6 xff0c 因为该BSP已经对接好RTduino了可以直接上手使用 一 RTduino简介 RTduino是RT Thread实时操作系统的Arduino生态兼容层 xff0c 为RT Threa
  • 一文揭秘字节跳动、华为、京东的薪资职级

    声明 xff1a 本文所有数字均不是官方数据 xff0c 为网络资料收集整理 字节跳动 01 全球员工总数 字节的员工数量目前超过5万人 图片来源 xff1a 字节范 02 岗位职级 字节跳动的职级研发序列一共10级 xff1a 字节跳动创
  • ESP_C3在ubuntu下运行RT-Thread

    1 clone源代码RT Thread git clone git 64 github com RT Thread rt thread git 2 开始搭建ESP IDF环境 进入源码到bsp文件夹下找到ESP32 C3 xff0c 开始配
  • uniapp中使用弹出层

    uniapp中使用弹出层 因为业务的需要 xff0c 需要弹出一个复选框 xff0c 使用uniapp中自带的框架 使用 xff1a 第一步 xff1a 下载下示例项目 xff0c 找到主要的文件夹 第二步 xff1a 将该文件夹放到组件的
  • 手写一个uniapp的步骤条组件

    span class token operator lt span template span class token operator gt span span class token operator lt span view span
  • uniapp中的分页

    数据量过多就会使用分页 第一种 xff1a API span class token comment 和data同级 span span class token function variable function onReachBotto
  • uniapp中生成随机的二维码并进行保存

    需求 xff1a 需要根据用户id的不同生成不同的二维码 xff0c 并进行本地保存 第一步 xff1a 下载插件 这里对于二维码的生成 xff0c 使用的是第三方插件weapp qrcode min js xff0c 主要用到的文件是 d
  • Pc端的基本Echarts

    Pc端的基本Echarts 双环传态图组件 span class token operator lt span template span class token operator gt span span class token oper
  • el-table表格的sortable排序的使用以及出现小数、%排序错乱

    前端实现排序 xff1a 只需要在表头上加上一个sortable属性即可 span class token tag span class token tag span class token punctuation lt span el t
  • 浏览器的回退和导航栏的选中转态不同步,路由在新窗口打开

    问题1 xff1a 浏览器的回退和导航栏的选中状态不能同步的问题 问题 xff1a 用户后退时候 xff0c 左边导航栏显示的还是上一个页面的导航 xff0c 但是路由和页面已经变了 span class token operator lt

随机推荐