亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 操作系統 > 正文

s3c6410_uboot中的代碼重定位(nand->sdram)

2024-06-28 13:24:55
字體:
來源:轉載
供稿:網友
s3c6410_uboot中的代碼重定位(nand->sdram)

本文僅探討s3c6410從nand Flash啟動u-boot時的代碼重定位過程

參考:

1)《USER'S MANUAL-S3C6410X》第二章 MEMORY MAP 第八章 NAND FLASH CONTROLLER

2)u-boot源碼:

u-boot-x.x.x/board/samsumg/smdk6410/lowlevel_init.S

u-boot-x.x.x/cpu/s3c64xx/start.S

u-boot-x.x.x/cpu/s3c64xx/nand_cp.c

代碼重定位過程簡述

由于在nand flash中無法運行代碼,所以當開發板從nand flash啟動時,我們需要將存儲在外設nand flash中的u-boot代碼搬運到sdram中運行,如何完成這個搬運工作呢?這需要借助一個跳板,即“stepping stone”,它是s3c6410的一塊內置sram,開發板上電時,nand flash控制器自動將nand flash的前8K的內容拷貝到sram中并執行,這一小段啟動代碼除了初始化硬件外,最重要的一個工作就是將nand flash中的所有u-boot代碼拷貝(即重定位)到sdram的指定地址上去,然后跳轉到sdram中執行。

重定位代碼解析:

1)nand接口初始化

u-boot啟動時,首先執行相應硬件平臺的start.S,start.S中調用lowlevel_init對時鐘,uart,nand,mmu等底層硬件作初始化。

start.S:

...bl    lowlevel_init    /* go setup pll,mux,memory */...

lowlevel_init.S:

.../* * Nand Interface Init for SMDK6400 */nand_asm_init:    ldr    r0, =ELFIN_NAND_BASE    ldr    r1, [r0, #NFCONF_OFFSET]    orr    r1, r1, #0x70    orr    r1, r1, #0x7700    str     r1, [r0, #NFCONF_OFFSET]    ldr    r1, [r0, #NFCONT_OFFSET]    orr    r1, r1, #0x03    str     r1, [r0, #NFCONT_OFFSET]    mov    pc, lr...

2)代碼重定位

從nand flash啟動時,重定位代碼如下:

start.S:

/* when we already run in ram, we don't need to relocate U-Boot.     * and actually, memory controller must be configured before U-Boot     * is running in ram.     */    ldr    r0, =0xff000fff    bic    r1, pc, r0        /* r0 <- current base addr of code */    ldr    r2, _TEXT_BASE        /* r1 <- original base addr in ram */    bic    r2, r2, r0        /* r0 <- current base addr of code */    cmp     r1, r2                  /* compare r0, r1                  */    beq     after_copy        /* r0 == r1 then skip flash copy   */#ifdef CONFIG_BOOT_NAND    mov    r0, #0x1000    bl    copy_from_nand#endif

r1存放當前代碼運行的起始地址,r2存放u-boot即將在sdram中運行的地址,如果兩個地址相等,說明此時u-boot已經在sdram中運行了,無需再執行從nand拷貝數據到sdram的動作;否則,此時u-boot還在它的臨時住所sram中執行,此地不可久留,需要執行copy_from_nand將u-boot代碼完完整整地拷貝到sdram中去,然后跳轉到sdram中去執行剩下的代碼。

/* * copy U-Boot to SDRAM and jump to ram (from NAND or OneNAND) * r0: size to be compared * Load 1'st 2blocks to RAM because U-boot's size is larger than 1block(128k) size */    .globl copy_from_nandcopy_from_nand:    mov    r10, lr        /* save return address */    mov    r9, r0    /* get ready to call C functions */    ldr    sp, _TEXT_PHY_BASE    /* setup temp stack pointer */    sub    sp, sp, #12    mov    fp, #0            /* no PRevious frame, so fp=0 */    mov    r9, #0x1000    bl    copy_uboot_to_ram3:    tst     r0, #0x0    bne    copy_failed    ldr    r0, =0x0c000000    ldr    r1, _TEXT_PHY_BASE1:    ldr    r3, [r0], #4    ldr    r4, [r1], #4    teq    r3, r4    bne    compare_failed    /* not matched */    subs    r9, r9, #4    bne    1b4:    mov    lr, r10        /* all is OK */    mov    pc, lrcopy_failed:    nop            /* copy from nand failed */    b    copy_failedcompare_failed:    nop            /* compare failed */    b    compare_failed

真正執行拷貝動作的是copy_uboot_to_ram函數,它定義在u-boot-x.x.x/cpu/s3c64xx/nand_cp.c中,

int copy_uboot_to_ram (void){    int large_block = 0;    int i;    vu_char id;            NAND_ENABLE_CE();        NFCMD_REG = NAND_CMD_READID;        NFADDR_REG =  0x00;    /* wait for a while */        for (i=0; i<200; i++);    id = NFDATA8_REG;    id = NFDATA8_REG;    if (id > 0x80)        large_block = 1;    /* read NAND Block.     * 128KB ->240KB because of U-Boot size increase. by scsuh     * So, read 0x3c000 bytes not 0x20000(128KB).     */    return nandll_read_blocks(CFG_PHY_UBOOT_BASE, 0x3c000, large_block);}

nand flash支持兩種頁大小,512B和2KB,large_block = 0時,頁大小為512字節,large_block = 1時,頁大小為2K字節。nandll_read_blocks拷貝nand flash從第0頁開始的0x3c00(240K)大小的數據到sdram的CFG_PHY_UBOOT_BASE地址處。

/* * Read data from NAND. */static int nandll_read_blocks (ulong dst_addr, ulong size, int large_block){        uchar *buf = (uchar *)dst_addr;        int i;    uint page_shift = 9;    if (large_block)        page_shift = 11;        /* Read pages */        for (i = 0; i < (0x3c000>>page_shift); i++, buf+=(1<<page_shift)) {                nandll_read_page(buf, i, large_block);        }        return 0;}

首先根據large_block判斷nand flash一個頁的大小,從而計算需要拷貝的頁的數量,即需要拷貝(0x3c000>>page_shift)個頁,nandll_read_page每次只拷貝一個頁的數據。

/* * address format *              17 16         9 8            0 * -------------------------------------------- * | block(12bit) | page(5bit) | offset(9bit) | * -------------------------------------------- */static int nandll_read_page (uchar *buf, ulong addr, int large_block){        int i;    int page_size = 512;    if (large_block)        page_size = 2048;        NAND_ENABLE_CE();        NFCMD_REG = NAND_CMD_READ0;        /* Write Address */        NFADDR_REG = 0;    if (large_block)            NFADDR_REG = 0;    NFADDR_REG = (addr) & 0xff;    NFADDR_REG = (addr >> 8) & 0xff;    NFADDR_REG = (addr >> 16) & 0xff;    if (large_block)        NFCMD_REG = NAND_CMD_READSTART;        NF_TRANSRnB();    /* for compatibility(2460). u32 cannot be used. by scsuh */    for(i=0; i < page_size; i++) {                *buf++ = NFDATA8_REG;        }        NAND_DISABLE_CE();        return 0;}

從nand flash中讀取數據的流程為片選(NAND_ENABLE_CE)->發讀命令(NFCMD_REG)->發地址(NFADDR_REG)->發讀命令(NFCMD_REG)->等待數據可讀(NF_TRANSRnB)->讀數據(NFDATA8_REG)。由于每次從NFDATA8_REG中只可讀取1個字節的數據,所以拷貝一頁需要讀取512或2048次。

當執行完copy_uboot_to_ram返回到start.S時,nand flash中的代碼重定位便完成了,此后程序跳轉到sdram中執行,stepping stone的職責就此結束。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩亚洲第一页| 亚洲理论在线a中文字幕| 亚洲欧美国产精品久久久久久久| 一区二区三区视频免费| 538国产精品视频一区二区| 欧美性猛交xxxx免费看| 亚洲男人天堂久| 日韩在线视频中文字幕| 亚洲人成电影在线播放| 岛国av午夜精品| 777精品视频| 日韩一区二区福利| 久久久视频在线| 日韩电影大全免费观看2023年上| 成人性教育视频在线观看| 日韩在线免费av| 午夜精品福利视频| 日韩欧美国产黄色| 88国产精品欧美一区二区三区| 亚洲国产私拍精品国模在线观看| 亚洲最大av网站| 亚洲天堂视频在线观看| 日韩成人中文字幕在线观看| 久久偷看各类女兵18女厕嘘嘘| 国产精品v片在线观看不卡| 久久网福利资源网站| 日本精品性网站在线观看| 欧美亚洲另类视频| 精品国产一区二区三区久久久| 国产www精品| 国产精品福利在线观看网址| 91精品国产综合久久久久久久久| 欧美黄色片免费观看| 精品国产鲁一鲁一区二区张丽| 国产成人精品视| 中文字幕欧美日韩| 日韩欧美在线观看| 萌白酱国产一区二区| 亚洲精品国产综合区久久久久久久| 日日摸夜夜添一区| 日韩久久免费视频| 欧洲成人在线视频| 亚洲加勒比久久88色综合| 4k岛国日韩精品**专区| 欧美性感美女h网站在线观看免费| 欧美国产日韩精品| 中文字幕免费精品一区高清| 亚洲精品电影网站| 夜夜嗨av一区二区三区四区| 久久久久久久电影一区| 国产精品久久久久久久久久久久| 热久久这里只有| 欧美大片大片在线播放| 亚洲大胆人体视频| 日韩中文字幕国产| 欧美一级片久久久久久久| 91在线视频一区| 欧美一级成年大片在线观看| 亚洲色图美腿丝袜| 久久电影一区二区| 亚洲va欧美va在线观看| 亚洲xxx视频| 91久久精品国产91久久性色| 欧美激情视频在线观看| 欧美黑人一区二区三区| 久久这里只有精品视频首页| 久久韩国免费视频| 欧美成人精品激情在线观看| 91在线精品视频| 亚洲在线免费看| 91色视频在线观看| 亚洲日本欧美中文幕| 97在线看福利| 久久久精品欧美| 久久成年人免费电影| 色噜噜亚洲精品中文字幕| 最近中文字幕2019免费| 亚洲天堂av综合网| 国产精品日日做人人爱| 成人444kkkk在线观看| 中文字幕久久久| 久久免费观看视频| 成人黄在线观看| 精品美女国产在线| 欧美成人手机在线| 国产精品成人在线| 中日韩美女免费视频网址在线观看| 欧美视频不卡中文| 在线播放国产一区二区三区| 在线看福利67194| 亚洲精品网址在线观看| 国产成人精品日本亚洲专区61| 久久躁狠狠躁夜夜爽| 国产精品午夜视频| 亚洲色图校园春色| 91沈先生在线观看| 日本乱人伦a精品| 97视频在线观看免费| 亚洲精品97久久| 欧美精品日韩三级| 国产精品日韩在线播放| 国产精品女主播视频| 日韩激情av在线免费观看| 久久精品视频播放| 欧美精品久久一区二区| 欧美激情高清视频| 国产日韩欧美日韩大片| 色妞欧美日韩在线| 国产91久久婷婷一区二区| 丝袜亚洲欧美日韩综合| 97久久超碰福利国产精品…| 亚洲www在线| 久久久国产视频| 国产亚洲精品久久| 91久久久久久久久久久久久| 96国产粉嫩美女| 亚洲国产精品福利| 亚洲精品国产品国语在线| 亚州欧美日韩中文视频| 国产日产久久高清欧美一区| 国产精品永久免费观看| 国产日韩欧美在线观看| 欧美激情免费在线| 亚洲欧洲日本专区| 欧美日韩精品中文字幕| 亚洲精品久久久久久久久久久久| 黄色一区二区在线观看| 久久久久久久国产精品| 色综合久久久888| 欧美日韩在线免费观看| 亚洲国产成人爱av在线播放| 亚洲免费电影一区| 国产成人精品免高潮在线观看| 91精品在线观| 国产精品自拍小视频| 日韩欧亚中文在线| 亚洲精品欧美一区二区三区| 欧美老女人bb| 亚洲男人的天堂在线| 亚洲成人999| 日本午夜在线亚洲.国产| 性欧美办公室18xxxxhd| 高清一区二区三区日本久| 伊人伊人伊人久久| 2018中文字幕一区二区三区| 亚洲午夜未删减在线观看| 亚洲精品91美女久久久久久久| 国产精品久久久久久久天堂| 久久网福利资源网站| 91色中文字幕| 欧美乱妇高清无乱码| 91精品国产高清| 91色视频在线观看| 欧美精品情趣视频| 亚洲色无码播放| 欧美中在线观看| 国产69精品久久久久99| 国产精品久久久久久影视| 欧美精品videossex性护士| 人体精品一二三区| 欧美性69xxxx肥| 久久99久久久久久久噜噜| 久久男人资源视频| 国产视频精品久久久|