希望通过此课程对计算机的工作原理有更深入的了解,同时了解一个简单模拟器是如何搭建的。以下是对模拟器NEMU编译过程中,遇到问题的记录。
一、模拟器编译步骤
1、下载项目源码
git clone -b 2022 git@github.com:NJU-ProjectN/ics-pa.git ics2022
2、配置编译选项
首次编译时,需要执行以下命令配置编译选项。默认ISA为RISCV32。这里以RISCV32为例,选择Exit使用默认值配置编译选项。
make menuconfig
3、编译
make
二、遇到的问题
本机环境为Ubuntu 20.04 LST、llvm-11.0(预编译版本)、gcc-9。编译过程中llvm版本、环境变量设置、gcc版本会导致各种各样的编译问题。
1、llvm版本问题
教程中推荐使用llvm11及以上版本。若出现如下提示,可升级llvm版本并参考连接中的教程配置编译文件:
或
src/utils/disasm.cc:37:2: error: #error Please use LLVM with major version >= 11
参考链接:Getting Source Code for PAs · GitBook
2、问题:error: ‘for’ loop initial declarations are only allowed in C99 mode
错误提示添加编译选项 -std=c99 或 -std=gnu99。
由于该项目使用的makefile进行编译,需要找到其对应编译文件,添加-std=c99。
编译规则文件:nemu/scripts/build.mk
在该文件CFLAGS变量上添加-std=c99。make后又出现问题:
提示-std=c99是用于c/objc的编译,c++不适用。查看build.mk发现40行.cc文件编译也用到了CFLAGS变量,因此仅在34行.c文件编译规则这里添加-std=c99。
3、问题:relocation R_X86_64_32 against `.rodata.str1.8' can not be used when making a PIE object; recompile with -fPIE
我的理解是编译目标都是PIE对象,但是在链接时不能为PIE对象。查了资料后,建议编译时添加-fPIC或者是-no-pie。
修改编译文件:/nemu/src/filelist.mk
第22行,-pie改为-no-pie。
至此,所有编译问题解决,正常编译完成后的输出如图所示。
三、运行测试
运行命令:
make run
输出如下图所示即测试成功。错误提示是课程故意留的作业, 后续课程中需要对此进行修正。