使用 C++23 从零实现 RISC-V 模拟器

使用 C++23 从零实现 RISC-V 模拟器

使用 C++23 从零实现的 RISC-V 模拟器,最终的模拟器可以运行 xv6 操作系统。

本教程参考了 Asami 所写的 Rust 版本的模拟器教程 ,但是原版只写了前三章。此外也参考了 Rare 对 rvemu 的改进 Rare 这也是一个 Rust 版本的并且已经完结了,对 rust 版本感兴趣的可以参考上面所给出对应的链接。

接下来我将会用 C++ 23 来实现,原则是即能用上的新特性全部都用上。以循序渐进的方式,最终实现一个可以运行 xv6 操作系统的 RISC-V 模拟器。此外重新组织了实现方式,一定程度上降低了难度梯度。

前置知识

假设读者学过 C 语言并且了解一点 C++ 的基本概念,即 C with class 水平即可。

对于 RISC-V 方面的知识可以参考下面的内容:

开发环境

  • Linux / Win(WSL) / MacOS

使用 docker 开发,其内部包含了一个 Ubuntu 20.04,其中用到了 riscv64-unknown-elf-gcc, 也可以用 clang 来编译。

lab0-start-code 分支是一个包含了 gtest 的启动代码。项目名称为 crvemu ,即 C++ RISC-V emulate 的缩写。

sh 复制代码
git clone --recurse-submodules https://github.com/weijiew/crvemu
cd crvemu && mkdir -p build && cd build
cmake .. && make -j $(nproc)
./crvemu
# Hello, World!

验证 gtest :

sh 复制代码
cmake .. && make -j $(nproc) && ./g_test

问题

如有任何问题,可以随时提 crvemu issue

👉🏻 文章汇总「从零实现模拟器、操作系统、数据库、编译器...」:https://okaitserrj.feishu.cn/docx/R4tCdkEbsoFGnuxbho4cgW2Yntc

相关推荐
国科安芯17 分钟前
AS32系列MCU芯片TIM模块的捕获和比较
单片机·嵌入式硬件·fpga开发·架构·risc-v
cooldream200914 小时前
C++20 与 C++23 新特性深度解析:迈向现代 C++ 的核心进化
c++·c++20·c++23
fpcc14 小时前
C++23中的import开发实践
c++23
云雾J视界7 天前
FPGA+RISC-V架构解析:构建高效传感器数据采集系统
fpga开发·架构·uart·risc-v·i2c·adxl345
电子科技圈9 天前
IAR与Quintauris携手推进RISC-V汽车实时应用的功能安全软件开发
嵌入式硬件·安全·设计模式·编辑器·汽车·risc-v
CinzWS10 天前
RISC-V RV32MCU 架构、启动与运行机制深度剖析
risc-v·exception
stay_cloud10 天前
RISC-V MCU 串口通信记录 —— 基于Genesys2
mcu·uart·risc-v
ChipCamp10 天前
芯片开发验证之RISC-V编译器:绕过构建的烦恼,直接用Arduino的
编译器·risc-v·objdump·汇编器·objcopy
全球通史13 天前
[特殊字符] RISC-V实战:从0到100+FPS!进迭时空(Spacemit)开发板YOLOv8部署终极指南
嵌入式硬件·yolo·risc-v
码界奇点14 天前
Linux进程间通信三System V 共享内存完全指南原理系统调用与 C 封装实现
linux·c语言·网络·c++·ux·risc-v