<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 

开发环境:win7 64位 + VMware12 + Ubuntu14.04 64位

工具链:linaro提供的gcc-linaro-6.1.1-2016.08-x86_64_arm-linux-gnueabi

要移植的u-boot版本:u-boot-2016-11

Tiny4412开发板硬件版本为

    底板:  Tiny4412/Super4412SDK 1506

       核心板:Tiny4412 - 1412

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 

在上一节我们初始化完成了exynos4412的时钟,接下来把tiny4412的debug串口用起来。

1、Tiny4412 debug 串口电路原理图

参考:Tiny4412SDK-1506-Schematic.pdf

Tiny4412-1412-Schematic.pdf

从原理图上我们可看出,tiny4412的debug串口使用的uart0.

2、uart0初始化步骤

   1. 选择UART的时钟源

2.将所涉及的UART通道管脚设为UART功能

3. 设置波特率:UBRDIVn寄存器(UART BAUD RATE DIVISOR)、UFRACVALn寄存器

4. 设置传输格式:ULCONn寄存器(UART LINE CONTROL)

5. 设置UART工作模式:UCONn寄存器(UART CONTROL)

6. UFCONn寄存器(UART FIFO CONTROL)、UFSTATn寄存器(UART FIFO STATUS)

3、使用Tiny4412 Debug 串口uart0代码设置

diff --git a/arch/arm/dts/exynos4412-tiny4412.dts b/arch/arm/dts/exynos4412-tiny4412.dts

index 8822d52..a467250 100644

--- a/arch/arm/dts/exynos4412-tiny4412.dts

+++ b/arch/arm/dts/exynos4412-tiny4412.dts

@@ -14,73 +14,16 @@

model = "Tiny4412 based on Exynos4412";

compatible = "samsung,tiny4412", "samsung,exynos4412";

-   aliases {

-       i2c0 = "/i2c@13860000";

-       i2c1 = "/i2c@13870000";

-       i2c2 = "/i2c@13880000";

-       i2c3 = "/i2c@13890000";

-       i2c4 = "/i2c@138a0000";

-       i2c5 = "/i2c@138b0000";

-       i2c6 = "/i2c@138c0000";

-       i2c7 = "/i2c@138d0000";

-       serial0 = "/serial@13800000";

-       console = "/serial@13810000";

-       mmc2 = "/sdhci@12530000";

-       mmc4 = "/dwmmc@12550000";

+   chosen {

+       stdout-path = "serial0";

};

-   i2c@13860000 {

-       samsung,i2c-sda-delay = <100>;

-       samsung,i2c-slave-addr = <0x10>;

-       samsung,i2c-max-bus-freq = <100000>;

-       status = "okay";

+   aliases {

+       serial0 = "/serial@13800000";

+       console = "/serial@13800000";

};

-   serial@13810000 {

+   serial0:serial@13810000 {

status = "okay";

};

-

-   sdhci@12510000 {

-       status = "disabled";

-   };

-

-   sdhci@12520000 {

-       status = "disabled";

-   };

-

-   sdhci@12530000 {

-       samsung,bus-width = <4>;

-       samsung,timing = <1 2 3>;

-       cd-gpios = <&gpk2 2 0>;

-   };

-

-   sdhci@12540000 {

-       status = "disabled";

-   };

-

-   dwmmc@12550000 {

-       samsung,bus-width = <8>;

-       samsung,timing = <2 1 0>;

-       samsung,removable = <0>;

-       fifoth_val = <0x203f0040>;

-       bus_hz = <400000000>;

-       div = <0x3>;

-       index = <4>;

-   };

-

-   ehci@12580000 {

-       compatible = "samsung,exynos-ehci";

-       reg = <0x12580000 0x100>;

-       #address-cells = <1>;

-       #size-cells = <1>;

-       phy {

-           compatible = "samsung,exynos-usb-phy";

-           reg = <0x125B0000 0x100>;

-       };

-   };

-

-   emmc-reset {

-       compatible = "samsung,emmc-reset";

-       reset-gpio = <&gpk1 2 0>;

-   };

};

diff --git a/arch/arm/mach-exynos/lowlevel_init.c b/arch/arm/mach-exynos/lowlevel_init.c

index 1e090fd..361727d 100644

--- a/arch/arm/mach-exynos/lowlevel_init.c

+++ b/arch/arm/mach-exynos/lowlevel_init.c

@@ -215,11 +215,17 @@ int do_lowlevel_init(void)

if (actions & DO_CLOCKS) {

system_clock_init();

+

#ifdef CONFIG_DEBUG_UART

#if (defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_SERIAL_SUPPORT)) || \

!defined(CONFIG_SPL_BUILD)

+       #ifdef TINY4412

+       exynos_pinmux_config(PERIPH_ID_UART0, PINMUX_FLAG_NONE);

+       #else

exynos_pinmux_config(PERIPH_ID_UART3, PINMUX_FLAG_NONE);

+       #endif

debug_uart_init();

+       printascii("UART DEBUG enable .... !!!\n\r");

#endif

#endif

mem_ctrl_init(actions & DO_MEM_RESET);

diff --git a/configs/tiny4412_defconfig b/configs/tiny4412_defconfig

index 93917b9..19d0dda 100644

--- a/configs/tiny4412_defconfig

+++ b/configs/tiny4412_defconfig

@@ -24,6 +24,16 @@ CONFIG_CMD_FS_GENERIC=y

CONFIG_OF_CONTROL=y

#

+#DEBUG UART

+#

+CONFIG_DEBUG_UART=y

+CONFIG_SPL_SERIAL_SUPPORT=y

+CONFIG_SPL_GPIO_SUPPORT=y

+CONFIG_DEBUG_UART_S5P=y

+CONFIG_DEBUG_UART_BASE=0x13800000

+CONFIG_DEBUG_UART_CLOCK=100000000

+

+#

#NOTE:do not delete this:

#

# CONFIG_CMD_IMLS is not set

编译下载代码到SD卡,从SD卡启动后,tiny4412开发板的com0串口上会输出如下调试字符串:

UART DEBUG enable .... !!!

后面移植调试u-boot SPL部分的代码时候,可以通过串口打印log的方式进行,比之前的点亮LED灯调试可以获取到更多信息。

参考

1、《Exynos 4412 SCP_Users Manual_Ver.0.10.00_Preliminary.pdf》

2、《嵌入式Linux系统开发完全手册_基于4412_上册.pdf》

3、uboot_tiny4412-20130729

4、Tiny4412裸机程序之UART收发数据 http://www.techbulo.com/1555.html

X-006 FriendlyARM tiny4412 u-boot移植之Debug串口用起来的更多相关文章

  1. X-009 FriendlyARM tiny4412 uboot移植之SD Card用起来Kernel boot起来

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

  2. X-004 FriendlyARM tiny4412 uboot移植之点亮指路灯

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

  3. X-003 FriendlyARM tiny4412 uboot移植之添加相应目录文件

    X-003 FriendlyARM tiny4412 uboot移植之添加相应目录文件 <<<<<<<<<<<<<< ...

  4. X-007 FriendlyARM tiny4412 u-boot移植之内存初始化

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

  5. X-001 FriendlyARM Tiny4412 uboot移植前奏

    版权声明:本文为博主原创文章,转载请注明出处 开发环境:win7 64位 + VMware12 + Ubuntu14.04 64位 工具链:linaro提供的gcc-linaro-6.1.1-2016 ...

  6. 基于tiny4412的u-boot移植(一)

    作者信息 作者:彭东林 邮箱:pengdonglin137@163.com QQ: 405728433 平台介绍 开发环境:win7 64位 + VMware11 + Ubuntu14.04 64位 ...

  7. X-008 FriendlyARM tiny4412 uboot移植之copy u-boot到DDR内存

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

  8. X-010 FriendlyARM tiny4412 uboot移植之移植网卡驱动TFTP用起来

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

  9. X-005 FriendlyARM tiny4412 uboot移植之时钟初始化

    <<<<<<<<<<<<<<<<<<<<<<<<< ...

随机推荐

  1. linux shell 远程执行命令

    经常要部署多台服务器上面的应用,如果一个个机器的登录太麻烦. 所有就想到编写一个脚本来部署不同的服务器 前提条件: 配置ssh免登陆 如果不会的请参加我的另外一篇文章 http://blog.csdn ...

  2. windows程序设计(二)

    MFC架构组成 1.CWinApp的派生类 2.必须在全局区定义一个派生类的对象 3.在CWinApp派生类内必须要有InitInstance虚函数的重写函数 在MFC软件工程以App类中的InitI ...

  3. HDU 5768 Lucky7 (容斥原理 + 中国剩余定理 + 状态压缩 + 带膜乘法)

    题意:……应该不用我说了,看起来就很容斥原理,很中国剩余定理…… 方法:因为题目中的n最大是15,使用状态压缩可以将所有的组合都举出来,然后再拆开成数组,进行中国剩余定理的运算,中国剩余定理能够求出同 ...

  4. 笔记整理--Linux编程

    linux c编程open() read() write()函数的使用方法及实例 | 奶牛博客 - Google Chrome (2013/8/31 17:56:10) 今天把文件IO操作的一些东东整 ...

  5. Hibernate中,将session绑定到线程时,在保存和查询数据的代码里,要正确的关闭session

    比如有个保存的方法 // 保存 public void save(){ Transaction t = XXX Session s = getSession.beginTransaction(); X ...

  6. JavaBean--实例:注册验证

    通过JSP+JavaBean完成一个注册用户的验证功能: index.jsp: 注册信息填写页,同时对错误数据进行错误提示 check.jsp:将输入表单数据自动赋值给JavaBean,同时验证,失败 ...

  7. 【摘自网络】dll库和lib库有什么区别

    简单地讲:第一:.DLL是动态链接库,而.LIB是静态链接库dll是个编译好的程序,调用时可以直接调用其中的函数,不参加工程的编译. 而lib应该说是一个程序集, 只是把一些相应的函数总结在一起, 如 ...

  8. 安卓开发之探秘蓝牙隐藏API(转)

    源:http://www.cnblogs.com/xiaochao1234/p/3793172.html 上次讲解Android的蓝牙基本用法,这次讲得深入些,探讨下蓝牙方面的隐藏API.用过Andr ...

  9. iOS启动屏 ➕ 闪屏的方法

    转载自:http://www.starming.com/index.php?v=index&view=21 在- (BOOL)application:(UIApplication *)appl ...

  10. 关于HTTP_CLIENT_IP,HTTP_X_FORWAR

    HTTP_CLIENT_IP:可通过http头伪造HTTP_X_FORWARDED_FOR:可通过http头伪造REMOTE_ADDR:可能是用户真实IP也可能是代理IP 服务端获取IP地址 http ...