java打印对象内存地址 分布式事务 事务消息 分布式事务 几种解决方案 分布式事务-Seata 分布式事务-Seata 分布式事务-LCN-TCC 分布式事务-LCN 分布式事务-消息队列-定时任务-本地事件表 Zuul网关实战02 Zuul网关实战01 灰度发布落地实战2 灰度发布落地实战1 Gsnova on Heroku build Systemd Debian system initialization manage multi id_rsa ubuntu 64bits cannot run 32bits app REHL power auditing Debug Assembly for ARMv8 on QEMU ARM体系结构--寄存器 Run Debian iso on QEMU ARMv8 QEMU ARM64 guide cross compiler install buildroot install QEMU install python入门--数据结构 python入门--内置数据类型 python入门--类 异常 python入门--条件表达式 方法 python入门--数字 字符串 数组 RTC驱动分析 块设备驱动 TCP UDP socket 触摸屏驱动 USB驱动 LED按键中断 LCD 驱动 驱动信号 根文件系统 实验 内核实验 字符设备驱动程序 绪论 uboot 实验 LCD 实验 系统时钟和UART 中断控制器 Nand Flash控制器 MMU 实验 储存管理器实验 GPIO实验 点亮LED 编译加载驱动 制作烧写内核 dnw替代方法 MINI2440 TQ2440安装配套Linux 使用NFS 制作烧写跟文件系统 grub引导Windows 烧写裸版程序-linux Ubuntu 网络没有 eth0 Linux自动挂载 烧写裸板程序 电路基础 Mac词典 Vim插件 Assembly 综合研究 Assembly 指令总结 Assembly 直接定址表 Assembly 使用BIOS进行键盘输入和磁盘读写 Assembly 外中断 Assembly 端口 Assembly int指令 Assembly 内中断 Assembly 标志寄存器 Assembly 转移指令的原理 Assembly Call和ret指令 Assembly 数据处理两个基本问题 Assembly 灵活定位内存地址 Assembly 包含多个段的程序 Assembly [bx] loop Assembly 第一个程序 Assembly 寄存器 (内存访问) Assembly 寄存器 AWS VPN with EC2 hidden file in picture(linux) Assembly 基础 idea shortcuts 常用快捷键 idea plugin folder install ruby and jekyll

uboot 实验

2015年02月11日

###u-boot

###最终目的:启动内核

  1. 从Flash读出内核 放到SDRAM
  2. 启动内核

###u-boot要实现的功能:

  1. 读Flash
  2. 初始化SDRAM
  3. 启动内核

###使用u-boot:

  1. 解压缩
  2. 打补丁:patch -p? < 补丁文件
  3. 配置:make 100ask24x0_config
  4. 编译:make

###u-boot功能:单片机程序 关看门狗

初始化时钟

初始化SDRAM

从FLASH读出内核

启动内核


分析配置过程:make 100ask24x0_config

从Makefile中找

分析编译:make

  1. 第一个文件 cpu/arm920t/start.S
  2. 链接地址:board/100ask24x0/u-boot.lds 0x33F80000

###硬件相关:

  1. 设SVC模式
  2. 关看门狗
  3. 屏蔽中断
  4. 初始化SDRAM
  5. 设置栈
  6. 时钟
  7. 代码从Flash–>拷贝到SDRAM
  8. 清BSS段
  9. 调用start_armboot

###U-boot:启动内核

  1. 从Flash读出内核
  2. 启动:do_bootm

####启动内核: 关键代码

s = getenv("bootcmd");
run_command(s, ...);

###u-boot界面: 关键代码

readline(读入串口的数据);
run_command

###u-boot的核心:命令

  1. 输入命令字符串–>name–>函数
  2. 动作–>函数

###分区: PC:每个硬盘上都有分区表

嵌入式Linux:Flash没有分区表,源代码里写死

###u-boot:Flash上存的内核:UImage 64字节头部+真正的内核

###do_bootm:

  1. 根据头部移动内核到合适的地方
  2. 启动:do_bootm_linux
    1. u-boot告诉内核一些参数–>设置启动参数
    2. 跳到入口地址启动内核

###u-boot:启动内核

  1. 从Flash读出
  2. 启动
    1. 设启动参数
    2. 跳到入口地址

####thekernel是函数指针

thekernel( 0, bd->bi_arch_number, bd->bi_boot_params);

bd->bi_arch_number 是机器ID,内核启动时比对,确定能否支持

bd->bi_boot_params 是内核启动参数内存


###u-boot命令查询: ? 命令


读取内核命令:

nand read.jffs2 0x30007FC0 kernal;

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

放到哪里去?——0x30007FC0

nand read.jffs2 0x30007FC0 0x00060000 0x00200000

bootm 0x30007FC0

设置参数保存在内存:

setup_start_tag (bd);
setup_memory_tags (bd);
setup_commandline_tag (bd, commandline);
setup_end_tag (bd);