首页 > 解决方案 > 运行`make qemu`得到错误:`qemu_mprotect__osdep: mprotect failed: Permission denied`

问题描述

我正在尝试在mac m1上做 mit6.828 实验室。安装后riscv-tool-chain,我尝试运行make qemu似乎是用来启动内核的,但一开始我得到了这个错误:

mkfs/mkfs fs.img README user/xargstest.sh user/_cat user/_echo user/_forktest user/_grep user/_init user/_kill user/_ln user/_ls user/_mkdir user/_rm user/_sh user/_stressfs user/_usertests user/_wc user/_zombie user/_cowtest user/_uthread user/_call user/_testsh user/_kalloctest user/_bcachetest user/_alloctest user/_bigfile
nmeta 46 (boot, super, log blocks 30 inode blocks 13, bitmap blocks 1) blocks 1954 total 2000
balloc: first 766 blocks have been allocated
balloc: write bitmap block at sector 45
qemu-system-riscv64 -machine virt -bios none -kernel kernel/kernel -m 128M -smp 1 -nographic -drive file=fs.img,if=none,format=raw,id=x0 -device virtio-blk-device,drive=x0,bus=virtio-mmio-bus.0
Could not allocate dynamic translator buffer
make: *** [qemu] Error 1

所以我从 github 克隆了 qemu 存储库以获取源代码,并检查版本到 v5.1.0,然后我应用此链接提到的此链接路径的补丁

配置运行如下:

 ./configure --disable-kvm --disable-werror --prefix=/usr/local --target-list="riscv64-softmmu"`

makeandmake install似乎运行良好,但是当我在实验室再次执行时make qemu,又出现了一个错误,我仍然没有找到如何解决这个问题:

qemu-system-riscv64 -machine virt -bios none -kernel kernel/kernel -m 128M -smp 3 -nographic -drive file=fs.img,if=none,format=raw,id=x0 -device virtio-blk-device,drive=x0,bus=virtio-mmio-bus.0
qemu-system-riscv64: qemu_mprotect__osdep: mprotect failed: Permission denied
**
ERROR:/Users/rezero/Desktop/6.828-note/qemus/qemu-5.1.0/tcg/tcg.c:733:tcg_region_init: assertion failed: (!rc)
Bail out! ERROR:/Users/rezero/Desktop/6.828-note/qemus/qemu-5.1.0/tcg/tcg.c:733:tcg_region_init: assertion failed: (!rc)
make: *** [qemu] Abort trap: 6

标签: linuxqemuriscvapple-m1mprotect

解决方案


由于我对 qemu 和 macos 不熟悉,所以我尝试了很多次。在这里我得到了:

# modify /etc/paths 
/usr/bin
/bin
/usr/local/bin
/usr/sbin
/sbin

# modify .zshrc
export PATH="/opt/homebrew/bin:$PATH"
export PATH="$HOME/bin:/usr/local/bin:$PATH"
export PATH="$PATH:/usr/local/opt/riscv-gnu-toolchain/bin"

仍然不知道发生了什么,但在我应用如下两个补丁后,事情似乎奏效了。(确保在 iterm 上关闭 Rosetta 模式,仍然使用 qemu 5.1.0)

patch1你可以下载并 cd 到 qemu 目录然后命令如下:patch -p1 < ../patch/v2-tcg-Fix-execution-on-Apple-Silicon.patch

patch2只有两行,直接打开osdep.c文件修改即可。

并在应用上述补丁后,运行配置:

./configure --disable-kvm --disable-werror --prefix=/usr/local --target-list="riscv64-softmmu"

make & make install

然后它起作用了,内核可以启动了。


推荐阅读