S5PV210 UART 相关说明

通用异步收发器简称 UART, 即 UNIVERSAL ASYNCHRONOUS RECEIVER AND TRANSMITTER,它用来传输串行数据。发送数据时, CPU 将并行数据写入 UART,UART 按照一定的格式在一根电线上串行发出;接收数据时, UART 检测另一根电线的信号,将串行收集在缓冲区中, CPU 即可读取 UART 获得这些数据。

在 S5PV210 中, UART 提供了 4 对独立的异步串口 I/O 端口,有 4 个独立的通道,每个通道可以工作于 DMA 模式或者中断模式。其中,通道 0 有 256byte 的的发送 FIFO 和 256byte 的接收 FIFO,通道 1 有 64byte 的的发送 FIFO 64byte 的接收 FIFO,而通道 2 和 3 只有 16byte 的的发送 FIFO 和 16byte 的接收 FIFO。

S5PV210 的 UART 结构图如下:

串口初始化程序

void uart_init()
{
/* 1 配置引脚用于 RX0/TX0 功能 */
GPA0CON = 0x22; /* 2 设置数据格式等 */
UFCON0 = 0x1; // 使能 FIFO
UMCON0 = 0x0; // 无流控
ULCON0 = 0x3; // 数据位:8, 无校验, 停止位: 1
UCON0 = 0x5; // 时钟: PCLK,禁止中断,使能 UART 发送、接收 /* 3 设置波特率 */
UBRDIV0 = UART_UBRDIV_VAL; // 34
UDIVSLOT0 = UART_UDIVSLOT_VAL; // 0xDFDD
}

程序分析:

第一步 配置引脚用于 RX0/TX0 功能

GPA0CON 寄存器如下图所示:

配置 GPA0CON = 0x22。

第二步 设置数据格式

ULCON0 寄存器如下图所示:

Word Length = 11,8bit 的数据;
Number of Stop Bit = 0,1bit 的停止位;
Parity Mode = 000,无校验;
Infrared Mode =0,使用普通模式;
所以 ULCON0 = 0x3。

第三步 配置 UART

UCON0 寄存器如下图所示:



Receive Mode = 01 ,使用中断模式或者轮询模式;
Transmit Mode = 01,使用中断模式或者轮询模式;
Send Break Signal = 0,普通传输;
Loop-back Mode = 0,不使用回环方式;
我们采用轮询的方式接受和发送数据,不使用中断,所以 bit[6-9]均为 0;
Clock Selection = 0,使用 PCLK 作为 UART 的工作时钟;
我们不使用 DMA,所以 bit[16]和 bit[20]均为 0;
所以 UCON0 = 0x5。

第四步 UFCON0 和 UMCON0

这两个寄存器比较简单, UFCON0 用来使能 FIFO, UMCON0 用来设置无流控。

第五步 设置波特率

主要是配置如下两个寄存器:

波特率设置相关公式:

UBRDIVn + (num of 1's in UDIVSLOTn)/16 = (PCLK / (bps x 16)) −1

UART 工作于 PSYS 下,所以 PCLK 即 PCLK_PSYS = 66MHz,我们的波特率 bps 设置为 115200,所以

(66MHz/(115200 x 16)) – 1 = 34.80 = UBRDIVn + (num of 1's in UDIVSLOTn)/16

所以,设置 UBRDIV0 = 34,num of 1's in UDIVSLOTn = 13。

根据下图得出 UDIVSLOTn 的值(友善的手册中直接用的(num of 1's in UDIVSLOTn)这个值):

轮询方式接收和发送一个字符

/* 接收一个字符 */
char getc(void)
{
while ((UFSTAT0 & 0xff) == 0); // 如果 RX FIFO 空,等待
return URXH0; // 取数据
}
/* 发送一个字符 */
void putc(char c)
{
while (UFSTAT0 & (1<<24)); // 如果 TX FIFO 满,等待
UTXH0 = c; // 写数据
}

通过读 UFSTAT0 发送/接收状态寄存器,当 Rx FIFO Count 不为 0 时说明接收到数据,读 URXH0 寄存器可以得到 8bit 的数据; 当 Tx FIFO Full = 0 时说明可以发送数据,写 8bit 的数据到 UTXH0。

UFSTAT0 寄存器如下图所示:

所做修改

在《友善之臂210手册》中,讲解的是通过 UTRSTAT0 这个 buffer state reg 来查看当前的状态,因为我们采用的 FIFO模式,并且 UTRSTAT0 与程序所用 Reg 也不符,所以手册中显然是错误的,我们写的分析是修改过的。(可能我参考的手册并不是友善之臂的最新版,没有检察出有此处小错误)

本篇文章参考:《友善之臂210手册》

S5PV210 串口配置与实验(轮询方式)的更多相关文章

  1. WPF非轮询方式更新数据库变化SqlDependency(数据库修改前台自动更新)

    上一章节我们讲到wpf的柱状图组件,它包含了非轮询方式更新数据库变化SqlDependency的内容,但是没有详细解释,现在给大家一个比较简单的例子来说明这部分内容. 上一章节: WPF柱状图(支持数 ...

  2. 14.4.9 Configuring Spin Lock Polling 配置Spin lock 轮询:

    14.4.9 Configuring Spin Lock Polling 配置Spin lock 轮询: 很多InnoDB mutexes 和rw-locks 是保留一小段时间,在一个多核系统, 它可 ...

  3. 负载均衡算法,轮询方式 大话设计模式之工厂模式 C#

    负载均衡算法,轮询方式 2018-04-13 17:37 by 天才卧龙, 13 阅读, 0 评论, 收藏, 编辑 学无止境,精益求精 十年河东,十年河西,莫欺少年穷 学历代表你的过去,能力代表你的现 ...

  4. CPU处理多任务——中断与轮询方式比较

    中断方式与轮询方式比较   中断的基本概念 程序中断通常简称中断,是指CPU在正常运行程序的过程中,由于预选安排或发生了各种随机的内部或外部事件,使CPU中断正在运行的程序,而转到为相应的服务程序去处 ...

  5. S5PV210 串口实验(中断方式)

    结合之前的串口实验(轮询方式)与中断体系分析,我们来做下中断方式的串口接收实验. start.S .global _start .global IRQ_handle _start: /* 关 Watc ...

  6. Apache的代理服务器的配置 (正向代理 ,反向代理,轮询调度)

    一. 代理服务器的了解1.代理服务器 代理服务器英文全称是Proxy Server,其功能就是代理网络用户去取得网络信息. Squid是一个缓存Internet 数据的软件,其接收用户的下载申请,并自 ...

  7. STM32F10x_硬件I2C主从通信(轮询发送,中断接收)

    Ⅰ.写在前面 关注我分享文章的朋友应该知道我在前面讲述过(软件.硬件)I2C主机控制从机EEPROM的例子.在I2C通信主机控制程序是比较常见的一种,可以说在实际项目中,很多应用都会使用到I2C通信. ...

  8. 误人子弟的网络,谈谈HTTP协议中的短轮询、长轮询、长连接和短连接

    引言 最近刚到公司不到一个月,正处于熟悉项目和源码的阶段,因此最近经常会看一些源码.在研究一个项目的时候,源码里面用到了HTTP的长轮询.由于之前没太接触过,因此LZ便趁着这个机会,好好了解了一下HT ...

  9. STM32学习笔记(五) USART异步串行口输入输出(轮询模式)

    学习是一个简单的过程,只要有善于发掘的眼睛,总能学到新知识,然而如何坚持不懈的学习却很困难,对我亦如此,生活中有太多的诱惑,最后只想说一句勿忘初心.闲话不多扯,本篇讲诉的是异步串行口的输入输出,串口在 ...

随机推荐

  1. VS中编译出现——计算机中丢失XINPUT1_4.dll解决办法

    如果用DX SDK 2010的版本,编译时可能就会出现这种问题. 解决办法,在链接库时把XInput.lib换成XINPUT9_1_0.LIB,重新编译就可以了. 用老操作系统 + 老DX SDK + ...

  2. discover功能--自动发现主机

    discover功能,让监控的管理更加管理和自动化,现在来演示下如何使用discover功能自动发现主机 1.配置discover 2.在被侦测机上安装zabbix agent 安装完成后,修改配置( ...

  3. EF6 学习笔记(二):操练 CRUD 增删改查

    EF6学习笔记总目录 ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 接上篇: EF6 学习笔记(一):Code First 方式生成数据库及初始化数据库实际操作 本篇原文链接: I ...

  4. STL中的容器介绍

    STL中的容器主要包括序列容器.关联容器.无序关联容器等. 一]序列容器 (1) vector vector 是数组的一种类表示,提供自动管理内存的功能,除非其他类型容器有更好满足程序的要求,否则,我 ...

  5. mysql windows 5.7 安装版下载地址

    https://dev.mysql.com/downloads/windows/installer/5.7.html

  6. Weex是如何让JS调用产生原生UIView的?

    从官方的Demo,我们知道,要在客户端显示Weex页面,是通过WXSDKInstance的实例实现的.我们先来看看这个类里面都有什么: @interface WXSDKInstance : NSObj ...

  7. ReactNative学习笔记(七)Navigator的使用

    前言 Navigator主要用于ReactNative中的跳转,中文文档: http://reactnative.cn/docs/0.39/using-navigators.html 懒得打字介绍更多 ...

  8. AndroidStudio环境安装与配置

    前言 大家好,给大家带来AndroidStudio环境安装与配置的概述,希望你们喜欢 AndroidStudio IDE下载 我们选择用Android Studio开发Android的App,Andr ...

  9. scrapy Data flow

    The data flow in Scrapy is controlled by the execution engine, and goes like this:1. The Engine gets ...

  10. H264三种码率控制方法(CBR, VBR, CVBR)

    CBR(Constant Bit Rate)是以恒定比特率方式进行编码,有Motion发生时,由于码率恒定,只能通过增大QP来减少码字大小,图像质量变差,当场景静止时,图像质量又变好,因此图像质量不稳 ...