• riscv


    https://mp.weixin.qq.com/s/piTE9z9belhxIAkrfzwBzA

    ​简单介绍linux kernel arch/riscv/boot/loader.S相关的内容。

    1. loader.S

    linux kernel arch/riscv/boot/loader.S中的代码供bootloader如uboot等调用。在loader.S中,linux kernel的代码被作为数据使用:

    可以看到,这里直接把编译生成的linux kernel代码,亦即arch/riscv/boot/Image作为binary数据,放在_start的位置。

    这是一种比较直接的做法,没有对Image文件做处理。在arm/x86中,Image会被压缩,然后再与被bootloader调用的启动程序链接到一起,在启动时会执行解压缩动作。

    2. loader.lds.S

    loader.lds.S是loader.S的链接脚本:

    其中:

    a. arch为riscv:

    b. 入口点(entry)是_start,这是指在loader.S中定义的_start;

    c. 链接的起始地址是KERNEL_LINK_ADDR;

    d. .payload段就是loader.S中包含进来的Image的内容;

    3. Makefile

    在arch/riscv/boot/Makefile中,定义了生成loader/loader.bin的规则:

    生成loader.bin的命令如下:

    使用objdump命令反汇编loader:

    得到的内容如下:

    这就是arch/rsicv/kernel/head.S中的内容,也就是Image中的内容。

    从中也可以看出KERNEL_LINK_ADDR的值为0x80000_0000,这也符合其定义:

    PAGE_OFFSET的定义如下:

    如果使用命令make ARCH=riscv CROSS_COMPILE=riscv64-unknown-elf- V=1进行编译:

    可以看到-DCONFIG_PAGE_OFFSET=0x80000000的选项。

    https://mp.weixin.qq.com/s/piTE9z9belhxIAkrfzwBzA 

  • 相关阅读:
    Hosts
    Jupyter notebook 文件路径
    [GDAL]在三维场景中显示DEM
    [GDAL]编译64位GDAL1.10
    ArcEngine几何变换中的策略模式
    AE Scene开发中的观察者模式
    象限角和方位角
    帧率控制和渲染帧率
    [3D]1.绘制三角形
    CSLA.Net学习(2)
  • 原文地址:https://www.cnblogs.com/wjcdx/p/15226486.html
Copyright © 2020-2023  润新知