u-boot分析(八)----串口初始化

u-boot分析(八)

  上篇博文我们按照210的启动流程,分析到了内存初始化,今天我们继续按照u-boot的启动流程对串口的初始化进行分析。

今天我们会用到的文档:

1.        2440芯片手册:http://download.csdn.net/detail/wrjvszq/8358949

2.        6410芯片手册:http://download.csdn.net/detail/wrjvszq/8358965

3.        210芯片手册:S5PV210_UM_REV1.1(我的不知道为什么传不上去大家去百度搜吧)

 

串口的初始化比较简单,我们今天会通过以下几点,对串口的初始化进行介绍:

1.      串口通信协议分析

2.      编程分析

 

l  串口通信协议分析

相信搞过单片机的对串口并不陌生,我下面仅仅是复习一下串口通信协议。

1.       RS232接口

我们常见的串口是九帧的串口如下图

注:上面为公头,下面为母头

其接口定义如下:

1.        DCD   载波检测

2.        RXD   接收数据

3.        TXD   发送数据

4.        DTR   数据终端准备

5.        GND  信号地

6.        DSR   数据设备准备好

7.        RTS   请求发送

8.        CTS   清除发送

9.        RI    振铃指示

注:红色标注的三个管脚最为重要

2.       异步串口通信协议

下图是其工作模式:

其各个位的意义如下:

l  起始位:先发出一个逻辑”0”的信号,表示传输字符的开始。

l  数据位:有效数据。

l  奇偶校验位:来校验资料传送的正确性。

l  停止位:它是一帧数据的传输结束。

l  空闲位:处于逻辑“1”状态,表示当前线路上没有资料传送。

l  波特率:表示每秒钟传送的二进制位数。

3.       数据发送接收过程

l  发送过程:

把数据发送到fifo中,fifo把数据发送到移位寄存器,然后在时钟脉冲的作用下,往串口线上发送一位bit数据。

l  接收过程:

接收移位寄存器接收到数据后,将数据放到fifo中,接受fifo事先设置好触发门限,当fifo中数据超过这个门限时,就触发一个中断,然后调用驱动中的中断服务函数,把数据写到flip_buf中。

l  编程分析

1.       初始化流程:

按照以往的经验去手册找其的初始化流程,但是没有找到,可以通过在网上查找资料,或者对照u-boot我们可以总结出通用的串口初始化流程:

1)        设置引脚工作模式

2)        设置数据格式

3)        设置工作模式(DMA,轮询,中断)

4)        设置波特率

2.       代码分析

通过上面的流程我们就不难理解u-boot的代码,大家可以自己分析:

 1 /*
 2  * uart_asm_init: Initialize UART in asm mode, 115200bps fixed.
 3  * void uart_asm_init(void)
 4  */
 5 uart_asm_init:
 6 
 7     /* set GPIO(GPA) to enable UART */
 8     @ GPIO setting for UART
 9     ldr    r0, =ELFIN_GPIO_BASE
10     ldr    r1, =0x22222222
11     str       r1, [r0, #GPA0CON_OFFSET]
12 
13     ldr     r1, =0x2222
14     str     r1, [r0, #GPA1CON_OFFSET]
15 
16     // HP V210 use. SMDK not use.
17 #if defined(CONFIG_VOGUES)
18     ldr    r1, =0x100
19     str    r1, [r0, #GPC0CON_OFFSET]
20 
21     ldr    r1, =0x4
22     str    r1, [r0, #GPC0DAT_OFFSET]
23 #endif
24 
25     ldr    r0, =ELFIN_UART_CONSOLE_BASE        @0xEC000000
26     mov    r1, #0x0
27     str    r1, [r0, #UFCON_OFFSET]
28     str    r1, [r0, #UMCON_OFFSET]
29 
30     mov    r1, #0x3
31     str    r1, [r0, #ULCON_OFFSET]
32 
33     ldr    r1, =0x3c5
34     str    r1, [r0, #UCON_OFFSET]
35 
36     ldr    r1, =UART_UBRDIV_VAL
37     str    r1, [r0, #UBRDIV_OFFSET]
38 
39     ldr    r1, =UART_UDIVSLOT_VAL
40     str    r1, [r0, #UDIVSLOT_OFFSET]
41 
42     ldr    r1, =0x4f4f4f4f
43     str    r1, [r0, #UTXH_OFFSET]        @'O'
44 
45     mov    pc, lr

 

 

 

转载于:https://www.cnblogs.com/wrjvszq/p/4237498.html

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

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

相关文章

linux 开启防火墙的指定端口

2019独角兽企业重金招聘Python工程师标准>>> 通过下面的命令可以开启允许对外访问的网络端口: /sbin/iptables -I INPUT -p tcp --dport 8011 -j ACCEPT #开启8011端口 /etc/rc.d/init.d/iptables save #保存配置 /etc/rc.d/init.d/iptables restart #…

纽曼皮尔逊准则Matlab实现,纽曼-皮尔逊准则,Neyman Pearson Criterion,在线英语词典,英文翻译,专业英语...

胡安曼纽尔方吉奥(阿根廷) 世界冠军 - 1951, 1954-1957参加大奖赛次数: 51 赢得分站赛冠军次数: 22 赢得杆位数: 27很多人都把方吉奥看作是最伟大的车手。在整整七个赛季的f1比赛中(他为了从一场几乎致命的事故中康复而错过了一个赛季),他获得了五次世界总冠军的头衔…

SpriteBuilder中的粒子系统属性

一个粒子发射器可以有2种模式,放射状和重力的(radial or gravity) 放射状模式允许你去使用发射器创建粒子旋涡状环绕在指定位置的效果。 当启用重力效果,你可以使得粒子在任何方向任意飞行,曲线或直线,有重力或无重力。 注意&…

Java:JDK安装

访问Oracle网站www.oracle.com/technetwork/java/javase/downloads下载jdk安装JDK时,不建议安装在有空格的路径名下,例如该目录c:\Program Files设置执行路径:在我的电脑_高级选项_环境变量中将jdk/bin的绝对路径加入到PATH中,以分…

基于matlab 宗晓萍,基于ADAMS和MATLAB的机械臂控制仿真

基于ADAMS和MATLAB的机械臂控制仿真宗晓萍;李月月【期刊名称】《微计算机信息》【年(卷),期】2009(000)035【摘要】运用多体系统动力学分析软件ADAMS建立虚拟模型,运用MATLAB 建立控制方案,对虚拟模型进行控制,将两者结合起来对二自由度机械臂关节角度进行控制,结果表明ADAMS和…

[转载]服务器和应用系统迁移方案

服务器和应用系统迁移方案 一、迁移方案总体思路 新旧系统的迁移是一个整体系统工程。迁移必须保证用户系统建设的相关要求,在迁移过程中,我们需要重点考虑几个问题: 1、数据迁移如何保障“业务中断停机时间”。业务中断对用用户无论是生产环…

记录知识点或技术方案信息

1 ActiveReports .NET报表控件的领导者 2 SignalR :.Net使用SignalR实现消息推送功能(聊天室) 3 Modernizr:在我们使用HTML5/CSS3技术的时候,如何更好地处理不支持HTML5/CSS3特性的旧版本浏览器问题;如果你正在使用最新的HTML5/CSS3来构建你…

Erlang 位串和二进制数据

http://blog.chinaunix.net/xmlrpc.php?rblog/article&uid25876834&id3300393 因为在本人工作中,服务端Erlang和客户端的flash通信都是发送二进制数据(协议)来通信,Erlang处理起来二进制数据真的很方便,在空余…

关于webstorm 配置 banbel

2019独角兽企业重金招聘Python工程师标准>>> file type : javascript files scope: project files program: ..............appData\Roaming\npm\babel.cmd argumemt: $FileName$ --out-file $FileNameWithoutExtension$.js -s ps: --out-put 输出es5 格式的文件 …

php imap 附件,学习猿地-PHP-imap 使用参考

1. 相关资料php-imap 用于获取邮件 ,但是没有详细的官方文档 ,在这里整理一份分享给大家composer require php-imap/php-imap2. php-imap 成员2.1 构造方法参数说明示例$imapPath服务地址{imap.163.com:143}$login登录名email163.com$password登录密码**…

微信朋友圈广告详细说明

根据官方发布的微信广告系统介绍,朋友圈广告来源于微信广告的一部分,与公众号广告形成了一整个体系。关于公众号的广告,简单说,他可以把微信公众号变成广告牌,会根据用户的阅读习惯以及个人信息来进行广告的投放。每一…

EasyExcel 导出文件的格式化

阿里开源的这个库,让 Excel 导出不再复杂(既要能写,还要写的好看) 之前聊了 EasyExcel 的内容导出,本文主要说一下导出文件的格式化,格式化包括工作表/单元格样式和内容格式化。毕竟,有时候还是…

JSON数组分配输出每个li

有这么一个JSON数组,需求是只需要输出每个数组里面的某个值,不需要全部输出来。 var data [ {"MachineID":"171914","Cost":"13,642.41","Currency":"PHP" }, {"MachineID":&qu…

[BZOJ 3236] [Ahoi2013] 作业 [BZOJ 3809] 【莫队(+分块)】

题目链接: BZOJ - 3236 BZOJ - 3809 算法一:莫队 首先,单纯的莫队算法是很好想的,就是用普通的第一关键字为 l 所在块,第二关键字为 r 的莫队。 这样每次端点移动添加或删除一个数字,用树状数组维护所求的…

武汉理工大学java,武汉理工大学 web技术基础

计算机网络是现代通信技术与计算机技术相结合的产物,Internet则是计算机网络的最具体的应用。Web服务是最主要的网络服务,几乎一提到Internet,就会想到Web技术。本课程将介绍互联网的发展历史,最新的科学进展,Web的工作…

mysql多实例

mysql的多实例有两种方式可以实现,两种方式各有利弊。第一种是使用多个配置文件启动不同的进程来实现多实例,这种方式的优势逻辑简单,配置简单,缺点是管理起来不太方便。第二种是通过官方自带的mysqld_multi使用单独的配置文件来实…

oracle闪回某个时间点的数据库,oracle11g 使用闪回查询恢复表到过去某一个时间点...

一、新建测试表并插入数据:oracle二、模拟表数据误删并提交:测试三、使用闪回查询来查误删前表的数据:(表误删是在15:08分左右误删,所以在15:08分以前表的数据仍是在的):spa四、用如今的数据与误删前的数据作对比&…

opengl微开发之1-从零開始

对OpenGL有一点了解之后,如今開始真正编写代码。 今天的内容: 使用FreeGLUT创建OpenGL的上下文环境 初始化GLEW 创建一个OpenGL的的模板范例 第一步: 一个OpenGL的上下文能够同意我们传递命令究竟层硬件,所以须要一个上下文环境。…

Git客户端(Windows系统)的使用(Putty)(转)

本文环境: 操作系统:Windows XP SP3 Git客户端:TortoiseGit-1.8.14.0-32bit 一、安装Git客户端 全部安装均采用默认! 1. 安装支撑软件 msysgit: http://msysgit.github.io/ 当前最新版本为v1.9.5。 2. 安装TortoiseGit 首先&#…

oracle只舍不入,Oracle常识基础(一)

一.Oracle数据类型1.字符数据类型.> char:可以存储字母数字值,长度在1到2000个字节。.> varchar2:存储可变长度的char类型字符串,大小在1到4000个字节范围内。.> long:存储可变长度的字符数据,最多存储2GB。long类型的使用限制:*********…