nand read.jffs2 0x30007FC0 kernel;

从NAND读出内核:从哪读,从kernel分区

放到哪去   -0x30007FC0

nand read.jffs2 0x30007FC0   0x00200000      0x00060000

device nand0 <nandflash0>, # parts = 4

#: name                        size            offset          mask_flags  0: bootloader          0x00040000      0x00000000      0

1: params              0x00020000      0x00040000      0

2: kernel              0x00200000      0x00060000      0

3: root                0x0fda0000      0x00260000      0

active partition: nand0,0 - (bootloader) 0x00040000 @ 0x00000000

defaults: mtdids  : nand0=nandflash0

mtdparts: mtdparts=nandflash0:256k@0(bootloader),128k(params),2m(kernel),-(root)

.jffs2 方便不用块对齐

bootm 0x30007FC0

flash内的内核,uimage 头部(64k) + 内核 0x30007FC0 是为了使内核的加载地址刚好为0x30008000 节省时间不必再把内核移动到加载地址

(1)根据头部移动内核到加载地址

(2)启动内核do_bootm_linux

   1、u_boot告诉内核一些参数,设置启动阐述

  2、跳到入口地址启动内核

setup_start_tag (bd);
setup_memory_tags (bd_t *bd)
setup_commandline_tag (bd_t *bd, char *commandline)
setup_end_tag (bd_t *bd)

struct tag {

struct tag_header hdr;

union {

 struct tag_core  core;

struct tag_mem32 mem;

struct tag_videotext videotext;

struct tag_ramdisk ramdisk;

struct tag_initrd initrd;

struct tag_serialnr serialnr;

struct tag_revision revision;

struct tag_videolfb videolfb;

struct tag_cmdline cmdline;

/*    * Acorn specific    */   struct tag_acorn acorn;

/*    * DC21285 specific    */   struct tag_memclk memclk;

} u;

struct tag_header {

u32 size;

u32 tag;

};

static void setup_start_tag (bd_t *bd)

{  params = (struct tag *) bd->bi_boot_params; ·  //开始开始存放地址

params->hdr.tag = ATAG_CORE;             //0x54410001

params->hdr.size = tag_size (tag_core);      //tag + size + core >>2 单位为4个字节

params->u.core.flags = 0;

params->u.core.pagesize = 0;

params->u.core.rootdev = 0;

params = tag_next (params);      //指向下一个tag

}

static void setup_memory_tags (bd_t *bd)

{

int i;

for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++)

{            //CONFIG_NR_DRAM_BANKS    1

  params->hdr.tag = ATAG_MEM;     //0x54410002

   params->hdr.size = tag_size (tag_mem32);      //

   params->u.mem.start = bd->bi_dram[i].start;     //0x30000000

   params->u.mem.size = bd->bi_dram[i].size;      //大小为初始化自定值  0x04000000

  params = tag_next (params);

}

}

static void setup_commandline_tag (bd_t *bd, char *commandline)

{

  char *p;                //char *commandline = getenv ("bootargs");

  if (!commandline)        //bootargs=noinitrd root=/dev/mtdblock3 init=/linuxrc console=ttySAC0使用串口0

     return;

  /* eat leading white space */

  for (p = commandline; *p == ' '; p++);

  /* skip non-existent command lines so the kernel will still

    * use its default command line.   */

   if (*p == '\0')   return;

  params->hdr.tag = ATAG_CMDLINE;     //0x54410009

  params->hdr.size =   (sizeof (struct tag_header) + strlen (p) + 1 + 4) >> 2;

  strcpy (params->u.cmdline.cmdline, p);

  params = tag_next (params); }

static void setup_end_tag (bd_t *bd)

{

  params->hdr.tag = ATAG_NONE;

  params->hdr.size = 0;

}

u_boot: 启动内核
1、从flash里读
2、启动
 a、设置启动参数
 b、跳跳到入口地址
 
 theKernel (0, bd->bi_arch_number, bd->bi_boot_params);
   bd->bi_boot_params 参数地址
   bd->bi_arch_number 机器id

uboot启动内核(3)的更多相关文章

  1. UBOOT启动内核过程

    1.摘要 (1).启动4步骤第一步:将内核搬移到DDR中第二步:校验内核格式.CRC等第三步:准备传参第四步:跳转执行内核(2).涉及到的主要函数是:do_bootm和do_bootm_linux(3 ...

  2. U-boot 启动内核

    1:什么是UBOOT,为什么要有UBOOT? UBOOT的主要作用是用来启动linux内核,因为CPU不能直接从块设备中执行代码,需要把块设备中的程序复制到内存中,而复制之前还需要进行很多初始化工作, ...

  3. linux的几个内核镜像格式Image 和 u-boot启动内核和文件系统时的一些环境变量的设置

    关于编译powerpc linux的几个Image参考原文 http://blog.sina.com.cn/s/blog_86a30b0c0100wfzt.html 转载▼   PowerPC架构 L ...

  4. 嵌入式linux开发uboot启动内核的机制(二)

    一.嵌入式系统的分区 嵌入式系统部署在Flash设备上时,对于不同SoC和Flash设备,bootloader.kernel.rootfs的分区是不同的.三星S5PV210规定启动设备的分区方案如下: ...

  5. 【转】UBOOT——启动内核

    转自:https://www.cnblogs.com/biaohc/p/6403863.html 1:什么是UBOOT,为什么要有UBOOT? UBOOT的主要作用是用来启动linux内核,因为CPU ...

  6. 嵌入式Linux驱动学习之路(六)u-boot启动内核

    内核启动是需要必要的启动参数.不能开机自动完全从0开始启动,需要uboot帮助内核实现重定位并提供参数. 首先,uboo会从Kernel分区中读取bootcmd环境变量,根据环境变量可自动启动. 分区 ...

  7. 使用Uboot启动内核并挂载NFS根文件系统

    配置编译好内核之后,将生成的内核文件uImage拷贝到/tftpboot/下,通过tftp服务器将内核下载到开发板,使用命令:tftp 31000000 uImage.下载完成之后配置bootargs ...

  8. uboot启动内核的实现

    前面我们分析了uboot 的整个流程,我们知道uboot启动以后所有功能都是通过命令来实现的,启动kernel就是执行了bootcmd里面的命令.命令执行过程在uboot中是非常重要的现在我们就来看u ...

  9. tiny4412学习(一)之从零搭建linux系统(烧写uboot、内核进emmc+uboot启动内核)【转】

    本文转载自:http://blog.csdn.net/fengyuwuzu0519/article/details/74080109 版权声明:本文为博主原创文章,转载请注明http://blog.c ...

  10. u-boot学习(五):u-boot启动内核

    u-boot的目的是启动内核.内核位于Flash中,那么u-boot就要将内核转移到内存中.然后执行命令执行之.这些操作是由bootcmd命令完毕的. bootcmd=nand read.jffs2 ...

随机推荐

  1. js-------》(小效果)实现倒计时及时间对象

    js实现倒计时及时间对象 JS实现倒计时效果代码如下: 1 <!doctype html> 2 <html> 3 <head> 4 <meta charset ...

  2. Callable与Future、FutureTask的学习 & ExecutorServer 与 CompletionService 学习 & Java异常处理-重要

    Callable是Java里面与Runnable经常放在一起说的接口. Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其他线程执行的任务 ...

  3. Spring MVC 之文件上传(七)

    SpringMVC同样使用了apache的文件上传组件.所以需要引入以下包: apache-commons-fileupload.jar apache-commons-io.jar 在springAn ...

  4. iOS开发 判断代理以及代理方法是否有人遵循

    if (self.delegate && [self.delegate respondsToSelector:@selector]) { return YES; }

  5. TP学习笔记

    ThinkPHP采用单一入口模式访问应用,对应用的所有请求都定向到应用的入口文件,系统会从URL参数中解析当前请求的模块.控制器和操作,下面是一个标准的URL访问格式: http://serverNa ...

  6. 通用 PE 工具箱1.9.6(XP内核)by Uepon(李培聪)

    通用 PE 工具箱1.9.6(XP内核)by Uepon(李培聪)官网:http://hi.baidu.com/uepon?page=21.8版论坛帖子:http://bbs.wuyou.net/fo ...

  7. 添加无线服务wzcsvc服务,Eventlog服务

    <添加eventlog服务.reg> Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentCont ...

  8. xcode 真机调试 failed to get the task for process xxx

    xcode 真机调试 failed to get the task for process xxx 此错误原因是,使用 in house profile 签名了真机调试的证书: 在 target--- ...

  9. 能源项目xml文件标签释义--default-lazy-init

    1.spring的default-lazy-init参数 spring在启动的时候,会默认加载会默认加载整个对象实例图,从初始化ACTION配置.到 service配置到dao配置.乃至到数据库连接. ...

  10. laravel 中 与前端的一些事1

    首先安装node.js 在命令行中敲node -v 可以查看node的版本信息 还需要安装npm,相当于php中的composer node.js中5.0版本后的都已经将npm打包进node了 还要安 ...