Cleanup os build script, add full image build script
Hopefully fix github issues: Match hosts to hostname #18 Wifi gets named something "predictable" instead of wlan0 #7
This commit is contained in:
parent
51a6e92be5
commit
ea1b984f6d
@ -5,6 +5,13 @@
|
|||||||
|
|
||||||
KVER=4.17.2
|
KVER=4.17.2
|
||||||
|
|
||||||
|
#Ensure Sudo
|
||||||
|
if [[ $UID != 0 ]]; then
|
||||||
|
echo "Please run this script with sudo:"
|
||||||
|
echo "sudo $0 $*"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
outmnt=$(mktemp -d -p `pwd`)
|
outmnt=$(mktemp -d -p `pwd`)
|
||||||
inmnt=$(mktemp -d -p `pwd`)
|
inmnt=$(mktemp -d -p `pwd`)
|
||||||
|
|
||||||
@ -12,13 +19,7 @@ outdev=/dev/loop4
|
|||||||
indev=/dev/loop5
|
indev=/dev/loop5
|
||||||
|
|
||||||
#A hacky way to ensure the loops are properly unmounted and the temp files are properly deleted.
|
#A hacky way to ensure the loops are properly unmounted and the temp files are properly deleted.
|
||||||
#Without this, a reboot is required to properly clean the loop devices and ensure a clean build
|
#Without this, a reboot is sometimes required to properly clean the loop devices and ensure a clean build
|
||||||
cleanuptwice() {
|
|
||||||
cleanup
|
|
||||||
cleanup
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
cleanup() {
|
cleanup() {
|
||||||
set +e
|
set +e
|
||||||
|
|
||||||
@ -29,9 +30,19 @@ cleanup() {
|
|||||||
umount -l $outmnt > /dev/null 2>&1
|
umount -l $outmnt > /dev/null 2>&1
|
||||||
rmdir $outmnt > /dev/null 2>&1
|
rmdir $outmnt > /dev/null 2>&1
|
||||||
losetup -d $outdev > /dev/null 2>&1
|
losetup -d $outdev > /dev/null 2>&1
|
||||||
|
|
||||||
|
set +e
|
||||||
|
|
||||||
|
umount -l $inmnt > /dev/null 2>&1
|
||||||
|
rmdir $inmnt > /dev/null 2>&1
|
||||||
|
losetup -d $indev > /dev/null 2>&1
|
||||||
|
|
||||||
|
umount -l $outmnt > /dev/null 2>&1
|
||||||
|
rmdir $outmnt > /dev/null 2>&1
|
||||||
|
losetup -d $outdev > /dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
trap cleanuptwice INT TERM EXIT
|
trap cleanup INT TERM EXIT
|
||||||
|
|
||||||
|
|
||||||
create_image() {
|
create_image() {
|
||||||
@ -55,34 +66,43 @@ create_image() {
|
|||||||
# create a 2GB image with the Chrome OS partition layout
|
# create a 2GB image with the Chrome OS partition layout
|
||||||
create_image librean-stretch-c201-libre-2GB.img $outdev 50M 40 $outmnt
|
create_image librean-stretch-c201-libre-2GB.img $outdev 50M 40 $outmnt
|
||||||
|
|
||||||
# INCLUDES=apt-utils,libc6,libdebconfclient0,awk,libz2-1.0,libblzma5,libselinux1,tar,libtinfo5,zlib1g,udev,kmod,net-tools,traceroute,iproute2,isc-dhcp-client,wpasupplicant,iw,alsa-utils,cgpt,vim-tiny,less,psmisc,netcat-openbsd,ca-certificates,bzip2,xz-utils,unscd,lightdm,lightdm-gtk-greeter,xfce4,xorg,ifupdown,nano,wicd,wicd-curses
|
|
||||||
|
|
||||||
# install Debian on it
|
# install Debian on it
|
||||||
export LC_ALL="en_US.UTF-8" #Change this as necessary if not US
|
export LC_ALL="en_US.UTF-8" #Change this as necessary if not US
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
export DEBIAN_FRONTEND=noninteractive
|
||||||
qemu-debootstrap --arch armhf stretch --include locales,init $outmnt http://deb.debian.org/debian
|
qemu-debootstrap --arch armhf stretch --include locales,init $outmnt http://deb.debian.org/debian
|
||||||
chroot $outmnt passwd -d root
|
chroot $outmnt passwd -d root
|
||||||
echo -n debsus > $outmnt/etc/hostname
|
|
||||||
|
#Place the config files and installer script and give them the proper permissions
|
||||||
|
echo -n librean > $outmnt/etc/hostname
|
||||||
cp -R os_configs/ $outmnt/os_configs/
|
cp -R os_configs/ $outmnt/os_configs/
|
||||||
cp Install.sh $outmnt/Install.sh
|
cp Install.sh $outmnt/Install.sh
|
||||||
ls $outmnt/
|
|
||||||
chmod +x $outmnt/os_configs/sound.sh
|
chmod +x $outmnt/os_configs/sound.sh
|
||||||
chmod +x $outmnt/Install.sh
|
chmod +x $outmnt/Install.sh
|
||||||
|
|
||||||
#install -D -m 644 80disable-recommends $outmnt/etc/apt/apt.conf.d/80disable-recommends #This should fix the issue of crda being installed but unconfigured causing regulatory.db firmware loading errors in dmesg
|
#install -D -m 644 80disable-recommends $outmnt/etc/apt/apt.conf.d/80disable-recommends #This should fix the issue of crda being installed but unconfigured causing regulatory.db firmware loading errors in dmesg
|
||||||
#cp -f /etc/resolv.conf $outmnt/etc/
|
|
||||||
cp /etc/hosts $outmnt/etc/ #This is what https://wiki.debian.org/EmDebian/CrossDebootstrap suggests
|
#Setup the chroot for apt
|
||||||
|
#This is what https://wiki.debian.org/EmDebian/CrossDebootstrap suggests
|
||||||
|
cp /etc/hosts $outmnt/etc/
|
||||||
cp sources.list $outmount/etc/apt/sources.list
|
cp sources.list $outmount/etc/apt/sources.list
|
||||||
|
|
||||||
|
#Setup the locale
|
||||||
cp /etc/locale.gen $outmnt/etc/
|
cp /etc/locale.gen $outmnt/etc/
|
||||||
# chroot $outmnt locale-gen
|
|
||||||
|
#Install the base packages
|
||||||
chroot $outmnt apt update
|
chroot $outmnt apt update
|
||||||
chroot $outmnt apt install -y initscripts udev kmod net-tools inetutils-ping traceroute iproute2 isc-dhcp-client wpasupplicant iw alsa-utils cgpt vim-tiny less psmisc netcat-openbsd ca-certificates bzip2 xz-utils ifupdown nano apt-utils python python-urwid
|
chroot $outmnt apt install -y initscripts udev kmod net-tools inetutils-ping traceroute iproute2 isc-dhcp-client wpasupplicant iw alsa-utils cgpt vim-tiny less psmisc netcat-openbsd ca-certificates bzip2 xz-utils ifupdown nano apt-utils python python-urwid
|
||||||
|
|
||||||
|
#Cleanup to reduce install size
|
||||||
chroot $outmnt apt-get autoremove --purge
|
chroot $outmnt apt-get autoremove --purge
|
||||||
chroot $outmnt apt-get clean
|
chroot $outmnt apt-get clean
|
||||||
chroot $outmnt apt-get install -y -d xorg acpi-support lightdm tasksel dpkg librsvg2-common xorg xserver-xorg-input-libinput alsa-utils anacron avahi-daemon eject iw libnss-mdns xdg-utils lxqt wicd-daemon wicd wicd-curses wicd-gtk xserver-xorg-input-synaptics
|
|
||||||
#sed -i s/'enable-cache hosts no'/'enable-cache hosts yes'/ -i $outmnt/etc/nscd.conf
|
|
||||||
#rm -f $outmnt/etc/resolv.conf
|
|
||||||
rm -rf $outmnt/etc/hosts #This is what https://wiki.debian.org/EmDebian/CrossDebootstrap suggests
|
|
||||||
|
|
||||||
|
#Download the packages to be installed by Install.sh: TODO: potentially dpkg-reconfigure locales?
|
||||||
|
chroot $outmnt apt-get install -y -d xorg acpi-support lightdm tasksel dpkg librsvg2-common xorg xserver-xorg-input-libinput alsa-utils anacron avahi-daemon eject iw libnss-mdns xdg-utils lxqt wicd-daemon wicd wicd-curses wicd-gtk xserver-xorg-input-synaptics
|
||||||
|
|
||||||
|
#Cleanup hosts
|
||||||
|
rm -rf $outmnt/etc/hosts #This is what https://wiki.debian.org/EmDebian/CrossDebootstrap suggests
|
||||||
|
echo -n "127.0.0.1 librean" > $outmnt/etc/hosts
|
||||||
|
|
||||||
# put the kernel in the kernel partition, modules in /lib/modules and AR9271
|
# put the kernel in the kernel partition, modules in /lib/modules and AR9271
|
||||||
# firmware in /lib/firmware
|
# firmware in /lib/firmware
|
||||||
@ -98,6 +118,7 @@ create_image librean-stretch-c201-libre-15GB.img $indev 512 30777343 $inmnt
|
|||||||
dd if=${outdev}p1 of=${indev}p1 conv=notrunc
|
dd if=${outdev}p1 of=${indev}p1 conv=notrunc
|
||||||
cp -a $outmnt/* $inmnt/
|
cp -a $outmnt/* $inmnt/
|
||||||
|
|
||||||
|
#Cleanup the 15GB image
|
||||||
umount -l $inmnt
|
umount -l $inmnt
|
||||||
rmdir $inmnt
|
rmdir $inmnt
|
||||||
losetup -d $indev
|
losetup -d $indev
|
||||||
|
10
buildLibrean.sh
Normal file
10
buildLibrean.sh
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh -xe
|
||||||
|
|
||||||
|
#Build everything
|
||||||
|
|
||||||
|
#Get sudo
|
||||||
|
sudo echo "Thanks."
|
||||||
|
#Build kernel WITHOUT SUDO, building the kernel with sudo is bad practice
|
||||||
|
./buildKernel.sh
|
||||||
|
#build os WITH sudo, debootstrap requires sudo
|
||||||
|
sudo ./buildDebian.sh
|
Loading…
Reference in New Issue
Block a user