You’ll use two sets of tools in this class: QEMU, a machine emulator for running your kernel; and a compiler toolchain, including assembler, linker, C compiler, and debugger, for compiling and testing your kernel.
You have two options to install your development environment. Please take care of this as soon as the semester starts as it can take some time to get familiar with the environment. There is technically a third option whereby you install all software and dependencies manually on Linux or Mac, but this is not officially supported.
We recommend the use of Docker Desktop, if your personal machine:
is reasonably new (maybe 4 years),
is reasonably up to date,
has adequate free disk space (ten gigabytes should do it).
Follow the installation instructions.
While Docker Desktop should work fine on most machines, it is possible that you may run into errors. Do not ask course staff to help you debug issues; instead, please use Option 2
which will rely on Duke VCM.
We have reserved a set of virtual machines (VMs) on Duke VCM. You first need to figure out how to ssh into the VM; if you are unfamiliar with this, please see the Duke VCM SSH Guide.
When you read the section below on “Using Docker”, make sure that you prefix your docker
(and your make
and make qemu
commands within the Docker container) with sudo
so that the commands run as root. If you don’t do this, you will see permission denied errors.
Docker constructs the environment for building and running course projects. Under the hood, Docker launches a container that runs alongside the host operating system, managing all dependencies and software requirements. We provide a standard Docker image on Dockerhub, which supports xv6 environment for the labs. The container runs bash with user xv6. The password of the user is also xv6.
Each lab will rely on the same base repo that contains all of the necessary files (e.g., xv6, grading scripts). Please clone the base repo in your host system (i.e., your personal machine or Duke VCM) before you start. Follow the git instructions to learn how to clone the base repo. Once you have the base repo cloned, you can start a new Docker container by running:
On Macbook/Linux:
On Windows Powershell:
On Windows Cmd:
This command also maps the xv6 repository directory into /home/xv6/xv6-riscv
inside your container. If successful, you should see the following output from the container:
The shell prompt (xv6@0c765f60374a:~/xv6-riscv$
) consists of the username (xv6
), hostname (0c765f60374a
), and current working directory (/home/xv6/xv6-riscv
or ~/xv6-riscv
). The hostname is the same as the container ID, so it will likely differ from the above example.
All of the kernel-oriented labs rely on the xv6 teaching OS. The Docker container will support building and running xv6 wit QEMU. To do this, run the following commands:
At this point, you are now in a shell hosted by the xv6 OS. You can run any available user-space programs (e.g., ls).
To exit from xv6 and return to the Docker container, type ctrl-a followed by x.
Now you are free to start working on your lab. The lab repo in your host system is mounted into the docker container, so you can open the repo with any editor of your choice on your host system (e.g., VSCode, vim, emacs). All the modifications will be reflected in the Docker container automatically.
If you are using a VCM machine, you can use VSCode and the Remote-SSH plugin to connect to you VCM machine.