1. 工作用户

uboot

2. u­boot 版本 1.1.4

3. 工具链 2.95.3

步骤

我们为开发板取名叫: crane2410, 并在 u­boot 中建立自己的开发板类型

修改 Makefile

[uboot@localhost uboot]#vi Makefile

#为 crane2410 建立编译项 crane2410_config : unconfig

@./mkconfig $(@:_config=) arm arm920t crane2410 NULL s3c24x0

各项的意思如下:

arm:              CPU 的架构(ARCH)

arm920t:      CPU 的类型(CPU),其对应于 cpu/arm920t 子目录。 crane2410: 开发板的型号(BOARD),对应于 board/crane2410 目录。 NULL:          开发者/或经销商(vender)。

s3c24x0:      片上系统(SOC)。

board 子目录中建立 crane2410

[uboot@localhost uboot]#cp ­rf board/smdk2410 board/crane2410 [uboot@localhost uboot]#cd board/crane2410

[uboot@localhost crane2410]#mv smdk2410.c crane2410.c

include/configs/中建立配置头文件

[uboot@localhost crane2410]#cd ../..

[uboot@localhost uboot]#cp include/configs/smdk2410.h include/configs/crane2410.h

指定交叉编译工具的路径

[uboot@localhost
uboot]#vi ~/.bashrc

export
PATH=/usr/local/arm/2.95.3/bin:$PATH

测试编译能否成功

[uboot@localhost
uboot]#make crane2410_config [uboot@localhost uboot]#make
CROSS_COMPILE=arm­linux­

3.2.6 修改 lowlevel_init.S 文件

依照开发板的内存区的配置情况, 修改 board/crane2410/lowlevel_init.S 文件,我的更改如下:

#include <config.h>

#include <version.h>

#define BWSCON 0x48000000

/* BWSCON */

#define DW8                (0x0)

#define DW16               (0x1)

#define DW32               (0x2)

#define WAIT               (0x1<<2)

#define UBLB               (0x1<<3)

#define B1_BWSCON          (DW16)

#define B2_BWSCON          (DW16)

#define B3_BWSCON          (DW16
+ WAIT + UBLB)

#define B4_BWSCON          (DW16)

#define B5_BWSCON          (DW16)

#define B6_BWSCON          (DW32)

#define B7_BWSCON          (DW32)

/* BANK0CON */

#define B0_Tacs            0x3    /* 
0clk */

#define B0_Tcos            0x3    /*  0clk */

#define B0_Tacc            0x7    /* 14clk */

#define B0_Tcoh            0x3    /*  0clk */

#define B0_Tah             0x3    /* 
0clk */

#define B0_Tacp            0x3

#define B0_PMC             0x3    /* normal
*/

/* BANK1CON */

#define B1_Tacs            0x3    /* 
0clk */

#define B1_Tcos            0x3    /*  0clk */

#define B1_Tacc            0x7    /* 14clk */

#define B1_Tcoh            0x3    /*  0clk */

#define B1_Tah             0x3    /* 
0clk */

#define B1_Tacp            0x3

#define B1_PMC             0x0

#define B2_Tacs            0x0

#define B2_Tcos            0x0

#define B2_Tacc            0x7

#define B2_Tcoh            0x0

#define B2_Tah             0x0

#define

#define

B2_Tacp B2_PMC

0x0 0x0

#define

B3_Tacs

0x0

/*

0clk

*/

#define

B3_Tcos

0x3

/*

4clk

*/

#define

B3_Tacc

0x7

/*

14clk

*/

#define

B3_Tcoh

0x1

/*

1clk

*/

#define

B3_Tah

0x0

/*

0clk

*/

#define

B3_Tacp

0x3

/*

6clk

*/

#define

B3_PMC

0x0

/*

normal

*/

#define

B4_Tacs

0x0

/*

0clk

*/

#define

B4_Tcos

0x0

/*

0clk

*/

#define

B4_Tacc

0x7

/*

14clk

*/

#define

B4_Tcoh

0x0

/*

0clk

*/

#define

#define

#define

B4_Tah

B4_Tacp B4_PMC

0x0

0x0 0x0

/*

/*

0clk

normal

*/

*/

#define

B5_Tacs

0x0

/*

0clk

*/

#define

B5_Tcos

0x0

/*

0clk

*/

#define

B5_Tacc

0x7

/*

14clk

*/

#define

B5_Tcoh

0x0

/*

0clk

*/

#define

#define

#define

B5_Tah

B5_Tacp B5_PMC

0x0

0x0 0x0

/*

/*

0clk

normal

*/

*/

#define

#define

B6_MT

B6_Trcd

0x3 0x1

/*

SDRAM

*/

#define
B6_SCAN

0x1

/*

9bit */

#define B7_MT

#define
B7_Trcd

#define
B7_SCAN

0x3 0x1 0x1

/*

/*

/*

SDRAM
*/

3clk */ 9bit */

/* REFRESH parameter

#define
REFEN

*/

0x1

/*

Refresh enable

*/

#define
TREFMD

#define
Trp

#define
Trc

#define
Tchr

#define
REFCNT

0x0

0x0 0x3 0x2 1113

/*

/*

/*

/*

/*

CBR(CAS before

2clk */ 7clk */ 3clk */

period=15.6us,

RAS)/Auto
refresh */

HCLK=60Mhz,
(2048+1-15.6*60)
*/

               

/**************************************/

_TEXT_BASE:

.word  TEXT_BASE

.globl
lowlevel_init lowlevel_init:

/* memory control configuration */

/* make r0 relative the current
location so that it */

/* reads SMRDATA out of FLASH rather than memory ! */ ldr   r0, =SMRDATA

ldr    r1, _TEXT_BASE
sub   r0, r0, r1

ldr    r1, =BWSCON   /* Bus Width Status Controller */ add          r2, r0, #13*4

0:

ldr     r3, [r0], #4

str     r3, [r1], #4

cmp     r2, r0

bne     0b

/* everything
is fine now */ mov    pc,
lr

.ltorg

/* the literal pools origin */

SMRDATA:

.word (0+(B1_BWSCON<<4)+(B2_BWSCON<<8)+(B3_BWSCON<<12)+(B4_BWSCON<<16)+(B5_BWSCON<<20)+(B6_BWSCON<<24)+(
B7_BWSCON<<28))

.word ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC))

.word ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC))

.word ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC))

.word ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC))

.word ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC))

.word ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC))

.word
((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN))

.word
((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN))

.word
((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT)

.word 0x31

.word 0x30

.word 0x30

UBOOT 的 Nand Flash 移植

UBOOT 的 Nand Flash 支持见第七部分的第 3 节.

 重新编译
u-boot

[uboot@localhost
uboot1.1.4]make CROSS_COMPILE=arm­linux­

u-boot
烧入 flash

1. 通过仿真器烧入 u­boot

通过仿真器 u­boot 烧写到 flash 中就可以从 NAND flash 启动了. 2. 通过 JTAG 接口,由工具烧入
flash

uboot 的移植过程的更多相关文章

  1. 【课程分享】深入浅出嵌入式linux系统移植开发 (环境搭建、uboot的移植、嵌入式内核的配置与编译)

    深入浅出嵌入式linux系统移植开发 (环境搭建.uboot的移植.嵌入式内核的配置与编译) 亲爱的网友,我这里有套课程想和大家分享,假设对这个课程有兴趣的,能够加我的QQ2059055336和我联系 ...

  2. uboot的启动过程-FDT

    uboot的启动过程,省略了汇编部分之后,第一个执行函数是board_init_f(),在uboot/common目录的board_f.c中   board_init_f函数,首先初始化了全局数据 # ...

  3. 【Linux开发】OpenCV在ARM-linux上的移植过程遇到的问题4---共享库中嵌套库带路径【已解决】

    [Linux开发]OpenCV在ARM-linux上的移植过程遇到的问题4-共享库中嵌套库带路径[已解决] 标签:[Linux开发] 紧接着上一篇,我居然又尝试了一下编译opencv,主要是因为由于交 ...

  4. OpenCV在ARM-linux上的移植过程遇到的问题3---共享库中嵌套库居然带路径【未解决】

    [Linux开发]OpenCV在ARM-linux上的移植过程遇到的问题3-共享库中嵌套库居然带路径[未解决] 标签(空格分隔): [Linux开发] 移植opencv到tq2440 一.下载open ...

  5. 18.17 U-Boot+内核移植

    18.17.1 移植U-Boot-2012.04.08 1.下载.建立source insight工程.编译.烧写.如果无运行分析原因. $ .tar.bz2 $ cd u-boot- $ make ...

  6. linux内核移植过程问题总结

    移植内核:2.6.30.4内核根目录下的.config为当前配置内核的且已经配置好的内核配置.make zImage以此为依据配置内核的过程:cd linux-2.6.30.4(进入Linux根目录) ...

  7. UBOOT启动内核过程

    1.摘要 (1).启动4步骤第一步:将内核搬移到DDR中第二步:校验内核格式.CRC等第三步:准备传参第四步:跳转执行内核(2).涉及到的主要函数是:do_bootm和do_bootm_linux(3 ...

  8. 从零开始之uboot、移植uboot2017.01(二、从入口分析流程)

    原创: To_run_away 从零开始学linux 本节的开始之前,先看一下uboot的链接脚本. 一.链接脚本 /* * Copyright (c) 2004-2008 Texas Instrum ...

  9. 【cocos2d-x-3.1.1列2】cocos2d-x3.1.1 安卓移植过程

    Evernote的链接: http://app.yinxiang.com/l/AAXeIjFsjjFAC68i6hUQkiwFFZg3Maz-AkA/ cocos2d-x 3.1.1  win移植到a ...

随机推荐

  1. BZOJ 3083: 遥远的国度 (树剖+线段树)

    传送门 解题思路 前两个操作都比较基础.对于第三个操作分类讨论一下,首先如果当前根不是要操作点的子树,那么就无影响,直接查询操作点的子树即可.第二种是当前根是操作点的子树,那就找到当前根到操作点这条链 ...

  2. NX二次开发-将工程图上的每个视图导出PNG图片

    大概思路是将每个视图导出PDF,在调另一个项目的EXE(PDF转PNG) //ExportDrawViewPng // Mandatory UF Includes #include <uf.h& ...

  3. PaperWeekly 第五期------从Word2Vec到FastText

    PaperWeekly 第五期------从Word2Vec到FastText 张俊 10 个月前 引 Word2Vec从提出至今,已经成为了深度学习在自然语言处理中的基础部件,大大小小.形形色色的D ...

  4. opencv-角点检测之Harris角点检测

    转自:https://blog.csdn.net/poem_qianmo/article/details/29356187 先看看程序运行截图:   一.引言:关于兴趣点(interest point ...

  5. RCC, Reset and Clock Control

  6. Day15:Python 【模块】及__name__:

    什么是模块: 在Python中,随着这代码的撰写,代码越来越长,所以产生了,模块这个概念,模块是什么?模块就是一个.py文件,在撰写代码时,我们把不同的功能的代码封装到一个.py文件里,用得时候导入 ...

  7. uoj74 【UR #6】破解密码

    题目 发现这个题的本质就是在做\(\rm hash\) 我们显然能够列出\(n\)个方程,之后高消,这是\(O(n^3)\)的 但是观察一下第一个和第二个方程 \[a_{1}26^{n-1}+a_{2 ...

  8. ES6 学习 -- 箭头函数(=>)

    (1).只有一个参数且只有一句表达式语句的,函数表达式的花括号可以不写let test = a => a; // 只有一个参数a,这里的表达式相当于 "return a" ( ...

  9. .Net串口通讯中的若干问题(C#多串口硬件识别、热插拔、Close方法报错问题、IsOpen的可靠性问题)

    一.需求场景 最近有时间静下心来研究SDK,串口通讯的.要求实现识别cp210x和cp2303驱动的两款硬件,并且2303的优先级高,即有2303识别之,没有再识别210x:要求实现热插拔,拔掉自动断 ...

  10. 用多线程发送邮箱(一次给一个用户发送N封邮件)

    前台不用写,后台执行方法就可以了. namespace SendMail { public partial class SendMail_Page : System.Web.UI.Page { pro ...