我们通过RS232来做实验。

通过电平转换芯片,

连接至核心板:

即:GPA0_0  GPA0_1     配置引脚为串口专用模式:

然后看

ULCONn  [31:0]       0x3

设置串口一帧传输数据的一帧对应的数据位为8倍,1位停止位,无奇偶校验位

UCONn  [31:0]     0x5

选择串口收发的模式为polling模式

UFCONn  [31:0]  0x0

选择传输的模式为非FIFO模式

UMCONn [31:0] 0x0

禁用硬件流控

UBRDIVn Specifies baud rate divisor
UFRACVALn Specifies divisor fractional value

用于控制波特率

目前采用的时钟源是100Mhz,一会再来验证。

UBRDIVn  =  (100000000 / 115200 / 16 - 1 ) = 53.253472222222222222222222222222   取整数

UFRACVALn = (53.2534722 - 53 )*16 = 4.05555      取整数

即配置为波特率为115200

UTRSTATn
从串口接收一个字节的数据:

读寄存器:

发送一个字节的数据,等待发送缓存寄存器无要发送的数据

写入寄存器:

 #ifndef TINY4412_LIB_H_
#define TINY4412_LIB_H_ typedef unsigned int u32;
typedef unsigned short u16;
typedef unsigned char u8; extern u32 read32(u32 reg);
extern u16 read16(u32 reg);
extern u8 read8(u32 reg);
extern void write8(u8 val, u32 reg);
extern void write16(u16 val, u32 reg);
extern void write32(u32 val, u32 reg); #define udelay ((void (*)(int))0x43e26480)
#define printf(...) (((int (*)(const char *, ...))0x43e11a2c)(__VA_ARGS__)) #endif

lib.h

编写uart.c

 #include <uart.h>
#include <stdarg.h> /*串口0的初始化*/
void uart0_init(void)
{
u32 val; /*设置GPA0[0:1]引脚为串口0专用的收发引脚*/
val = read32(GPA0CON);
val &= ~0xff;
val |= 0x22;
write32(val, GPA0CON); /*设置串口传输数据的一帧对应的数据位为
8位,1位停止位,无奇偶校验位*/
write32(0x3, ULCONn); /*选择串口收发的模式为polling模式*/
write32(0x5, UCONn); /*选择传输的模式为非FIFO模式*/
write32(0x0, UFCONn); /*禁用硬件流控*/
write32(0x0, UMCONn); /*设置波特率为115200, 根据手册1399的公式推出*/
write32(, UBRDIVn);
write32(, UFRACVALn); /*时钟源的选择: MPLL_USER_T, MPLL*/
val = read32(CLK_SRC_PERIL0);
val &= ~0xf;
val |= 0x6;
write32(val, CLK_SRC_PERIL0); /*分频*/
val = read32(CLK_DIV_PERIL0);
val &= ~0xf;
val |= 0x7;
write32(val, CLK_DIV_PERIL0);
} void uputchar(int ch)
{
/*等待发送缓存寄存器无要发送的数据*/
while (!(read32(UTRSTATn) & 0x2)) {
;
} write8(ch, UTXHn); if (ch == '\n') {
uputchar('\r');
}
} /*从串口接收一个字节的数据*/
int ugetchar(void)
{
int val; /*等待串口控制器接收到有效数据*/
while (!(read32(UTRSTATn) & 0x1)) {
;
} val = read8(URXHn);
if (val == '\r') {
val = '\n';
} uputchar(val); return val;
} char *ugets(char *buf)
{
int ch; char *tmp = buf; while ((ch = ugetchar()) != '\n') {
*tmp++ = ch;
} *tmp = '\0'; return buf;
} void uputs(const char *buf)
{
while (*buf) {
uputchar(*buf);
buf++;
}
} /*93 --> "5d"*/
void xtoa(int n, char *buf)
{
int i;
if (n < ) {
if (n < ) {
buf[] = '' + n;
} else {
buf[] = n - + 'a';
}
buf[] = '\0'; return;
} xtoa(n/, buf); for (i = ; buf[i] != '\0'; i++); if ((n%) < ) {
buf[i] = (n%) + '';
} else {
buf[i] = (n%) - + 'a';
} buf[i+] = '\0';
} /*93 --> "93" */
void itoa(int n, char *buf)
{
int i; if (n < ) {
buf[] = n + '';
buf[] = '\0';
return;
} itoa(n/, buf); for (i = ; buf[i] != '\0'; i++) {
;
} buf[i] = (n%) + '';
buf[i+] = '\0';
} void uprintf(const char *fmt, ...)
{
int val;
va_list va;
char buf[]; va_start(va, fmt); while (*fmt) {
if (*fmt == '%') {
fmt++;
switch (*fmt) {
case 'c':
uputchar(va_arg(va, int));
break;
case 'd':
val = va_arg(va, int);
if (val < ) {
uputchar('-');
val = - val;
}
itoa(val, buf);
uputs(buf);
break;
case 'x':
val = va_arg(va, int);
xtoa(val, buf);
uputs(buf);
break;
case 's':
uputs(va_arg(va, char *));
break;
default:
break;
}
} else {
uputchar(*fmt);
} fmt++;
}
}

uart.c

测试用例就直接调用uprintf可以测试所有功能。

exynos4412—UART裸板复习的更多相关文章

  1. exynos4412—CMU裸板复习

    本章描述了Exynos 4412 SCP的时钟管理单元(CMUs).在Exynos 4412 SCP中,CMUs控制相位锁相环(PLLs),并为CPU.总线和单个ip的功能时钟生成系统时钟.它们还与电 ...

  2. 裸板驱动总结(makefile+lds链接脚本+裸板调试)

    在裸板2440中,当我们使用nand启动时,2440会自动将前4k字节复制到内部sram中,如下图所示: 然而此时的SDRAM.nandflash的控制时序等都还没初始化,所以我们就只能使用前0~40 ...

  3. [转载非常好的文章]JLink+GDBServer调试S3C6410裸板的初始化代码 For OK6410开发板

    要调试裸板,有两种初始化方法,一个是用烧好的uboot初始化,再有就是直接用JLink+GDBServer初始化.代码参考了网上的资料,根据手头的OK6410开发板做了修改.整体代码如下: # Con ...

  4. arm裸板驱动总结(makefile+lds链接脚本+裸板调试)

    在裸板2440中,当我们使用nand启动时,2440会自动将前4k字节复制到内部sram中,如下图所示: 然而此时的SDRAM.nandflash的控制时序等都还没初始化,所以我们就只能使用前0~40 ...

  5. 裸板中中断异常处理,linux中断异常处理 ,linux系统中断处理的API,中断处理函数的要求,内核中登记底半部的方式

    1.linux系统中的中断处理  1.0裸板中中断异常是如何处理的?     以s5p6818+按键为例          1)按键中断的触发        中断源级配置            管脚功 ...

  6. S5PV210裸板驱动:启动

    以往2440和6410的启动方式,只要我们把裸板代码烧写到NAND FLASH的开始位置,当开发板上点启动时,处理器会自动从NAND FLASH上拷贝前面一段的代码到内部的RAM中执行.按照以前的方法 ...

  7. 嵌入式 hi3518c裸板uboot烧写、kernel烧写、fs烧写小结

    1.在uboot中我可以添加自己的命令,添加的方法是找到一个uboot的命令,然后模仿着去增加属于自己的命令代码以及实现函数就可以 2.记住在使用printf进行调试的时候,在遇到指针或者字符串的时候 ...

  8. uboot-tiny4412启动流程(下)----如何将自己的裸板测试程序加入uboot中启动测试

    今天在工作上搞了一天高通的芯片uboot程序,目的是希望将一个裸板的程序移植到uboot中,并且开机让它运行.这个芯片是NXP4330,目前是高通的一个芯片,基于ARM-contexA9架构,那么就跟 ...

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

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

随机推荐

  1. c#编程指南(三) 泛型委托(Generic Delegate)

    泛型委托实际上就是一个.NET Framework预定义的委托,基本涵盖了所有常用的委托,所以一般不用用户重新声明啦. 很简单,看下面简单的小例子: //void method(); Action t ...

  2. 关于单一网络适配器拓扑TMG

    单网络适配器拓扑的功能 在单网络适配器拓扑中可以实现有限的 Forefront TMG 功能,其中包括: 针对 HTTP.HTTPS 和 CERN 代理 FTP 的正向 (CERN) 代理(仅限下载) ...

  3. 为什么S/4HANA的销售订单创建会触发生产订单的创建

    调用S/4HANA销售订单创建函数SD_SALES_DOCU_MAINTAIN创建一个销售订单时,会触发生产订单的创建. 销售订单的每个行项目对应一个独立的生产订单,SD_SALES_DOCU_MAI ...

  4. 上海大智慧某站未授权访问&SQL注入

    详细说明: 注入:禁用JS,http://dzh.com.cn/admin/userlist.phphttp://dzh.com.cn/admin/editUser.php?username=test ...

  5. Service Fabric eShop On Containers

    Service Fabric承载eShop On Containers 从模块化到微服务化 从Pet Shop 到eShop on Container都是Microsoft在技术演进的路径上给开发者展 ...

  6. Thread Costs

    https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/Multithreading/CreatingTh ...

  7. JSON解析问题

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/quanqinayng/article/details/25121955 这是data.chatFil ...

  8. PHP------面向对象的特性

    面向对象的特性 一.面向对象有三大特性: 封装.继承.多态.(非常重要,第一要记住!!!!!!!!!!) 二.封装 封装就是用来做类的,把一个类封装起来.做类不能随便的做.我们做类不能随便去写一个类, ...

  9. Myeclipse 自带Tomcat启动8080端口占用

    在启动Myeclipse自带的Tomcat发现报错,显示8080端口被占用 第一步:window+r 组合键,调出命令窗口. 第二步:输出命令:netstat -ano|findstr 8080   ...

  10. POJ 1845 Sumdiv 【二分 || 逆元】

    任意门:http://poj.org/problem?id=1845. Sumdiv Time Limit: 1000MS Memory Limit: 30000K Total Submissions ...