今天成功编译uboot并在我的开发板上移植成功。
参考文章: http://blog.chinaunix.net/u1/34474/showart_410294.html
1.开发环境:
目标板:友善之臂
2410
(
sbc2410x
)
bootloader
:
u-boot 1.1.6
Crosscompile arm-linux-gcc- 3.3.2
配置好开发环境后,测试编译一下,看能不能编译通过。
#make sbc2410x_config
#make all
如果编译成功,并能够生成
uboot.bin
文件,那么之前搭建的开发环境是成功的。下面为了使
uboot
支持开发板的
nandflash
,还要修改源程序。
2.1
要修改的部分
由于
uboot 1.1.6
支持
sbc2410x
开发板(
/board/sbc2410x
),因此我直接修改
/board/sbc2410x/
目录下的源文件,使之支持
nandflash
。
1.cpu/arm920t/start.s
2.board/sbc2410x/
目录下新建文件
nand_read.c
3.
修改
/board/sbc2410x/
目录下的
Makefile
文件,增加
nand_flash.o
文件。
4.include/configs/sbc2410x.h
2.2
具体程序的修改并移植
1
.
修改
cpu/arm920t/start.S
文件,因为
u-boot
的入口程序是
/cpu/arm920t/start.S,
故需在该程序中添加
nandflash
的复位程序,以及实现从
nand
flash
中把
u-boot
搬移到
RAM
中的功能程序。
1
)在
copy_loop
之后,
stack_setup
之前添加
#ifdef CONFIG_S 3C 2410_NAND_BOOT
/*****
新添加的部分开始
*****/
#ifdef CONFIG_S 3C 2410_NAND_BOOT /*
这个一定要放在堆栈设置之前
*/
bl copy_myself
ldr r1, =on_the_ram
add pc, r1, #0
nop
nop
1: b 1b @ infinite loop
on_the_ram:
#endif
/*****
新添加的部分结束
*****/
2
)在
_start_armboot: .word start_armboot
命令之后添加一段程序
/*****
新添加的部分开始
*****/
#ifdef CONFIG_S 3C 2410_NAND_BOOT
copy_myself:
mov r10, lr
mov r1, #NAND_CTL_BASE
ldr r2, =0xf830
str r2, [r1, #oNFCONF]
ldr r2, [r1, #oNFCONF]
bic r2, r2, #0x800 @ enable chip
str r2, [r1, #oNFCONF]
mov r2, #0xff
strb r2, [r1, #oNFCMD]
mov r3, #0
1:add r3, r3, #0x1
cmp r3, #0xa
blt 1b
2:ldr r2, [r1, #oNFSTAT]
tst r2, #0x1
beq 2b
ldr r2, [r1, #oNFCONF]
orr r2, r2, #0x800 @ disable chip
str r2, [r1, #oNFCONF]
@ get read to call C functions (for nand_read())
ldr sp, DW_STACK_START @ setup stack pointer
mov fp, #0 @ no previous frame, so fp=0
@ copy vivi to RAM
ldr r0, =UBOOT_RAM_BASE
mov r1, #0x0 @
设置第二个参数:
nand flash
的起始地址
mov r2, #0x20000 @
设置第三个参数:
u-boot
的长度
(128k)
bl nand_read_ll @
调用
nand_read_ll()
,此函数定义在
borad/smdk2410/nand_read.c
中
tst r0, #0x0
beq ok_nand_read
#ifdef CONFIG_DEBUG_LL
bad_nand_read:
ldr r0, STR_FAIL
ldr r1, SerBase
bl PrintWord
1:b 1b @ infinite loop
#endif
ok_nand_read:
#ifdef CONFIG_DEBUG_LL
ldr r0, STR_OK
ldr r1, SerBase
bl PrintWord
#endif
@ verify
检查搬移后的数据,如果前
4k
完全相同,表示搬移成功
mov r0, #0
ldr r1, =UBOOT_RAM_BASE
mov r2, #0x400 @4 bytes * 1024 = 4K-bytes
go_next:
ldr r3, [r0], #4
ldr r4, [r1], #4
teq r3, r4
bne notmatch
subs r2, r2, #4
beq done_nand_read
bne go_next
notmatch:
#ifdef CONFIG_DEBUG_LL
sub r0, r0, #4
ldr r1, SerBase
bl PrintHexWord
ldr r0, STR_FAIL
ldr r1, SerBase
bl PrintWord
#endif
1:b 1b
done_nand_read:
#ifdef CONFIG_DEBUG_LL
ldr r0, STR_OK
ldr r1, SerBase
bl PrintWord
#endif
mov pc, r10
@ clear memory
@ r0: start address
@ r1: length
mem_clear:
mov r2, #0
mov r3, r2
mov r4, r2
mov r5, r2
mov r6, r2
mov r7, r2
mov r8, r2
mov r9, r2
clear_loop:
stmia r0!, {r2-r9}
subs r1, r1, #(8 * 4)
bne clear_loop
mov pc, lr
#endif @ CONFIG_S 3C 2410_NAND_BOOT
/*****
新添加的部分结束
*****/
3)
在文件的最后添加一段程序
/*****
新添加的部分开始
*****/
.align 2
DW_STACK_START:
.word STACK_BASE+STACK_SIZE-4
/*****
新添加的部分结束
*****/
2
在
board/sbc2410x
中加入
nand Flash
读函数,建立
nand_read.c
,供
start.S
调用,从
nand flash
中把
u-boot
拷贝到
RAM
。为如下内容
(copy from vivi)
:
#include <config.h>
#define __REGb(x) (*(volatile unsigned char *)(x))
#define __REGi(x) (*(volatile unsigned int *)(x))
#define NF_BASE 0x4e000000
#define NFCONF __REGi(NF_BASE + 0x0)
#define NFCMD __REGb(NF_BASE + 0x4)
#define NFADDR __REGb(NF_BASE + 0x8)
#define NFDATA __REGb(NF_BASE + 0xc)
#define NFSTAT __REGb(NF_BASE + 0x10)
#define BUSY 1
inline void wait_idle(void) {
int i;
while(!(NFSTAT & BUSY))
for(i=0; i<10; i++);
}
#define NAND_SECTOR_SIZE 512
#define NAND_BLOCK_MASK (NAND_SECTOR_SIZE - 1)
/* low level nand read function */
int nand_read_ll(unsigned char *buf, unsigned long start_addr, int size)
{
int i, j;
if ((start_addr & NAND_BLOCK_MASK) || (size & NAND_BLOCK_MASK)) {
return -1; /* invalid alignment */
}
/* chip Enable */
NFCONF &= ~0x800;
for(i=0; i<10; i++);
for(i=start_addr; i < (start_addr + size);) {
/* READ0 */
NFCMD = 0;
/* Write Address */
NFADDR = i & 0xff;
NFADDR = (i >> 9) & 0xff;
NFADDR = (i >> 17) & 0xff;
NFADDR = (i >> 25) & 0xff;
wait_idle();
for(j=0; j < NAND_SECTOR_SIZE; j++, i++) {
*buf = (NFDATA & 0xff);
buf++;
}
}
/* chip Disable */
NFCONF |= 0x800; /* chip disable */
return 0;
}
3.
修改
board/sbc2410x/Makefile
文件
OBJS :=sbc2410x.o flash.o nand_read.o
4.
修改
include/configs/sbc2410x.h
文件,添加如下内容:
在最后一个
#endif
之前添加如下程序:
/*******
新增部分开始
**********/
/* * Nandflash Boot */
#define CONFIG_S 3C 2410_NAND_BOOT 1 /*
支持从
nand flash
启动
*/
#define STACK_BASE 0x 33f 00000
#define STACK_SIZE 0x8000
#define UBOOT_RAM_BASE 0x 33f 80000
/* NAND Flash Controller */
#define NAND_CTL_BASE 0x4E000000
#define bINT_CTL(Nb) __REG(INT_CTL_BASE + (Nb))
/* Offset */
#define oNFCONF 0x00
#define oNFCMD 0x04
#define oNFADDR 0x08
#define oNFDATA 0x 0c
#define oNFSTAT 0x10
#define oNFECC 0x14
/*******
新增部分结束
**********/
2.3
重新编译源码
#make distclean
#make clean
#make sbc2410x_config
#make all
最后在
u-boot
根目录下生成
uboot.bin
文件。