【RISC-V】区分加载地址、链接地址、运行地址

原本是没有这个概念区分的,现代通用计算机(PC、手机、服务器)都有MMU,你的操作系统内核会自动处理了这一切,你不需要区分这些,但是当你的机器上电时,还没有操作系统内核接管时,你开发的裸机/嵌入式/引导程序需要明确区分这些地址:

┌─上电过程─────────────────────────────────────────┐

│ 上电复位 → BIOS/UEFI固件 → Bootloader → 操作系统内核 → 用户空间 │

└────────────────────────────────────────────────┘

  • 加载地址:程序真正复制或存储(有些固件程序就存储在ROM中)到内存中的起始物理。
  • 链接地址:链接地址是链接器(linker)在生成可执行文件或目标文件时,为每个符号和段分配的虚拟地址。
  • 运行地址:程序真正运行时的内存地址,也是PC在执行指令或访问数据时,实际使用的内存地址

所以

什么情况下一段程序三者地址相同:

比较少见了,现在程序基本都在虚拟内存下运行,只有标准静态链接的非 PIE(Position-Independent Executable)用户态可执行程序三者地址相同(在编译时要明确指明-no-pie参数)

什么情况下加载地址与链接地址不同,但是链接地址与运行地址相同:

一般你编写的程序(大多数用户态程序)都是这个模式,上面也说了,当你的程序运行在 带 MMU 的操作系统 (如 Linux、Windows)时,你的操作系统加载器会将程序加载到内存的虚拟地址。CPU 运行时使用该虚拟地址访问代码和数据。此时链接地址与运行地址与加载地址都相同。

什么情况下链接地址与运行地址不同:

内核或裸机程序在 MMU 开启之前的程序,比如Bootloader 的第二阶段,还有RISCV架构中MMU 开启前会调用固件接口程序和启动操作系统内核的汇编代码(因为MMU启动后归MMU接管了)

注意!!!:这些任务不能依赖虚拟内存 ,代码必须是位置无关(Position-Independent) 或已知加载地址的。

举一个真实的例子,Linux 内核在编译链接时,会被链接脚本链接到一个高的虚拟地址 0xffffffff80000000(. = 0xffffffff80000000,但Bootloader中(如 OpenSBI 或 U-Boot)将内核镜像加载地址编写在了内存的0x80200000处

如何解决:内核代码里的所有MMU启动前的汇编代码都不基于基址编写,而是基于PC编写,用auipc和lla这些,当MMU开启后,立即跳转到虚拟地址

相关推荐
国科安芯3 小时前
基于RISC-V架构的抗辐照MCU在空间EDFA控制单元中的可靠性分析
单片机·嵌入式硬件·性能优化·架构·risc-v·安全性测试
国科安芯2 天前
空间站机械臂中MCU与CANFD抗辐照芯片的集成研究
单片机·嵌入式硬件·fpga开发·架构·risc-v
信创天地3 天前
国产化分布式服务框架双雄:Dubbo与Spring Cloud Alibaba 服务调用解决方案全解析
人工智能·系统架构·开源·dubbo·运维开发·risc-v
weixin_5531320710 天前
探索Vortex开源GPGPU:RISC-V SIMT架构(4-2),TCU 矩阵计算(1)
矩阵·架构·github·risc-v·wmma·simt·tcu
OpenAnolis小助手13 天前
RISC-V 基金会 Data Center SIG 第六次会议圆满结束,推动数据中心缺口改进及引入
ai·risc-v
码云数智-园园13 天前
“架构之争,生态之合”:.NET 生态系统对 LoongArch 与 RISC-V 的支持深度解析
架构·.net·risc-v
国科安芯14 天前
火箭传感器控制单元的抗辐照MCU选型与环境适应性验证
单片机·嵌入式硬件·架构·risc-v·安全性测试
蒹葭玉树19 天前
【C++上岸】C++常见面试题目--操作系统篇(第三十期)
c++·面试·risc-v
国科安芯20 天前
面向星载芯片原子钟的RISC-V架构MCU抗辐照特性研究及可靠性分析
单片机·嵌入式硬件·架构·制造·risc-v·pcb工艺·安全性测试
思尔芯S2C23 天前
FPGA原型验证实战:如何应对外设连接问题
fpga开发·risc-v·soc设计·prototyping·原型验证