All Projects → tinyclub → Linux 0.11 Lab

tinyclub / Linux 0.11 Lab

Licence: gpl-2.0
Docker/Qemu/Bochs Based Linux 0.11 Kernel Development Environment; New Linux ELF Video Course from this project author: https://www.cctalk.com/m/group/88089283

Programming Languages

c
50402 projects - #5 most used programming language

Projects that are alternatives of or similar to Linux 0.11 Lab

Linux Lab
Docker/Qemu Based Linux Kernel Learning, Development and Testing Environment; New Linux ELF Video Course from this project author: https://www.cctalk.com/m/group/88089283
Stars: ✭ 771 (+39.17%)
Mutual labels:  lab, linux-kernel, qemu
Linux Kernel Module Cheat
The perfect emulation setup to study and develop the Linux kernel v5.4.3, kernel modules, QEMU, gem5 and x86_64, ARMv7 and ARMv8 userland and baremetal assembly, ANSI C, C++ and POSIX. GDB step debug and KGDB just work. Powered by Buildroot and crosstool-NG. Highly automated. Thoroughly documented. Automated tests. "Tested" in an Ubuntu 19.10 ho…
Stars: ✭ 2,748 (+396.03%)
Mutual labels:  linux-kernel, qemu
Linux-Kernel-Driver-Programming
Implementation of PCI drivers, kprobe, sysfs, devfs, sensor driver, miscdevices, synchronization
Stars: ✭ 43 (-92.24%)
Mutual labels:  debugging, linux-kernel
run qemu
A script to create bootable OS images, and run qemu with a locally built kernel.
Stars: ✭ 16 (-97.11%)
Mutual labels:  linux-kernel, qemu
virtblkiosim
Virtual Linux block device driver for simulating and performing I/O.
Stars: ✭ 30 (-94.58%)
Mutual labels:  linux-kernel, qemu
m3forth
m3forth is a forth cross-compiler for cortex-m3 ARM microcontrollers
Stars: ✭ 16 (-97.11%)
Mutual labels:  debugging, qemu
Go Qemu
Go packages to interact with QEMU using the QEMU Machine Protocol (QMP). Apache 2.0 Licensed.
Stars: ✭ 481 (-13.18%)
Mutual labels:  qemu
Tensor Sensor
The goal of this library is to generate more helpful exception messages for numpy/pytorch matrix algebra expressions.
Stars: ✭ 532 (-3.97%)
Mutual labels:  debugging
Packer Templates
Packer templates for Vagrant base boxes
Stars: ✭ 471 (-14.98%)
Mutual labels:  qemu
Snoop
A powerful set of Python debugging tools, based on PySnooper
Stars: ✭ 467 (-15.7%)
Mutual labels:  debugging
Sudo Su
Laravel package to easily login as other users during development.
Stars: ✭ 554 (+0%)
Mutual labels:  debugging
Stern
⎈ Multi pod and container log tailing for Kubernetes
Stars: ✭ 5,614 (+913.36%)
Mutual labels:  debugging
Xqemu
Open-source emulator to play original Xbox games on Windows, macOS, and Linux
Stars: ✭ 518 (-6.5%)
Mutual labels:  qemu
Radiography
Text-ray goggles for your Android UI.
Stars: ✭ 482 (-13%)
Mutual labels:  debugging
Rdma Core
RDMA core userspace libraries and daemons
Stars: ✭ 536 (-3.25%)
Mutual labels:  linux-kernel
Darthsidious
Building an Active Directory domain and hacking it
Stars: ✭ 479 (-13.54%)
Mutual labels:  lab
Mitmproxy
An interactive TLS-capable intercepting HTTP proxy for penetration testers and software developers.
Stars: ✭ 25,495 (+4501.99%)
Mutual labels:  debugging
Trace Nodejs
Trace is a visualised distributed tracing platform designed for microservices.
Stars: ✭ 471 (-14.98%)
Mutual labels:  debugging
Traceback with variables
Adds variables to python traceback. Simple, lightweight, controllable. Debug reasons of exceptions by logging or pretty printing colorful variable contexts for each frame in a stacktrace, showing every value. Dump locals environments after errors to console, files, and loggers. Works in Jupyter and IPython. Install with pip or conda.
Stars: ✭ 509 (-8.12%)
Mutual labels:  debugging
Spy
👀 Linux kernel mode debugfs keylogger
Stars: ✭ 546 (-1.44%)
Mutual labels:  linux-kernel

Subscribe Wechat

Linux 0.11 Lab

The old Linux kernel source version 0.11 and the integrated experiment environment.

CS630 Qemu Lab is a related project, it is a friendly learning environment for the X86 assembly course: CS630.

If you want to learn the latest Linux Kernel, please try our Linux Lab

Linux 0.11 Lab Demo

Contents

Introduction

  • Basic information

  • Features

    • compilable with many different versions of Gcc.
    • has been tested under modern Linux, Mac OS X and even work on Windows (with docker support).
    • add bulit-in qemu and bochs support, include running and debugging.
    • integrate different prebuilt rootfs (floopy, ramdisk and harddisk).
    • allow to generate callgraph of every specified function

Install the environment

Linux 0.11 Lab works on Linux, Windows and Mac OSX, but please install docker at first, then simply install the environment with these three commands:

$ git clone https://gitee.com/tinylab/cloud-lab.git
$ cd cloud-lab/
$ tools/docker/run linux-0.11-lab

Notes: Some examples depends on minix fs kernel module, but the Linux kernel used by the docker of windows, macosx and even some Linux distributions may not provide such kernel module, please compile one yourself. Ubuntu is recommended.

Install docker

Docker is required by Linux 0.11 Lab, please install it at first:

  • Linux, Mac OSX, Windows 10: Docker CE

    • For Windows user, please use 'Git Bash Here' in right mouse press menu, Windows PowerShell is NOT supported.
  • older Windows: Docker Toolbox or Virtualbox/Vmware + Linux.

Notes:

In order to run docker without password, please make sure your user is added in the docker group:

$ sudo usermod -aG docker $USER

In order to speedup docker images downloading, please configure a local docker mirror in /etc/default/docker, for example:

$ grep registry-mirror /etc/default/docker
DOCKER_OPTS="$DOCKER_OPTS --registry-mirror=https://docker.mirrors.ustc.edu.cn"
$ service docker restart

In order to avoid network ip address conflict, please try following changes and restart docker:

$ grep bip /etc/default/docker
DOCKER_OPTS="$DOCKER_OPTS --bip=10.66.0.10/16"
$ service docker restart

If the above changes not work, try something as following:

$ grep dockerd /lib/systemd/system/docker.service
ExecStart=/usr/bin/dockerd -H fd:// --bip=10.66.0.10/16 --registry-mirror=https://docker.mirrors.ustc.edu.cn
$ service docker restart

If still have errors like 'Client.Timeout exceeded while waiting headers', please try the other docker mirror sites:

Configuration in Ubuntu:

$ echo "DOCKER_OPTS=\"\$DOCKER_OPTS --registry-mirror=<your accelerate address>\"" | sudo tee -a /etc/default/docker
$ sudo service docker restart

For Ubuntu 12.04, please install the new kernel at first, otherwise, docker will not work:

$ sudo apt-get install linux-generic-lts-trusty

If installed via Docker Toolbox, please enter into the /mnt/sda1 directory of the default system on Virtualbox, otherwise, after poweroff, the data will be lost for the default /root directory is only mounted in DRAM.

$ cd /mnt/sda1

For Linux or Mac OSX, please simply choose one directory in ~/Downloads or ~/Documents.

$ cd ~/Documents

Older methods

For Linux System

This is a BAD method, but if really want a try, please comment 'DOCKER ?= yes' in Makefile at first:

Here is the deprecated method in Linux system:

  • The Linux distributions: debian and ubuntu (>= 14.04) are recommended

  • Install basic tools

      $ sudo apt-get install vim cscope exuberant-ctags build-essential qemu lxterminal
    
  • Optional

      $ sudo apt-get install bochs vgabios bochsbios bochs-doc bochs-x libltdl7 bochs-sdl bochs-term
      $ sudo apt-get install graphviz cflow
    

For Mac OSX System

  • Install xcode from "App Store"

  • Install Mac package manage tool: MacPorts from http://www.macports.org/install.php

    • Check your OS X version from "About This Mac", for example, Lion

    • Go to the "Mac OS X Package (.pkg) Installer" part and download the corresponding version

    • Self update MacPorts

            $ xcode-select --switch /Applications/Xcode.app/Contents/Developer
            $ sudo port -v selfupdate
      
  • Install cross compiler gcc and binutils

      $ sudo port install i386-elf-binutils i386-elf-gcc
    
  • Install qemu

      $ sudo port install qemu
    
  • Install graphviz and cflow

      $ sudo port install GraphViz
      $ sudo port install cflow
    
  • Install gdb. 'Cause port doesn't provide i386-elf-gdb, use the pre-compiled tools/mac/gdb.xz or download its source and compile it.

      $ cd tools/mac/ ; tar Jxf gdb.xz
    

Optional

$ sudo port install cscope
$ sudo port install ctags

$ wget ftp://ftp.gnu.org/gnu/gdb/gdb-7.4.tar.bz2
$ tar -xzvf gdb-7.4.tar.bz2
$ cd gdb-7.4
$ ./configure --target=i386-elf
$ make

Hack Linux 0.11

Notes To enable kvm speedup for hardisk boot, please make sure cpu virtualization is enabled in bios features.

$ make help		// get help
$ make  		// compile
$ make boot-hd	// boot it on qemu with hard disk image
$ make boot-hd G=0  // Use curses based terminal instead of graphics, friendly for ssh login, exit with 'ESC+2 quit' or 'ALT+2 quit'

$ make switch                // switch to another emulator, between qemu and bochs
Switch to use emulator: bochs
$ make boot VM=qemu|bochs    // specify the emulator, between qemu and bochs

// edit .kernel_gdbinit(for kernel.sym) and .boot_gdbinit(for bootsect.sym and setup.sym) before debugging

$ make debug-hd	// debug kernel.sym via qemu and start gdb automatically to connect it.
$ make debug-hd DST=src/boot/bootsect.sym  // debug bootsect, can not debug code after ljmp
$ make debug-hd DST=src/boot/setup.sym     // debug setup, can not debug after ljmp

Hack Rootfs

Three different root filesystem images are stored in rootfs/:

  • rootram.img -- RAM image
  • rootimage -- Floppy image
  • hdc-0.11.img-- Harddisk image

Ram image

rootram.img is mountable directly:

$ mkdir /path/to/rootram/
$ sudo mount rootfs/rootram.img /path/to/rootram/

A new target ramfs-install is added to install files from examples/ to ramfs.

$ make ramfs-install

Floppy image

rootimage-0.11 is a minix filesystem, must with -t minix obviously:

$ sudo mkdir /path/to/rootimage/
$ sudo mount -t minix rootfs/rootimage-0.11 /path/to/rootimage

A new target flp-install is added to install files from examples/ to floppy image.

$ make flp-install

Harddisk image

hdc-0.11.img has a partition table, should be mounted with an offset:

$ mkdir /path/to/hdc/
$ fdisk -lu rootfs/hdc-0.11.img
$ fdisk -l rootfs/hdc-0.11.img

Disk rootfs/hdc-0.11.img: 127 MB, 127631360 bytes
16 heads, 38 sectors/track, 410 cylinders, total 249280 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000

              Device Boot      Start         End      Blocks   Id  System
rootfs/hdc-0.11.img1               2      124031       62015   81  Minix / old Linux
rootfs/hdc-0.11.img2          124032      248063       62016   81  Minix / old Linux

$ sudo mount -o offset=$((2*512)) rootfs/hdc-0.11.img /path/to/hdc/

A new target hda-install is added to install files from examples/ to harddisk image.

$ make hda-install

Examples

Some examples are stored in examples/ with their own README.md:

Syscall -- shows how to add a new system call

A new demonstration is added: Linux 0.11 Lab: Add a new syscall into Linux 0.11

Host:

$ patch -p1 < examples/syscall/syscall.patch
$ make start-hd

Emulator:

$ cd examples/syscall/
$ make
as -o syscall.o syscall.s
ld -o syscall syscall.o
./syscall
Hello, Linux 0.11

Notes If not examples/ found in default directory: /usr/root of Linux 0.11, that means your host may not have minix fs kernel module, compile one yourself, or switch your host to Ubuntu.

Linux 0.00

Host:

$ make boot-hd

Emulator:

$ cd examples/linux-0.00
$ make
$ sync

Host:

$ make linux-0.00

Building Linux 0.11 in Linux 0.11

Host:

$ make boot-hd

Emulator:

$ cd examples/linux-0.11
$ make
$ sync

Host:

$ make hd-boot

Changes

Contact and Sponsor

Our contact wechat is tinylab, welcome to join our user & developer discussion group.

** Contact us and Sponsor via wechat **

contact-sponsor

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].