下面是具体的代码实现:

 #define S3C2440_MPLL_200MHZ ((0x5C<<12)|(0x01<<4)|(0x02))
#define MEM_CTL_BASE     0x48000000
.text
.global _start:
_start:                  /* 关闭看门狗 * /
 ldr r0, =0x53000000
    mov r1,#0
    str r1,[0]
   
 
    /* 设置时钟 */
    ldr r0,=0x4c000014
    mov r1,#0x03;    //FCLK:HCLk:PCLK=1:2:4,HDIVN=1,PDIVN=1
    str r1,[r0]
   /*如果HDIVN非0,CPU的总线模式应该从“fast bus mode ”变为 asynchronous,这是根据数据手册来的,数据手册要求这样做(条件:如果FCLK不等于HCLK的话)*/
   mrc p15,0,r1,cl,c0,0   /*读出控制寄存器*/
   orr r1,r1,#0xc0000000  /*设置为"asynchronous bus mode"*/
   mcr p15,0,r1,c1,c0,0   /*写入控制寄存器*/
  
   /*设置MPLLCON= S3C2440_MPLL_200MHZ*/
 ldr r0,= 0x4c000004
 ldr r1,= s3c2440_MPLL_200MHZ    /*伪汇编指的是在编译时,如果这个值比较复杂的话,那就会将这个值拆分放在内存的某个地方,然后再读那个内存地址*/
 str r1,[r0]
 /* 初始化SDRAM */
     ldr r0,=MEM_CTL_BASE
     adr r1,sdram_config     /*得到当前地址*/
     add r3,r0,#(13*4)
1b:
  ldr r2,[r1],#4
  str r2,[r0],#4
  cmp r0,r3
  bne 1b
 
sdram_config:
   .long     0x22011110    //BWSCOON
   .long     0x00000700    //BANKCON0
   .long     0x00000700    //BANKCON1
   .long     0x00000700    //BANKCON2
   .long     0x00000700    //BANKCON3
   .long     0x00000700    //BANKCON4
   .long     0x00000700    //BANKCON5
   .long     0x00018005    //BANKCON6
   .long     0x008c04F4   
   .long     0x000000B1    //BANKSIZE
   .long     0x00000030    //MRSRB6
   .long     0x00000030    //MRSRB7
  
 
/* 重定位bootloader ,把本身的代码从flash复制到它的链接地址去*/
   ldr sp,= 0x34000000
   bl  nand_init          /*初始化nandflash*/
  
   mov r0,#0
   ldr r1, =_start        /*计算需要拷贝的文件的大小*/
   ldr r2, =__bss_start
   sub r2,r3,r1
  
   bl copy_code_to_sdram    /*将代码拷贝到sdram中*/
   bl clear_bss             /*bss段中的变量都赋值为0,至于为甚麽,我认为是语法的问题*/
/* 执行main  */
   ldr lr,=halt
   ldr pc,=main
halt:
   b  halt    /*假设main函数有返回值的话,一直停在这里,避免单板跑飞。*/
void clear_bss(void)      /*清除bss段,将这段都赋值为0*/
{
      
        extern int __bss_start,__bss_end;
     int *p = &__bss_start;
      for(;p < &__bss_end;p++)
       *p = 0;
  
}
void   nand_init(void)
{    #define TACLS 0
     #define TWTPH0 3
  #define TERPH1 0
    /*设置时序*/
  S3C2440nand->NFCONF = (TACLS<<12) | (TWRPH0<<8) | (TWRPH1<<4);
  /*使能nand flash控制器,初始化ECC,禁止片选*/
  s3c2440nand->NFCONT = (1<<4) | (1<<1)| (1<<0);
 
}
/*nand发出命令函数*/
void nand_cmd(unsigned char cmd)
{
   int i;
  NFCMMMD cmd;
  for (i = 0;i < 10;i++);  /*必须等待一会,否则程序会出错*/
}
/*nand的地址函数*/
void nand_addr(unsigned int addr)
{
  unsigned int col = addr /2048;
  unsigned int page = addr % 2048;
  volatile int i;
  NFADDR = col & 0xff;
  for (i = 0;i < 10;i++);
  NFADDR = (col >> 8) & 0xff;
  for (i = 0;i < 10;i++);
 
  NFADDR = page & 0xff;
  for (i = 0;i < 10;i++);
  NFADDR = (page >> 8) & 0xff;
  for (i = 0;i < 10;i++);
  NFADDR = (page >> 16) & 0xff;
  for (i = 0;i < 10;i++)
}
/*nand的等待函数*/
void nand_wait_ready()
{
 while(!(NFSTAT & 1));
}
/*nand的数据*/
void unsigned char  nand_data(void)
{
 return NFDATA;
 
}
/*nand片选函数*/
void nand_select(void)
{
  NFCONT &= ~(1<<1);
}
/*取消片选函数*/
void  nand_deselect(void)
{
 NFCONT |= (1<<1);
}
/*nand的读函数*/
void nand_read(unsigned int addr,unsigned char *buf.unsigned int len)

  int col = addr /2048;   /*col指的是读的是第一页的某个地址,并不是从0开始读的*/
  int i = 0;
  /*选中*/
  nand_select();
 
while(1)
  {/*发出读命令00h*/
   nand_cmd(0x00);
  
  /*发出地址(分5步发出)*/
  nand_addr(addr);
 
  /*发出读命令*/
  nand_cmd(0x30);
 
  /*判断状态*/
  nand_wait_ready();
 
  /*读数据*/
  for(;col< 2048;&&(i<len);col++)
  {
  buf[i] = nand_data();
  i++;
  addr++;
  }
   col =0;
 }
  /*取消选中,禁止nandflash发出片选信号*/
   nand_deselect();
}
  

从零开始写bootloader(1)的更多相关文章

  1. 从零开始写bootloader(2)

    下图是设置内核启动参数的存放图示,由于bootloader启动内核时,需要给内核传输一些启动参数,但是由于当bootloader把内核 启动之后,程序就跳转到内核中执行了,再也不会回到bootload ...

  2. 深入浅出React Native 3: 从零开始写一个Hello World

    这是深入浅出React Native的第三篇文章. 1. 环境配置 2. 我的第一个应用 将index.ios.js中的代码全部删掉,为什么要删掉呢?因为我们准备从零开始写一个应用~学习技术最好的方式 ...

  3. 从零开始写redis客户端(deerlet-redis-client)之路——第一个纠结很久的问题,restore引发的血案

    引言 正如之前的一篇博文,LZ最近正在从零开始写一个redis的客户端,主要目的是为了更加深入的了解redis,当然了,LZ也希望deerlet客户端有一天能有一席之地.在写的过程当中,LZ遇到了一个 ...

  4. 从零开始写一个武侠冒险游戏-8-用GPU提升性能(3)

    从零开始写一个武侠冒险游戏-8-用GPU提升性能(3) ----解决因绘制雷达图导致的帧速下降问题 作者:FreeBlues 修订记录 2016.06.23 初稿完成. 2016.08.07 增加对 ...

  5. 从零开始写一个武侠冒险游戏-7-用GPU提升性能(2)

    从零开始写一个武侠冒险游戏-7-用GPU提升性能(2) ----把地图处理放在GPU上 作者:FreeBlues 修订记录 2016.06.21 初稿完成. 2016.08.06 增加对 XCode ...

  6. 从零开始写一个武侠冒险游戏-6-用GPU提升性能(1)

    从零开始写一个武侠冒险游戏-6-用GPU提升性能(1) ----把帧动画的实现放在GPU上 作者:FreeBlues 修订记录 2016.06.19 初稿完成. 2016.08.05 增加对 XCod ...

  7. 读《架构探险——从零开始写Java Web框架》

    内容提要 <架构探险--从零开始写Java Web框架>首先从一个简单的 Web 应用开始,让读者学会如何使用 IDEA.Maven.Git 等开发工具搭建 Java Web 应用:接着通 ...

  8. 从零开始写一个Tomcat(叁)--请求解析

    挖坑挖了这么长时间也该继续填坑了,上文书讲到从零开始写一个Tomcat(贰)--建立动态服务器,讲了如何让服务器解析请求,分离servlet请求和静态资源请求,读取静态资源文件输出或是通过URLCla ...

  9. 使用USBASP给Arduino烧写bootloader教程

    源:使用UsbAsp给UNO烧写bootloader ATMEGA16U2.ATMEGA328P固件烧写教程 arduino板由于操作不发导致固件损坏,或者想更新固件怎么办?今天给大家介绍一下如何使用 ...

随机推荐

  1. HTML学习-2标记标签-2

    三.表单元素 ①<form></form>表单标签,代表表单 主要属性:1.action提交到的页面.   2.method数据提交方式(get显示提交,有长度限制.post隐 ...

  2. 1016B - Segment Occurrences(字符串的匹配)

    题意:字符串a,字符串b,给你q个区间,让你求a的区间内字符串b出现了多少次 之前用的前缀数组做的,没想起来,发现这个其实也可以 #include<cstdio> #include< ...

  3. cxgrid中回车键光标移到下列

    OptionsBehavior.GoToNextCellOnEnter:=True; 更完善的回车 可以在焦点到了最后一列再回车时有下一行则移到下一行的第一列,没有下一行则新增记录并移到第一列 pro ...

  4. Lazarus下改变DBGrid记录的颜色,与Delphi不同了。

    功能:根据一条记录满足特定条件,使用不同的颜色进行显示. 来源:http://www.aliyagoo.com/blog 主要事件是在PrepareCanvas 不是DrawColumnCell 而且 ...

  5. RabbitMQ.Net 应用(1)

    风浪子 概述 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Pu ...

  6. 重建redo文件

    需求背景 由于前期安装oracle时redo文件大小或者路径规划不合理需要进行修改,以便满足性能测试要求.redo文件规划大小建议与生产环境一致. 重做日志相关数据字典 1.v$log  记录数据库中 ...

  7. C++随记

    1.const限定符 const限定变量的值不可变,并且const对象必须要初始化 const int buf = 512; //正确,表明buf的值为512 buf = 400;  //错误,buf ...

  8. [namespace]PHP命名空间的动态访问 & 使用技巧

    ----------------------------------------------------------------------------------------------- /* | ...

  9. java实现excel表格导出

    Java 实现导出excel表 POI 1.首先下载poi-3.6-20091214.jar,下载地址如下: http://download.csdn.net/detail/evangel_z/389 ...

  10. Java Script 基础总结

    1学习ajax需要一点CSS的基础和JavaScipt基础 今天重温一下Javascrpt基础 1.<script type="text/javascript">< ...