ARM裸编程系列---UART

时间:2022-12-15 14:32:07

S5PV210 UART说明

通用异步收发器缩写UART,这是UNIVERSAL ASYNCHRONOUS RECEIVER AND TRANSMITTER。它被用来传送串行数据。当发送数据,CPU将并行数据写入UART,UART依照一定的格式在一根电线上串行发出;接收数据 时。UART检測还有一根电线的信号,将串行收集在缓冲区中。CPU就可以读取UART获得这些数据。

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

S5PV210的uart结构图例如以下:

ARM裸编程系列---UART

UART使用标准的TTL/CMCOS逻辑电平来表示数据,为了增强数据抗干扰能力和提高传输长度,通常将TTL/CMOS逻辑电平转换为RS-232逻辑电平,查看原理图可知Mini210S使用的是MAX3232SOP芯片,使用的是TX0和DX0:

ARM裸编程系列---UART

搜索“XuTXD0”,可知:

ARM裸编程系列---UART

通过设置UART相关寄存器。我们就能够驱动UART工作,达到发送和接收字符的目的。

样例:

int main()
{
char c;
uart_init(); // 初始化串口
while (1)
{
c = getc (); // 接收一个字符c
putc(c+1); // 发送字符c+1
}
return 0;
}

在main函数中。先会调用uart_init()初始化UART。然后使用getc接收PC发过来的字符,再调用putc()将该字符+1回复给PC。

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

上述代码共同拥有3个步骤。以下我们来一一解说每个步骤:

第一步 配置引脚用于RX/TX功能

參考UART引脚连接图,我们须要设置GPA0CON和GPA1CON寄存器使GPA0和GPA1引脚用于UART功能。

ARM裸编程系列---UART

ARM裸编程系列---UART

第二步 设置数据格式等

<1> ULCON0用来设置数据格式,见下图

ARM裸编程系列---UART

Word Length = 11,8bit的数据;

Number of Stop Bit = 0,1bit的停止位;

Parity Mode = 000,无校验;

Infrared Mode =0,使用普通模式;

所以ULCON0=0x3

<2> 9UCON0是UART的配置寄存器。见下图

ARM裸编程系列---UART

ARM裸编程系列---UART

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

<3> UFCON0和UMCON0

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

第三步 设置波特率

波特率即每秒传输的数据位数。涉及两个寄存器:UBRDIV0和UDIVSLOT0

ARM裸编程系列---UART

ARM裸编程系列---UART

波特率设置相关公式:UBRDIVn + (num of 1’s in UDIVSLOTn)/16 = (PCLK / (bps x 16)) ?1

当中,由Maximum Operating Frequency for Each Sub-block图可知。UART工作于PSYS下,所以PCLK即PCLK_PSYS = 66.5MHz,我们的波特率bps设置为115200,所以

(66.5MHz/(115200 x 16)) – 1 = 35.08 = UBRDIVn + (num of 1’s in UDIVSLOTn)/16,所以我们设置UBRDIV0=35。UDIVSLOT0=0x1

getc()和putc()的代码例如以下:

// 接收一个字符

char getc(void)

{

while ((UFSTAT0 & 0xff) == 0); // 假设RX FIFO空,等待

return URXH0; // 取数据

}

// 发送一个字符

void putc(char c)

{

while (UFSTAT0 & (1<<24)); // 假设TX FIFO满,等待

UTXH0 = c; // 写数据

}

ARM裸编程系列---UART

ARM裸编程系列---UART

ARM裸编程系列---UART

通 过读UTRSTAT0 发送/接收状态寄存器,当Receive buffer data ready= 1时说明接收到数据,读URXH0寄存器能够得到8bit的数据;当Transmitter empty = 1时说明能够发送数据,写8bit的数据到UTXH0。

完整代码地址:https://github.com/zhouhui321/gec210-nos/tree/master/uart_putchar

版权声明:本文博主原创文章,博客,未经同意不得转载。

ARM裸编程系列---UART的更多相关文章

  1. ARM NEON 编程系列2 - 基本指令集

    ARM NEON 编程系列2 - 基本指令集 前言 本系列博文用于介绍ARM CPU下NEON指令优化. 博文github地址:github 相关代码github地址:github NEON指令集 主 ...

  2. ARM NEON编程系列1-导论

    ARM NEON 编程系列1 - 导论 前言 本系列博文用于介绍ARM CPU下NEON指令优化. 博文github地址:github 相关代码github地址:github NEON历史 ARM处理 ...

  3. 关于在arm裸板编程时使用printf问题的解决方法

    在ARM裸板驱动编程中,是不允许程序直接调用C库程序的.为什么呢?因为此时kernel还没有被加载,所以在封装在kernel层的C库的API是用不了的,那怎么办? 在开发过程中,printf的功能我不 ...

  4. ARM的体系结构与编程系列博客——ARM处理器系列介绍

    ARM处理器系列介绍 现在到了3月,过年过得过于舒服了.系列博客也停更了近半月,我果然是个慢(lan)性(gui)子,那么趁着到校的第一天晚上,就写一篇博客来继续我的系列博客了!众所周知,ARM处理器 ...

  5. ARM裸板开发:04&lowbar;MMU 链接地址与运行地址不一致时,(SDRAM)初始化程序地址无关码问题的分析

    ARM裸板开发过程,程序的链接地址设置为为0x30000000,而前期的启动代码以及相关硬件的初始化代码需要在内部iRAM(steppingstone,起始地址0x0)的4K中运行.链接地址与运行地址 ...

  6. &lbrack; 高并发&rsqb;Java高并发编程系列第二篇--线程同步

    高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...

  7. 猫哥网络编程系列:HTTP PEM 万能调试法

    注:本文内容较长且细节较多,建议先收藏再阅读,原文将在 Github 上维护与更新. 在 HTTP 接口开发与调试过程中,我们经常遇到以下类似的问题: 为什么本地环境接口可以调用成功,但放到手机上就跑 ...

  8. 猫哥网络编程系列:详解 BAT 面试题

    从产品上线前的接口开发和调试,到上线后的 bug 定位.性能优化,网络编程知识贯穿着一个互联网产品的整个生命周期.不论你是前后端的开发岗位,还是 SQA.运维等其他技术岗位,掌握网络编程知识均是岗位的 ...

  9. 【linux草鞋应用编程系列】&lowbar;6&lowbar; 重定向和VT100编程

    一.文件重定向     我们知道在linux shell 编程的时候,可以使用文件重定向功能,如下所示: [root@localhost pipe]# echo "hello world&q ...

随机推荐

  1. 阿里云accessKey如何创建?~ 2015&period;08&period;25

    选择导航条上面的ACCESSKeys(工单服务左边,我一开始也没注意到) 创建一下,然后同意 验证一下 收工

  2. NoSQL和Redis简介及Redis在Windows下的安装和使用教程

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/103.html?1455869099 NoSQL简介 介绍redis前,我 ...

  3. 支持向量机 support vector machine

    SVM(support Vector machine) (1) SVM(Support Vector Machine)是从瓦普尼克(Vapnik)的统计学习理论发展而来的,主要针对小样本数据进行学习. ...

  4. RHCA442学习笔记-Unit11内存缓存

      Unit 11 Memory Caches 内存缓存           学习目标:                 A. 使用内存来改善运行慢的子系统的服务时间.   11.1 Strategi ...

  5. 记录一下MYSQL的SQL语法

    这是加时间的语法 update  mylog set  mydate= DATE_ADD( mydate, INTERVAL 13 HOUR) WHERE mydate BETWEEN '2014-0 ...

  6. &lbrack;Python&rsqb;网络爬虫(二):利用urllib2通过指定的URL抓取网页内容

    版本号:Python2.7.5,Python3改动较大. 所谓网页抓取,就是把URL地址中指定的网络资源从网络流中读取出来,保存到本地. 类似于使用程序模拟IE浏览器的功能,把URL作为HTTP请求的 ...

  7. &lbrack;USACO07NOV&rsqb;电话线Telephone Wire

    [USACO07NOV]电话线Telephone Wire 时间限制: 1 Sec  内存限制: 128 MB 题目描述 电信公司要更换某个城市的网线.新网线架设在原有的 N(2 <= N &l ...

  8. fontFamily &&num;39&semi;Ionicons&&num;39&semi; is not a system font and has not been loaded through Expo&period;Font&period;loadAsync的问题

    import * as React from "react";import { Provider } from "mobx-react/native";impo ...

  9. python-函数入门&lpar;一&rpar;

    1.什么是函数: 可重复使用的,用来实现单一,或相关联功能的代码段. 函数分为内置函数和自定义函数,这里先讲自定义函数 2.如何定义函数: #语法 def 函数名(参数1,参数2,参数3,...): ...

  10. flex布局简介

    一.概述 浮动在移动布局中不再重要,flex盒模型越来越重要. flexbox经历过三个版本,主要区别是2009年到2012年之间的语法变化. 最新的语法和现在规范是同步的(例display:flex ...