X-Git-Url: http://git.zerfleddert.de/cgi-bin/gitweb.cgi/m1-debian/blobdiff_plain/b054227611f4fc4023b0837c0ee198d54977543a..3ab9bf68d3d565cc2cef898a1996738ba677e5f0:/bootstrap.sh?ds=inline diff --git a/bootstrap.sh b/bootstrap.sh index 1b7af23..ae8ade0 100644 --- a/bootstrap.sh +++ b/bootstrap.sh @@ -8,58 +8,72 @@ set -e unset LC_CTYPE unset LANG +export DEBOOTSTRAP=debootstrap + +handle_crosscompile() +{ + if [ "`uname -m`" != 'aarch64' ]; then + export ARCH=arm64 + export CROSS_COMPILE=aarch64-linux-gnu- + export DEBOOTSTRAP=qemu-debootstrap + fi +} + +build_linux() +{ +( + handle_crosscompile + test -d linux || git clone --depth 1 https://github.com/jannau/linux -b spmi/work + cd linux + git fetch + git reset --hard origin/spmi/work; git clean -f -x -d &> /dev/null + curl -s https://tg.st/u/9ce9060dea91951a330feeeda3ad636bc88c642c.patch | git am - + curl -s https://tg.st/u/5nly | git am - + curl -s https://tg.st/u/0wM8 | git am - + curl -s https://tg.st/u/256f5efbf23ff68c489dad92f99d1cecfb021729.patch | git am - + curl -s https://tg.st/u/8737955a0263d09ffa8550658dfcac1df3d0665c.patch | git am - + curl -s https://tg.st/u/0001-4k-iommu-patch.patch | git am - + curl -s https://tg.st/u/0001-21-02-axboe-grabbing-anv-lock-around-the-issue-does-.patch | git am - + curl -s https://tg.st/u/config-2022-02-13 > .config + make olddefconfig + make -j $(( 2* `nproc`)) V=0 bindeb-pkg &> /dev/null +) +} + build_m1n1() { ( test -d m1n1 || git clone --recursive https://github.com/AsahiLinux/m1n1.git cd m1n1 git fetch - git reset --hard origin/main; git clean -f -x -d - make -j 16 + git reset --hard origin/main; git clean -f -x -d &> /dev/null + make -j $(( 2* `nproc`)) &> /dev/null ) } build_uboot() { ( - # Build u-boot + handle_crosscompile test -d u-boot || git clone --depth 1 https://github.com/jannau/u-boot -b x2r10g10b10 cd u-boot git fetch - git reset --hard origin/x2r10g10b10; git clean -f -x -d + git reset --hard origin/x2r10g10b10; git clean -f -x -d &> /dev/null curl -s https://tg.st/u/v2-console-usb-kbd-Limit-poll-frequency-to-improve-performance.diff | patch -p1 make apple_m1_defconfig - make -j 16 + make -j $(( 2* `nproc`)) &> /dev/null ) cat m1n1/build/m1n1.bin `find linux/arch/arm64/boot/dts/apple/ -name \*.dtb` u-boot/u-boot-nodtb.bin > u-boot.bin cat m1n1/build/m1n1.macho `find linux/arch/arm64/boot/dts/apple/ -name \*.dtb` u-boot/u-boot-nodtb.bin > u-boot.macho } -build_linux() -{ -( - test -d linux || git clone --depth 1 https://github.com/AsahiLinux/linux -b smc/work - cd linux - git fetch - git reset --hard origin/smc/work; git clean -f -x -d - curl -s https://tg.st/u/9ce9060dea91951a330feeeda3ad636bc88c642c.patch | git am - - curl -s https://tg.st/u/5nly | git am - - curl -s https://tg.st/u/0wM8 | git am - - curl -s https://tg.st/u/m1-config-smc-2022-02-06 > .config - curl -s https://tg.st/u/256f5efbf23ff68c489dad92f99d1cecfb021729.patch | git am - - curl -s https://tg.st/u/8737955a0263d09ffa8550658dfcac1df3d0665c.patch | git am - - - make olddefconfig - make -j 16 bindeb-pkg -) -} - build_rootfs() { ( + handle_crosscompile sudo rm -rf testing - sudo eatmydata debootstrap --arch=arm64 --include initramfs-tools,wpasupplicant,tcpdump,vim,tmux,vlan,ntpdate,bridge-utils,parted,curl,wget,grub-efi-arm64,mtr-tiny,dbus,ca-certificates,sudo,openssh-client testing testing http://ftp.fau.de/debian + sudo eatmydata ${DEBOOTSTRAP} --arch=arm64 --include initramfs-tools,wpasupplicant,tcpdump,vim,tmux,vlan,ntpdate,bridge-utils,parted,curl,wget,grub-efi-arm64,mtr-tiny,dbus,ca-certificates,sudo,openssh-client testing testing http://ftp.fau.de/debian export KERNEL=`ls -1rt linux-image*.deb | grep -v dbg | tail -1` @@ -78,7 +92,7 @@ build_rootfs() sudo cp ../../files/wpa.conf etc/wpa_supplicant/wpa_supplicant.conf sudo bash -c 'chroot . apt update' - sudo bash -c 'chroot . apt install -y firmware-linux-free' + sudo bash -c 'chroot . apt install -y firmware-linux' sudo -- perl -p -i -e 's/root:x:/root::/' etc/passwd @@ -129,7 +143,8 @@ build_di_stick() sudo rm -rf initrd; mkdir initrd; (cd initrd; gzip -cd ../initrd.gz | sudo cpio -imd --quiet) sudo rm -rf initrd/lib/modules/* sudo cp -a testing/lib/modules/* initrd/lib/modules/ - sudo cp ../files/wpa.conf initrd/etc/ + sudo cp ../files/wifi.sh initrd/ + sudo cp ../files/boot.sh initrd/ (cd initrd; find . | cpio --quiet -H newc -o | pigz > ../di-stick/initrd.gz) sudo rm -rf initrd cp testing/usr/lib/grub/arm64-efi/monolithic/grubaa64.efi di-stick/efi/boot/bootaa64.efi @@ -146,10 +161,9 @@ upload() for FILE in "$@"; do MYCURLARGS="$MYCURLARGS -F file=@${FILE}"; done; - curl -n -D - $MYCURLARGS https://upload.glanzmann.de/ | grep ^x-location | awk '{print $2}' + curl -4 -n -D - $MYCURLARGS https://upload.glanzmann.de/ | grep ^x-location | awk '{print $2}' } - upload_artefacts() { export KERNEL=`ls -1rt linux-image*.deb | grep -v dbg | tail -1` @@ -160,6 +174,8 @@ upload_artefacts() mkdir -p build cd build +sudo apt-get install -y build-essential bash git locales gcc-aarch64-linux-gnu libc6-dev-arm64-cross device-tree-compiler imagemagick ccache eatmydata debootstrap pigz libncurses-dev qemu-user-static binfmt-support + build_linux build_m1n1 build_uboot