s3c2440裸机-UART编程(一、UART硬件介绍及传输原理)
1.uart硬件介绍
UART的全称是Universal Asynchronous Receiver and Transmitter(异步收发器)。 uart主要用于:
1.打印调试
2.数据传输
串口通过三根线即可,发送、接收、地线。

pc的TxD -> arm的RxD (UART write)
arm的TxD -> pc的RxD (UART read)
2.uart的参数和格式
波特率:表示每秒传输多少bit,bits per second(bps).一般波特率都会有9600,19200,115200等选项。
格式:
起始位: 先发出一个逻辑”0”的信号,表示传输数据的开始。
数据位:可以是5~8位逻辑”0”或”1”。一般7位,刚好可以传输所有ASCII码。
校验位:
奇校验:(校验位+数据位)使得“1”的位数为奇数
偶校验:(校验位+数据位)使得“1”的位数为偶数
举个栗子:
‘A’的ASCII值是0x41,二进制就是01000001,那么奇校验就在校验位写‘1’,偶校验就在校验位写‘0’
停止位:它是一个字符数据的结束标志。
3.UART是如何传输一个字符‘A’的
‘A’的ASCII值是0x41,二进制就是01000001,怎样把这8位数据发送给PC机呢?
1.双方约定好波特率(每一位占据的时间)
2.规定传输协议
现在处于这种模式:arm的TxD -> pc的RxD (UART read)
1.arm拉低uart总线1bit的时间(起始位)
2.arm根据数据位依次驱动TxD的电平,同时PC依次读取uart总线,数据到达PC的RxD引脚,pc依次获得数据位
为了能够进行远距离的传输数据,我们的PC是使用的RS-232逻辑电平,而arm开发板使用的TTL/CMOS逻辑电平。这里先讲解下什么是TTL逻辑电平,什么是RS-232逻辑电平。
TTL/CMOS逻辑电平:
0(低电平0-0.7v)表示逻辑'0'
1(高电平2-5v) 表示逻辑'1'
RS-232逻辑电平:
(+3V ~ +12V) 表示逻辑'0'
(-12V ~ -3V) 表示逻辑'1'
TTL逻辑电平的波形:

RS232逻辑电平的波形:

那么在起始信号开始后开始计时,arm每隔一个时钟往TxD放1bit数据,同时pc也从RxD get 1bit数据.
arm pc
TxD=data[0:], data[0:]=RxD
TxD=data[1:], data[1:]=RxD
...
TxD=data[7:], data[7:]=RxD
为什么用RS232?
我们知道RS232的逻辑'0'和逻辑'1'相差较大,比TTL/CMOS差距大,那么逻辑电平不容易出现反转,能传输更远的距离,在工业上用得比较多。
所以我们上面PC拿到的数据是不对的,那么需要一个TTL转RS232的电平转换芯片。

4.ARM芯片是如何收发数据的呢?

发送数据:
内存将数据放入发送FIFO(64byte),通过发送移位器将数据一位一位的依次发送到TXDn,这样PC就可以从总线上依次get到数据。
接收数据:
当pc的TXDn端将数据发送到总线后,arm获取RXDn的引脚电平依次get到数据,逐位放进接收移位器,再放入FIFO,写入内存。
当然,也可不使用fifo,直接让内存与移位器交互,不过这样会造成浪费内存资源,内存的频率是很高滴,降低了内存的吞吐量
s3c2440裸机-UART编程(一、UART硬件介绍及传输原理)的更多相关文章
- s3c2440裸机-时钟编程(二、配置时钟寄存器)
s3c2440裸机编程-时钟编程(二.配置时钟寄存器) 1.2440时钟时序 下图是2440时钟配置时序: 1.上电后,nRESET复位信号拉低,此时cpu还无法取指令工作. 2.nRESET复位信号 ...
- s3c2440裸机-时钟编程(一、2440时钟体系介绍)
1.总线框架 下图是2440的总线框架,其中有AHB(Advanced High performance Bus)高速总线,APB(Advanced Peripheral Bus)外围总线. 不同总线 ...
- s3c2440裸机-异常中断(一. 异常、中断的原理与流程)
1.异常中断概述 在arm架构的处理器中,cpu有7中工作模式,2中工作状态. 1.CPU模式(Mode): 7种Mode: 除了usr/sys,其他5种都是异常模式.我们知道中断属于异常的2中,中断 ...
- s3c2440裸机-UART编程(二、UART编程实现)
UART编程 1.初始化 我们的2440支持3个UART串口,以uart0为例讲解. 那么我们需要实现以下这几个函数完成串口的最基本功能: (1)uart0_init()用于初始化串口 (2)putc ...
- Win32 API UART编程
下面是一个使用Win32 API进行UART编程的简单示例. #include <windows.h> #include <stdio.h> int WINAPI WinMai ...
- s3c2440裸机-代码重定位(2.编程实现代码重定位)
代码重定位(2.编程实现代码重定位) 1.引入链接脚本 我们上一节讲述了为什么要重定位代码,那么怎么去重定位代码呢? 上一节我们发现"arm-linux-ld -Ttext 0 -Tdata ...
- 四、s3c2440 裸机开发 通用异步收发器UARN
四.通用异步收发器UARN 原文地址 http://blog.csdn.net/woshidahuaidan2011/article/details/51137047 by jaosn Email: ...
- 【转载】s3c2440裸机开发调试环境(MDK4.6,Jlink v8,mini2440)
用于arm裸机程序开发的IDE基本有 以下3个:MDK,IAR,还有ADS.具体它们的具体情况在这里我就不多说了,百度一下就明白了.由于之前开发c51,stm32时候都使用了MDK开发环境,而且MDK ...
- linux上使用J-Link调试S3C2440裸机代码
linux上使用J-Link调试S3C2440裸机代码 工具: segger的jlink仿真器 segger的jlink for linux 交叉编译工具链里面的arm-xx-linux-xx-gdb ...
随机推荐
- 利用keras自带房价数据集进行房价预测
import numpy as np from keras.datasets import boston_housing from keras import layers from keras imp ...
- 【1】基于OpenCV的DLL动态库隐式连接
1DLL的作用 DLL是一个包含可由多个程序同时使用的代码和数据的库.例如:在Windows操作系统中,Comdlg32 DLL执行与对话框有关的常见函数.因此,每个程序都可以使用该DLL中包含的功能 ...
- jQuery 源码解析(二十五) DOM操作模块 html和text方法的区别
html和text都可以获取和修改DOM节点里的内容,方法如下: html(value) ;获取匹配元素集合中的一个元素的innerHTML内容,或者设置每个元素的innerHTML内容, ...
- ELK:ElasticSearch中有数据,Kibana查询不到数据
ElasticSearch中有数据,Kibana查询不到数据 多数原因就是Linux的时区问题, 在linux输入date查看当前时间是否根本地相对应,不对应那么你就来对了, 解决方案一. 这个选择的 ...
- code snippet:依赖属性propa的小技巧
很早之前就玩过VS里面的code snippet,相当方便. 今天在用prop自动属性代码时,无意中用了一下propa,然后就自动出来了依赖属性的代码片段,太方便了,尤其是对于WPF新手来说,比如我这 ...
- MyBatis框架之第一篇
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis.201 ...
- iOS中截取字符串指定位置
直接上代码: NSString *string = @"今天是个好日子,忘记穿秋裤了"; NSString *string1 = [];//截取掉下标7之后的字符串 NSStrin ...
- sqlserver的表变量在没有预估偏差的情况下,与物理表可join产生的性能问题
众所周知,在sqlserver中,表变量最大的特性之一就是没有统计信息,无法较为准备预估其数据分布情况,因此不适合参与较为复杂的SQL运算.当SQL相对简单的时候,使用表变量,在某些场景下,即便是对表 ...
- [转载]MGR变量group_replication_primary_member
组复制的状态变量只有一个,目前在8.0.17这个版本上还是存在的,未来会被废弃掉,我们在单主的模式下,可以用来查看哪个节点是读写节点. mysql: [Warning] Using a passwor ...
- pycharm报错:Process finished with exit code -1073741819 (0xC0000005)解决办法
这个是几个月前的问题了,有小伙伴在CSDN问我咋解决的,那我今天在这边把这个问题解决办法分享下吧,免得大家把很多时间都浪费在安装排坑上面,有些坑虽然解决了还真不知道啥原因. 我的pycharm一直用的 ...