通用异步收发传输器(Universal Asynchronous Receiver Transmitter)

原理

发送数据时,CPU将并行数据写入UART,UART按照一定的格式在一根电线上串行发出

接收数据时,UART检测另一根电线上的信号,将串行收集放在缓冲区中,CPU即可读取UART获取这些数据

UART以全双工方式传输数据,最精简的连接方法只有3根线:

TxD:发送数据

RxD:接收数据

Gnd:给双方提供参考电平

连线图

为了增强数据的抗干扰能力、提高数据传输长度,通常将TTL/CMOS逻辑电平转换为RS-232逻辑电平,3~12V表示0,-3~-12V表示1

发送数据之前,UART之间要约定好数据的传输速率(每位所占据的时间,其倒数称为波特率)、数据的传输格式(多少个数据位、是否使用校验位、是奇校验还是偶校验、有多少个停止位)

波形





数据位:二进制0b1010101,十六进制0x55,大写字母U

S3C2410/S3C2440特性

3个独立通道,每个都可以工作于中断模式或者DMA模式,即UART可以发出中断或DMA请求以便UART和CPU之间传输数据

S3C2410 UART的每个通道都有16字节的发送FIFO和16字节的接收FIFO;S3C2440 UART的FIFO深度为64

发送数据时,CPU先将数据写入发送FIFO中,然后UART会自动将FIFO中的数据复制到“发送移位器”中,发送移位器将数据一位一位地发送到TxDn数据线上(根据设定的格式,插入开始位、校验位和停止位)

接收数据时,“接收移位器”将RxDn数据线上的数据一位一位地接收进来,然后复制到接收FIFO中,CPU即可从中读取数据

S3C2410/S3C2440 UART的每个通道支持停止位1位、2位,数据位5、6、7、8位,支持校验位,另外还有红外发送、接收功能

S3C2410/S3C2440使用

S3C2410/S3C2440还要选择管脚为UART功能、选择UART通道的工作模式为中断模式或DMA模式

1.设置UART通道管脚为UART功能

比如UART通道0中,GPH2、GPH3分别用作TXD0、RXD0。设置GPHCON寄存器将GPH2、GPH3引脚的功能设为TXD0、RXD0

2.设置波特率

UBRDIVn寄存器(UART BAUD RATE DIVISOR)

根据给定的波特率、所选择的时钟源的频率,可以计算UBRDIVn寄存器(n为0~2,对应3个UART通道)的值

UBRDIVn = (int)(UART clock / (buad rate * 16)) - 1

3.设置传输格式

ULCONn寄存器(UART LINE CONTROL)

功能          位       说明
数据位宽度 [1:0] 0b00:5位,0b01:6位
0b10:7位,0b11:8位
停止位宽度 [2] 0:一帧中有一个停止位
1:一帧中有两个停止位
校验模式 [5:3] 设置校验位的产生方法、校验方法
0b0xx:无校验
0b100:奇校验
0b101:偶校验
0b110:发送数据时强制设为1,接收数据时检查是否为1
0b111:发送数据时强制设为0,接收数据时检查是否为0
红外模式 [6] 0:正常模式
1:红外模式

4.UCONn寄存器(UART CONTROL)

UCONn寄存器用于选择UART时钟源、设置UART中断方式等

功能          位        说明
接收中断方式 [8] 如下情况发生时,将产生接收中断
不使用FIFO时,接收到一个数据;
使用FIFO时,FIFO中的数据达到RxFIFO的触发阈值。
中断方式设置如下:
0:脉冲
1:电平
发送中断方式 [9] 如下情况发生时,将产生发送中断
不使用FIFO时,发送缓冲区变空;
使用FIFO时,FIFO中的数据达到TxFIFO的触发阈值。
中断方式设置如下:
0:脉冲
1:电平
时钟选择 [10] 选择UART时钟源
0:PCLK
1:UEXTCLK

5.UFCONn寄存器(UART FIFO CONTROL)UFSTATn寄存器(UART FIFO STATUS)

UFCONn寄存器用于设置是否使用FIFO,设置各FIFO的触发阈值,即发送FIFO中有多少个数据时产生中断、接收FIFO中有多少个数据时产生中断并可以通过设置UFCONn寄存器来复位各个FIFO

读取UFSTATn寄存器可以知道各个FIFO是否已经满、其中有多少个数据

UART串口简介的更多相关文章

  1. linux UART串口驱动开发文档

    转:http://www.360doc.com/content/10/0417/18/829197_23519037.shtml linux UART串口驱动开发文档时间:2010-01-09 14: ...

  2. Linux下使用putty进行UART串口调试【转】

    本文转载自:http://blog.csdn.net/xzongyuan/article/details/11593101 版权声明:本文为博主原创文章,未经博主允许不得转载. 使用putty进行串口 ...

  3. 基于STM32之UART串口通信协议(四)Printf发送

    一.前言 1.简介 前面在UART发送中已经讲解过如何调用HAL库的HAL_UART_Transmit函数来实现串口发送,而在调用这个函数来实现串口发送的话,但是在发送数据或者字符的时候,需要将数据或 ...

  4. 基于STM32之UART串口通信协议(二)发送

    一.前言 1.简介 在上一篇UART详解中,已经有了关于UART的详细介绍了,也有关于如何使用STM32CubeMX来配置UART的操作了,而在该篇博客,主要会讲解一下如何实现UART串口的发送功能. ...

  5. 基于STM32之UART串口通信协议(一)详解

    一.前言 1.简介 写的这篇博客,是为了简单讲解一下UART通信协议,以及UART能够实现的一些功能,还有有关使用STM32CubeMX来配置芯片的一些操作,在后面我会以我使用的STM32F429开发 ...

  6. 基于STM32之UART串口通信协议(三)接收

    一.前言 1.简介 回顾上一篇UART发送当中,已经讲解了如何实现UART的发送操作了,接下来这一篇将会继续讲解如何实现UART的接收操作. 2.UART简介 嵌入式开发中,UART串口通信协议是我们 ...

  7. (三) UART 串口通讯

    UART  : university asynchronous receiver and transmitter UART  // 通用异步接收器和发送器 为什么要有串口:因为许多嵌入式设备没有显示屏 ...

  8. 【C51】UART串口通信

    我们常需要单片机和其他模块进行通信,数据传输,常用的方式就是串口通信技术. 常用来 单片机<-->电脑,  单片机<-->单片机之间通信. 串行通信 versus 并行通信 并 ...

  9. Uart串口与RS232串口的区别

    Uart指的是TTL电平的串口:RS232指的是RS232电平的串口. TTL电平是3.3V的,而RS232是负逻辑电平,它定义+5~+12V为低电平,而-12~-5V为高电平. Uart串口的RXD ...

随机推荐

  1. Bootstarp学习

    Bootstarp中文网 http://www.bootcss.com/ https://v2.bootcss.com/javascript.html

  2. 数学建模python matlab 编程(疾病传播模型)

    例12:一只游船上有800(1000)人,一名游客不慎患传染病,12(10)小时后有3人发病,由于船上不能及时隔离,问经过60(30)小时,72小时,患此病的人数.(与人口模型和Logistic模型类 ...

  3. SSD总结

    SSD: Single Shot MultiBox Detector 1. Introduction 改进点: 以前的方法都是先搞bounding box,再对box里面做分类.特点:精度高,速度慢. ...

  4. GBDT详解例子

    https://blog.csdn.net/zpalyq110/article/details/79527653

  5. dp[2019.5.25]_2

    1.对于长度相同的2个字符串A和B,其距离定义为相应位置字符距离之和.2个非空格字符的距离是它们的ASCII码之差的绝对值.空格与空格的距离为0,空格与其他字符的距离为一定值k. 在一般情况下,字符串 ...

  6. Flutter 页面下拉刷新和上拉加载

    flutter_easyrefresh 正如名字一样,EasyRefresh很容易就能在Flutter应用上实现下拉刷新以及上拉加载操作,它支持几乎所有的Flutter控件.它的功能与Android的 ...

  7. 简单实现react中虚拟DOM渲染

    /** * @method createElement * @param type {string} * @param props {Object} * @param children {string ...

  8. manjaro 给笔记本安装18.1系统时发现中文变成了方块字

    解决方案: 1.连接网络,wifi/本地连接 2.打开终端 3.同步数据 如果是第一次,我们需要先同步本地数据包,先输入 sudo pacman -Syy 4.安装字体 sudo pacman -S ...

  9. leetcode907 Sum of Subarray Minimums

    思路: 对于每个数字A[i],使用单调栈找到A[i]作为最小值的所有区间数量,相乘并累加结果.时间复杂度O(n). 实现: class Solution { public: int sumSubarr ...

  10. 【OpenCV开发】使用OpenCV的OpenCL(ocl)模块

    参加OpenCV的OpenCL模块(以下称OCL)移植工作已经有2个月了.这里我说移植而不是开发,是因为大部分OCL模块的函数都是从已经很成熟的GPU模块移植过来的.于是目前阶段OCL模块所支持的函数 ...