uboot-启动流程

boot总体启动流程
    uboot代码分两个部分,stage1由汇编代码主要实现CPU内部硬件初始化,stage2由C代码主要实现外围接口初始化;CPU上电后会根据启动模式去对应的启动介质约定的地址拿到stage1汇编代码在CPU内部内存运行,完成硬件初始化后把stage2代码拷贝到内存并执行入口函数,接着开始初始化外围设备接口,最后再加载内核和挂载文件系统。
    stage1
        设置SVC模式,disable FIQ IRQ,关闭watchdog,关闭MME和Cache,初始化MEM,拷贝stage2代码到内存并跳入函数入口;
    stage2
        初始化gd、bd内存空间,初始化CPU、board、interrupt、env、serial、dram,初始化flash,mem,env,device,console,IRQ,最后进入main_loop。

stage1代码描述
    (以下代码基于sp6700 uboot分析)

	arch/arm/cpu/u-boot.lds
		ENTRY(_start) ENTRY伪指令定义代码段的入口
		arch/arm/cpu/armv7/start.o (.text*)		

	arch/arm/cpu/armv7/start.S 
		_start: b	reset
		
		reset:
			mrs	r0, cpsr
			and	r1, r0, #0x1f			@ mask mode bits
			teq	r1, #0x1a				@ test for HYP mode
			bicne	r0, r0, #0x1f		@ clear all mode bits
			orrne	r0, r0, #0x13		@ set SVC mode
	orr	
			r0, r0, #0xc0				@ disable FIQ and IRQ
			msr	cpsr,r0
			adr r0, _start      /* r0 <- current position of code   */
			ldr r1, _TEXT_BASE  /* test if we run from flash or RAM */
			teq r0, r1          /* don't reloc during debug         */
			bleq _main
			
	    如果_start与_TEXT_BASE相等,不等的话就设置地址和长度循环拷贝flash到RAM中
			ldr r2, _end_ofs    /* r2 <- size of u-boot             */
			add r2, r0, r2      /* r2 <- source end address         */
			
		reloc_loop:
			ldmia r0!, {r3-r10} /* copy from source address [r0]    */
			stmia r1!, {r3-r10} /* copy to   target address [r1]    */
			cmp r0, r2          /* until source end addreee [r2]    */
			blo reloc_loop
			ldr r0, _main_safe   拷贝完后跳到_main
			mov pc, r0

		.globl _main_safe

		_main_safe:
			.word _main

	arch/arm/lib/crt0.S
		ENTRY(_main)
			ldr	sp, =(CONFIG_SPL_STACK)
			bic	sp, sp, #7			/* 8-byte alignment for ABI compliance */bic清除取反位
			sub	sp, sp, #GD_SIZE	/* allocate one GD above SP */sp - GD_SIZE相当于留足GD_SIZE空间
			bic	sp, sp, #7			/* 8-byte alignment for ABI compliance */
			mov	r9, sp				/* GD is above SP */把gd地址赋值给r9保存
			mov	r0, #0

			bl	board_init_f				/* 对gd结构体成员赋值 */
			ldr	sp, [r9, #GD_START_ADDR_SP]	/* sp = gd->start_addr_sp */
			bic	sp, sp, #7					/* 8-byte alignment for ABI compliance */
			ldr	r9, [r9, #GD_BD]			/* r9 = gd->bd */
			sub	r9, r9, #GD_SIZE			/* new GD is below bd */
			adr	lr, here 这里什么意思?
			ldr	r0, [r9, #GD_RELOC_OFF]		/* r0 = gd->reloc_off */
			add	lr, lr, r0
			ldr	r0, [r9, #GD_RELOCADDR]		/* r0 = gd->relocaddr */
			b	relocate_code

		here:
			ldr	pc, =board_init_r			/* this is auto-relocated! */
											/* we should not return here. */
		ENDPROC(_main)

stage2代码描述
    (以下代码基于umhi3716mv310 uboot分析)
    board.c
    board\hi3716mv310\board.c
    start_armboot是U-Boot执行的第一个C语言函数,完成系统初始化工作,进入主循环,处理用户输入的命令。这里只简要列出了主要执行的函数流程:

    void start_armboot (void)
    {
		  //全局数据变量指针gd占用r8。
		  DECLARE_GLOBAL_DATA_PTR;
          
          /* 给全局数据变量gd安排空间*/
          gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));
          memset ((void*)gd, 0, sizeof (gd_t));
          
          /* 给板子数据变量gd->bd安排空间*/
          gd->bd = (bd_t*)((char*)gd - sizeof(bd_t));
          memset (gd->bd, 0, sizeof (bd_t));
          monitor_flash_len = _bss_start - _armboot_start;//取u-boot的长度。
          
          /* 顺序执行init_sequence数组中的初始化函数 */
          for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) {
                 if ((*init_fnc_ptr)() != 0) {
                         hang ();
                 }
          }
		  //有些函数在 fastboot\board\hi3716mv310\board.c 文件中
          
          /*配置可用的Flash */
          size = flash_init ();
        ……
          /* 初始化堆空间 */
          mem_malloc_init (_armboot_start - CFG_MALLOC_LEN);
          /* 重新定位环境变量, */
          env_relocate ();
          /* 从环境变量中获取IP地址 */
          gd->bd->bi_ip_addr = getenv_IPaddr ("ipaddr");
          /* 以太网接口MAC 地址 */
          ……
          devices_init ();      /* 设备初始化 */
          jumptable_init ();  //跳转表初始化
          console_init_r ();    /* 完整地初始化控制台设备 */
          enable_interrupts (); /* 使能中断处理 */
          /* 通过环境变量初始化 */
          if ((s = getenv ("loadaddr")) != NULL) {
                  load_addr = simple_strtoul (s, NULL, 16);
          }
          /* main_loop()循环不断执行 */
          for (;;) {
                  main_loop ();      /* 主循环函数处理执行用户命令 -- common/main.c */
          }
   }
   
	初始化函数序列init_sequence[]
	init_sequence[]数组保存着基本的初始化函数指针。这些函数名称和实现的程序文件在下列注释中。
   
	init_fnc_t *init_sequence[] = {
         cpu_init,             /* 基本的处理器相关配置 -- cpu/arm920t/cpu.c */
         board_init,           /* 基本的板级相关配置 -- board/smdk2410/smdk2410.c */
         interrupt_init,       /* 初始化例外处理 -- cpu/arm920t/s3c24x0/interrupt.c */
         env_init,             /* 初始化环境变量 -- common/env_flash.c */
         init_baudrate,        /* 初始化波特率设置 -- lib_arm/board.c */
         serial_init,          /* 串口通讯设置 -- cpu/arm920t/s3c24x0/serial.c */
         console_init_f,       /* 控制台初始化阶段1 -- common/console.c */
         display_banner,       /* 打印u-boot信息 -- lib_arm/board.c */
         dram_init,            /* 配置可用的RAM -- board/smdk2410/smdk2410.c */
         display_dram_config,  /* 显示RAM的配置大小 -- lib_arm/board.c */
         NULL,
	};
	整个u-boot的执行就进入等待用户输入命令,解析并执行命令的死循环中。

u-boot主要的数据结构
    u-boot的主要功能是用于引导OS的,但是本身也提供许多强大的功能,可以通过输入命令行来完成许多操作。所以它本身也是一个很完备的系统。u-boot的大部分操作都是围绕它自身的数据结构,这些数据结构是通用的,但是不同的板子初始化这些数据就不一样了。所以u-boot的通用代码是依赖于这些重要的数据结构的。这里说的数据结构其实就是一些全局变量。

  1)gd 全局数据变量指针,它保存了u-boot运行需要的全局数据,类型定义:
  		typedef struct global_data {
           bd_t  *bd;      //board data pointor板子数据指针
           unsigned long flags;  //指示标志,如设备已经初始化标志等。
           unsigned long baudrate; //串口波特率
           unsigned long have_console; /* 串口初始化标志*/
           unsigned long reloc_off;   /* 重定位偏移,就是实际定向的位置与编译连接时指定的位置之差,一般为0 */
           unsigned long env_addr; /* 环境参数地址*/
           unsigned long env_valid; /* 环境参数CRC检验有效标志 */
           unsigned long fb_base; /* base address of frame buffer */
           #ifdef CONFIG_VFD
           unsigned char vfd_type; /* display type */
           #endif
           void  **jt;  /* 跳转表,1.1.6中用来函数调用地址登记 */
        } gd_t;

	2)bd 板子数据指针。板子很多重要的参数。 类型定义如下:    
		typedef struct bd_info {
             int   bi_baudrate;     /* 串口波特率 */
             unsigned long bi_ip_addr;   /* IP 地址 */
             unsigned char bi_enetaddr[6]; /* MAC地址*/
             struct environment_s        *bi_env;
             ulong         bi_arch_number; /* unique id for this board */
             ulong         bi_boot_params; /* 启动参数 */
             struct    /* RAM 配置 */
             {
            ulong start;
            ulong size;
             }bi_dram[CONFIG_NR_DRAM_BANKS];
        } bd_t; 		  

	3)环境变量指针 env_t *env_ptr = (env_t *)(&default_environment[0]);(common/env_common.c)   V310 fastboot:
	   env_ptr指向环境参数区,系统启动时默认的环境参数environment[],定义在common/environment.c中。 
	   参数解释:
		bootdelay 定义执行自动启动的等候秒数 
		baudrate 定义串口控制台的波特率 
		netmask 定义以太网接口的掩码 
		ethaddr 定义以太网接口的MAC地址 
		bootfile 定义缺省的下载文件 
		bootargs 定义传递给Linux内核的命令行参数 
		bootcmd 定义自动启动时执行的几条命令 
		serverip 定义tftp服务器端的IP地址 
		ipaddr 定义本地的IP地址 
		stdin 定义标准输入设备,一般是串口 
		stdout 定义标准输出设备,一般是串口 
		stderr 定义标准出错信息输出设备,一般是串口  	
 
	4)设备相关: 暂无
	   u-boot把可以用为控制台输入输出的设备添加到设备列表devlist,并把当前用作标准IO的设备指针加入stdio_devices数组中。
	   在调用标准IO函数如printf()时将调用stdio_devices数组对应设备的IO函数如putc()。
 
	5)命令相关的数据结构,后面介绍。
	6)与具体设备有关的数据结构,
		如flash_info_t flash_info[CFG_MAX_FLASH_BANKS];记录nor flash的信息。
		nand_info_t nand_info[CFG_MAX_NAND_DEVICE]; nand flash块设备信息

u-boot的重要细节
    主要分析流程中各函数的功能。按启动顺序罗列一下启动函数执行细节。按照函数start_armboot流程进行分析:

	1)DECLARE_GLOBAL_DATA_PTR;
	这个宏定义在include/global_data.h中:
	#define DECLARE_GLOBAL_DATA_PTR     register volatile gd_t *gd asm ("r8")
	声明一个寄存器变量 gd 占用r8。这个宏在所有需要引用全局数据指针gd_t *gd的源码中都有申明。
	这个申明也避免编译器把r8分配给其它的变量. 所以gd就是r8,这个指针变量不占用内存。

	2)gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));
	对全局数据区进行地址分配,_armboot_start为0x3f000000,CFG_MALLOC_LEN是堆大小+环境数据区大小,config/smdk2410.h中CFG_MALLOC_LEN大小定义为192KB.

	3)gd->bd = (bd_t*)((char*)gd - sizeof(bd_t));
    分配板子数据区bd首地址。
    这样结合start.s中栈的分配,
    stack_setup:
	ldr	r0, _TEXT_BASE                      @ upper 128 KiB: relocated uboot
	sub	r0, r0, #CONFIG_BOOTHEAD_GAP        @ boot head gap
	sub	r0, r0, #CONFIG_SYS_MALLOC_LEN      @ malloc area
	sub	r0, r0, #CONFIG_SYS_GBL_DATA_SIZE   @ bdinfo
	sub	sp, r0, #12              @ leave 3 words for abort-stack
	and	sp, sp, #~7              @ 8 byte alinged for (ldr/str)d
	不难得出上文所述的内存分配结构。
	下面几个函数是初始化序列表init_sequence[]中的函数:
	
	4)cpu_init();定义于cpu/arm920t/cpu.c 
		分配IRQ,FIQ栈底地址,由于没有定义CONFIG_USE_IRQ,所以相当于空实现。
	
	5)board_init;极级初始化,定义于board/smdk2410/smdk2410.c
	设置PLL时钟,GPIO,使能I/D cache.
	设置bd信息:
		gd->bd->bi_arch_number = MACH_TYPE_GODBOX;  // 机器类型 id 8000
		gd->bd->bi_boot_params = CFG_BOOT_PARAMS;   // 0x80000000 + 0x0100  规定给内核设置的启动参数的地址放在哪里
		
    6)interrupt_init;定义于cpu/arm920t/s3c24x0/interrupt.c 
		初始化2410的PWM timer 4,使其能自动装载计数值,恒定的产生时间中断信号,但是中断被屏蔽了用不上。

    7)env_init;定义于common/env_flash.c(搜索的时候发现别的文件也定义了这个函数,而且没有宏定义保证只有一个被编译,这是个问题,有高手知道指点一下!)
		功能:指定环境区的地址。default_environment是默认的环境参数设置。
		gd->env_addr  = (ulong)&default_environment[0];
		gd->env_valid = 0;
   
	8)init_baudrate;初始化全局数据区中波特率的值
		gd->bd->bi_baudrate = gd->baudrate =(i > 0)
		? (int) simple_strtoul (tmp, NULL, 10)
		: CONFIG_BAUDRATE;
		
    9)serial_init; 串口通讯设置 定义于cpu/arm920t/s3c24x0/serial.c 
     	根据bd中波特率值和pclk,设置串口寄存器。
	
    10)console_init_f;控制台前期初始化common/console.c
    由于标准设备还没有初始化(gd->flags & GD_FLG_DEVINIT=0),这时控制台使用串口作为控制台
    函数只有一句:gd->have_console = 1;
	
    10)dram_init,初始化内存RAM信息。board/smdk2410/smdk2410.c
    其实就是给gd->bd中内存信息表赋值而已。
    gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
  	gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
  	初始化序列表init_sequence[]主要函数分析结束。
 
	11)flash_init;定义在board/smdk2410/flash.c
	这个文件与具体平台关系密切,smdk2410使用的flash与FS2410不一样,所以移植时这个程序就得重写。
	flash_init()是必须重写的函数,它做哪些操作呢?
	首先是有一个变量flash_info_t flash_info[CFG_MAX_FLASH_BANKS]来记录flash的信息。flash_info_t定义:
	typedef struct {
		ulong size;   /* 总大小BYTE  */
		ushort sector_count;  /* 总的sector数*/
		ulong flash_id;  /* combined device & manufacturer code */
		ulong start[CFG_MAX_FLASH_SECT];   /* 每个sector的起始物理地址。 */
		uchar protect[CFG_MAX_FLASH_SECT]; /* 每个sector的保护状态,如果置1,在执行erase操作的时候将跳过对应sector*/
		 #ifdef CFG_FLASH_CFI //我不管CFI接口。
		.....
		 #endif
	} flash_info_t;
    flash_init()的操作就是读取ID号,ID号指明了生产商和设备号,根据这些信息设置size,sector_count,flash_id.以及start[]、protect[]。

	12)把视频帧缓冲区设置在bss_end后面。
	addr = (_bss_end + (PAGE_SIZE - 1)) & ~(PAGE_SIZE - 1);
	size = vfd_setmem (addr);
	gd->fb_base = addr;
	
	13)mem_malloc_init (_armboot_start - CFG_MALLOC_LEN);
	设置heap区,供malloc使用。下面的变量和函数定义在lib_arm/board.c
	malloc可用内存由mem_malloc_start,mem_malloc_end指定。而当前分配的位置则是mem_malloc_brk。
	mem_malloc_init负责初始化这三个变量。malloc则通过sbrk函数来使用和管理这片内存。
    static ulong mem_malloc_start = 0;
    static ulong mem_malloc_end = 0;
    static ulong mem_malloc_brk = 0;
    static
    void mem_malloc_init (ulong dest_addr)
    {
     mem_malloc_start = dest_addr;
     mem_malloc_end = dest_addr + CFG_MALLOC_LEN;
     mem_malloc_brk = mem_malloc_start;
    
     memset ((void *) mem_malloc_start, 0,
       mem_malloc_end - mem_malloc_start);
    }
    void *sbrk (ptrdiff_t increment)
    {
     ulong old = mem_malloc_brk;
     ulong new = old + increment;
    
     if ((new < mem_malloc_start) || (new > mem_malloc_end)) {
      return (NULL);
     }
     mem_malloc_brk = new;
     return ((void *) old);
    }
	
	14)env_relocate() 环境参数区重定位
	由于初始化了heap区,所以可以通过malloc()重新分配一块环境参数区,
	但是没有必要,因为默认的环境参数已经重定位到RAM中了。
	/**这里发现个问题,ENV_IS_EMBEDDED是否有定义还没搞清楚,而且CFG_MALLOC_LEN也没有定义,也就是说如果ENV_IS_EMBEDDED没有定义则执行malloc,是不是应该有问题?**/
	15)IP,MAC地址的初始化。主要是从环境中读,然后赋给gd->bd对应域就OK。
	16)devices_init ();定义于common/devices.c
	int devices_init (void)//我去掉了编译选项,注释掉的是因为对应的编译选项没有定义。
	{
		 devlist = ListCreate (sizeof (device_t));//创建设备列表
		i2c_init (CFG_I2C_SPEED, CFG_I2C_SLAVE);//初始化i2c接口,i2c没有注册到devlist中去。
		//drv_lcd_init ();
		//drv_video_init ();
		//drv_keyboard_init ();
		//drv_logbuff_init ();
		drv_system_init ();  //这里其实是定义了一个串口设备,并且注册到devlist中。
		//serial_devices_init ();
		//drv_usbtty_init ();
		//drv_nc_init ();
	}
  经过devices_init(),创建了devlist,但是只有一个串口设备注册在内。显然,devlist中的设备都是可以做为console的。
	16)jumptable_init ();初始化gd->jt。1.1.6版本的jumptable只起登记函数地址的作用。并没有其他作用。
	17)console_init_r ();后期控制台初始化
     主要过程:查看环境参数stdin,stdout,stderr中对标准IO的指定的设备名称,再按照环境指定的名称搜索devlist,将搜到的设备指针赋给标准IO数组stdio_devices[]。置gd->flag标志GD_FLG_DEVINIT。这个标志影响putc,getc函数的实现,未定义此标志时直接由串口serial_getc和serial_putc实现,定义以后通过标准设备数组stdio_devices[]中的putc和getc来实现IO。
	下面是相关代码:
    void putc (const char c)
         {
         #ifdef CONFIG_SILENT_CONSOLE
          if (gd->flags & GD_FLG_SILENT)//GD_FLG_SILENT无输出标志
           return;
         #endif
          if (gd->flags & GD_FLG_DEVINIT) {//设备list已经初始化
           /* Send to the standard output */
           fputc (stdout, c);
          } else {
           /* Send directly to the handler */
           serial_putc (c);//未初始化时直接从串口输出。
          }
         }
       void fputc (int file, const char c)
        {
         if (file < MAX_FILES)
          stdio_devices[file]->putc (c);
        }
	为什么要使用devlist,std_device[]?
	为了更灵活地实现标准IO重定向,任何可以作为标准IO的设备,如USB键盘,LCD屏,串口等都可以对应一个device_t的结构体变量,只需要实现getc和putc等函数,就能加入到devlist列表中去,也就可以被assign为标准IO设备std_device中去。如函数
	int console_assign (int file, char *devname); /* Assign the console 重定向标准输入输出*/
	这个函数功能就是把名为devname的设备重定向为标准IO文件file(stdin,stdout,stderr)。其执行过程是在devlist中查找devname的设备,返回这个设备的device_t指针,并把指针值赋给std_device[file]。

	18)enable_interrupts(),使能中断。由于CONFIG_USE_IRQ没有定义,空实现。
	    #ifdef CONFIG_USE_IRQ
		/* enable IRQ interrupts */
		void enable_interrupts (void)
    {
     unsigned long temp;
     __asm__ __volatile__("mrs %0, cpsr/n"
            "bic %0, %0, #0x80/n"
            "msr cpsr_c, %0"
            : "=r" (temp)
            :
            : "memory");
    }
    #else
        void enable_interrupts (void)
    {  
    }  
	19)设置CS8900的MAC地址。
		cs8900_get_enetaddr (gd->bd->bi_enetaddr);  
	20)初始化以太网。
		eth_initialize(gd->bd);//bd中已经IP,MAC已经初始化
	21)main_loop ();定义于common/main.c
		至此所有初始化工作已经完毕。main_loop在标准转入设备中接受命令行,然后分析,查找,执行。

U-boot中命令相关的代码

    命令相关的函数和定义
    @main_loop:这个函数里有太多编译选项,对于smdk2410,去掉所有选项后等效下面的程序

	void main_loop()
	{
		static char lastcommand[CFG_CBSIZE] = { 0, };
		int len;
		int rc = 1;
		int flag;
		 char *s;
		int bootdelay;
		s = getenv ("bootdelay");   //自动启动内核等待延时
		bootdelay = s ? (int)simple_strtol(s, NULL, 10) : CONFIG_BOOTDELAY;
	   
		debug ("### main_loop entered: bootdelay=%d/n/n", bootdelay);
		s = getenv ("bootcmd");  //取得环境中设置的启动命令行
		debug ("### main_loop: bootcmd=/"%s/"/n", s ? s : "");
   
		if (bootdelay >= 0 && s && !abortboot (bootdelay))
		{
			run_command (s, 0);//执行启动命令行,smdk2410.h中没有定义CONFIG_BOOTCOMMAND,所以没有命令执行。
		}
    
		for (;;) {
		len = readline(CFG_PROMPT);//读取键入的命令行到console_buffer
   
		flag = 0; /* assume no special flags for now */
		if (len > 0)
			strcpy (lastcommand, console_buffer);//拷贝命令行到lastcommand.
		else if (len == 0)
			flag |= CMD_FLAG_REPEAT;
		if (len == -1)
			puts ("/n");
		else
			rc = run_command (lastcommand, flag); //执行这个命令行。
   
		if (rc <= 0) {
			/* invalid command or not repeatable, forget it */
			lastcommand[0] = 0;
		}
   }
 	@run_comman();在命令table中查找匹配的命令名称,得到对应命令结构体变量指针,以解析得到的参数调用其处理函数执行命令。
    @命令结构构体类型定义:command.h中,
	struct cmd_tbl_s {
		char  *name;                         	/* 命令名   */
		int  maxargs;                         	/* 最大参数个数maximum number of arguments */
		int  repeatable; /* autorepeat allowed?  */
												/* Implementation function 命令执行函数*/
		int  (*cmd)(struct cmd_tbl_s *, int, int, char *[]);
		char  *usage;                        	/* Usage message (short) */
		#ifdef CFG_LONGHELP
		char  *help;                          	/* Help  message (long) */
		#endif
		#ifdef CONFIG_AUTO_COMPLETE
												/* do auto completion on the arguments */
		int  (*complete)(int argc, char *argv[], char last_char, int maxv, char *cmdv[]);
		#endif
   };
   typedef struct cmd_tbl_s cmd_tbl_t;

   //定义section属性的结构体。编译的时候会单独生成一个名为.u_boot_cmd的section段。
   #define Struct_Section  __attribute__ ((unused,section (".u_boot_cmd")))

   //这个宏定义一个命令结构体变量。并用name,maxargs,rep,cmd,usage,help初始化各个域。
   #define U_BOOT_CMD(name,maxargs,rep,cmd,usage,help) /
   cmd_tbl_t __u_boot_cmd_##name Struct_Section = {#name, maxargs, rep, cmd, usage, help}

V310 fastboot开机打印

System startup


Xls Version:  v1.4.0
Reg Time:     2015-5-26  下午 06:3hi3716m31dma_hi3716mv310_ddr3_512Mbyte_16bit_2layers_nand.reg
Reg Name:     hi3716m31dma_hi3716mv310_ddr3_512Mbyte_16bit_2layers_nand.reg

Relocate Boot to DDR	//display_relocate_to_ddr 里面打印: 作用:装载boot到DDR中

Jump to DDR				//clear_bss_loop: bl	display_jump_to_ddr 这个里面打印的,
						//然后执行语句:ldr	pc, _start_armboot  @ jump to C code 

//_start_armboot: .word start_armboot 接下来执行C代码了
				
Fastboot 3.3.0-svn (gsdk@dell910) (Jul 27 2015 - 14:29:47)	//display_banner 里面打印的

Fastboot:      Version 3.3.0								//dram_init 里面打印的
Build Date:    Jul 27 2015, 14:30:07
CPU:           Hi3716Mv310  
Boot Media:    NAND
DDR Size:      512MB

Check nand flash controller v610. found		//nand_init -> nand_init_chip -> board_nand_init -> hinfc610_init 这里打印的
Special NAND id table Version 1.36			//nand_spl_ids_register  nand_spl_ids.c
Nand ID: 0xC8 0xDA 0x90 0x95 0x44 0x7F 0x7F 0x7F	//nand_get_special_flash_type
Nand: GIGA NAND 256MiB 3,3V 8-bit 			//nand_get_flash_type
Nand(HW-Auto): Block:128KB Page:2KB OOB:64B ECC:4bit/512 Chip:256MB*1	//nand_get_flash_type  Chip:256MB*1:// nand_scan_ident
Net:   upWarning: failed to set MAC address
, downWarning: failed to set MAC address

/*
nand flash结构体数组信息:
struct nand_flash_dev nand_flash_ids[] = {

spi flash结构体数组信息:
struct spi_info hisfc350_spi_info_table[] =

*/

Boot Env on NAND							//show_boot_env 这个里面打印的
    Env Offset:          0x00100000
    Backup Env Offset:   0x00180000
    Env Size:            0x00020000
    Env Range:           0x00020000

ID_WORD has already been locked
HI_FLASH_Ioctl(HI_FLASH_CMD_GET_ERASE_SIZE):0x20000 

loaderdb value:HI_LOADER_GetFmt:772:enHdTvModetype = 0xb:enTvModetype = 0x1
__um_logo_param_sync.177 [hdFmt:8] [u32OutWidth:1280] [u32OutHeight:720] [sdFmt:11]
__um_logo_param_sync.234 [u32OutWidth:1280] [u32OutHeight:720] [sdFmt:11]
start sync bootargs
ASSERT:[schedule.c 811]g_buff=861fb000
ASSERT:[schedule.c 812]flash_addr=0x00100000 flash_size=0x20000
ASSERT:[schedule.c 813]flash_bak_addr=0x00180000 flash_bak_size=0x20000
ASSERT:[schedule.c 833] BootMedia:2.enFlashType:1

u32ParamCrcOri = 0x905092be, u32ParamCrc = 0x905092be,
u32ParamBakCrcOri = 0x905092be, u32ParamBakCrc = 0x905092be,
CFG_ENV_SIZE = 0x20000
sync bootargs seccuss

*******************************************
*                                         *
*      The SDK version is V310.           *
   [UM_VER] UM_FASTBOOT_5.1.07141002.0       
*                                         *
*******************************************

g_gpionumb=0x2d
regDeInit=0x16
regDeInit=0x16
Loader_Main->1411, get bootarges mem=128M console=ttyAMA0,115200 mmz=ddr,0,0x88000000,128M LogBufSize=0x80000 root=/dev/mtdblock11 ubi.mtd=dvt5_2 ubi.mtd=nvram ubi.mtd=ui ubi.mtd=fs root=ubi3_0 rw rootflags=sync rootfstype=ubifs rw mtdparts=hinand:0x100000(fastboot),0x80000(bargs),0x80000(bbargs),0x80000(stbid),0xc0000(ldb),0xc0000(bakldb),0xa00000(ml),0xa00000(bl),0xa00000(dvt5_2),0xf00000(nvram),0xa00000(kernel),0x6400000(fs),0x5000000(app),0xa00000(ui),0x300000(baseparam),0x400000(logo)

 SN:061117001011900019F021BD10
[STB_INFO] MAC: 0019F021BD10
set mac to eth0 = 00:19:F0:21:BD:10
function:um_set_mac,line:1338
press Power for force upgrade!
s32Ret=-1,u32PressStatus=-1,u32KeyValue=0xffffffff
(Re)start USB...
USB0:   Register 1212 NbrPorts 2
USB EHCI 1.00
scanning bus 0 for devices... 2 USB Device(s) found
       scanning usb for storage devices... 0 Storage Device(s) found
NO Such file: usb_update.bin on usb device
NO Such file: usb_update_force.bin on usb device
db.ota_type=0x4c,net_ota_type=0x4c u32FailedCnt=0

>> Loading 'loader' image.
Skipping bad block 0x00960000
Skipping bad block 0x00960000
Press Ctrl+C to stop autoboot
## Booting kernel from Legacy Image at 861fb000 ...
   Image Name:   Linux-3.10.0_hisilicon
   Image Type:   ARM Linux Kernel Image (uncompressed)
   Data Size:    6945720 Bytes = 6.6 MiB
   Load Address: 80a00000
   Entry Point:  80a00000
   Verifying Checksum ... OK
   Loading Kernel Image ... OK
OK

Starting kernel ...

Uncompressing Linux... done, booting the kernel.
Booting Linux on physical CPU 0x0
Linux version 3.10.0_hisilicon (gsdk@dell910) (gcc version 4.4.1 (Hisilicon_v200(gcc4.4-290+glibc-2.11+eabi+nptl)) ) #31 Sat Sep 19 11:07:50 CST 2015
CPU: ARMv7 Processor [414fc091] revision 1 (ARMv7), cr=10c53c7d
CPU: PIPT / VIPT nonaliasing data cache, VIPT aliasing instruction cache
Machine: hi3716mv310
Memory policy: ECC disabled, Data cache writeback
CPU: All CPU(s) started in SVC mode.
CPU: Hi3716Mv310 
Built 1 zonelists in Zone order, mobility grouping on.  Total pages: 32512
Kernel command line: mem=128M console=ttyAMA0,115200 mmz=ddr,0,0x88000000,128M LogBufSize=0x80000 root=/dev/mtdblock11 ubi.mtd=dvt5_2 ubi.mtd=nvram ubi.mtd=ui ubi.mtd=fs root=ubi3_0 rw rootflags=sync rootfstype=ubifs rw mtdparts=hinand:0x100000(fastboot),0x80000(bargs),0x80000(bbargs),0x80000(stbid),0xc0000(ldb),0xc0000(bakldb),0xa00000(ml),0xa00000(bl),0xa00000(dvt5_2),0xf00000(nvram),0xa00000(kernel),0x6400000(fs),0x5000000(app),0xa00000(ui),0x300000(baseparam),0x400000(logo)
drivers/common/mmz/drv_media_mem.c(1412): 000000------setup_zones=ddr,0,0x88000000,128M------000000
PID hash table entries: 512 (order: -1, 2048 bytes)
Dentry cache hash table entries: 16384 (order: 4, 65536 bytes)
Inode-cache hash table entries: 8192 (order: 3, 32768 bytes)
Memory: 128MB = 128MB total
Memory: 100116k/100116k available, 30956k reserved, 0K highmem
Virtual kernel memory layout:
    vector  : 0xffff0000 - 0xffff1000   (   4 kB)
    fixmap  : 0xfff00000 - 0xfffe0000   ( 896 kB)
    vmalloc : 0xc8800000 - 0xff000000   ( 872 MB)
    lowmem  : 0xc0000000 - 0xc8000000   ( 128 MB)
    modules : 0xbf000000 - 0xc0000000   (  16 MB)
      .text : 0xc0008000 - 0xc04ca318   (4873 kB)
      .init : 0xc04cb000 - 0xc17110dc   (18713 kB)
      .data : 0xc1712000 - 0xc175bd60   ( 296 kB)
       .bss : 0xc175bd60 - 0xc17f8520   ( 626 kB)
SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
NR_IRQS:128
GIC CPU mask not found - kernel will fail to boot.
GIC CPU mask not found - kernel will fail to boot.
sched_clock: 32 bits at 24MHz, resolution 41ns, wraps every 178956ms
Calibrating delay loop... 1620.37 BogoMIPS (lpj=8101888)
pid_max: default: 4096 minimum: 301
Mount-cache hash table entries: 512
CPU: Testing write buffer coherency: ok
Setting up static identity map for 0xc03f5798 - 0xc03f57f0
L310 cache controller enabled
l2x0: 8 ways, CACHE_ID 0x410000c9, AUX_CTRL 0x72420001, Cache size: 131072 B
NET: Registered protocol family 16
DMA: preallocated 256 KiB pool for atomic coherent allocations
Serial: AMBA PL011 UART driver
uart:0: ttyAMA0 at MMIO 0x101e5000 (irq = 60) is a PL011 rev2
console [ttyAMA0] enabled
bio: create slab <bio-0> at 0
SCSI subsystem initialized
usbcore: registered new interface driver usbfs
usbcore: registered new interface driver hub
usbcore: registered new device driver usb
Switching to clocksource timer1
NET: Registered protocol family 2
TCP established hash table entries: 1024 (order: 1, 8192 bytes)
TCP bind hash table entries: 1024 (order: 0, 4096 bytes)
TCP: Hash tables configured (established 1024 bind 1024)
TCP: reno registered
UDP hash table entries: 256 (order: 0, 4096 bytes)
UDP-Lite hash table entries: 256 (order: 0, 4096 bytes)
NET: Registered protocol family 1
RPC: Registered named UNIX socket transport module.
RPC: Registered udp transport module.
RPC: Registered tcp transport module.
RPC: Registered tcp NFSv4.1 backchannel transport module.
squashfs: version 4.0 (2009/01/31) Phillip Lougher
NFS: Registering the id_resolver key type
Key type id_resolver registered
Key type id_legacy registered
msgmni has been set to 195
io scheduler noop registered
io scheduler deadline registered (default)
spiflash: Check Spi Flash Controller V350. Found
Found Nand Flash Controller V610.
Nand ID: 0xC8 0xDA 0x90 0x95 0x44 0x7F 0x7F 0x7F
Nand: GIGA NAND 256MiB 3,3V 8-bit 
Nand(HW-Auto): Block:128KB Page:2KB OOB:64B ECC:4bit/512 Chip:256MB*1
16 cmdlinepart partitions found on MTD device hinand
Creating 16 MTD partitions on "hinand":
0x000000000000-0x000000100000 : "fastboot"
0x000000100000-0x000000180000 : "bargs"
0x000000180000-0x000000200000 : "bbargs"
0x000000200000-0x000000280000 : "stbid"
0x000000280000-0x000000340000 : "ldb"
0x000000340000-0x000000400000 : "bakldb"
0x000000400000-0x000000e00000 : "ml"
0x000000e00000-0x000001800000 : "bl"
0x000001800000-0x000002200000 : "dvt5_2"
0x000002200000-0x000003100000 : "nvram"
0x000003100000-0x000003b00000 : "kernel"
0x000003b00000-0x000009f00000 : "fs"
0x000009f00000-0x00000ef00000 : "app"
0x00000ef00000-0x00000f900000 : "ui"
0x00000f900000-0x00000fc00000 : "baseparam"
0x00000fc00000-0x000010000000 : "logo"
libphy: himii: probed
Up port phy at 0x02 is connect
libphy: PHY himii:01 not found
usbcore: registered new interface driver usb-storage
usbcore: registered new interface driver usbserial

猜你喜欢

转载自blog.csdn.net/TSZ0000/article/details/82896897