免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1252 | 回复: 0
打印 上一主题 下一主题

移植Uboot-1.3.2到QQ2440 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-25 12:01 |只看该作者 |倒序浏览

参考tekkman的uboot移植文章,讲解的非常详细;按照这个步骤修改,基本没出现什么大错;
感谢tekkman的共享!
http://blog.chinaunix.net/u1/34474/article_62956.html

[color="#000000"]一,准备工作
[color="#000000"]1 进入U-Boot目录,修改Makefile
[color="#000000"]smdk2410_config : unconfig
@$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
[color="#000000"]新建
[color="#000000"]qq2440_config : unconfig
@$(MKCONFIG) $(@:_config=) arm arm920t qq2440 NULL s3c24x0
[color="#ff0102"]2.在board文件夹下创建开发板qq2440目录
[color="#000000"]$cp -arf smdk2410/*   qq2440/$cd qq2440[color="#000000"]$mv smdk2410.c qq2440.c
[color="#000000"]修改makefile
[color="#000000"]3. 在include/configs/中建立配置头文件
[color="#000000"]$cp include/configs/smdk2410.h include/configs/qq2440.h
[color="#767676"]二,[color="#000000"]修改文件内容,[color="#000000"]适应QQ2440开发板
[color="#000000"]根据代码执行顺序
[color="#000000"]1 修改/cpu/arm920t/start.S
  (1)修改中断禁止部分
#if defined(CONFIG_S3C2400) || defined(CONFIG_S3C2410) || defined(CONFIG_S3C2440)
    ldr     r0, =pWTCON
    mov     r1, #0x0
    str     r1, [r0]
    /*
     * mask all IRQs by setting all bits in the INTMR - default
     */
    mov    r1, #0xffffffff
    ldr    r0, =INTMSK
    str    r1, [r0]
[color="#000000"]//添加或者直接替换s3c2410的
# if  defined(CONFIG_S3C2440)    ldr    r1, =0x7fff   //根据2440芯片手册,INTSUBMSK有15位可用    ldr    r0, =INTSUBMSK    str    r1, [r0]# endif
[color="#000000"](2)[color="#000000"]时钟设置
[color="#000000"]# if defined(CONFIG_S3C2400)
#  define pWTCON  0x15300000
#  define INTMSK  0x14400008 /* Interupt-Controller base addresses */
#  define CLKDIVN 0x14800014 /* clock divisor register */
#elif defined(CONFIG_S3C2410) || defined(CONFIG_S3C2440)
#  define pWTCON  0x53000000
#  define INTMSK  0x4A000008 /* Interupt-Controller base addresses */
#  define INTSUBMSK 0x4A00001C
#  define CLKDIVN 0x4C000014 /* clock divisor register */
/* 配置主频405M */
#define CLK_CTL_BASE        0x4C000000  /* clock */
#if defined(CONFIG_S3C2440)
#define MDIV_405       0x7f
/*FCLK:HCLK:PCLK = 1:4:8 */
ldr r0, =CLKDIVN
[color="#ff0000"] mov r1, #5
str r1, [r0]

mrc p15, 0, r1, c1, c0, 0  @ read ctrl register
orr r1, r1, #0xc0000000  @ Asynchronous  
mcr p15, 0, r1, c1, c0, 0  @ write ctrl register

[color="#ff0000"]#if defined(CONFIG_S3C2440)
    /*now, CPU clock is 405.00 Mhz   */
    mov    r1, #CLK_CTL_BASE
    mov    r2, #MDIV_405
    add    r2, r2, #PSDIV_405
    str    r2, [r1, #0x04]
#endif
[color="#000000"]#endif /* CONFIG_S3C2400 || CONFIG_S3C2410 || CONFIG_S3C2440*/
(3)[color="#0001ff"]将从Flash[color="#0001ff"]启动改成从NAND Flash[color="#0001ff"]启动
[color="#000000"]将以下U[color="#000102"]-Boot[color="#000102"]的重定向语句段:[color="#000102"]
[color="#000102"]#ifndef CONFIG_SKIP_RELOCATE_UBOOT[color="#000102"]
[color="#000102"]relocate:                /* relocate U-Boot to RAM        */[color="#000102"]
[color="#000102"]    adr    r0, _start        /* r0 [color="#000102"]替换成:[color="#000102"]
[color="#ff0102"]#ifdef CONFIG_S3C2440_NAND_BOOT   @tekkaman@@@@@@@@@@@@@@@@SSSSSSSSSSSSS[color="#ff0102"]
[color="#ff0102"]    @ reset NAND[color="#ff0102"]
[color="#ff0102"]    mov    r1, #NAND_CTL_BASE[color="#ff0102"]
[color="#ff0102"]    ldr    r2, =( (7
[color="#ff0102"]
[color="#000102"]在 “  _start_armboot:    .word start_armboot  ” [color="#000102"]后加入:
[color="#ff0102"]   .align     2[color="#ff0102"]
[color="#ff0102"]DW_STACK_START:  .word  STACK_BASE+STACK_SIZE-4
2.在board/qq2440/添加nand_read.c文件
在启动时,将uboot从nandflash拷贝到RAM执行的读取函数
#include
#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 NFCONT        __REGi(NF_BASE + 0x4)
#define NFCMD        __REGb(NF_BASE + 0x8)
#define NFADDR        __REGb(NF_BASE + 0xC)
#define NFDATA        __REGb(NF_BASE + 0x10)
#define NFSTAT        __REGb(NF_BASE + 0x20)
//#define GPDAT        __REGi(GPIO_CTL_BASE+oGPIO_F+oGPIO_DAT)
#define NAND_CHIP_ENABLE  (NFCONT &= ~(1
#define BUSY 4
inline void wait_idle(void) {
    while(!(NFSTAT & BUSY));
    NFSTAT |= BUSY;
}
#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 */
    }
    NAND_CHIP_ENABLE;
    for(i=start_addr; i
        /* Write Address */
        NFADDR = i & 0xff;
        NFADDR = (i >> 9) & 0xff;
        NFADDR = (i >> 17) & 0xff;
        NFADDR = (i >> 25) & 0xff;
        NAND_DETECT_RB;
        for(j=0; j
修改相关makefile
3.修改include/configs/qq2440.h
[color="#ff0102"]/*
* Nandflash Boot
*/
#define CONFIG_S3C2440_NAND_BOOT 1
#define STACK_BASE    0x33f00000
#define STACK_SIZE    0x8000
//#define UBOOT_RAM_BASE    0x33f80000
/* NAND Flash Controller */
#define NAND_CTL_BASE        0x4E000000
#define bINT_CTL(Nb)        __REG(INT_CTL_BASE + (Nb))
/* Offset */
#define oNFCONF            0x00
#define oNFCONT            0x04
#define oNFCMD            0x08
#define oNFADDR            0x0c
#define oNFDATA            0x10
#define oNFSTAT            0x20
#define oNFECC            0x2c
[color="#ff0102"]4. [color="#000000"]修改board/tekkaman/tekkaman2440/lowlevel_init.S文件
[color="#000102"]    [color="#000102"]依照开发板的内存区的配置情况[color="#000102"], [color="#000102"]修改[color="#000102"]board/qq2440/lowlevel_init.S[color="#000102"]文件,一般仿smdk2440的配置
[color="#ff0102"]......[color="#000102"]
[color="#000102"]/* REFRESH parameter */[color="#000102"]
[color="#000102"]#define REFEN             0x1    /* Refresh enable */[color="#000102"]
[color="#000102"]#define TREFMD             0x0    /* CBR(CAS before RAS)/Auto refresh */[color="#000102"]
[color="#ff0102"]#define Trp             0x2    /* 4clk */[color="#000102"]
[color="#000102"]#define Trc             0x3    /* 7clk */[color="#000102"]
[color="#000102"]#define Tchr             0x2    /* 3clk */[color="#000102"]
[color="#ff0102"]#define REFCNT             1012 [color="#000102"]   
[color="#ff0102"]5 [color="#000000"]修改[color="#000000"]/board/qq2440/qq2440.c
[color="#000102"]......
[color="#ff0102"]#elif FCLK_SPEED==1        /* Fout = 405MHz */[color="#ff0102"]
[color="#ff0102"]//#define M_MDIV    0x5c[color="#ff0102"]
[color="#ff0102"]//#define M_PDIV    0x4[color="#ff0102"]
[color="#ff0102"]//#define M_SDIV    0x0[color="#ff0102"]
[color="#ff0102"]#define M_MDIV    0x7f[color="#ff0102"]
[color="#ff0102"]#define M_PDIV    0x2[color="#ff0102"]
[color="#ff0102"]#define M_SDIV    0x1[color="#000102"]
[color="#000102"]......[color="#000102"]
[color="#000102"]#elif USB_CLOCK==1[color="#000102"]
[color="#ff0102"]//#define U_M_MDIV    0x48[color="#ff0102"]
[color="#ff0102"]//#define U_M_PDIV    0x3[color="#ff0102"]
[color="#ff0102"]#define U_M_MDIV    0x38[color="#ff0102"]
[color="#ff0102"]#define U_M_PDIV    0x2[color="#000102"]
[color="#000102"]#define U_M_SDIV    0x2
[color="#ff0102"]......
[color="#ff0102"]/* set up the I/O ports */[color="#000102"]
[color="#000102"]gpio->GPACON = 0x007FFFFF;[color="#ff0000"]
[color="#ff0000"]//gpio->GPBCON = 0x00044556;[color="#ff0000"]
[color="#ff0000"]gpio->GPBCON = 0x00055556;//gpb5,6,7,8为4个led输出
[color="#ff0102"]......[color="#ff0102"]
[color="#ff0102"]    /* arch number of S3C2440 -Board */[color="#000102"]
[color="#000102"]    gd->bd->bi_arch_number = [color="#ff0102"]MACH_TYPE_S3C2440[color="#000102"] ;
[color="#ff0102"]/* adress of boot parameters */
[color="#ff0102"]gd->bd->bi_boot_params = 0x30000100;
[color="#ff0102"]icache_enable();
[color="#ff0102"]dcache_enable();
[color="#ff0102"]return 0;
[color="#ff0102"]}
[color="#ff0102"]6 [color="#000000"]NAND Flash的读写需要的配置
/* * NAND flash settings* */
#if CONFIG_CMD_NAND // (CONFIG_COMMANDS & CFG_CMD_NAND)
#define CFG_NAND_BASE 0x4E000000 /* NandFlash控制器在SFR区起始寄存器地址 */
#define CFG_MAX_NAND_DEVICE 1 /* 支持的最在Nand Flash数据 */
#define SECTORSIZE 512 /* 1页的大小 */
#define NAND_SECTOR_SIZE SECTORSIZE
#define NAND_BLOCK_MASK 511/* 页掩码 */
#define ADDR_COLUMN 1 /* 一个字节的Column地址 */
#define ADDR_PAGE 3 /* 3字节的页块地址!!!!!*/
#define ADDR_COLUMN_PAGE 4 /* 总共4字节的页块地址!!!!! */
#define NAND_ChipID_UNKNOWN 0x00 /* 未知芯片的ID号 */
#define NAND_MAX_FLOORS 1
#define NAND_MAX_CHIPS 1
[color="#ff0102"]/* Nand Flash命令层底层接口函数 */
#define WRITE_NAND_COMMAND(d, adr) {rNFCMD = d;}
#define WRITE_NAND_ADDRESS(d, adr) {rNFADDR = d;}
#define WRITE_NAND(d, adr) {rNFDATA = d;}
#define READ_NAND(adr) (rNFDATA)
#define NAND_WAIT_READY(nand) {while(!(rNFSTAT&(1
[color="#ff0102"]#define WRITE_NAND_COMMANDW(d, adr) NF_CmdW(d)
[color="#ff0102"]/* the following functions are NOP's because S3C24X0 handles this in hardware */
[color="#ff0102"]#define NAND_CTL_CLRALE(nandptr)
#define NAND_CTL_SETALE(nandptr)
#define NAND_CTL_CLRCLE(nandptr)
#define NAND_CTL_SETCLE(nandptr)
/* 允许Nand Flash写校验 */
#define CONFIG_MTD_NAND_VERIFY_WRITE 1
[color="#ff0102"]#define rNFCONF (*(volatile unsigned int *)0x4e000000)
#define rNFCONT (*(volatile unsigned int *)0x4e000004)
#define rNFCMD (*(volatile unsigned char *)0x4e000008)
#define rNFADDR (*(volatile unsigned char *)0x4e00000c)
#define rNFDATA (*(volatile unsigned char *)0x4e000010)
#define rNFSTAT (*(volatile unsigned int *)0x4e000020)
#define rNFECC (*(volatile unsigned int *)0x4e00002c)
[color="#ff0102"]#endif    /* __CONFIG_H */

[color="#ff0102"]7、在多个文件中添加“CONFIG_S3C2440”,使得原来s3c2410的代码可以编译进来。
[color="#ff0102"](1)/include/common.h
[color="#ff0102"](2)/include/s3c24x0.h
[color="#ff0102"](3)/cpu/arm920t/s3c24x0/interrupts.c
[color="#ff0102"]在get_tbclk (void)添加 defined(CONFIG_VCMA9) || defined(CONFIG_S3C2440)
[color="#ff0102"](4)/cpu/arm920t/s3c24x0/serial.c;由于主频变化,这里波特率设置需要重新计算
[color="#ff0102"](5)/cpu/arm920t/s3c24x0/speed.c;根据原来2410的代码,修改匹配2440
[color="#ff0102"](1)/cpu/arm920t/s3c24x0/interrupts.c[color="#ff0102"]

[color="#ff0102"]8、[color="#000000"]在 include/linux/mtd/nand_ids.h的结构体nand_flash_ids加入[color="#000000"]
[color="#ff0102"]static struct nand_flash_dev nand_flash_ids[] = {
[color="#ff0102"]......
    {"Samsung K9F1208U0B",  NAND_MFR_SAMSUNG, 0x76, 26, 0, 3, 0x4000, 0},
[color="#000000"]......[color="#ff0102"]
[color="#ff0102"]};
[color="#ff0102"][color="#ff0102"]
[color="#ff0102"]9. board.c添加
#include

[color="#ff0102"][color="#ff0102"]

[color="#ff0102"]10 在/include/s3c24x0.h中加入2440 的NAND FLASH 寄存器定义和CAMDIVN定义:
[color="#ff0102"]......
[color="#ff0102"]typedef struct {
[color="#ff0102"]         S3C24X0_REG32   LOCKTIME;
[color="#ff0102"]         S3C24X0_REG32   MPLLCON;
[color="#ff0102"]         S3C24X0_REG32   UPLLCON;
[color="#ff0102"]         S3C24X0_REG32   CLKCON;
[color="#ff0102"]         S3C24X0_REG32   CLKSLOW;
[color="#ff0102"]         S3C24X0_REG32   CLKDIVN;
[color="#ff0102"]         S3C24X0_REG32   CAMDIVN;
[color="#ff0102"]} /*__attribute__((__packed__))*/ S3C24X0_CLOCK_POWER;
[color="#ff0102"]......
[color="#ff0102"]#if defined(CONFIG_S3C2410)
[color="#ff0102"]/* NAND FLASH (see S3C2410 manual chapter 6) */
[color="#ff0102"]typedef struct {
[color="#ff0102"]         S3C24X0_REG32   NFCONF;
[color="#ff0102"]         S3C24X0_REG32   NFCMD;
[color="#ff0102"]         S3C24X0_REG32   NFADDR;
[color="#ff0102"]         S3C24X0_REG32   NFDATA;
[color="#ff0102"]         S3C24X0_REG32   NFSTAT;
[color="#ff0102"]         S3C24X0_REG32   NFECC;
[color="#ff0102"]} /*__attribute__((__packed__))*/ S3C2410_NAND;
[color="#ff0102"]#endif
[color="#ff0102"]#if defined (CONFIG_S3C2440)
[color="#ff0102"]/* NAND FLASH (see S3C2440 manual chapter 6) */
[color="#ff0102"]typedef struct {
[color="#ff0102"]         S3C24X0_REG32   NFCONF;
[color="#ff0102"]         S3C24X0_REG32   NFCONT;
[color="#ff0102"]         S3C24X0_REG32   NFCMD;
[color="#ff0102"]         S3C24X0_REG32   NFADDR;
[color="#ff0102"]         S3C24X0_REG32   NFDATA;
[color="#ff0102"]         S3C24X0_REG32   NFMECC0;
[color="#ff0102"]         S3C24X0_REG32   NFMECC1;
[color="#ff0102"]         S3C24X0_REG32   NFSECC;
[color="#ff0102"]         S3C24X0_REG32   NFSTAT;
[color="#ff0102"]         S3C24X0_REG32   NFESTAT0;
[color="#ff0102"]         S3C24X0_REG32   NFESTAT1;
[color="#ff0102"]         S3C24X0_REG32   NFECC;
[color="#ff0102"]} /*__attribute__((__packed__))*/ S3C2410_NAND;
[color="#ff0102"]#endif
[color="#ff0102"]
[color="#ff0102"]三、交叉编译U-Boot。
在U-Boot的根目录下生成uboot.bin下载到开发板

[color="#ff0102"]运行,出现如下结果,uboot移植基本成功;在打印nand:64MiB时有点慢。
[color="#ff0102"]在qq2440.h文件没有定义CFG_NAND_LEGACY,系统调用的drivers/mtd/nand/nand.c中的nand_init();

U-Boot 1.3.2 (Aug 31 2008 - 18:36:25)
U-Boot code: 33f80000 -> 33f9f328; BSS: -> 33fa4608
DRAM:  64 MB
Flash:  1 MB
NAND:  64 MiB
*** Warning - bad CRC or NAND, using default environment
In:    serial
Out:   serial
Err:   serial
QQ2440 >

[color="#ff0102"][color="#ff0102"]
[color="#ff0102"]注意uboot1.3.2在命令配置上与以前版本的不同;1.3.2
以前是CFG开头,如ping命令(看cmd_net.c)以前是#if (CONFIG_COMMANDS &
CFG_CMD_PING);而1.3.2版是#if
defined(CONFIG_CMD_PING);就是在include/configs/board.h直接定义CONFIG_CMD_PING就可
以了

[color="#ff0102"]
[color="#ff0102"]
网络可以用,host开启tftp服务器,在uboot用命令tftp可以下载内核映象
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/79779/showart_1878800.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP