• 系统移植--前言


    移植

        不同架构的处理器指令集不兼容,即便是相同的处理器架构,板卡不同驱动代码也不兼容

        Linux是一个通用的内核并不是为某一个特定的处理器架构或板卡设计的,所以从官方获取Linux源码后我们要先经过相应的配置使其与我们当前的硬件平台相匹配后才能进行编译和安装

    安装过程

    开发板启动过程

    1.开发板上电后首先运行SOC内部iROM中固化的代码(BL0),这段代码先对基本的软硬件环境(时钟等...)进行初始化,然后再检测拨码开关位置获取启动方式,然后再将对应存储器中的uboot搬移到内存,然后跳转到uboot运行
    2. uboot开始运行后首先对开发板上的软硬件环境做进一步初始化,然后将linux内核、设备树(dtb)、根文件系统(rootfs)从外部存储器(或网络)搬移到内存,然后跳转到linux运行
    3. linux开始运行后先对系统环境做初始化,当系统启动完成后,Linux再从内存中(或网络)挂载根文件系统
    CPU能够读写的范围大小即为 地址空间-->由地址总线宽度决定(32位)
    2^32 = 4G 为4412可读写空间,  4G内存进行划分得地址映射表(各个地址的用途)
    刚上电时PC指向0地址 iROM(inter read only memory)中的BL0;
     ROM:  read only memory   只读程序 。 4412扩了1G内存 0x4000 000 -  0x8000 0000
    RAM: random access memory  随机存取存储器
    EMMC -> 硬盘,断电数据不丢失
    想要执行,先要放到内存RAM中,供CPU去读取执行
    上电后:
    1.首先执行iROM中的BL0, BL0做了三件事:
    a.初始化时钟,内存等;b.读取拨码开关状态( SD卡启动);c. SD卡内容uboot放到内存RAM中;
    非EMMC中的uboot,因为非EMMC启动
    2.uboot将linux从EMMC中搬到RAM内存中;
    3.uboot将dtb(device tree)从EMMC中搬到RAM内存中;
    4.uboot将rootfs从EMMC中搬到RAM内存中;
    5.uboot完成任务停止,linux 启动,做一些初始化
    linux + dtb   --> linux
  • 相关阅读:
    【Pytorch + AlexNet + torchsummary】torchsummary 查看网 及 各层输出的 feature map 尺寸
    解决重启Linux服务器后数据消失问题
    Spring Boot Starter 剖析与实践
    LeetCode力扣刷题——指针三剑客之二:树
    如何解hard算法题?
    U盘无法正常格式化?教你一个强力的办法
    视频监控系统/视频云存储EasyCVR接入国标GB28181设备无法播放设备录像,是什么原因?
    文件共享服务器(cifs协议 -- 微软开发)
    mysql基础知识篇(一)
    SpringBoot自动配置原理分析
  • 原文地址:https://blog.csdn.net/2302_76785838/article/details/133715546