This is a playground to play with the Linux kernel, providing a easy to build and debug kernel inside a Docker container.
The following steps are verified on Ubuntu 20.04, x86-64 machine.
The following are the packages and tools that are required to use this repo.
We expect the machine to have atleast 5 GB of free disk space.
- Install VSCode by following the official instructions.
- Install Remote Development extension in VSCode (Identifier : ms-vscode-remote.vscode-remote-extensionpack) - Refer instructions on how to install extensions.
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose
- Create docker group :
sudo groupadd docker
- Add your user to the docker group :
sudo usermod -aG docker $USER
- Reboot or logout and login again
Note: all our steps are expected to work with VSCode. You may be able to use our image without VSCode but we do not currently support it.
Clone the playground repository:
git clone https://github.com/purs3lab/linux-playground.git
The playground is integrated into the VSCode IDE. So start by opening the linux-playground
folder in the VSCode IDE.
code linux-playground
Once the playground is open, in VSCode you may see a message window at the bottom right of the editor window:
Click on Reopen in Container
This command will build the relevant container image and bring up the workspace in the new environment.
The VSCode will restart and you will see tthe following message at the bottom right of the window
This may take a while. Once this process is done you should get your workspace now open inside the container. If you open a terminal from inside VS Code you should get a prompt from inside the container and everything.
At this point your VScode window should contain the linux kernel sources and you should see the following:
Since we are trying to mount a basic filesystem, it needs to be built before you are able to start the playground.
Once you are inside the container, you can build the filesystem by opening the command palette using Ctrl + Shift + P and typing: Tasks: Run Task
Which should give you a prompt with multiple options (This is the VSCode Tasks List).
Select the (Needed) build-fs
option. This should create the filesystem that would be used by the kernel.
Note : If you want to run the same command without using vscode, you should be able to find a bash script at /scripts/build-fs.sh