V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
ksco
V2EX  ›  分享创造

从零实现一个 RISC-V 模拟器

  •  
  •   ksco · 2022-06-24 12:45:55 +08:00 · 3551 次点击
    这是一个创建于 885 天前的主题,其中的信息可能已经有所发展或是发生改变。

    写了一个非常小的 RISC-V 模拟器,只有 1500 行 C 代码,可以运行 xv6 。写完之后对于模拟器的运行原理也算是有了一个基础的理解。

    开源地址: https://github.com/ksco/nanoemu

    运行截图:

    10 条回复    2022-06-28 11:24:49 +08:00
    jdjingdian
        1
    jdjingdian  
       2022-06-24 15:15:54 +08:00   ❤️ 1
    不明觉厉,火钳刘明
    uilvn
        2
    uilvn  
       2022-06-24 15:24:13 +08:00   ❤️ 1
    已 star
    kimown
        3
    kimown  
       2022-06-24 17:11:07 +08:00
    这是用 x86 指令模拟 risc-v 吗
    ksco
        4
    ksco  
    OP
       2022-06-24 17:24:37 +08:00   ❤️ 1
    @kimown #3 你说的是类似 QEMU TCG 那种动态翻译吗?不是的,就是单纯的软件模拟。
    kimown
        5
    kimown  
       2022-06-24 17:44:01 +08:00
    @ksco 是软件模拟 risc-v 硬件吗
    ksco
        6
    ksco  
    OP
       2022-06-24 17:53:47 +08:00
    @kimown #5 对的,实现了 I M A 三个扩展的部分指令,以及部分特权级指令。总之刚好可以用来运行 xv6 。
    misaka19000
        7
    misaka19000  
       2022-06-24 18:06:16 +08:00
    不明觉厉,火钳刘明!!!
    TimeSea
        8
    TimeSea  
       2022-06-24 19:01:32 +08:00 via Android   ❤️ 1
    好厉害,这个学期学校让我们用的 verilog 写的 cpu,不知道能不能也把这个跑起来
    f1384793
        9
    f1384793  
       2022-06-28 10:13:29 +08:00
    @ksco 请问楼主用的哪个版本的 xv6 ?
    ksco
        10
    ksco  
    OP
       2022-06-28 11:24:49 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1064 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 19:58 · PVG 03:58 · LAX 11:58 · JFK 14:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.