博客
关于我
嵌入式 linux 系统的组成与启动
阅读量:479 次
发布时间:2019-03-06

本文共 571 字,大约阅读时间需要 1 分钟。

组成

arch Ivanka bootloader + kernel + rootfs

启动流程

  • CPU 中固化的一小段代码
  • 操作 SPI 控制器,从 SPI Flash 0 地址开始读数据到 RAM
  • CPU 开始从 RAM 读取指令并执行
  • 首先执行 bootloader 第一部分
  • 此部分为汇编代码且不做压缩
  • 初始化 CPU、DDR、PLL、Cache 等硬件组件
  • CPU 执行 bootloader 第二段代码
  • 完成串口、Flash、网口等驱动的初始化
  • 构建 shell 环境来接受用户输入
  • 整个 bootloader 运行期间 MMU 未初始化,所有地址访问采用物理地址方式
  • 解压并拷贝 kernel 到 RAM
  • 设置启动参数如 console=ttyS0,115200 root=31:2 mtdparts=ar7100-nor0:196608(boot),835236(kernel),-(rootfs)
  • 跳转至 kernel 入口开始运行
  • kernel 开始运行
  • 初始化 kernel 子系统
  • 完成 MMU 初始化
  • 挂载 rootfs,根文件系统通过启动参数获得
  • kernel 实现 Flash访问 abstraction 通过 MTD 子系统
  • 初始化各类驱动程序
  • 启动 /sbin/init
  • 执行 rcS 脚本
  • 启动 shell
  • 转载地址:http://anmdz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现lfu cache缓存算法(附完整源码)
    查看>>
    Objective-C实现LFU缓存算法(附完整源码)
    查看>>
    Objective-C实现linear algebra线性代数算法(附完整源码)
    查看>>
    Objective-C实现linear congruential generator线性同余发生器算法(附完整源码)
    查看>>
    Objective-C实现linear discriminant analysis线性判别分析算法(附完整源码)
    查看>>
    Objective-C实现linear regression线性回归算法(附完整源码)
    查看>>
    Objective-C实现linear search线性搜索算法(附完整源码)
    查看>>
    Objective-C实现Linear search线性搜索算法(附完整源码)
    查看>>
    Objective-C实现LinearSieve线性素数筛选算法 (附完整源码)
    查看>>
    Objective-C实现LinkedListNode链表节点类算法(附完整源码)
    查看>>
    Objective-C实现LinkedList链表算法(附完整源码)
    查看>>
    Objective-C实现local weighted learning局部加权学习算法(附完整源码)
    查看>>
    Objective-C实现logistic regression逻辑回归算法(附完整源码)
    查看>>
    Objective-C实现logistic sigmoid函数(附完整源码)
    查看>>
    Objective-C实现longest Common Substring最长公共子串算法(附完整源码)
    查看>>
    Objective-C实现longest increasing subsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现longestCommonSubsequence最长公共子序列算法(附完整源码)
    查看>>
    Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现lorenz transformation 洛伦兹变换算法(附完整源码)
    查看>>
    Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
    查看>>