查看UART在硬件上的信息,阅读JZ2440原理图可以看到:


  JZ2440开发板的UART0是可以跟USB相接的,用于打印调试,UART1,UART2两个串口用来外接模块。所以本文仅对UART0进行操作。

从上图可以看到,UART0的TXD0和RXD0对应GPH2和GPH3,硬件上获取的信息大概就就是这些,接下来对芯片手册的UART部分进行分析:


首先需要设置UART0的TXD0和RXD0引脚,对应的GPHCON,GPHDAT,GPHUP寄存器见下图:

    GPHCON: 将GPH2和GPH3分别设置为TXD0和RXD0

    GPHUP:  由于JZ2440的串口采用TTL标准,所以一开始应该是高电位,需要将相应引脚的电位上拉

         这里往GPHUP寄存的的bit3和bit2里写入1,即可完成设置。

    

下图是串口的结构图:

    1、发送过程:数据由内存传递到发送缓冲寄存器,再由发送移位器通过发送引脚TXD0将数据传递出去

    2、接收过程:外部数据通过接收引脚RXD0传至接收移位器,再由接收缓冲寄存器传递至内存中。

另外:这里选用非FIFO模式,所以移位寄存器一次只能传递1个字节


想要传输数据,波特率和数据格式肯定需要约定好,下面对波特率和数据格式的设置进行分析:

a、波特率

  阅读下方图片中波特率的说明,可以知道:波特率发生器的设定与UBRDIV0和UART clock有关,UART clock这里选用PCLK=50MHz

波特率选用115200,根据公式UBRDIVn = (int)( UART clock / ( buad rate x 16) ) -1可以计算出:       

        UBRDIV0  = (int)(50000000 / (115200 x 16) ) -1
               = (int)(27.1) -1 (四舍五入到最接近的整数)
               = 27 -1 =


UART clock选择:选用PCLK


b、数据格式

这里采用8位数据位,无校验位,1位停止位,即 8n1


阅读芯片手册发现,UTRSATA0寄存器用来判断UART0是否发送/接收完成:  

   当bit [2]为1时表明发送完成了

   当bit [0]为0时表明接收完成了   


传输模式寄存器:这里采用中断/查询模式


根据发送/接收缓冲寄存器的描述,可以发现:JZ2440采用小字节序,UTXH0和URXH0都是按1个字节发送或者接收。


对UART0的分析大概就是这些了,要实现以上的描述,离不开程序:

uart.c

 /* UART0的初始化,以及UART0打印调试函数 */
#include "s3c2440_soc.h"
void uart0_init(void) //串口0初始化函数
{
/* 设置UART0串口的引脚
** GPHCON寄存器的bit[7:6]为10(GPH3为RXD[0]),bit[5:4]为10(GPH2为TXD[0])
** 因为开发板串口采用TTL标准,GPHUP寄存器对应的bit[2]和bit[3]需要设置为电位上拉
*/
GPHCON &=~((<<)|(<<)); //先清零
GPHCON |= ((<<)|(<<));
GPHUP &=~((<<)|(<<)); //对应bit使能上拉 /* 设置波特率
** UBRDIVn = (int)( UART clock / ( buad rate x 16) ) –1
** UART的时钟默认采用PCLK=50MHz
** UBRDIV0 = (int)( 50000000 / ( 115200 x 16) ) –1 = 26
*/ UBRDIV0 = ; /* 设置数据发送格式:数据位为8位,无校验位,停止位1位,即8n1
** 设置ULCON0寄存器,bit[5:3]为000,bit2为0,bit[1:0]为11
** 即ULCON0=0x00000003
*/ ULCON0 = 0x00000003; /* 设置发送和接收模式为中断/查询模式:
** UCON0寄存器的bit[3:2]为01,bit[1:0]为01,UCON0=0x00000005;
*/ UCON0 = 0x00000005;
} /* 串口的输入和输出 */ /* 根据UART的发送和接收状态位寄存器 UTRSTAT0 的状态,判断发送/接收完成与否
** 发送:看bit[2]的状态,当bit[2]为1时表明发送完成了
** 接收:看bit[0]的状态,当bit[0]为0时表明接收完成了
** 发送缓冲寄存器UTXH0,接收缓冲寄存器URXH0
*/
int putchar(int c)
{
while(!(UTRSTAT0 & (<<))); //当发送缓冲寄存器和发送移位器不是空的时候,循环等待
UTXH0 = (unsigned char)c; //反之,当上一个发送完了,再向发送缓冲寄存器写入字符(这里是按单个字节发送)
}
int getchar(void)
{
while(!(UTRSTAT0 & (<<))); //当接收缓冲寄存器是空的时候,循环等待
return URXH0; //当接收缓冲寄存器非空的时候,返回接收缓冲寄存器得到的值
}
int puts(const char *s)
{
while (*s) //当*s有内容时
{
putchar(*s); //调用putchar函数
s++; //让s指针加1
} }

自定义头文件 uart.h :

 #ifndef     _UART_H                // 如果某个文件第一次包含这个头文件,_UART_H这个宏没有定义时
#define _UART_H // 定义_UART_H这个宏 void uart0_init(void);
int putchar(int c);
int getchar(void);
int puts(const char *s); #endif

主程序 main.c

 #include "s3c2440_soc.h"
#include "uart.h"
int main(void)
{ unsigned char c;
uart0_init();
puts("Hello,world!\n\r");
while()
{
c=getchar(); // 从PC键盘上得到输入字符(串 )
if (c == '\r') // 换行处理 ,不论输入\n或者\r,都会换行并使光标到行首
{
putchar('\n');
}
if (c == '\n')
{
putchar('\r');
}
putchar(c); // 输出得到的字符(串 )到PC,PC屏幕会显示串口传过来的字符(串 )
}
return ;
}

makefile :

all:
arm-linux-gcc -c -o led.o led.c
arm-linux-gcc -c -o uart.o uart.c
arm-linux-gcc -c -o main.o main.c
arm-linux-gcc -c -o start.o start.S
arm-linux-ld -Ttext start.o led.o uart.o main.o -o uart.elf
arm-linux-objcopy -O binary -S uart.elf uart.bin
arm-linux-objdump -D uart.elf > uart.dis
clean:
rm *.bin *.o *.elf *.dis

这里只列出了部分文件,上传所有文件到 linux 编译后,得到uart.bin文件,烧写到JZ2440开发板,可以实现简单的打印调试功能,见下图:

JZ2440开发板:UART(串口)使用(学习笔记)的更多相关文章

  1. JZ2440开发板:用按键点亮LED灯(学习笔记)

    本文是对韦东山嵌入式第一期学习的记录之一,如有您需要查找的信息,可以继续往下阅读. 想要用按键点亮LED灯,就需要知道按键和LED灯的相关信息,这样才可以进行之后的操作.阅读JZ2440的原理图,可以 ...

  2. JZ2440开发板:修改ARM芯片时钟(学习笔记)

    想要修改ARM芯片的时钟,需要去查询芯片手册和原理图,获取相关的信息(见下方图片) 首先来看时钟的结构图 根据结构图可以看出,时钟源有两种选择:1. XTIpll和XTOpll所连接的晶振 2. EX ...

  3. Linux学习 :移植U-boot_2016.09到JZ2440开发板

    一.下载源码:ftp://ftp.denx.de/pub/u-boot/ 二.初始化编译: ①新建一个单板: cd board/samsung/ cp smdk2410 smdk2440 -rf   ...

  4. Linux学习 :移植U-boot_2012.04.01到JZ2440开发板

    一.下载U-boot源码:ftp://ftp.denx.de/pub/u-boot/ 二.uboot的启动过程: 部分硬件初始化——>加载完整uboot到RAM——>跳转到第二阶段入口开始 ...

  5. 基于JZ2440开发板编写bootloader总结(一)

    凡走过必留下痕迹,学点什么都会有用的. 本系列博文总结了自己在学习嵌入式Linux编程过程中的收获,若有错误,恳请指正,谢谢! --参考教材韦东山系列教材 bootloader 是一个用于启动linu ...

  6. 《Node.js开发实战详解》学习笔记

    <Node.js开发实战详解>学习笔记 ——持续更新中 一.NodeJS设计模式 1 . 单例模式 顾名思义,单例就是保证一个类只有一个实例,实现的方法是,先判断实例是否存在,如果存在则直 ...

  7. Jz2440开发板熟悉

    title: Jz2440开发板熟悉 tags: ARM date: 2018-10-14 15:05:56 --- 概述 外部晶振为12M Nand Flash 256M,Nor Flash 2M, ...

  8. 《Cocos2d-x游戏开发实战精解》学习笔记4--实战一个简单的钢琴

    上一节学习了使用Cocos2d-x播放音乐的方法,但是那种方法一般只适合于播放较大的音乐,而一般比较短小的音乐(如游戏中的打斗.按键音效等)则要通过playEffect来播放.本节使用该方法以及之前学 ...

  9. 《Cocos2d-x游戏开发实战精解》学习笔记3--在Cocos2d-x中播放声音

    <Cocos2d-x游戏开发实战精解>学习笔记1--在Cocos2d中显示图像 <Cocos2d-x游戏开发实战精解>学习笔记2--在Cocos2d-x中显示一行文字 之前的内 ...

随机推荐

  1. PHP:通过MVC,实现第三方登录(百度)

    这里,仓鼠将手把手记录下来实现第三方登录的流程,这里以百度为例 百度开发者中心-官方网址:传送门. 所有第三方接口都不支持本地调试,只有真实的项目和服务器才有可能申请成功. 所以申请的资料全部都要填写 ...

  2. S/4HANA生产订单的标准状态和透明工厂原型状态的映射

    事务码CO03查看生产订单的状态: 从下面的界面能看出S/4HANA里生产订单在任意时刻可能存在多个状态: 生产订单的ID和状态ID的关系是1:N,维护在数据库表VSAUFK里: 如何把上述SAP系统 ...

  3. bzoj2336 [HNOI2011]任务调度

    Description 正解:搜索+随机化. 先写个搜索,枚举所有没有要求的任务属于哪一种任务,然后再用爬山来更新最优解. 具体来说就是先把所有先做任务$A$的按照$a$时间从大到小排序,先做任务$B ...

  4. xampp安装及使用时的问题总结

    本文主要介绍易错点,具体安装过程可参考链接1 1.首先要以管理员身份运行,否则报错. 2.如果你的网站首页名字不是index,那么你在访问的时候就必须输入你首页的全称. 3.htdocs就是网站的根目 ...

  5. MyBatis(8)延迟加载&缓存

    什么是延迟加载? resultMap可以实现高级映射,association,collection具有延迟加载的功能.   当我们需要查询某个信息的时候,再去查询,达到按需查询,就是延迟加载   可以 ...

  6. JS中的prototype (转载)

    JS中的prototype   JS中的phototype是JS中比较难理解的一个部分 本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是 ...

  7. flex布局兼容性写法

    CSS样式 flex:定义布局为盒模型 flex-v:盒模型垂直布局 flex-1:子元素占据剩余的空间 flex-align-center:子元素垂直居中 flex-pack-center:子元素水 ...

  8. Linux关于scp命令

    声明:本文主要转自https://www.2cto.com/os/201503/379474.html scp主要应用场景如下: (1)必要时,每个季度或者每月将数据由这台服务器传输到另外一台,不过前 ...

  9. JSON数据转换之net.sf.json包的使用

    转载 解析json之net.sf.json https://blog.csdn.net/itlwc/article/details/38442667 一.介绍 使用之前需要导入的jar包: json- ...

  10. [转]MFC子线程更改图像数据后更新主窗口图像显示方法

    程序思路是由外部的输入输出控制卡发出采集图像信号,之后相机采集图像得到图像数据指针,接收图像数据指针创建成图像最后显示到MFC对话框应用程序的Picture Control控件上,同时,为了标定相机位 ...