V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
Sponsored by
LinkedIn
不坐班的神仙工作 · 去任何你想去的地方远程,赚一线城市的工资
2000 个不用出门 Social 的全球远程工作,帮助 V2EX 的小伙伴开启全新的工作方式。
Promoted by LinkedIn
ksco
V2EX  ›  分享创造

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

  •  
  •   ksco ·
    ksco · 97 天前 · 2109 次点击
    这是一个创建于 97 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

    运行截图:

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