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 #…

关于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 格式的文件 …

微信朋友圈广告详细说明

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

EasyExcel 导出文件的格式化

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

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 首先&#…

两道二分coming~

第一道:poj 1905Expanding Rods 题意:两道墙(距离L)之间架一根棒子,棒子受热会变长,弯曲,长度变化满足公式( s(1n*C)*L),求的是弯曲的高度h。 首先来看这个图…

十天学Linux内核之第七天---电源开和关时都发生了什么

十天学Linux内核之第七天---电源开和关时都发生了什么 原文:十天学Linux内核之第七天---电源开和关时都发生了什么说实话感觉自己快写不下去了,其一是有些勉强跟不上来,其二是感觉自己越写越差,刚开始可能是新鲜感以及很多读者的鼓励&#xf…

dede php 里加nofollow,织梦导航栏目如何加nofollow

很多用织梦程序做网站的朋友会发现,dedecms后台并没有直接加nofollow的选项。那如果想要给联系我们、关于我们等导航栏目加上nofollow该怎么解决呢?笔者在网上也找了一些资料,有通过修改数据库增加参数的方法,但没有成功。今天笔者…

【Cocos2d-Js实战教学(1)横版摇杆八方向移动】

本教程主要通过搭建一个横版摇杆八方向移动的实例,让大家如何用Cocos2dx-Js来做一款游戏,从基础了解Cocos2dx-Js的基本实现原理,从创建工程,到各个知识点的梳理。 教程分为上下两讲: 上讲有2个小节: 1&…

在单文档中显示我的第一个对话框

在单文档中显示我的第一个对话框 (2010-04-19 21:19:50) 转载▼标签: it 今天编写了在单文档中创建对话框以及调用对话框的代码,收获很多; 1:OnInitDialog函数的加载问题尤其是在VS上的加载;(这一点花了…

主机Window不能访问该虚拟机Linux Samba文件服务提供了一个文件夹

我最近遇到一个问题。虚拟机Linux中间Samba服务常开。主办“\\192.168.229.200” (我的虚拟机Linux址)訪问不了Share文件夹(/var/test),并且经过数次的重新启动,检查配置。再重新启动,都没法解决。后来突然想到了主机管…

Linux进程间通信(四) - 共享内存

共享内存的优势 采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝。对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,而共享内存则只拷贝两次数据&…

jQuery EasyUI使用教程之基本的拖放

2019独角兽企业重金招聘Python工程师标准>>> <jQuery EasyUI最新版下载> 本教程将为你展示如何使HTML元素可拖动。在这个示例中我们将创建3个DIV元素&#xff0c;然后使它们能够被拖动。 查看演示 首先&#xff0c;我们创建3个div元素&#xff1a; < div i…

在Linux中head命令,Linux 中 head 命令实例

原标题&#xff1a;Linux 中 head 命令实例head命令将每个文件的前10行打印到标准输出。对于多个文件&#xff0c;在每个文件前面加上一个给出文件名的头。如果没有文件&#xff0c;或者文件为-&#xff0c;则读取标准输入。如何使用head命令使用head显示/etc/passwd前十行内容…

【原创】Git删除暂存区或版本库中的文件

0 基础 我们知道Git有三大区&#xff08;工作区、暂存区、版本库&#xff09;以及几个状态&#xff08;untracked、unstaged、uncommited&#xff09;&#xff0c;下面只是简述下Git的大概工作流程&#xff0c;详细的可以参见本博客的其他有关Git的文章【链接】。&#xff08;1…

JMS

JMS即Java消息服务&#xff08;Java Message Service&#xff09;应用程序接口是一个Java平台中关于面向消息中间件&#xff08;MOM&#xff09;的API&#xff0c;用于在两个应用程序之间&#xff0c;或分布式系统中发送消息&#xff0c;进行异步通信。Java消息服务是一个与具体…

Android学习四、Android中的Adapter

一、Adapter的介绍 An Adapter object acts as a bridge between an AdapterView and the underlying data for that view. The Adapter provides access to the data items. The Adapter is also responsible for making a View for each item in the data set. 一个Adapter是…

linux select shell,linux之shell编程select和case用法

shell里的select用法&#xff1a;语法&#xff1a;#i/bin/bashselect 变量 in 列表do要执行的语句done举例&#xff1a;#!/bin/bashecho "What is your favourite OS?"select var in "windows" "Linux" "Gnu Hurd" "Free BSD&qu…