Skip to content

Commit 47ba63d

Browse files
committed
add a Dockerfile to build the disk image
Also use the archive link for `debootstrap` to avoid EOL links.
1 parent 1cf07ac commit 47ba63d

File tree

4 files changed

+117
-59
lines changed

4 files changed

+117
-59
lines changed

scripts/create-image/Dockerfile

Lines changed: 36 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
FROM ubuntu:24.04 AS base
2+
3+
ENV DEBIAN_FRONTEND=noninteractive
4+
5+
SHELL ["/bin/bash", "-c"]
6+
7+
RUN <<EOF
8+
apt-get update
9+
apt-get install -y \
10+
ssh \
11+
debootstrap \
12+
e2fsprogs \
13+
$NULL
14+
apt-get clean
15+
ln -sf /bin/env /bin/sudo
16+
EOF
17+
18+
ENV DIR=chroot
19+
ENV RELEASE=trixie
20+
ENV PREINSTALL_PKGS=openssh-server,curl,tar,gcc,libc6-dev,time,strace,sudo,less,psmisc,selinux-utils,policycoreutils,checkpolicy,selinux-policy-default,wget
21+
ENV ADD_PACKAGE="make,sysbench,git,vim,tmux,usbutils,tcpdump,net-tools"
22+
23+
ENV FEATURE=minimal
24+
ENV SEEK=2047
25+
ENV PERF=false
26+
ENV IN_DOCKER=true
27+
28+
# Use COPY after agt-get to allow caching apt
29+
WORKDIR /src
30+
COPY --chmod=0755 debootstrap.sh /src/
31+
RUN ./debootstrap.sh
32+
33+
# will copy the img file to /mnt. Need --privilege flag for docker run.
34+
COPY --chmod=0755 configure.sh /src/
35+
CMD ["bash", "-x", "./configure.sh"]
36+

scripts/create-image/configure.sh

Lines changed: 64 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
#!/bin/bash
2+
# Copyright 2025 syzkaller project authors. All rights reserved.
3+
# Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.
4+
5+
# Set some defaults and enable promtless ssh to the machine for root.
6+
sudo sed -i '/^root/ { s/:x:/::/ }' $DIR/etc/passwd
7+
echo 'T0:23:respawn:/sbin/getty -L ttyS0 115200 vt100' | sudo tee -a $DIR/etc/inittab
8+
mkdir -p $DIR/etc/network
9+
printf '\nauto eth0\niface eth0 inet dhcp\n' | sudo tee -a $DIR/etc/network/interfaces
10+
echo '/dev/root / ext4 defaults 0 0' | sudo tee -a $DIR/etc/fstab
11+
echo 'debugfs /sys/kernel/debug debugfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
12+
#echo 'securityfs /sys/kernel/security securityfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
13+
#echo 'configfs /sys/kernel/config/ configfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
14+
echo 'binfmt_misc /proc/sys/fs/binfmt_misc binfmt_misc defaults 0 0' | sudo tee -a $DIR/etc/fstab
15+
echo "kernel.printk = 7 4 1 3" | sudo tee -a $DIR/etc/sysctl.conf
16+
echo 'debug.exception-trace = 0' | sudo tee -a $DIR/etc/sysctl.conf
17+
echo "net.core.bpf_jit_enable = 1" | sudo tee -a $DIR/etc/sysctl.conf
18+
echo "net.core.bpf_jit_kallsyms = 1" | sudo tee -a $DIR/etc/sysctl.conf
19+
echo "net.core.bpf_jit_harden = 0" | sudo tee -a $DIR/etc/sysctl.conf
20+
echo "kernel.softlockup_all_cpu_backtrace = 1" | sudo tee -a $DIR/etc/sysctl.conf
21+
echo "kernel.kptr_restrict = 0" | sudo tee -a $DIR/etc/sysctl.conf
22+
echo "kernel.watchdog_thresh = 60" | sudo tee -a $DIR/etc/sysctl.conf
23+
echo "net.ipv4.ping_group_range = 0 65535" | sudo tee -a $DIR/etc/sysctl.conf
24+
echo -en "127.0.0.1\tlocalhost\n" | sudo tee $DIR/etc/hosts
25+
echo "nameserver 8.8.8.8" | sudo tee -a $DIR/etc/resolve.conf
26+
echo "pwn" | sudo tee $DIR/etc/hostname
27+
28+
# Add perf support
29+
if [ "$PERF" == "true" ]; then
30+
cp -r $KERNEL $DIR/tmp/
31+
sudo chroot $DIR /bin/bash -c "apt-get update; apt-get install -y flex bison python-dev libelf-dev libunwind8-dev libaudit-dev libslang2-dev libperl-dev binutils-dev liblzma-dev libnuma-dev"
32+
sudo chroot $DIR /bin/bash -c "cd /tmp/linux/tools/perf/; make"
33+
sudo chroot $DIR /bin/bash -c "cp /tmp/linux/tools/perf/perf /usr/bin/"
34+
rm -r $DIR/tmp/linux
35+
fi
36+
37+
# create a default user called user
38+
echo "user::1000:1000:user:/home/user:/bin/bash" | sudo tee -a $DIR/etc/passwd
39+
echo "user:x:1000:" | sudo tee -a $DIR/etc/group
40+
sudo mkdir -p $DIR/home/user/.ssh
41+
sudo chown -R 1000:1000 $DIR/home/user
42+
43+
# install python3
44+
sudo chroot $DIR /bin/bash -c "apt-get update"
45+
sudo chroot $DIR /bin/bash -c "apt-get install -y python3 && ln -s /usr/bin/python3 /usr/bin/python"
46+
47+
# create ssh key and save it
48+
ssh-keygen -f $RELEASE.id_rsa -t rsa -N ''
49+
sudo mkdir -p $DIR/root/.ssh/
50+
cat $RELEASE.id_rsa.pub | sudo tee $DIR/root/.ssh/authorized_keys
51+
cat $RELEASE.id_rsa.pub | sudo tee $DIR/home/user/.ssh/authorized_keys
52+
sudo chown -R 1000:1000 $DIR/home/user
53+
54+
# Build a disk image
55+
dd if=/dev/zero of=$RELEASE.img bs=1M seek=$SEEK count=1
56+
sudo mkfs.ext4 -F $RELEASE.img
57+
sudo mkdir -p /fs/$DIR /mnt
58+
sudo mount -o loop $RELEASE.img /fs/$DIR
59+
sudo cp -a $DIR/. /fs/$DIR/.
60+
sudo umount /fs/$DIR
61+
62+
if [ "$IN_DOCKER" = true ]; then
63+
cp $RELEASE.* /mnt
64+
fi

scripts/create-image/create-image.sh

Lines changed: 4 additions & 59 deletions
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@ RELEASE=trixie
2020
FEATURE=minimal
2121
SEEK=2047
2222
PERF=false
23+
IN_DOCKER=false
2324

2425
# Display help function
2526
display_help() {
@@ -77,66 +78,10 @@ if [ $PERF = "true" ] && [ -z ${KERNEL+x} ]; then
7778
fi
7879

7980
# If full feature is chosen, install more packages
80-
if [ $FEATURE = "full" ]; then
81+
if [ "$FEATURE" = "full" ]; then
8182
PREINSTALL_PKGS=$PREINSTALL_PKGS","$ADD_PACKAGE
8283
fi
8384

84-
sudo rm -rf $DIR
85-
mkdir -p $DIR
86-
sudo debootstrap --include=$PREINSTALL_PKGS $RELEASE $DIR
85+
source ./debootstrap.sh
86+
source ./configure.sh
8787

88-
# Set some defaults and enable promtless ssh to the machine for root.
89-
sudo sed -i '/^root/ { s/:x:/::/ }' $DIR/etc/passwd
90-
echo 'T0:23:respawn:/sbin/getty -L ttyS0 115200 vt100' | sudo tee -a $DIR/etc/inittab
91-
printf '\nauto eth0\niface eth0 inet dhcp\n' | sudo tee -a $DIR/etc/network/interfaces
92-
echo '/dev/root / ext4 defaults 0 0' | sudo tee -a $DIR/etc/fstab
93-
echo 'debugfs /sys/kernel/debug debugfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
94-
#echo 'securityfs /sys/kernel/security securityfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
95-
#echo 'configfs /sys/kernel/config/ configfs defaults 0 0' | sudo tee -a $DIR/etc/fstab
96-
echo 'binfmt_misc /proc/sys/fs/binfmt_misc binfmt_misc defaults 0 0' | sudo tee -a $DIR/etc/fstab
97-
echo "kernel.printk = 7 4 1 3" | sudo tee -a $DIR/etc/sysctl.conf
98-
echo 'debug.exception-trace = 0' | sudo tee -a $DIR/etc/sysctl.conf
99-
echo "net.core.bpf_jit_enable = 1" | sudo tee -a $DIR/etc/sysctl.conf
100-
echo "net.core.bpf_jit_kallsyms = 1" | sudo tee -a $DIR/etc/sysctl.conf
101-
echo "net.core.bpf_jit_harden = 0" | sudo tee -a $DIR/etc/sysctl.conf
102-
echo "kernel.softlockup_all_cpu_backtrace = 1" | sudo tee -a $DIR/etc/sysctl.conf
103-
echo "kernel.kptr_restrict = 0" | sudo tee -a $DIR/etc/sysctl.conf
104-
echo "kernel.watchdog_thresh = 60" | sudo tee -a $DIR/etc/sysctl.conf
105-
echo "net.ipv4.ping_group_range = 0 65535" | sudo tee -a $DIR/etc/sysctl.conf
106-
echo -en "127.0.0.1\tlocalhost\n" | sudo tee $DIR/etc/hosts
107-
echo "nameserver 8.8.8.8" | sudo tee -a $DIR/etc/resolve.conf
108-
echo "pwn" | sudo tee $DIR/etc/hostname
109-
110-
# Add perf support
111-
if [ $PERF = "true" ]; then
112-
cp -r $KERNEL $DIR/tmp/
113-
sudo chroot $DIR /bin/bash -c "apt-get update; apt-get install -y flex bison python-dev libelf-dev libunwind8-dev libaudit-dev libslang2-dev libperl-dev binutils-dev liblzma-dev libnuma-dev"
114-
sudo chroot $DIR /bin/bash -c "cd /tmp/linux/tools/perf/; make"
115-
sudo chroot $DIR /bin/bash -c "cp /tmp/linux/tools/perf/perf /usr/bin/"
116-
rm -r $DIR/tmp/linux
117-
fi
118-
119-
# create a default user called user
120-
echo "user::1000:1000:user:/home/user:/bin/bash" | sudo tee -a $DIR/etc/passwd
121-
echo "user:x:1000:" | sudo tee -a $DIR/etc/group
122-
sudo mkdir -p $DIR/home/user/.ssh
123-
sudo chown -R 1000:1000 $DIR/home/user
124-
125-
# install python3
126-
sudo chroot $DIR /bin/bash -c "apt-get update"
127-
sudo chroot $DIR /bin/bash -c "apt-get install -y python3 && ln -s /usr/bin/python3 /usr/bin/python"
128-
129-
# create ssh key and save it
130-
ssh-keygen -f $RELEASE.id_rsa -t rsa -N ''
131-
sudo mkdir -p $DIR/root/.ssh/
132-
cat $RELEASE.id_rsa.pub | sudo tee $DIR/root/.ssh/authorized_keys
133-
cat $RELEASE.id_rsa.pub | sudo tee $DIR/home/user/.ssh/authorized_keys
134-
sudo chown -R 1000:1000 $DIR/home/user
135-
136-
# Build a disk image
137-
dd if=/dev/zero of=$RELEASE.img bs=1M seek=$SEEK count=1
138-
sudo mkfs.ext4 -F $RELEASE.img
139-
sudo mkdir -p /mnt/$DIR
140-
sudo mount -o loop $RELEASE.img /mnt/$DIR
141-
sudo cp -a $DIR/. /mnt/$DIR/.
142-
sudo umount /mnt/$DIR
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
#!/bin/bash
2+
# Copyright 2025 syzkaller project authors. All rights reserved.
3+
# Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.
4+
5+
sudo rm -rf $DIR
6+
mkdir -p $DIR
7+
8+
if ! \
9+
sudo debootstrap --include=$PREINSTALL_PKGS $RELEASE $DIR; \
10+
then
11+
sudo debootstrap --no-check-gpg --include=$PREINSTALL_PKGS $RELEASE $DIR \
12+
http://archive.debian.org/debian
13+
fi

0 commit comments

Comments
 (0)