03:2440--UART

news2024/11/19 0:51:01

目录

一:UART

1:概念

2:工作模式

3:逻辑电平

4:串口结构图

5:时间的计算

二:寄存器

1:简单的UART传输数据

A:GPHCON--配置引脚  

B:GPHUP----使能内部上拉​编辑

C: UCON0---设置频率115200

D: ULCON0----数据格式8n1

E:发送数据

A:UTRSTAT0

B:UTXHO--发送数据输缓冲寄存器

F:接收数据

A:UTRSTAT0​​​​​​​

B:URXH0 ---接收缓冲区寄存器

三:代码

1:UART的简单实现


一:UART

1:概念

        S3C2440A通用异步收发器(UART)提供三个独立的异步串行I/O (SIO)端口,每个端口都可以在基于中断或基于dma的模式下工作。换句话说,UART可以生成中断或DMA请求来在CPU和UART之间传输数据。使用系统时钟,UART可以支持高达921.6Kbps的波特率。如果外部设备为UART提供UEXTCLK,则UART可以以更高的速度运行。每个UART信道包含两个64字节的fifo,分别用于接收和发送。

        S3C2440A UART包括可编程波特率,红外(IR)发送/接收,一个或两个停止位插入,5位,6位,7位或8位数据宽度和奇偶校验。

        每个UART包括波特率发生器、发送器、接收器和控制单元。波特率发生器可以通过PCLK, FCLK/n或UEXTCLK(外部输入时钟)进行时钟。

        发射器和接收器包含64字节的fifo和数据移位器。数据被写入FIFO,然后在传输之前复制到传输移位器。然后通过传输数据引脚(TxDn)将数据移出。同时,接收数据从接收数据引脚(RxDn)转移,然后从移位器复制到FIFO。

        1:波特率 : 双方约定每一位占用的时间

        2:格式 : 数据位, 停止位, 校验位, 流量控制

        校验分为奇校验和偶校验, 以前的电解技术没有那么稳定, 使用采用了;  不过现在使用比较少;

        

        数据位+校验位为 " 1"的个数

eg: 数据位为8位--0001 0001 --采用奇校验 使用校验位为1;   3个1所以是奇校验

       如果采用偶校验,  校验位为0----2个1就是偶校验 

        作用 :  串口不仅可以为我们打印调式信息, 还可以连接需要外设模块,  实现之间的通信 (GPS, 蓝牙,  mpu6050......)

       这个和STM32发送的基本一样详情可以参考我的 : 09:STM32-------USART串口通信+串口数据包

2:工作模式

假设2440现在需要向外面的pc端口发送一个数据,  他的工作模式如下

发送 "A" 0x41 0b0100 0001

2440向pc段发送数据  

        A : 首先逻辑电平是高电平

        B : ARM被拉低(开始位)---告诉pc段我要开始发送数据了;  在这里会停留1bit的时间,  也就是我们双方约定的波特率.

        C:通过拉低逻辑电平电平的方式传输数据.  每一位停留一个波特率的时间.  一般数据为采用8位

        D:在一个数据位发送介绍拉高电平告诉, pc段我们发送完了

pc段读取数据:

        在数据位中间的位置开始读取数据

3:逻辑电平

        TTL电平传输方式-----我们2440采用的就是这种的传输方式;      当电平高在某一个范围的时候他就会被判定位高电平, 同理在电平低于某一个范围的时候被判定为低电平. 

          RS232电平传输----我们pc段采用这种方式的传输

2种不同的电平协议是不能相互传输数据的,  我们的2440添加了电平转化芯片或者USB串口芯片. 

原理图:

        可以看到我们引脚需要我们的配置, 来把他变为发送和接收引脚.  而不是普通的GPIO口

4:串口结构图

简单理解:

2440向pc段发送数据:

          A:FIFO会向内存中取到需要发送的数据

          B:在这个UART单元中FIFO把数据发送到移位器里面去,  移位器通过逐步发送,把数据发送到了pc段.

pc段向2440发送数据:

        A:pc段把数据发送给我移位器, 移位器逐步接收.

        B:移位器再把数据发送给我FIFO, FIFO,  程序从FIFO把数据取出来写入内存. 

可以使用中断或者不断查看标志位的方式来查看数据是否发送完毕.

5:时间的计算

二:寄存器

1:简单的UART传输数据

A:GPHCON--配置引脚  

        注意我们使用的发送和接收的是0号,  在下面选择寄存器是也应该选择0号.

        可以看到了我们需要把GPH2 GPH3配置使他为发送和接收引脚,  而不是普通的GPIO口

GPHCON &= ~((3 << 4) | (3 << 6));
GPHCON |= ((2 << 4) | (2 << 6));

B:GPHUP----使能内部上拉

	GPHUP &= ~((1 << 2) | (1 << 3));  /* 使能内部上拉 */

把GPH2和GPH3的接收引脚上拉

C: UCON0---设置频率115200

UART块中有三个UART控制寄存器,包括UCONO、UCON1和UCON2。

        时钟我们选择默认的PCLK时钟----在上一节中我们调节PCLK的频率为50MHZ

        UBRDIVn = (int)(selected clock / (baudrate x 16) ) –1

        我们使用我们的FCLK作为我们的时钟源--在汇编中是50MHZ

        UBRDIVn=(5000 0000 /(115200*16))-1=26

UBRDIV0 = 26;

        我们只需要最简单的实现---所以只有打开发送和接收模式

UCON0 = 0x00000005;

全部代码----实现了频率为11520, 打开接收和发送模式

UCON0 = 0x00000005;
UBRDIV0 = 26;

D: ULCON0----数据格式8n1

/*数据格式*/
	ULCON0 = 0x00000003;  //不能写为这个ULCON0 |= (3 << 1)因为还要关注其他位;/*数据位=8,停止位=1,无奇偶校验 8n1*/

E:发送数据

A:UTRSTAT0

        发射机空;    当传输缓冲寄存器没有有效数据要传输且传输移位寄存器为空时,自动设置为1。

0 =不空        1=发射机(传输缓冲区和移位寄存器)空

while ((UTRSTAT0 & (1 << 2)) == 0); //while (!(UTRSTAT0 & (1 << 2)));

B:UTXHO--发送数据输缓冲寄存器

        在UART块中有三个UART传输缓冲寄存器,包括UTXHO、UTXH1和UTXH2。UTXHn有一个8位的数据用于传输数据。

return URXH0;

全部代码

while ((UTRSTAT0 & (1 << 2)) == 0); //while (!(UTRSTAT0 & (1 << 2)));

UTXH0 = (unsigned char)c;

F:接收数据

A:UTRSTAT0
	while ((UTRSTAT0 & (1 << 0)) == 0); //while (!(UTRSTAT0 & (1 << 0)));
B:URXH0 ---接收缓冲区寄存器

        在UART块中有三个UART接收缓冲区寄存器,包括URXHO, URXH1和URXH2。URXHn对接收的数据有一个8位的数据。

return URXH0

全部代码

while ((UTRSTAT0 & (1 << 0)) == 0); //while (!(UTRSTAT0 & (1 << 0)));
return URXH0;

全部的代码见---三:代码 1:UART的简单实现

三:代码

1:UART的简单实现

#include "sc2440_so.h"
/*在UART块中有三个UART线路控制寄存器,包括ULCONO、ULCON1和ULCON2。
	我们使用的是--ULCONO
	*/
//115200 8n1
void UART_init()
{
	/*引脚设置*/
	GPHCON &= ~((3 << 4) | (3 << 6));
	GPHCON |= ((2 << 4) | (2 << 6));

	GPHUP &= ~((1 << 2) | (1 << 3));  /* 使能内部上拉 */

	/*设置波特率---设置波特率位115200*/
	/*
	 UBRDIVn = (int)(selected clock / (baudrate x 16) ) –1
	 我们使用我们的FCLK作为我们的时钟源--在汇编中是50MHZ
	UBRDIVn=(5000 0000 /(115200*16))-1=26
	*/
	UCON0 = 0x00000005;
	UBRDIV0 = 26;

	/*数据格式*/
	ULCON0 = 0x00000003;  //不能写为这个ULCON0 |= (3 << 1)因为还要关注其他位;/*数据位=8,停止位=1,无奇偶校验 8n1*/
}
int putchar(int c)
{
	/*发送数据*/
	while ((UTRSTAT0 & (1 << 2)) == 0); //while (!(UTRSTAT0 & (1 << 2)));
	

	UTXH0 = (unsigned char)c;
}

int getchar(void)
{
	/*接收数据*/
	while ((UTRSTAT0 & (1 << 0)) == 0); //while (!(UTRSTAT0 & (1 << 0)));
	

	return URXH0;
}

int puts(const char* s)
{
	while (*s)
	{
		putchar(*s);
		s++;
	}

}



#ifndef __UART_H
#define __UART_H

void UART_init();
int putchar(int c);
int getchar(void);
int puts(const char* s);


#endif

#ifndef __SC2440_SO_H
#define __SC2440_SO_H

#define ULCON0 (*((volatile unsigned int*)0x50000000))
#define UCON0 (*((volatile unsigned int*)0x50000004))
#define UBRDIV0 (*((volatile unsigned int*)0x50000028))
#define GPHCON (*((volatile unsigned int*)0x56000070))
#define GPHUP (*((volatile unsigned int*)0x56000078))
#define UFCON0 (*((volatile unsigned int*)0x50000008))
#define UTRSTAT0 (*((volatile unsigned int*)0x50000010))
#define UTXH0 (*((volatile unsigned char*)0x50000020))
#define URXH0 (*((volatile unsigned char*)0x50000024))

#endif

#include "uart.h"
#include "sc2440_so.h"
int main(void)
{
	unsigned char c;

	UART_init();
	puts("Hello, world!\n\r");

	while (1)
	{
		c = getchar();
		if (c == '\r')
		{
			putchar('\n');
		}

		if (c == '\n')
		{
			putchar('\r');
		}

		putchar(c);
	}
	return 0;
}

分析makefile文件

我们要使用makefile文件交叉编译来生成bin文件

all:
	
	arm-linux-gcc -c -o uart.o uart.c
	arm-linux-gcc -c -o main.o main.c
	arm-linux-gcc -c -o start.o start.S
	arm-linux-ld -Ttext 0 start.o  uart.o main.o -o uart.elf
	arm-linux-objcopy -O binary -S uart.elf uart.bin
	arm-linux-objdump -D uart.elf > uart.dis
clean:
	rm *.bin *.o *.elf *.dis
	

        A: 先把所以的c语言和汇编语言全部, 编译为.o文件

        B:链接: 这是一个链接命令,用于将三个目标文件(start.o、uart.o、main.o)链接成一个可执行文件(uart.elf)。其中-Ttext 0指定了链接地址的起始地址为0,start.o是程序的入口地址。这个命令会将三个目标文件中的符号解析出来,并将它们放到正确的位置上,生成可执行文件

        C:这个命令的作用是将uart.elf文件转换为uart.bin文件。其中,-O binary表示输出格式为二进制文件,-S表示去掉所有的符号信息。这个命令通常用于将可执行文件转换为裸机程序,以便在嵌入式系统中运行。(把连接生成的elf文件转换为单板使用的bin文件)

        D:对连接生成的elf文件进行反汇编,调试错误时用。生成.dis文件

1:UART每发送完一个数据发送停止位, 还是发送完想要发送的数据在发送停止位?

        根据引用中的定义,UART协议的数据传输包括起始位、数据位和终止位。其中,起始位是低电平,终止位是高电平。在UART发送一段数据时,每个数据字节后面都会跟随一个停止位。停止位的数量取决于UART协议的设置,通常为1个或2个。因此,UART发送一段数据,一共发送的停止位数量为1个或2个,具体取决于UART协议的设置

2:UART发送数据是发送完毕,接收端在读取, 还是一边发送, 接收端一边读取

        根据提供的引用内容,UART是一种通用异步接收器/发送器,其主要目的是发送和接收串行数据。在UART发送数据时,数据包以串行方式从发送UART送至接收UART,接收UART以预配置的波特率对数据线进行采样。因此,在UART发送数据时,接收端需要一边接收一边读取数据,否则数据将会丢失

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

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

相关文章

makefile 学习(5)完整的makefile模板

参考自&#xff1a; (1&#xff09;深度学习部署笔记(二): g, makefile语法&#xff0c;makefile自己的CUDA编程模板(2&#xff09;https://zhuanlan.zhihu.com/p/396448133(3) 一个挺好的工程模板&#xff0c;(https://github.com/shouxieai/cpp-proj-template) 1. c 编译流…

linux嵌入式时区问题

目录 操作说明实验参考 最近有个针对时区的需求&#xff0c;研究了下。 查询网上的一些设置&#xff0c;发现基本都是系统中自带的一些文件&#xff0c;然后开机时解析&#xff0c;或者是有个修改的命令。 操作 但针对嵌入式常用到的 busybox 制作的最小系统&#xff0c;并没…

图论|知识图谱——详解自下而上构建知识图谱全过程

导读&#xff1a;知识图谱的构建技术主要有自顶向下和自底向上两种。其中自顶向下构建是指借助百科类网站等结构化数据源&#xff0c;从高质量数据中提取本体和模式信息&#xff0c;加入到知识库里。而自底向上构建&#xff0c;则是借助一定的技术手段&#xff0c;从公开采集的…

activiti流程回退与跳转

学习连接 【工作流Activiti7】3、Activiti7 回退与会签 【工作流Activiti7】4、Activiti7 结束/终止流程 Activiti-跳转到指定节点、回退 ativiti6.0 流程节点自由跳转实现、拒绝/不同意/返回上一节点、流程撤回、跳转、回退等操作&#xff08;通用实现&#xff0c;亲测可用…

基于python+TensorFlow+Django算法模型的车辆车型识别系统

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介简介技术栈主要模块1. 数据预处理2. 模型构建3. 模型训练4. 模型集成5. 用户界面 系统工作流程未来改进计划 二、功能三、系统四. 总结 一项目简介 # 车辆车…

【linux】基本指令(中篇)

echo指令 将引号内容打印到显示屏上 输出的重定向 追加的重定向 输出的重定向 我们学习c语言的时候当以写的方式创建一个文件&#xff0c;就会覆盖掉该文件之前的内容 当我们以追加的方式打开文件的时候&#xff0c;原文件内容不会被覆盖而是追加 more指令 10.more指令…

cephadm部署ceph quincy版本

环境说明 IP主机名角色 存储设备 192.168.2.100 master100 mon,mgr,osd,mds,rgw 大于5G的空设备192.168.2.101node101mon,mgr,osd,mds,rgw大于5G的空设备192.168.2.102node102mon,mgr,osd,mds,rgw大于5G的空设备 关闭防火墙 关闭并且禁用selinux 配置主机名/etc/hosts …

⑦【Redis GEO 】Redis常用数据类型:GEO [使用手册]

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ Redis GEO ⑦Redis GEO 基本操作命令1.geoadd …

原生JS实现计算器(内含源码)

前言 本文讲解了JavaScript如何在一小时内实现一个简易计算器&#xff0c;这里最大的亮点就在于&#xff0c;我在JS中只用了一个事件&#xff0c;就实现了计算器的效果和功能&#xff0c;那么好文本正式开始。 布局和样式流程 首先是HTMLCSS结构&#xff1a;这里主要用到的…

基于uQRCode封装的Vue3二维码生成插件

标题&#xff1a;基于uQRCode封装的Vue3二维码生成插件 摘要&#xff1a;本文介绍了一种基于uQRCode封装的Vue3二维码生成插件&#xff0c;可以在Javascript运行环境下生成二维码并返回图片地址。该插件适用于所有Javascript运行环境&#xff0c;并且支持微信小程序。本文将详…

在Python中matplotlib函数的plt.plot()函数的颜色参数设置,以及可以直接运行的程序代码!

文章目录 前言一、使用字符串颜色&#xff1a;二、使用十六进制颜色&#xff1a;三、使用RGB元组&#xff1a;四、使用颜色映射&#xff1a;总结 前言 在matplotlib中&#xff0c;plt.plot()函数可以接受颜色参数&#xff0c;可以设置为字符串颜色&#xff08;如red&#xff0…

笔记:pycharm当有多个plt.show()时候,只显示第一个plt.show()

import matplotlib.pyplot as plt import numpy as np# 创建数据 x np.linspace(0, 10, 100) y1 np.sin(x) y2 np.cos(x) y3 np.tan(x) y4 np.exp(x)# 创建一个2x2的子图网格 # fig plt.figure() fig,((ax1, ax2), (ax3, ax4)) plt.subplots(nrows2, ncols2, figsize(8,…

Redis:事务操作

目录 Redis事务定义相关命令事务的错误处事务冲突的问题Redis事务三特性 Redis事务定义 redis事务是一个单独的隔离操作&#xff0c;事务中的所有命令都会序列化、按顺序地执行&#xff0c;事务在执行的过程中&#xff0c;不会被其他客户端发送来的命令请求所打断。 redis事务…

车载电子电器架构 ——电子电气架构设计方案概述

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 注:本文1万多字,认证码字,认真看!!! 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证…

作为Java初学者,如何快速学好Java?

作为Java初学者&#xff0c;如何快速学好Java&#xff1f; 开始的一些话 对于初学者来说&#xff0c;编程的学习曲线可能相对陡峭。这是正常现象&#xff0c;不要感到沮丧。逐步学习&#xff0c;循序渐进。 编程是一门实践性的技能&#xff0c;多写代码是提高的唯一途径。尽量…

【一起来学kubernetes】7、k8s中的ingress详解

引言配置示例负载均衡的实现负载均衡策略实现模式实现方案Nginx类型Ingress实现Treafik类型Ingress实现HAProxy类型ingress实现Istio类型ingress实现APISIX类型ingress实现 更多 引言 Ingress是Kubernetes集群中的一种资源类型&#xff0c;用于实现用域名的方式访问Kubernetes…

[图片来源BZhan]最小生成树(Prim➕Kruskal)、最短路径(Dijkstra➕Floyd)

文章目录 0.基础知识0.1图的存储结构0.2算法复杂度1.BFS和DFS2.Prim和Kruskal 1.最小生成树1.1Prim算法1.算法思想2.Prim代码实现 1.2Kruskal算法1.算法思想2.Kruskal代码实现[demo] 2.最短路径2.1问题抽象:2.2两种常见的最短路径问题:1.Dijkstra: 单源最短路径O(N^2)2.Floyd: …

停车管理系统

1 用户信息管理 2 车位信息管理 3 车位费用设置 4 停泊车辆查询 5 车辆进出管理 6 用户个人中心 7 预定停车位 8 缴费信息 9 业务逻辑详解 1 用户停车&#xff1a;user用户登录&#xff0c;在预定停车位菜单&#xff0c;选择一个车位点击预定即可 2 车辆驶出&#xff1a;admin…

【数据结构实验】图(二)将邻接矩阵存储转换为邻接表存储

文章目录 1. 引言2. 邻接表表示图的原理2.1 有向权图2.2 无向权图2.3 无向非权图2.1 有向非权图 3. 实验内容3.1 实验题目&#xff08;一&#xff09;数据结构要求&#xff08;二&#xff09;输入要求&#xff08;三&#xff09;输出要求 3.2 算法实现 4. 实验结果 1. 引言 图是…

电磁场信息论及先进MIMO (黄大年茶思屋座谈) 笔记

天线阵的负载动态调控&#xff0c;动态阻抗匹配网络&#xff0c;实时跟着扫描角度的变化而变化&#xff0c;可能突破Hannan极限。 新的天线构架&#xff1a; 周期 —》非周期 每个单元不一样 动态可调&#xff0c;可重构 每个天线多端口或多模式 多层天线 非周期结构天线的增…