feature/build-my-own-kernel-rootfs #2
@ -93,7 +93,7 @@ func setupEnv() int {
|
|||||||
|
|
||||||
cfg := firecracker.Config{
|
cfg := firecracker.Config{
|
||||||
SocketPath: socketPath,
|
SocketPath: socketPath,
|
||||||
KernelImagePath: "./out/vmlinux-5.10.204",
|
KernelImagePath: "./out/vmlinux",
|
||||||
LogPath: "./out/firecracker.log",
|
LogPath: "./out/firecracker.log",
|
||||||
LogLevel: "Debug",
|
LogLevel: "Debug",
|
||||||
KernelArgs: "console=ttyS0 reboot=k panic=1 pci=off",
|
KernelArgs: "console=ttyS0 reboot=k panic=1 pci=off",
|
||||||
|
@ -11,11 +11,15 @@ use-ubuntu: ../out/ubuntu-22.04.ext4 ../out/ubuntu-22.04.id_rsa
|
|||||||
ln -fs $< ../out/rootfs.ext4
|
ln -fs $< ../out/rootfs.ext4
|
||||||
|
|
||||||
kernel: ../out/vmlinux-5.10.204
|
kernel: ../out/vmlinux-5.10.204
|
||||||
@echo "linux kernel retrieve"
|
ln -fs $< ../out/vmlinux
|
||||||
|
|
||||||
../out/vmlinux-5.10.204:
|
../out/vmlinux-5.10.204:
|
||||||
wget -O $@ https://s3.amazonaws.com/spec.ccfc.min/firecracker-ci/v1.7/$(ARCH)/vmlinux-5.10.204
|
wget -O $@ https://s3.amazonaws.com/spec.ccfc.min/firecracker-ci/v1.7/$(ARCH)/vmlinux-5.10.204
|
||||||
|
|
||||||
|
CONFIG_FILE=$(wildcard ./kernel-config/*.config)
|
||||||
|
../out/vmvmlinux-custom: ./kernel.sh $(CONFIG_FILE)
|
||||||
|
bash ./kernel.sh
|
||||||
|
|
||||||
../out/arch-rootfs.ext4: ./arch-rootfs.sh
|
../out/arch-rootfs.ext4: ./arch-rootfs.sh
|
||||||
bash ./arch-rootfs.sh
|
bash ./arch-rootfs.sh
|
||||||
|
|
||||||
|
@ -2,46 +2,46 @@
|
|||||||
|
|
||||||
# inspired by https://github.com/oraoto/archlinux-firecracker/blob/master/scripts/build-arch-kernel.sh
|
# inspired by https://github.com/oraoto/archlinux-firecracker/blob/master/scripts/build-arch-kernel.sh
|
||||||
|
|
||||||
KERNEL_VERSION=5.11.2
|
set -ex
|
||||||
|
|
||||||
mkdir -p build
|
KERNEL_VERSION=v5.11
|
||||||
|
WD=../out
|
||||||
cd build
|
|
||||||
|
|
||||||
## Install build tools
|
## Install build tools
|
||||||
# pacman -Syu base-devel bc pahole --ignore linux-firmware
|
# pacman -Syu base-devel bc pahole --ignore linux-firmware
|
||||||
|
|
||||||
## Get kernel source
|
## Get kernel source
|
||||||
curl -o linux.tar.xz "https://mirrors.tuna.tsinghua.edu.cn/kernel/v5.x/linux-$KERNEL_VERSION.tar.xz"
|
git clone https://github.com/torvalds/linux.git "$WD"/linux
|
||||||
tar xf linux.tar.xz
|
git checkout $KERNEL_VERSION
|
||||||
cd linux-$KERNEL_VERSION/
|
|
||||||
|
|
||||||
## Get Archlinux kernel config
|
## Get Archlinux kernel config
|
||||||
curl -o .config https://git.archlinux.org/svntogit/packages.git/plain/trunk/config?h=packages/linux
|
curl -o "$WD"/linux/.config https://git.archlinux.org/svntogit/packages.git/plain/trunk/config?h=packages/linux
|
||||||
|
|
||||||
|
CONFIG_PATH="$WD"/linux/.config
|
||||||
|
|
||||||
## Disable modules
|
## Disable modules
|
||||||
sed 's/\(.*\)=m/#\1 is not set/g' -i .config
|
sed 's/\(.*\)=m/#\1 is not set/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)MOUSE\(.*\)=y/\1MOUSE\2=n/g' -i .config
|
sed 's/\(.*\)MOUSE\(.*\)=y/\1MOUSE\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)USB\(.*\)=y/\1USB\2=n/g' -i .config
|
sed 's/\(.*\)USB\(.*\)=y/\1USB\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)TOUCHSCREEN\(.*\)=y/\1TOUCHSCREEN\2=n/g' -i .config
|
sed 's/\(.*\)TOUCHSCREEN\(.*\)=y/\1TOUCHSCREEN\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)HID\(.*\)=y/\1HID\2=n/g' -i .config
|
sed 's/\(.*\)HID\(.*\)=y/\1HID\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)GPU\(.*\)=y/\1GPU\2=n/g' -i .config
|
sed 's/\(.*\)GPU\(.*\)=y/\1GPU\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)GPIO\(.*\)=y/\1GPIO\2=n/g' -i .config
|
sed 's/\(.*\)GPIO\(.*\)=y/\1GPIO\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)NVDIMM\(.*\)=y/\1NVDIMM\2=n/g' -i .config
|
sed 's/\(.*\)NVDIMM\(.*\)=y/\1NVDIMM\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)MFD\(.*\)=y/\1MFD\2=n/g' -i .config
|
sed 's/\(.*\)MFD\(.*\)=y/\1MFD\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)XEN\(.*\)=y/\1XEN\2=n/g' -i .config
|
sed 's/\(.*\)XEN\(.*\)=y/\1XEN\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)VIDEO\(.*\)=y/\1VIDEO\2=n/g' -i .config
|
sed 's/\(.*\)VIDEO\(.*\)=y/\1VIDEO\2=n/g' -i "$CONFIG_PATH"
|
||||||
# sed 's/\(.*\)PCI\(.*\)=y/\1PCI\2=n/g' -i .config
|
# sed 's/\(.*\)PCI\(.*\)=y/\1PCI\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)WLAN\(.*\)=y/\1WLAN\2=n/g' -i .config
|
sed 's/\(.*\)WLAN\(.*\)=y/\1WLAN\2=n/g' -i "$CONFIG_PATH"
|
||||||
sed 's/\(.*\)DRM\(.*\)=y/\1DRM\2=n/g' -i .config
|
sed 's/\(.*\)DRM\(.*\)=y/\1DRM\2=n/g' -i "$CONFIG_PATH"
|
||||||
|
|
||||||
cat ../../config/virtio.config >> .config
|
cat kernel-config/config/virtio.config >> "$CONFIG_PATH"
|
||||||
cat ../../config/fs.config >> .config
|
cat kernel-config/config/fs.config >> "$CONFIG_PATH"
|
||||||
cat ../../config/net.config >> .config
|
cat kernel-config/config/net.config >> "$CONFIG_PATH"
|
||||||
|
|
||||||
## Add KVM guest support
|
## Add KVM guest support
|
||||||
make kvm_guest.config
|
make kvm_guest.config
|
||||||
|
|
||||||
make -j$(nproc)
|
#make -j$(nproc)
|
||||||
|
#
|
||||||
./scripts/extract-vmlinux ./arch/x86_64/boot/bzImage > ../../output/arch-vmlinux.bin
|
#./scripts/extract-vmlinux ./arch/x86_64/boot/bzImage > "$WD"/arch-vmlinux.bin
|
||||||
|
Loading…
Reference in New Issue
Block a user