XV6的使用与介绍

XV6的使用

Xv6是由麻省理工学院(MIT)为操作系统工程的课程(代号6.828),开发的一个教学目的的操作系统。这里介绍一下它的使用,如果只看MIT课程的翻译的话可能有很多地方都不理解,学的很乱,这里给出基本的XV6的环境搭建和使用。

这里推荐使用我基于linxi的镜像重新制作的docker镜像loserfromlazy/mit6.s081-gdb:latest避免不同环境造成的bug。

我这里是使用linxi大大的docke镜像修改后的镜像(具体原因见下面),他的镜像是基于2020实验版本制作的,首先我们拉取镜像并启动:

它的镜像使用的是gdb-multiarch,这个调试工具无法si单步进入ecall指令,这时可以安装riscv64-unknown-elf-gdb,这是MIT6.S081课程上使用的调试工具,安装方法

然后进入到该镜像,并进入到xv6-labs-2020目录:

在这个目录下使用make qemu命令即可启动xv6系统,如果想停止xv6系统的话,就另起一个终端,进入此镜像,然后执行pkill -f qemu命令即可。

xv6启动后我们输入ls命令可以见到其所有的可执行的命令:

我们可以看到ls命令也在其中。其实我们可以将这里的所有命令理解为用户程序,我们可以在xv6-labs-2020/user下见到他们:

如果我们想自己编写C程序并在XV6中运行的话,那么只需要将编写好的c文件放到这个user目录下,然后在Makefile文件中加入我们编写的文件。比如上图中的sleep.c就是我自己编写的C程序文件,然后我们去编辑Makefile,主要改这个地方:

然后回到xv6-labs-2020目录下,执行make clean命令,在执行make qemu即可。然后我们就可以在XV6中调用自己的c程序了。就跟调用ls命令是一样的。

点击链接有彩蛋,领取更多Java书籍。

相关推荐
Java编程爱好者9 分钟前
1-5 线程池:Thread+阻塞队列+循环
后端
jnrjian11 分钟前
Library Cache Load Lock library cache pins are replaced by mutexes
java·后端·spring
用户94161469336522 分钟前
Python 批量获取 A 股全市场 K 线数据并计算技术指标(附完整代码)
后端
小江的记录本43 分钟前
【Kafka核心】Kafka高性能的四大核心支柱:零拷贝、批量发送、页缓存、压缩
java·数据库·分布式·后端·缓存·kafka·rabbitmq
SamDeepThinking1 小时前
程序员过35岁之前,应该完成的三件事
java·后端·程序员
952361 小时前
SpringAOP
java·后端·学习·spring
zx2859634002 小时前
Laravel6.x新特性全解析
java·后端·spring
Jul1en_2 小时前
Claude 迁移 Codex 工作流迁移与更新
java·服务器·前端·后端·ai编程
神奇小汤圆2 小时前
京东二面:假如SQL中join了10张表,如何优化性能?
后端
神奇小汤圆2 小时前
Spring AOP底层黑科技:巧妙破解微服务异步线程池导致事务与链路上下文丢失难题
后端