自己写bootloader1 - start.S,基于s3c2440

来源:互联网 发布:算法视频教程 编辑:程序博客网 时间:2024/05/22 03:15
bootloader的目的是启动内核。主要做两方面的工作:把内核从nand读入sdram,跳转执行。bootloader分成两步走:第一是硬件相关的初始化,然后跳转到main中执行。首先是硬件相关初始化:关看门狗,设置时钟,初始化SDRAM,代码重定位,跳转到main中执行。start.S里面的代码(start.S不能是start.s) #define S3C2440_MPLL_200MHZ     ((0x5c<<12)|(0x01<<4)|(0x02))#define S3C2440_MPLL_200MHZ     ((0x5c<<12)|(0x01<<4)|(0x02))#define     MEM_CTL_BASE    0x48000000text.global _start _start:/*1关看门狗*/ldr r0, =0x53000000mov r1, #0 str r1, [r0]/* 2: 设置时钟*/ldr r0, =0x4c000014mov r1, #0x03;str r1, [r0]mrc    p15, 0, r1, c1, c0, 0orr    r1, r1, #0xc0000000mcr    p15, 0, r1, c1, c0, 0ldr r0, =0x4c000004ldr r1, =S3C2440_MPLL_200MHZstr r1, [r0]/* 3: 初始化sdram*/ldr r0, =MEM_CTL_BASE adr r1, sdram_config /*得到当前的地址,不是链接地址*/add r3, r0, #(13*4)1: ldr r2, [r1], #4str r2, [r0], #4cmp r0, r3bne 1b/* 4: 重定位:把bootloader 的代码从flash到sdram中*/ldr sp, =0x34000000bl nand_initmov r0, #0 ldr r1, =_startldr r2, =__bss_startsub r2, r2, r1bl copy_to_sdrambl clean_bss/* 5: 调用main*/ldr lr, =haltldr pc, =main halt:b haltsdram_config:.long 0x22011110//BWSCON.long 0x00000700//BANKCON0.long 0x00000700//BANKCON1.long 0x00000700//BANKCON2.long 0x00000700//BANKCON3  .long 0x00000700//BANKCON4.long 0x00000700//BANKCON5.long 0x00018005//BANKCON6.long 0x00018005//BANKCON7.long 0x008C04F4// REFRESH.long 0x000000B1//BANKSIZE.long 0x00000030//MRSRB6.long 0x00000030//MRSRB7

0 0
原创粉丝点击