]> git.zerfleddert.de Git - m1-debian/blob - bootstrap.sh
7582b15d1290b097e4189743940c7dd6727bf952
[m1-debian] / bootstrap.sh
1 #!/bin/bash
2
3 set -x
4 set -e
5
6 unset LC_CTYPE
7 unset LANG
8
9 build_m1n1()
10 {
11 (
12 test -d m1n1 || git clone --recursive https://github.com/AsahiLinux/m1n1.git
13 cd m1n1
14 git fetch
15 git reset --hard origin/main; git clean -f -x -d
16 make -j 16
17 )
18 }
19
20 build_uboot()
21 {
22 (
23 # Build u-boot
24 test -d u-boot || git clone https://github.com/kettenis/u-boot
25 cd u-boot
26 git fetch
27 git reset --hard origin/apple-m1-m1n1-nvme; git clean -f -x -d
28 make apple_m1_defconfig
29 # it is normal that it runs on an error at the end
30 make -j 16 || true
31 )
32
33 cat m1n1/build/m1n1.macho `find u-boot -name \*.dtb` u-boot/u-boot-nodtb.bin > u-boot.macho
34 }
35
36 build_linux()
37 {
38 (
39 test -d linux || git clone --depth 1 https://github.com/AsahiLinux/linux
40 cd linux
41 git fetch
42 git reset --hard origin/asahi; git clean -f -x -d
43 curl -s https://tg.st/u/9ce9060dea91951a330feeeda3ad636bc88c642c.patch | git am -
44 curl -s https://tg.st/u/5nly | git am -
45 curl -s https://tg.st/u/asahi-config-2022-01-19 > .config
46 make olddefconfig
47 make -j 16 bindeb-pkg
48 )
49 }
50
51 build_rootfs()
52 {
53 (
54 sudo rm -rf testing
55 sudo eatmydata debootstrap --arch=arm64 --include iwd,tcpdump,vim,tmux,vlan,ntpdate,bridge-utils,parted,curl,wget,grub-efi-arm64,mtr-tiny,dbus testing testing http://ftp.fau.de/debian
56
57 cd testing
58
59 sudo bash -c 'echo live > etc/hostname'
60
61 sudo bash -c 'echo > etc/motd'
62
63 sudo bash -c 'echo "deb http://deb.debian.org/debian testing main contrib non-free" > etc/apt/sources.list'
64 sudo bash -c 'echo "deb-src http://deb.debian.org/debian testing main contrib non-free" >> etc/apt/sources.list'
65
66 sudo bash -c 'chroot . apt update'
67 sudo bash -c 'chroot . apt install -y firmware-linux'
68
69 sudo -- perl -p -i -e 's/root:x:/root::/' etc/passwd
70
71 sudo -- ln -s lib/systemd/systemd init
72
73 sudo cp ../linux-image-5.16.0-asahi-next-20220118-gdcd14bb2ec40_5.16.0-asahi-next-20220118-gdcd14bb2ec40-1_arm64.deb .
74
75 sudo chroot . dpkg -i linux-image-5.16.0-asahi-next-20220118-gdcd14bb2ec40_5.16.0-asahi-next-20220118-gdcd14bb2ec40-1_arm64.deb
76
77 sudo rm linux-image-5.16.0-asahi-next-20220118-gdcd14bb2ec40_5.16.0-asahi-next-20220118-gdcd14bb2ec40-1_arm64.deb
78 sudo bash -c 'apt-get clean'
79 )
80 }
81
82 build_stick()
83 {
84 (
85 rm -rf stick
86 mkdir -p stick/efi/boot stick/boot
87 sudo bash -c 'cd testing; find . | cpio --quiet -H newc -o | pigz > ../stick/initrd.gz'
88 cp testing/usr/lib/grub/arm64-efi/monolithic/grubaa64.efi stick/efi/boot/bootaa64.efi
89 cp testing/boot/vmlinuz* stick/vmlinuz
90
91 cat > stick/boot/grub.cfg <<EOF
92 echo Loading Kernel...
93 linux (hd0,msdos1)/vmlinuz net.ifnames=0
94 echo Loading initrd... Please wait
95 initrd (hd0,msdos1)/initrd.gz
96 boot
97 EOF
98
99 )
100 }
101
102 # build_m1n1
103 # build_uboot
104 # build_linux
105 # build_rootfs
106 build_stick
Impressum, Datenschutz