/linux-0.11-lab

5 分钟 Linux 0.11 快速构建实验环境

Primary LanguageC

Linux 0.11 Lab

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

Contents

Introduction

  • Basic information

  • Features

    • compilable with many different versions of Gcc.
    • has been tested under modern Linux, Mac OS X.
    • 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
    • a Dockerfile added to simplify this setup on other systems (e.g. Windows).

Build on Linux

Linux Setup

  • The Linux distributions: debian and ubuntu are recommended

  • Some tools: gcc gdb qemu cscope ctags cflow graphviz

      $ apt-get install vim cscope exuberant-ctags build-essential qemu
    
  • Use with docker (everything is installed by default for you)

    • Install docker engine (Official doc is here)

            $ sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
            $ sudo -s
            $ version=`sed -n -e "/main$/p" /etc/apt/sources.list | head -1 | cut -d' ' -f3`
            $ echo "deb https://apt.dockerproject.org/repo ubuntu-$(version) main" > /etc/apt/sources.list.d/docker.list
            $ exit
            $ sudo apt-get -y update
            $ sudo apt-get -y install docker-engine
            $ sudo usermod -aG docker $USER
      
    • Build and Start the service

            $ docker build -t tinylab/linux-0.11-lab ./
            $ CONTAINER_ID=$(docker run -d -p 6080:6080 -v $PWD/:/linux-0.11-lab/ tinylab/linux-0.11-lab)
            $ docker logs $CONTAINER_ID | sed -n 1p
            User: ubuntu Pass: ubuntu
      
    • Access it via http://localhost:6080/vnc.html Or http://172.17.0.1:6080/vnc.html with 'ubuntu' as password

            $ docker exec $CONTAINER_ID ifconfig eth0 | grep "inet addr:"
            inet addr:172.17.0.1  Bcast:0.0.0.0  Mask:255.255.0.0
      

Optional (bochs emulator instead of qemu)

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

$ make switch       // switch to another emulator, between qemu and bochs
Switch to use emulator: bochs

Hack Linux 0.11

$ make help		// get help
$ make  		// compile
$ make start-hd	// boot it on qemu with hard disk image
$ make debug-hd	// debug it via qemu & gdb, you'd start gdb to connect it.

$ gdb images/kernel.sym
(gdb) target remote :1234
(gdb) b main
(gdb) c

                    // to debug the bootsect or setup part, please load the symbol files
$ gdb boot/bootsect.sym
$ gdb boot/setup.sym

Optional

$ echo "add-auto-load-safe-path $PWD/.gdbinit" > ~/.gdbinit  // let gdb auto load the commands in .gdbinit

Build on Mac OS X

Note: A simpler method is use Docker Toolbox with our Dockerfile, see Build on the other systems

Mac OS X Setup

  • 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 qemu
    
  • Install qemu

      $ sudo port install i386-elf-binutils i386-elf-gcc
    
  • 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

Same as Hack Linux-0.11 on Linux

Build on Other Systems (include Mac OS X, Windows)

If want to use this Lab on the other systems, such as Windows (and even Mac OS X), with the Dockerfile support, everything is simplified.

Only need to install the docker toolbox, which is a lightweight Linux distribution made specifially to run Docker containers, with this tool and our Dockerfile, we can simply build a Linux 0.11 Lab on every system.

Setup with Docker Toolbox and Dockerfile

  • Install Docker Toolbox and boot into it

    please follow Docker Toolbox Installation.

  • Build and Start the service

      $ docker build -t tinylab/linux-0.11-lab ./
      $ CONTAINER_ID=$(docker run -d -p 6080:6080 -v $PWD/:/linux-0.11-lab/ tinylab/linux-0.11-lab)
      $ docker logs $CONTAINER_ID | sed -n 1p
      User: ubuntu Pass: ubuntu
    
  • Access it via http://localhost:6080/vnc.html Or http://172.17.0.1:6080/vnc.html

      $ docker exec $CONTAINER_ID ifconfig eth0 | grep "inet addr:"
      inet addr:172.17.0.1  Bcast:0.0.0.0  Mask:255.255.0.0
    

Hack Linux 0.11

Same as Hack Linux-0.11 on Linux

Changes