1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153 |
- #!/bin/bash
- #
- # Copyright (c) 2013-2021 Igor Pecovnik, igor.pecovnik@gma**.com
- #
- # This file is licensed under the terms of the GNU General Public
- # License version 2. This program is licensed "as is" without any
- # warranty of any kind, whether express or implied.
- # Functions:
- # install_common
- # install_rclocal
- # install_distribution_specific
- # post_debootstrap_tweaks
- install_common()
- {
- display_alert "Applying common tweaks" "" "info"
- # install rootfs encryption related packages separate to not break packages cache
- if [[ $CRYPTROOT_ENABLE == yes ]]; then
- display_alert "Installing rootfs encryption related packages" "cryptsetup" "info"
- chroot "${SDCARD}" /bin/bash -c "apt-get -y -qq --no-install-recommends install cryptsetup" \
- >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- if [[ $CRYPTROOT_SSH_UNLOCK == yes ]]; then
- display_alert "Installing rootfs encryption related packages" "dropbear-initramfs" "info"
- chroot "${SDCARD}" /bin/bash -c "apt-get -y -qq --no-install-recommends install dropbear-initramfs cryptsetup-initramfs" \
- >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- fi
- fi
- # add dummy fstab entry to make mkinitramfs happy
- echo "/dev/mmcblk0p1 / $ROOTFS_TYPE defaults 0 1" >> "${SDCARD}"/etc/fstab
- # required for initramfs-tools-core on Stretch since it ignores the / fstab entry
- echo "/dev/mmcblk0p2 /usr $ROOTFS_TYPE defaults 0 2" >> "${SDCARD}"/etc/fstab
- # adjust initramfs dropbear configuration
- # needs to be done before kernel installation, else it won't be in the initrd image
- if [[ $CRYPTROOT_ENABLE == yes && $CRYPTROOT_SSH_UNLOCK == yes ]]; then
- # Set the port of the dropbear ssh daemon in the initramfs to a different one if configured
- # this avoids the typical 'host key changed warning' - `WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!`
- [[ -f "${SDCARD}"/etc/dropbear-initramfs/config ]] && \
- sed -i 's/^#DROPBEAR_OPTIONS=/DROPBEAR_OPTIONS="-p '"${CRYPTROOT_SSH_UNLOCK_PORT}"'"/' \
- "${SDCARD}"/etc/dropbear-initramfs/config
- # setup dropbear authorized_keys, either provided by userpatches or generated
- if [[ -f $USERPATCHES_PATH/dropbear_authorized_keys ]]; then
- cp "$USERPATCHES_PATH"/dropbear_authorized_keys "${SDCARD}"/etc/dropbear-initramfs/authorized_keys
- else
- # generate a default ssh key for login on dropbear in initramfs
- # this key should be changed by the user on first login
- display_alert "Generating a new SSH key pair for dropbear (initramfs)" "" ""
- ssh-keygen -t ecdsa -f "${SDCARD}"/etc/dropbear-initramfs/id_ecdsa \
- -N '' -O force-command=cryptroot-unlock -C 'AUTOGENERATED_BY_ARMBIAN_BUILD' >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- # /usr/share/initramfs-tools/hooks/dropbear will automatically add 'id_ecdsa.pub' to authorized_keys file
- # during mkinitramfs of update-initramfs
- #cat "${SDCARD}"/etc/dropbear-initramfs/id_ecdsa.pub > "${SDCARD}"/etc/dropbear-initramfs/authorized_keys
- # The version of the Linux kernel
- CRYPTROOT_SSH_UNLOCK_KEY_NAME="${BOARD^}_${REVISION}_${DISTRIBUTION,}_${RELEASE}_${SELECTED_CONFIGURATION}_linux"$(grab_version "$LINUXSOURCEDIR")"".key
- # copy dropbear ssh key to image output dir for convenience
- cp "${SDCARD}"/etc/dropbear-initramfs/id_ecdsa "${DEST}/images/${CRYPTROOT_SSH_UNLOCK_KEY_NAME}"
- display_alert "SSH private key for dropbear (initramfs) has been copied to:" \
- "$DEST/images/$CRYPTROOT_SSH_UNLOCK_KEY_NAME" "info"
- fi
- fi
- # create modules file
- local modules=MODULES_${BRANCH^^}
- if [[ -n "${!modules}" ]]; then
- tr ' ' '\n' <<< "${!modules}" > "${SDCARD}"/etc/modules
- elif [[ -n "${MODULES}" ]]; then
- tr ' ' '\n' <<< "${MODULES}" > "${SDCARD}"/etc/modules
- fi
- # create blacklist files
- local blacklist=MODULES_BLACKLIST_${BRANCH^^}
- if [[ -n "${!blacklist}" ]]; then
- tr ' ' '\n' <<< "${!blacklist}" | sed -e 's/^/blacklist /' > "${SDCARD}/etc/modprobe.d/blacklist-${BOARD}.conf"
- elif [[ -n "${MODULES_BLACKLIST}" ]]; then
- tr ' ' '\n' <<< "${MODULES_BLACKLIST}" | sed -e 's/^/blacklist /' > "${SDCARD}/etc/modprobe.d/blacklist-${BOARD}.conf"
- fi
- # configure MIN / MAX speed for cpufrequtils
- cat <<-EOF > "${SDCARD}"/etc/default/cpufrequtils
- ENABLE=true
- MIN_SPEED=$CPUMIN
- MAX_SPEED=$CPUMAX
- GOVERNOR=$GOVERNOR
- EOF
- # remove default interfaces file if present
- # before installing board support package
- rm -f "${SDCARD}"/etc/network/interfaces
- # disable selinux by default
- mkdir -p "${SDCARD}"/selinux
- [[ -f "${SDCARD}"/etc/selinux/config ]] && sed "s/^SELINUX=.*/SELINUX=disabled/" -i "${SDCARD}"/etc/selinux/config
- # remove Ubuntu's legal text
- [[ -f "${SDCARD}"/etc/legal ]] && rm "${SDCARD}"/etc/legal
- # Prevent loading paralel printer port drivers which we don't need here.
- # Suppress boot error if kernel modules are absent
- if [[ -f "${SDCARD}"/etc/modules-load.d/cups-filters.conf ]]; then
- sed "s/^lp/#lp/" -i "${SDCARD}"/etc/modules-load.d/cups-filters.conf
- sed "s/^ppdev/#ppdev/" -i "${SDCARD}"/etc/modules-load.d/cups-filters.conf
- sed "s/^parport_pc/#parport_pc/" -i "${SDCARD}"/etc/modules-load.d/cups-filters.conf
- fi
- # console fix due to Debian bug
- sed -e 's/CHARMAP=".*"/CHARMAP="'$CONSOLE_CHAR'"/g' -i "${SDCARD}"/etc/default/console-setup
- # add the /dev/urandom path to the rng config file
- echo "HRNGDEVICE=/dev/urandom" >> "${SDCARD}"/etc/default/rng-tools
- # ping needs privileged action to be able to create raw network socket
- # this is working properly but not with (at least) Debian Buster
- chroot "${SDCARD}" /bin/bash -c "chmod u+s /bin/ping"
- # change time zone data
- echo "${TZDATA}" > "${SDCARD}"/etc/timezone
- chroot "${SDCARD}" /bin/bash -c "dpkg-reconfigure -f noninteractive tzdata >/dev/null 2>&1"
- # set root password
- chroot "${SDCARD}" /bin/bash -c "(echo $ROOTPWD;echo $ROOTPWD;) | passwd root >/dev/null 2>&1"
- # enable automated login to console(s)
- #mkdir -p "${SDCARD}"/etc/systemd/system/getty@.service.d/
- #mkdir -p "${SDCARD}"/etc/systemd/system/serial-getty@.service.d/
- #cat <<-EOF > "${SDCARD}"/etc/systemd/system/serial-getty@.service.d/override.conf
- #[Service]
- #ExecStartPre=/bin/sh -c 'exec /bin/sleep 10'
- #ExecStart=
- #ExecStart=-/sbin/agetty --noissue --autologin root %I \$TERM
- #Type=idle
- #EOF
- #cp "${SDCARD}"/etc/systemd/system/serial-getty@.service.d/override.conf "${SDCARD}"/etc/systemd/system/getty@.service.d/override.conf
- # force change root password at first login
- #chroot "${SDCARD}" /bin/bash -c "chage -d 0 root"
- # change console welcome text
- echo -e "${VENDOR} ${REVISION} ${RELEASE^} \\l \n" > "${SDCARD}"/etc/issue
- echo "${VENDOR} ${REVISION} ${RELEASE^}" > "${SDCARD}"/etc/issue.net
- sed -i "s/^PRETTY_NAME=.*/PRETTY_NAME=\"${VENDOR} $REVISION "${RELEASE^}"\"/" "${SDCARD}"/etc/os-release
- # enable few bash aliases enabled in Ubuntu by default to make it even
- sed "s/#alias ll='ls -l'/alias ll='ls -l'/" -i "${SDCARD}"/etc/skel/.bashrc
- sed "s/#alias la='ls -A'/alias la='ls -A'/" -i "${SDCARD}"/etc/skel/.bashrc
- sed "s/#alias l='ls -CF'/alias l='ls -CF'/" -i "${SDCARD}"/etc/skel/.bashrc
- # root user is already there. Copy bashrc there as well
- cp "${SDCARD}"/etc/skel/.bashrc "${SDCARD}"/root
- # display welcome message at first root login
- touch "${SDCARD}"/root/.not_logged_in_yet
- if [[ ${DESKTOP_AUTOLOGIN} != no ]]; then
- # set desktop autologin
- touch "${SDCARD}"/root/.desktop_autologin
- fi
- # NOTE: this needs to be executed before family_tweaks
- local bootscript_src=${BOOTSCRIPT%%:*}
- local bootscript_dst=${BOOTSCRIPT##*:}
- local bootdir=$([[ "$BOOTFS_TYPE" == "fat" ]] || echo "/boot")
- # create extlinux config file
- if [[ $SRC_EXTLINUX == yes ]]; then
- mkdir -p $SDCARD/boot/extlinux
- cat <<-EOF > "$SDCARD/boot/extlinux/extlinux.conf"
- label ${VENDOR}
- kernel $bootdir/$NAME_KERNEL
- initrd $bootdir/$NAME_INITRD
- EOF
- if [[ -n $BOOT_FDT_FILE ]]; then
- if [[ $BOOT_FDT_FILE != "none" ]]; then
- echo " fdt $bootdir/dtb/$BOOT_FDT_FILE" >> "$SDCARD/boot/extlinux/extlinux.conf"
- fi
- else
- echo " fdtdir $bootdir/dtb/" >> "$SDCARD/boot/extlinux/extlinux.conf"
- fi
- else
- if [[ "${BOOTCONFIG}" != "none" ]]; then
- if [ -f "${USERPATCHES_PATH}/bootscripts/${bootscript_src}" ]; then
- cp "${USERPATCHES_PATH}/bootscripts/${bootscript_src}" "${SDCARD}/boot/${bootscript_dst}"
- else
- cp "${EXTER}/config/bootscripts/${bootscript_src}" "${SDCARD}/boot/${bootscript_dst}"
- fi
- fi
- if [[ -n $BOOTENV_FILE ]]; then
- if [[ -f $USERPATCHES_PATH/bootenv/$BOOTENV_FILE ]]; then
- cp "$USERPATCHES_PATH/bootenv/${BOOTENV_FILE}" "${SDCARD}"/boot/orangepiEnv.txt
- elif [[ -f $EXTER/config/bootenv/$BOOTENV_FILE ]]; then
- cp "${EXTER}/config/bootenv/${BOOTENV_FILE}" "${SDCARD}"/boot/orangepiEnv.txt
- fi
- fi
- # TODO: modify $bootscript_dst or orangepiEnv.txt to make NFS boot universal
- # instead of copying sunxi-specific template
- if [[ $ROOTFS_TYPE == nfs ]]; then
- display_alert "Copying NFS boot script template"
- if [[ -f $USERPATCHES_PATH/nfs-boot.cmd ]]; then
- cp "$USERPATCHES_PATH"/nfs-boot.cmd "${SDCARD}"/boot/boot.cmd
- else
- cp "${EXTER}"/config/templates/nfs-boot.cmd.template "${SDCARD}"/boot/boot.cmd
- fi
- fi
- [[ -n $OVERLAY_PREFIX && -f "${SDCARD}"/boot/orangepiEnv.txt && ($BRANCH =~ current|next || $BOARDFAMILY =~ "rockchip-rk3588"|"rockchip-rk356x") ]] && \
- echo "overlay_prefix=$OVERLAY_PREFIX" >> "${SDCARD}"/boot/orangepiEnv.txt
- [[ -n $DEFAULT_OVERLAYS && -f "${SDCARD}"/boot/orangepiEnv.txt && ($BRANCH =~ current|next || $BOARDFAMILY =~ "rockchip-rk3588"|"rockchip-rk356x") ]] && \
- echo "overlays=${DEFAULT_OVERLAYS//,/ }" >> "${SDCARD}"/boot/orangepiEnv.txt
- [[ -n $BOOT_FDT_FILE && -f "${SDCARD}"/boot/orangepiEnv.txt ]] && \
- echo "fdtfile=${BOOT_FDT_FILE}" >> "${SDCARD}/boot/orangepiEnv.txt"
- fi
- # initial date for fake-hwclock
- date -u '+%Y-%m-%d %H:%M:%S' > "${SDCARD}"/etc/fake-hwclock.data
- echo "${HOST}" > "${SDCARD}"/etc/hostname
- # set hostname in hosts file
- cat <<-EOF > "${SDCARD}"/etc/hosts
- 127.0.0.1 localhost
- 127.0.1.1 $HOST
- ::1 localhost $HOST ip6-localhost ip6-loopback
- fe00::0 ip6-localnet
- ff00::0 ip6-mcastprefix
- ff02::1 ip6-allnodes
- ff02::2 ip6-allrouters
- EOF
- cd $SRC
- # Prepare and export caching-related params common to all apt calls below, to maximize apt-cacher-ng usage
- export APT_EXTRA_DIST_PARAMS=""
- [[ $NO_APT_CACHER != yes ]] && APT_EXTRA_DIST_PARAMS="-o Acquire::http::Proxy=\"http://${APT_PROXY_ADDR:-localhost:3142}\" -o Acquire::http::Proxy::localhost=\"DIRECT\""
- display_alert "Cleaning" "package lists"
- chroot "${SDCARD}" /bin/bash -c "apt-get clean"
- display_alert "Updating" "package lists"
- chroot "${SDCARD}" /bin/bash -c "apt-get ${APT_EXTRA_DIST_PARAMS} update" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- display_alert "Temporarily disabling" "initramfs-tools hook for kernel"
- chroot "${SDCARD}" /bin/bash -c "chmod -v -x /etc/kernel/postinst.d/initramfs-tools" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- # install family packages
- if [[ -n ${PACKAGE_LIST_FAMILY} ]]; then
- display_alert "Installing PACKAGE_LIST_FAMILY packages" "${PACKAGE_LIST_FAMILY}"
- chroot "${SDCARD}" /bin/bash -c "DEBIAN_FRONTEND=noninteractive apt-get ${APT_EXTRA_DIST_PARAMS} -yqq --no-install-recommends install $PACKAGE_LIST_FAMILY" >> "${DEST}"/${LOG_SUBPATH}/install.log
- fi
- # install board packages
- if [[ -n ${PACKAGE_LIST_BOARD} ]]; then
- display_alert "Installing PACKAGE_LIST_BOARD packages" "${PACKAGE_LIST_BOARD}"
- chroot "${SDCARD}" /bin/bash -c "DEBIAN_FRONTEND=noninteractive apt-get ${APT_EXTRA_DIST_PARAMS} -yqq --no-install-recommends install $PACKAGE_LIST_BOARD" >> "${DEST}"/${LOG_SUBPATH}/install.log || { display_alert "Failed to install PACKAGE_LIST_BOARD" "${PACKAGE_LIST_BOARD}" "err"; exit 2; }
- fi
- # remove family packages
- if [[ -n ${PACKAGE_LIST_FAMILY_REMOVE} ]]; then
- display_alert "Removing PACKAGE_LIST_FAMILY_REMOVE packages" "${PACKAGE_LIST_FAMILY_REMOVE}"
- chroot "${SDCARD}" /bin/bash -c "DEBIAN_FRONTEND=noninteractive apt-get ${APT_EXTRA_DIST_PARAMS} -yqq remove --auto-remove $PACKAGE_LIST_FAMILY_REMOVE" >> "${DEST}"/${LOG_SUBPATH}/install.log
- fi
- # remove board packages
- if [[ -n ${PACKAGE_LIST_BOARD_REMOVE} ]]; then
- display_alert "Removing PACKAGE_LIST_BOARD_REMOVE packages" "${PACKAGE_LIST_BOARD_REMOVE}"
- for PKG_REMOVE in ${PACKAGE_LIST_BOARD_REMOVE}; do
- chroot "${SDCARD}" /bin/bash -c "DEBIAN_FRONTEND=noninteractive apt-get ${APT_EXTRA_DIST_PARAMS} -yqq remove --auto-remove ${PKG_REMOVE}" >> "${DEST}"/${LOG_SUBPATH}/install.log
- done
- fi
- # install u-boot
- # @TODO: add install_bootloader() extension method, refactor into u-boot extension
- [[ "${BOOTCONFIG}" != "none" ]] && {
- if [[ "${REPOSITORY_INSTALL}" != *u-boot* ]]; then
- UBOOT_VER=$(dpkg --info "${DEB_STORAGE}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb" | grep Descr | awk '{print $(NF)}')
- install_deb_chroot "${DEB_STORAGE}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb"
- else
- UBOOT_VER=$(dpkg --info "${DEB_ORANGEPI}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb" | grep Descr | awk '{print $(NF)}')
- install_deb_chroot "${DEB_ORANGEPI}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb" "orangepi"
- fi
- }
- call_extension_method "pre_install_kernel_debs" << 'PRE_INSTALL_KERNEL_DEBS'
- *called before installing the Armbian-built kernel deb packages*
- It is not too late to `unset KERNELSOURCE` here and avoid kernel install.
- PRE_INSTALL_KERNEL_DEBS
- # install kernel
- [[ -n $KERNELSOURCE ]] && {
- if [[ "${REPOSITORY_INSTALL}" != *kernel* ]]; then
- VER=$(dpkg --info "${DEB_STORAGE}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb" | awk -F"-" '/Source:/{print $2}')
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb"
- if [[ -f ${DEB_STORAGE}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb ]]; then
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb"
- fi
- if [[ $INSTALL_HEADERS == yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL/image/headers}_${REVISION}_${ARCH}.deb"
- else
- cp "${DEB_STORAGE}/${CHOSEN_KERNEL/image/headers}_${REVISION}_${ARCH}.deb" "${SDCARD}"/opt/
- fi
- else
- VER=$(dpkg --info "${DEB_ORANGEPI}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb" | grep Descr | awk '{print $(NF)}')
- VER="${VER/-$LINUXFAMILY/}"
- install_deb_chroot "${DEB_ORANGEPI}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb" "orangepi"
- if [[ -f ${DEB_ORANGEPI}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb ]]; then
- install_deb_chroot "${DEB_ORANGEPI}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb" "orangepi"
- fi
- if [[ $INSTALL_HEADERS == yes ]]; then
- install_deb_chroot "${DEB_ORANGEPI}/${CHOSEN_KERNEL/image/headers}_${REVISION}_${ARCH}.deb" "orangepi"
- fi
- fi
- }
- call_extension_method "post_install_kernel_debs" << 'POST_INSTALL_KERNEL_DEBS'
- *allow config to do more with the installed kernel/headers*
- Called after packages, u-boot, kernel and headers installed in the chroot, but before the BSP is installed.
- If `KERNELSOURCE` is (still?) unset after this, Armbian-built firmware will not be installed.
- POST_INSTALL_KERNEL_DEBS
- # install board support packages
- if [[ "${REPOSITORY_INSTALL}" != *bsp* ]]; then
- install_deb_chroot "${DEB_STORAGE}/$RELEASE/${BSP_CLI_PACKAGE_FULLNAME}.deb"
- else
- install_deb_chroot "${DEB_ORANGEPI}/$RELEASE/${CHOSEN_ROOTFS}_${BSP_CLI_PACKAGE_FULLNAME}.deb" "orangepi"
- fi
- # install orangepi-desktop
- if [[ "${REPOSITORY_INSTALL}" != *orangepi-desktop* ]]; then
- if [[ $BUILD_DESKTOP == yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/${RELEASE}/${CHOSEN_DESKTOP}_${REVISION}_all.deb"
- install_deb_chroot "${DEB_STORAGE}/${RELEASE}/${BSP_DESKTOP_PACKAGE_FULLNAME}.deb"
- # install display manager and PACKAGE_LIST_DESKTOP_FULL packages if enabled per board
- desktop_postinstall
- fi
- else
- if [[ $BUILD_DESKTOP == yes ]]; then
- install_deb_chroot "${CHOSEN_DESKTOP}" "orangepi"
- # install display manager and PACKAGE_LIST_DESKTOP_FULL packages if enabled per board
- desktop_postinstall
- fi
- fi
- # install orangepi-firmware
- if [[ "${REPOSITORY_INSTALL}" != *orangepi-firmware* ]]; then
- if [[ -f ${DEB_STORAGE}/orangepi-firmware_${REVISION}_all.deb ]]; then
- install_deb_chroot "${DEB_STORAGE}/orangepi-firmware_${REVISION}_all.deb"
- fi
- else
- if [[ -f ${DEB_STORAGE}/orangepi-firmware_${REVISION}_all.deb ]]; then
- install_deb_chroot "${DEB_ORANGEPI}/orangepi-firmware_${REVISION}_all.deb" "orangepi"
- fi
- fi
- # install orangepi-config
- if [[ "${PACKAGE_LIST_RM}" != *orangepi-config* ]]; then
- if [[ "${REPOSITORY_INSTALL}" != *orangepi-config* ]]; then
- if [[ $BUILD_MINIMAL != yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/orangepi-config_${REVISION}_all.deb"
- fi
- else
- if [[ $BUILD_MINIMAL != yes ]]; then
- install_deb_chroot "${DEB_ORANGEPI}/orangepi-config_${REVISION}_all.deb" "orangepi"
- fi
- fi
- fi
- # install orangepi-zsh
- if [[ "${PACKAGE_LIST_RM}" != *orangepi-zsh* ]]; then
- if [[ "${REPOSITORY_INSTALL}" != *orangepi-zsh* ]]; then
- if [[ $BUILD_MINIMAL != yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/orangepi-zsh_${REVISION}_all.deb"
- fi
- else
- if [[ $BUILD_MINIMAL != yes ]]; then
- install_deb_chroot "orangepi-zsh" "remote"
- fi
- fi
- fi
- # install plymouth-theme-orangepi
- if [[ $PLYMOUTH == yes && $BUILD_DESKTOP == yes && $RELEASE != buster ]]; then
- if [[ "${REPOSITORY_INSTALL}" != *plymouth-theme-orangepi* ]]; then
- install_deb_chroot "${DEB_STORAGE}/orangepi-plymouth-theme_${REVISION}_all.deb"
- else
- install_deb_chroot "orangepi-plymouth-theme" "remote"
- fi
- fi
- # install kernel sources
- if [[ -f ${DEB_STORAGE}/${CHOSEN_KSRC}_${REVISION}_all.deb && $INSTALL_KSRC == yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KSRC}_${REVISION}_all.deb"
- elif [[ $INSTALL_KSRC == yes ]]; then
- display_alert "Please set BUILD_KSRC=yes to generate the kernel source package" "" "wrn"
- fi
- # install wireguard tools
- if [[ $WIREGUARD == yes ]]; then
- chroot "${SDCARD}" /bin/bash -c "apt-get -y -qq install wireguard-tools --no-install-recommends" >> "${DEST}"/debug/install.log 2>&1
- fi
- # freeze orangepi packages
- if [[ $BSPFREEZE == yes ]]; then
- display_alert "Freezing Orange Pi packages" "$BOARD" "info"
- chroot "${SDCARD}" /bin/bash -c "apt-mark hold ${CHOSEN_KERNEL} ${CHOSEN_KERNEL/image/headers} \
- linux-u-boot-${BOARD}-${BRANCH} ${CHOSEN_KERNEL/image/dtb}" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- fi
- # add orangepi user
- chroot "${SDCARD}" /bin/bash -c "adduser --quiet --disabled-password --shell /bin/bash --home /home/${OPI_USERNAME} --gecos ${OPI_USERNAME} ${OPI_USERNAME}"
- chroot "${SDCARD}" /bin/bash -c "(echo ${OPI_PWD};echo ${OPI_PWD};) | passwd "${OPI_USERNAME}" >/dev/null 2>&1"
- for additionalgroup in sudo netdev audio video disk tty users games dialout plugdev input bluetooth systemd-journal ssh docker; do
- chroot "${SDCARD}" /bin/bash -c "usermod -aG ${additionalgroup} ${OPI_USERNAME} 2>/dev/null"
- done
- # fix for gksu in Xenial
- touch ${SDCARD}/home/${OPI_USERNAME}/.Xauthority
- chroot "${SDCARD}" /bin/bash -c "chown ${OPI_USERNAME}:${OPI_USERNAME} /home/${OPI_USERNAME}/.Xauthority"
- # set up profile sync daemon on desktop systems
- chroot "${SDCARD}" /bin/bash -c "which psd >/dev/null 2>&1"
- if [ $? -eq 0 ]; then
- echo -e "${OPI_USERNAME} ALL=(ALL) NOPASSWD: /usr/bin/psd-overlay-helper" >> ${SDCARD}/etc/sudoers
- touch ${SDCARD}/home/${OPI_USERNAME}/.activate_psd
- chroot "${SDCARD}" /bin/bash -c "chown $OPI_USERNAME:$OPI_USERNAME /home/${OPI_USERNAME}/.activate_psd"
- fi
- # remove deb files
- rm -f "${SDCARD}"/root/*.deb
- # copy boot splash images
- cp "${EXTER}"/packages/blobs/splash/orangepi-u-boot.bmp "${SDCARD}"/boot/boot.bmp
- cp "${EXTER}"/packages/blobs/splash/logo.bmp "${SDCARD}"/boot/logo.bmp
- # copy audio.wav and mute.wav
- cp "${EXTER}"/packages/blobs/audio_wav/audio.wav "${SDCARD}"/usr/share/sounds/alsa/
- cp "${EXTER}"/packages/blobs/audio_wav/mute.wav "${SDCARD}"/usr/share/sounds/alsa/
- cp "${EXTER}"/packages/blobs/test.mp4 "${SDCARD}"/usr/local/
- # copy watchdog test programm
- cp "${EXTER}"/packages/blobs/watchdog/watchdog_test_${ARCH} "${SDCARD}"/usr/local/bin/watchdog_test
- [[ -f "${SDCARD}"/usr/bin/gnome-session ]] && sed -i "s/user-session.*/user-session=ubuntu-wayland/" ${SDCARD}/etc/lightdm/lightdm.conf.d/22-orangepi-autologin.conf > /dev/null 2>&1
- [[ -f "${SDCARD}"/usr/bin/startplasma-x11 ]] && sed -i "s/user-session.*/user-session=plasma-x11/" ${SDCARD}/etc/lightdm/lightdm.conf.d/22-orangepi-autologin.conf
- # execute $LINUXFAMILY-specific tweaks
- [[ $(type -t family_tweaks) == function ]] && family_tweaks
- call_extension_method "post_family_tweaks" << 'FAMILY_TWEAKS'
- *customize the tweaks made by $LINUXFAMILY-specific family_tweaks*
- It is run after packages are installed in the rootfs, but before enabling additional services.
- It allows implementors access to the rootfs (`${SDCARD}`) in its pristine state after packages are installed.
- FAMILY_TWEAKS
- # enable additional services
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-firstrun.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-firstrun-config.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-zram-config.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-hardware-optimize.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-ramlog.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-resize-filesystem.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-hardware-monitor.service >/dev/null 2>&1"
- # copy "first run automated config, optional user configured"
- cp ${EXTER}/packages/bsp/orangepi_first_run.txt.template "${SDCARD}"/boot/orangepi_first_run.txt.template
- ## switch to beta repository at this stage if building nightly images
- #[[ $IMAGE_TYPE == nightly ]] \
- #&& echo "deb http://beta.orangepi.com $RELEASE main ${RELEASE}-utils ${RELEASE}-desktop" \
- #> "${SDCARD}"/etc/apt/sources.list.d/orangepi.list
- # Cosmetic fix [FAILED] Failed to start Set console font and keymap at first boot
- [[ -f "${SDCARD}"/etc/console-setup/cached_setup_font.sh ]] \
- && sed -i "s/^printf '.*/printf '\\\033\%\%G'/g" "${SDCARD}"/etc/console-setup/cached_setup_font.sh
- [[ -f "${SDCARD}"/etc/console-setup/cached_setup_terminal.sh ]] \
- && sed -i "s/^printf '.*/printf '\\\033\%\%G'/g" "${SDCARD}"/etc/console-setup/cached_setup_terminal.sh
- [[ -f "${SDCARD}"/etc/console-setup/cached_setup_keyboard.sh ]] \
- && sed -i "s/-u/-x'/g" "${SDCARD}"/etc/console-setup/cached_setup_keyboard.sh
- # fix for https://bugs.launchpad.net/ubuntu/+source/blueman/+bug/1542723
- chroot "${SDCARD}" /bin/bash -c "chown root:messagebus /usr/lib/dbus-1.0/dbus-daemon-launch-helper"
- chroot "${SDCARD}" /bin/bash -c "chmod u+s /usr/lib/dbus-1.0/dbus-daemon-launch-helper"
- # disable samba NetBIOS over IP name service requests since it hangs when no network is present at boot
- chroot "${SDCARD}" /bin/bash -c "systemctl --quiet disable nmbd 2> /dev/null"
- # disable low-level kernel messages for non betas
- if [[ -z $BETA ]]; then
- sed -i "s/^#kernel.printk*/kernel.printk/" "${SDCARD}"/etc/sysctl.conf
- fi
- # disable repeated messages due to xconsole not being installed.
- [[ -f "${SDCARD}"/etc/rsyslog.d/50-default.conf ]] && \
- sed '/daemon\.\*\;mail.*/,/xconsole/ s/.*/#&/' -i "${SDCARD}"/etc/rsyslog.d/50-default.conf
- # disable deprecated parameter
- sed '/.*$KLogPermitNonKernelFacility.*/,// s/.*/#&/' -i "${SDCARD}"/etc/rsyslog.conf
- # enable getty on multiple serial consoles
- # and adjust the speed if it is defined and different than 115200
- #
- # example: SERIALCON="ttyS0:15000000,ttyGS1"
- #
- ifs=$IFS
- for i in $(echo "${SERIALCON:-'ttyS0'}" | sed "s/,/ /g")
- do
- IFS=':' read -r -a array <<< "$i"
- [[ "${array[0]}" == "tty1" ]] && continue # Don't enable tty1 as serial console.
- display_alert "Enabling serial console" "${array[0]}" "info"
- # add serial console to secure tty list
- [ -z "$(grep -w '^${array[0]}' "${SDCARD}"/etc/securetty 2> /dev/null)" ] && \
- echo "${array[0]}" >> "${SDCARD}"/etc/securetty
- if [[ ${array[1]} != "115200" && -n ${array[1]} ]]; then
- # make a copy, fix speed and enable
- cp "${SDCARD}"/lib/systemd/system/serial-getty@.service \
- "${SDCARD}/lib/systemd/system/serial-getty@${array[0]}.service"
- sed -i "s/--keep-baud 115200/--keep-baud ${array[1]},115200/" \
- "${SDCARD}/lib/systemd/system/serial-getty@${array[0]}.service"
- fi
- chroot "${SDCARD}" /bin/bash -c "systemctl daemon-reload" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable serial-getty@${array[0]}.service" \
- >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- if [[ "${array[0]}" == "ttyGS0" && $LINUXFAMILY == sun8i && $BRANCH == legacy ]]; then
- mkdir -p "${SDCARD}"/etc/systemd/system/serial-getty@ttyGS0.service.d
- cat <<-EOF > "${SDCARD}"/etc/systemd/system/serial-getty@ttyGS0.service.d/10-switch-role.conf
- [Service]
- ExecStartPre=-/bin/sh -c "echo 2 > /sys/bus/platform/devices/sunxi_usb_udc/otg_role"
- EOF
- fi
- done
- IFS=$ifs
- [[ $LINUXFAMILY == sun*i ]] && mkdir -p "${SDCARD}"/boot/overlay-user
- # to prevent creating swap file on NFS (needs specific kernel options)
- # and f2fs/btrfs (not recommended or needs specific kernel options)
- [[ $ROOTFS_TYPE != ext4 ]] && touch "${SDCARD}"/var/swap
- # install initial asound.state if defined
- mkdir -p "${SDCARD}"/var/lib/alsa/
- [[ -n $ASOUND_STATE ]] && cp "${EXTER}/packages/blobs/asound.state/${ASOUND_STATE}" "${SDCARD}"/var/lib/alsa/asound.state
- # save initial orangepi-release state
- cp "${SDCARD}"/etc/orangepi-release "${SDCARD}"/etc/orangepi-image-release
- # DNS fix. package resolvconf is not available everywhere
- if [ -d /etc/resolvconf/resolv.conf.d ] && [ -n "$NAMESERVER" ]; then
- echo "nameserver $NAMESERVER" > "${SDCARD}"/etc/resolvconf/resolv.conf.d/head
- fi
- # permit root login via SSH for the first boot
- sed -i 's/#\?PermitRootLogin .*/PermitRootLogin yes/' "${SDCARD}"/etc/ssh/sshd_config
- # enable PubkeyAuthentication
- sed -i 's/#\?PubkeyAuthentication .*/PubkeyAuthentication yes/' "${SDCARD}"/etc/ssh/sshd_config
- if [ -f "${SDCARD}"/etc/NetworkManager/NetworkManager.conf ]; then
- # configure network manager
- sed "s/managed=\(.*\)/managed=true/g" -i "${SDCARD}"/etc/NetworkManager/NetworkManager.conf
- # remove network manager defaults to handle eth by default
- rm -f "${SDCARD}"/usr/lib/NetworkManager/conf.d/10-globally-managed-devices.conf
- # most likely we don't need to wait for nm to get online
- chroot "${SDCARD}" /bin/bash -c "systemctl disable NetworkManager-wait-online.service" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- # Just regular DNS and maintain /etc/resolv.conf as a file
- sed "/dns/d" -i "${SDCARD}"/etc/NetworkManager/NetworkManager.conf
- sed "s/\[main\]/\[main\]\ndns=default\nrc-manager=file/g" -i "${SDCARD}"/etc/NetworkManager/NetworkManager.conf
- if [[ -n $NM_IGNORE_DEVICES ]]; then
- mkdir -p "${SDCARD}"/etc/NetworkManager/conf.d/
- cat <<-EOF > "${SDCARD}"/etc/NetworkManager/conf.d/10-ignore-interfaces.conf
- [keyfile]
- unmanaged-devices=$NM_IGNORE_DEVICES
- EOF
- fi
- elif [ -d "${SDCARD}"/etc/systemd/network ]; then
- # configure networkd
- rm "${SDCARD}"/etc/resolv.conf
- ln -s /run/systemd/resolve/resolv.conf "${SDCARD}"/etc/resolv.conf
- # enable services
- chroot "${SDCARD}" /bin/bash -c "systemctl enable systemd-networkd.service systemd-resolved.service" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- if [ -e /etc/systemd/timesyncd.conf ]; then
- chroot "${SDCARD}" /bin/bash -c "systemctl enable systemd-timesyncd.service" >> "${DEST}"/${LOG_SUBPATH}/install.log 2>&1
- fi
- umask 022
- cat > "${SDCARD}"/etc/systemd/network/eth0.network <<- __EOF__
- [Match]
- Name=eth0
- [Network]
- #MACAddress=
- DHCP=ipv4
- LinkLocalAddressing=ipv4
- #Address=192.168.1.100/24
- #Gateway=192.168.1.1
- #DNS=192.168.1.1
- #Domains=example.com
- NTP=0.pool.ntp.org 1.pool.ntp.org
- __EOF__
- fi
- # avahi daemon defaults if exists
- [[ -f "${SDCARD}"/usr/share/doc/avahi-daemon/examples/sftp-ssh.service ]] && \
- cp "${SDCARD}"/usr/share/doc/avahi-daemon/examples/sftp-ssh.service "${SDCARD}"/etc/avahi/services/
- [[ -f "${SDCARD}"/usr/share/doc/avahi-daemon/examples/ssh.service ]] && \
- cp "${SDCARD}"/usr/share/doc/avahi-daemon/examples/ssh.service "${SDCARD}"/etc/avahi/services/
- # nsswitch settings for sane DNS behavior: remove resolve, assure libnss-myhostname support
- sed "s/hosts\:.*/hosts: files mymachines dns myhostname/g" -i "${SDCARD}"/etc/nsswitch.conf
- # build logo in any case
- boot_logo
- # disable MOTD for first boot - we want as clean 1st run as possible
- chmod -x "${SDCARD}"/etc/update-motd.d/*
- }
- install_rclocal()
- {
- if [[ $BURN_IMAGE == yes ]]; then
- cat <<-EOF > "${SDCARD}"/etc/rc.local
- #!/bin/sh -e
- #
- # rc.local
- #
- # This script is executed at the end of each multiuser runlevel.
- # Make sure that the script will "exit 0" on success or any other
- # value on error.
- #
- # In order to enable or disable this script just change the execution
- # bits.
- #
- # By default this script does nothing.
- burn_to_emmc
- exit 0
- EOF
- else
- cat <<-EOF > "${SDCARD}"/etc/rc.local
- #!/bin/sh -e
- #
- # rc.local
- #
- # This script is executed at the end of each multiuser runlevel.
- # Make sure that the script will "exit 0" on success or any other
- # value on error.
- #
- # In order to enable or disable this script just change the execution
- # bits.
- #
- # By default this script does nothing.
- exit 0
- EOF
- fi
- chmod +x "${SDCARD}"/etc/rc.local
- }
- install_distribution_specific()
- {
- display_alert "Applying distribution specific tweaks for" "$RELEASE" "info"
- case $RELEASE in
- xenial)
- # remove legal info from Ubuntu
- [[ -f "${SDCARD}"/etc/legal ]] && rm "${SDCARD}"/etc/legal
- # ureadahead needs kernel tracing options that AFAIK are present only in mainline. disable
- chroot "${SDCARD}" /bin/bash -c \
- "systemctl --no-reload mask ondemand.service ureadahead.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c \
- "systemctl --no-reload mask setserial.service etc-setserial.service >/dev/null 2>&1"
- ;;
- stretch|buster|sid)
- # remove doubled uname from motd
- [[ -f "${SDCARD}"/etc/update-motd.d/10-uname ]] && rm "${SDCARD}"/etc/update-motd.d/10-uname
- # rc.local is not existing but one might need it
- install_rclocal
- ;;
- bullseye)
- # remove doubled uname from motd
- [[ -f "${SDCARD}"/etc/update-motd.d/10-uname ]] && rm "${SDCARD}"/etc/update-motd.d/10-uname
- # rc.local is not existing but one might need it
- install_rclocal
- # fix missing versioning
- [[ $(grep -L "VERSION_ID=" "${SDCARD}"/etc/os-release) ]] && echo 'VERSION_ID="11"' >> "${SDCARD}"/etc/os-release
- [[ $(grep -L "VERSION=" "${SDCARD}"/etc/os-release) ]] && echo 'VERSION="11 (bullseye)"' >> "${SDCARD}"/etc/os-release
- ;;
-
- bookworm)
- # remove doubled uname from motd
- [[ -f "${SDCARD}"/etc/update-motd.d/10-uname ]] && rm "${SDCARD}"/etc/update-motd.d/10-uname
- # rc.local is not existing but one might need it
- install_rclocal
- # fix missing versioning
- [[ $(grep -L "VERSION_ID=" "${SDCARD}"/etc/os-release) ]] && echo 'VERSION_ID="12"' >> "${SDCARD}"/etc/os-release
- [[ $(grep -L "VERSION=" "${SDCARD}"/etc/os-release) ]] && echo 'VERSION="11 (bookworm)"' >> "${SDCARD}"/etc/os-release
- # remove security updates repository since it does not exists yet
- sed '/security/ d' -i "${SDCARD}"/etc/apt/sources.list
- ;;
- bionic|focal|hirsute|impish|jammy|noble)
- # by using default lz4 initrd compression leads to corruption, go back to proven method
- sed -i "s/^COMPRESS=.*/COMPRESS=gzip/" "${SDCARD}"/etc/initramfs-tools/initramfs.conf
- echo -e "\n[Install]\nWantedBy=multi-user.target" >> "${SDCARD}"/lib/systemd/system/lightdm.service
- # cleanup motd services and related files
- chroot "${SDCARD}" /bin/bash -c "systemctl disable motd-news.service >/dev/null 2>&1"
- chroot "${SDCARD}" /bin/bash -c "systemctl disable motd-news.timer >/dev/null 2>&1"
- rm -f "${SDCARD}"/etc/update-motd.d/{10-uname,10-help-text,50-motd-news,80-esm,80-livepatch,90-updates-available,91-release-upgrade,95-hwe-eol}
- # remove motd news from motd.ubuntu.com
- [[ -f "${SDCARD}"/etc/default/motd-news ]] && sed -i "s/^ENABLED=.*/ENABLED=0/" "${SDCARD}"/etc/default/motd-news
- # rc.local is not existing but one might need it
- install_rclocal
- if [ -d "${SDCARD}"/etc/NetworkManager ]; then
- local RENDERER=NetworkManager
- else
- local RENDERER=networkd
- fi
- # Basic Netplan config. Let NetworkManager/networkd manage all devices on this system
- [[ -d "${SDCARD}"/etc/netplan ]] && cat <<-EOF > "${SDCARD}"/etc/netplan/orangepi-default.yaml
- network:
- version: 2
- renderer: $RENDERER
- EOF
- # DNS fix
- if [ -n "$NAMESERVER" ]; then
- sed -i "s/#DNS=.*/DNS=$NAMESERVER/g" "${SDCARD}"/etc/systemd/resolved.conf
- fi
- # Journal service adjustements
- sed -i "s/#Storage=.*/Storage=volatile/g" "${SDCARD}"/etc/systemd/journald.conf
- sed -i "s/#Compress=.*/Compress=yes/g" "${SDCARD}"/etc/systemd/journald.conf
- sed -i "s/#RateLimitIntervalSec=.*/RateLimitIntervalSec=30s/g" "${SDCARD}"/etc/systemd/journald.conf
- sed -i "s/#RateLimitBurst=.*/RateLimitBurst=10000/g" "${SDCARD}"/etc/systemd/journald.conf
- # Chrony temporal fix https://bugs.launchpad.net/ubuntu/+source/chrony/+bug/1878005
- sed -i '/DAEMON_OPTS=/s/"-F -1"/"-F 0"/' "${SDCARD}"/etc/default/chrony
- # disable conflicting services
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload mask ondemand.service >/dev/null 2>&1"
- ;;
- esac
- # use list modules INITRAMFS
- if [ -f "${EXTER}"/config/modules/"${MODULES_INITRD}" ]; then
- display_alert "Use file list modules INITRAMFS" "${MODULES_INITRD}"
- sed -i "s/^MODULES=.*/MODULES=list/" "${SDCARD}"/etc/initramfs-tools/initramfs.conf
- cat "${EXTER}"/config/modules/"${MODULES_INITRD}" >> "${SDCARD}"/etc/initramfs-tools/modules
- fi
- }
- post_debootstrap_tweaks()
- {
- # remove service start blockers and QEMU binary
- rm -f "${SDCARD}"/sbin/initctl "${SDCARD}"/sbin/start-stop-daemon
- chroot "${SDCARD}" /bin/bash -c "dpkg-divert --quiet --local --rename --remove /sbin/initctl"
- chroot "${SDCARD}" /bin/bash -c "dpkg-divert --quiet --local --rename --remove /sbin/start-stop-daemon"
- rm -f "${SDCARD}"/usr/sbin/policy-rc.d "${SDCARD}/usr/bin/${QEMU_BINARY}"
- call_extension_method "post_post_debootstrap_tweaks" "config_post_debootstrap_tweaks" << 'POST_POST_DEBOOTSTRAP_TWEAKS'
- *run after removing diversions and qemu with chroot unmounted*
- Last chance to touch the `${SDCARD}` filesystem before it is copied to the final media.
- It is too late to run any chrooted commands, since the supporting filesystems are already unmounted.
- POST_POST_DEBOOTSTRAP_TWEAKS
- }
- on_chroot()
- {
- if [ "$SETFCAP" != "1" ]; then
- export CAPSH_ARG="--drop=cap_setfcap"
- fi
- capsh $CAPSH_ARG "--chroot=${ROOTFS_DIR}/" -- -e "$@"
- }
- export -f on_chroot
- # shellcheck disable=SC2119
- run_sub_stage()
- {
- log "Begin ${SUB_STAGE_DIR}"
- #pushd "${SUB_STAGE_DIR}" > /dev/null
- cd ${SUB_STAGE_DIR}
- for i in {00..99}; do
- if [ -f "${SUB_STAGE_DIR}/${i}-debconf" ]; then
- display_alert "Begin ${SUB_STAGE_DIR}/${i}-debconf" "" "info"
- on_chroot << EOF
- debconf-set-selections <<SELEOF
- $(cat "${i}-debconf")
- SELEOF
- EOF
- display_alert "End ${SUB_STAGE_DIR}/${i}-debconf" "" "info"
- fi
- if [ -f "${SUB_STAGE_DIR}/${i}-packages-nr" ]; then
- display_alert "Begin ${SUB_STAGE_DIR}/${i}-packages-nr" "" "info"
- PACKAGES="$(sed -f "${EXTER}/packages/raspi/scripts/remove-comments.sed" < "${SUB_STAGE_DIR}/${i}-packages-nr")"
- if [ -n "$PACKAGES" ]; then
- on_chroot << EOF
- apt-get -o Acquire::Retries=3 install --no-install-recommends -y $PACKAGES
- EOF
- fi
- display_alert "End ${SUB_STAGE_DIR}/${i}-packages-nr" "" "info"
- fi
- if [ -f "${SUB_STAGE_DIR}/${i}-packages" ]; then
- display_alert "Begin ${SUB_STAGE_DIR}/${i}-packages" "" "info"
- PACKAGES="$(sed -f "${EXTER}/packages/raspi/scripts/remove-comments.sed" < "${SUB_STAGE_DIR}/${i}-packages")"
- if [ -n "$PACKAGES" ]; then
- on_chroot << EOF
- apt-get -o Acquire::Retries=3 install -y $PACKAGES
- EOF
- fi
- display_alert "End ${SUB_STAGE_DIR}/${i}-packages" "" "info"
- fi
- # if [ -d "${SUB_STAGE_DIR}/${i}-patches" ]; then
- # log "Begin ${SUB_STAGE_DIR}/${i}-patches"
- # pushd "${STAGE_WORK_DIR}" > /dev/null
- # #cd ${STAGE_WORK_DIR}
- #
- # QUILT_PATCHES="${SUB_STAGE_DIR}/${i}-patches"
- # SUB_STAGE_QUILT_PATCH_DIR="$(basename "$SUB_STAGE_DIR")-pc"
- # mkdir -p "$STAGE_WORK_DIR/$SUB_STAGE_QUILT_PATCH_DIR"
- # ln -snf "$STAGE_WORK_DIR/$SUB_STAGE_QUILT_PATCH_DIR" .pc
- # ln -snfv "${ROOTFS_DIR}" ${STAGE_WORK_DIR}/rootfs
- # quilt upgrade
- # if [ -e "${SUB_STAGE_DIR}/${i}-patches/EDIT" ]; then
- # echo "Dropping into bash to edit patches..."
- # bash
- # fi
- # RC=0
- # quilt push -a || RC=$?
- # case "$RC" in
- # 0|2)
- # ;;
- # *)
- # false
- # ;;
- # esac
- # #popd > /dev/null
- # cd -
- # log "End ${SUB_STAGE_DIR}/${i}-patches"
- # fi
- if [ -x ${i}-run.sh ]; then
- display_alert "Begin ${SUB_STAGE_DIR}/${i}-run.sh" "" "info"
- ./${i}-run.sh
- display_alert "End ${SUB_STAGE_DIR}/${i}-run.sh" "" "info"
- fi
- if [ -f ${i}-run-chroot.sh ]; then
- display_alert "Begin ${SUB_STAGE_DIR}/${i}-run-chroot.sh" "" "info"
- on_chroot < ${i}-run-chroot.sh
- display_alert "End ${SUB_STAGE_DIR}/${i}-run-chroot.sh" "" "info"
- fi
- done
- #popd > /dev/null
- log "End ${SUB_STAGE_DIR}"
- }
- run_stage(){
- rm -rf "${SRC}"/output/raspi
- [[ ! -d "${SRC}"/output/raspi ]] && mkdir -p "${SRC}"/output/raspi
- STAGE_WORK_DIR="${SRC}/output/raspi"
- if [ ! -f ${STAGE_DIR}/SKIP ]; then
- if [ -x ${STAGE_DIR}/prerun.sh ]; then
- display_alert "Begin ${STAGE_DIR}/prerun.sh" "" "info"
- source ${STAGE_DIR}/prerun.sh
- display_alert "End ${STAGE_DIR}/prerun.sh" "" "info"
- fi
- for SUB_STAGE_DIR in "${STAGE_DIR}"/*; do
- if [ -d "${SUB_STAGE_DIR}" ] && [ ! -f "${SUB_STAGE_DIR}/SKIP" ]; then
- run_sub_stage
- fi
- done
- fi
- }
- log ()
- {
- date +"[%T] $*"
- }
- install_opi_specific()
- {
- cd $SRC
- # install u-boot
- UBOOT_VER=$(dpkg --info "${DEB_STORAGE}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb" | grep Descr | awk '{print $(NF)}')
- install_deb_chroot "${DEB_STORAGE}/u-boot/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb"
- # install kernel
- VER=$(dpkg --info "${DEB_STORAGE}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb" | awk -F"-" '/Source:/{print $2}')
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb"
- if [[ -f ${DEB_STORAGE}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb ]]; then
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL/image/dtb}_${REVISION}_${ARCH}.deb"
- fi
- if [[ $INSTALL_HEADERS == yes ]]; then
- install_deb_chroot "${DEB_STORAGE}/${CHOSEN_KERNEL/image/headers}_${REVISION}_${ARCH}.deb"
- else
- cp "${DEB_STORAGE}/${CHOSEN_KERNEL/image/headers}_${REVISION}_${ARCH}.deb" "${SDCARD}"/opt/
- fi
- dpkg_install_deb_chroot "$EXTER/packages/raspi/orangepi/debs/raspi-config_20230214_all.deb"
- case ${BOARDFAMILY} in
- "rockchip-rk356x")
- rk35xx_gpu_vpu_tweaks
- esac
- [[ ! -d "${SDCARD}/lib/firmware" ]] && mkdir -p "${SDCARD}/lib/firmware"
- cp -rfa ${EXTER}/cache/sources/orangepi-firmware-git/* ${SDCARD}/lib/firmware/
- # NOTE: this needs to be executed before family_tweaks
- local bootscript_src=${BOOTSCRIPT%%:*}
- local bootscript_dst=${BOOTSCRIPT##*:}
- if [[ "${BOOTCONFIG}" != "none" ]]; then
- if [ -f "${USERPATCHES_PATH}/bootscripts/${bootscript_src}" ]; then
- cp "${USERPATCHES_PATH}/bootscripts/${bootscript_src}" "${SDCARD}/boot/${bootscript_dst}"
- else
- cp "${EXTER}/config/bootscripts/${bootscript_src}" "${SDCARD}/boot/${bootscript_dst}"
- fi
- fi
- if [[ -n $BOOTENV_FILE ]]; then
- if [[ -f $USERPATCHES_PATH/bootenv/$BOOTENV_FILE ]]; then
- cp "$USERPATCHES_PATH/bootenv/${BOOTENV_FILE}" "${SDCARD}"/boot/orangepiEnv.txt
- elif [[ -f $EXTER/config/bootenv/$BOOTENV_FILE ]]; then
- cp "${EXTER}/config/bootenv/${BOOTENV_FILE}" "${SDCARD}"/boot/orangepiEnv.txt
- fi
- fi
- [[ -n $OVERLAY_PREFIX && -f "${SDCARD}"/boot/orangepiEnv.txt && ($BRANCH =~ current|next || $BOARDFAMILY =~ "rockchip-rk3588"|"rockchip-rk356x") ]] && \
- echo "overlay_prefix=$OVERLAY_PREFIX" >> "${SDCARD}"/boot/orangepiEnv.txt
- [[ -n $DEFAULT_OVERLAYS && -f "${SDCARD}"/boot/orangepiEnv.txt && ($BRANCH =~ current|next || $BOARDFAMILY =~ "rockchip-rk3588"|"rockchip-rk356x") ]] && \
- echo "overlays=${DEFAULT_OVERLAYS//,/ }" >> "${SDCARD}"/boot/orangepiEnv.txt
- [[ -n $BOOT_FDT_FILE && -f "${SDCARD}"/boot/orangepiEnv.txt ]] && \
- echo "fdtfile=${BOOT_FDT_FILE}" >> "${SDCARD}/boot/orangepiEnv.txt"
- # install initial asound.state if defined
- mkdir -p "${SDCARD}"/var/lib/alsa/
- [[ -n $ASOUND_STATE ]] && cp "${EXTER}/packages/blobs/asound.state/${ASOUND_STATE}" "${SDCARD}"/var/lib/alsa/asound.state
- # create modules file
- local modules=MODULES_${BRANCH^^}
- if [[ -n "${!modules}" ]]; then
- tr ' ' '\n' <<< "${!modules}" > "${SDCARD}"/etc/modules
- elif [[ -n "${MODULES}" ]]; then
- tr ' ' '\n' <<< "${MODULES}" > "${SDCARD}"/etc/modules
- fi
- # create blacklist files
- local blacklist=MODULES_BLACKLIST_${BRANCH^^}
- if [[ -n "${!blacklist}" ]]; then
- tr ' ' '\n' <<< "${!blacklist}" | sed -e 's/^/blacklist /' > "${SDCARD}/etc/modprobe.d/blacklist-${BOARD}.conf"
- elif [[ -n "${MODULES_BLACKLIST}" ]]; then
- tr ' ' '\n' <<< "${MODULES_BLACKLIST}" | sed -e 's/^/blacklist /' > "${SDCARD}/etc/modprobe.d/blacklist-${BOARD}.conf"
- fi
- cat <<-EOF > "${SDCARD}"/etc/orangepi-release
- # PLEASE DO NOT EDIT THIS FILE
- BOARD=${BOARD}
- BOARD_NAME="$BOARD_NAME"
- BOARDFAMILY=${BOARDFAMILY}
- BUILD_REPOSITORY_URL=${BUILD_REPOSITORY_URL}
- BUILD_REPOSITORY_COMMIT=${BUILD_REPOSITORY_COMMIT}
- DISTRIBUTION_CODENAME=${RELEASE}
- DISTRIBUTION_STATUS=${DISTRIBUTION_STATUS}
- VERSION=${REVISION}
- LINUXFAMILY=${LINUXFAMILY}
- ARCH=${ARCHITECTURE}
- IMAGE_TYPE=$IMAGE_TYPE
- BOARD_TYPE=$BOARD_TYPE
- INITRD_ARCH=${INITRD_ARCH}
- KERNEL_IMAGE_TYPE=${KERNEL_IMAGE_TYPE}
- BRANCH=${BRANCH}
- EOF
- install -d "${SDCARD}/etc/initramfs/post-update.d/"
- install -m 755 "${EXTER}/packages/bsp/common/etc/initramfs/post-update.d/99-uboot" "${SDCARD}/etc/initramfs/post-update.d/"
- install -m 755 "${EXTER}/packages/raspi/orangepi/common/files/hciattach_opi" "${SDCARD}/usr/bin/"
- install -m 755 "${EXTER}/packages/raspi/orangepi/common/files/brcm_patchram_plus" "${SDCARD}/usr/bin/"
- install -d "${SDCARD}/usr/lib/orangepi/"
- install -m 755 "${EXTER}/packages/raspi/orangepi/common/files/orangepi-hardware-optimization" "${SDCARD}/usr/lib/orangepi/"
- install -m 755 "${EXTER}/packages/raspi/orangepi/common/files/orangepi-hardware-optimize.service" "${SDCARD}/usr/lib/systemd/system/"
- chroot "${SDCARD}" /bin/bash -c "systemctl --no-reload enable orangepi-hardware-optimize.service >/dev/null 2>&1"
- install_wiringop
- rm $SDCARD/root/*.deb >/dev/null 2>&1
- }
- install_raspi_specific()
- {
- export TARGET_HOSTNAME=${TARGET_HOSTNAME:-raspberrypi}
- export FIRST_USER_NAME=${FIRST_USER_NAME:-pi}
- export FIRST_USER_PASS
- export DISABLE_FIRST_BOOT_USER_RENAME=${DISABLE_FIRST_BOOT_USER_RENAME:-0}
- export WPA_ESSID
- export WPA_PASSWORD
- export WPA_COUNTRY
- export ENABLE_SSH="${ENABLE_SSH:-0}"
- export PUBKEY_ONLY_SSH="${PUBKEY_ONLY_SSH:-0}"
- export LOCALE_DEFAULT="${LOCALE_DEFAULT:-en_GB.UTF-8}"
- export KEYBOARD_KEYMAP="${KEYBOARD_KEYMAP:-gb}"
- export KEYBOARD_LAYOUT="${KEYBOARD_LAYOUT:-English (UK)}"
- export TIMEZONE_DEFAULT="${TIMEZONE_DEFAULT:-Europe/London}"
- export PUBKEY_SSH_FIRST_USER
- export APT_PROXY
- export STAGE
- export STAGE_DIR
- export STAGE_WORK_DIR
- export PREV_STAGE
- export PREV_STAGE_DIR
- export ROOTFS_DIR=${SDCARD}
- export PREV_ROOTFS_DIR
- export IMG_SUFFIX
- export NOOBS_NAME
- export NOOBS_DESCRIPTION
- export EXPORT_DIR
- export EXPORT_ROOTFS_DIR
- export QUILT_PATCHES
- export QUILT_NO_DIFF_INDEX=1
- export QUILT_NO_DIFF_TIMESTAMPS=1
- export QUILT_REFRESH_ARGS="-p ab"
- #check username is valid
- if [[ ! "$FIRST_USER_NAME" =~ ^[a-z][-a-z0-9_]*$ ]]; then
- echo "Invalid FIRST_USER_NAME: $FIRST_USER_NAME"
- exit 1
- fi
- if [[ "$DISABLE_FIRST_BOOT_USER_RENAME" == "1" ]] && [ -z "${FIRST_USER_PASS}" ]; then
- echo "To disable user rename on first boot, FIRST_USER_PASS needs to be set"
- echo "Not setting FIRST_USER_PASS makes your system vulnerable and open to cyberattacks"
- exit 1
- fi
- if [[ "$DISABLE_FIRST_BOOT_USER_RENAME" == "1" ]]; then
- echo "User rename on the first boot is disabled"
- echo "Be advised of the security risks linked to shipping a device with default username/password set."
- fi
- if [[ -n "${APT_PROXY}" ]] && ! curl --silent "${APT_PROXY}" >/dev/null ; then
- echo "Could not reach APT_PROXY server: ${APT_PROXY}"
- exit 1
- fi
- if [[ -n "${WPA_PASSWORD}" && ${#WPA_PASSWORD} -lt 8 || ${#WPA_PASSWORD} -gt 63 ]] ; then
- echo "WPA_PASSWORD" must be between 8 and 63 characters
- exit 1
- fi
- if [[ "${PUBKEY_ONLY_SSH}" = "1" && -z "${PUBKEY_SSH_FIRST_USER}" ]]; then
- echo "Must set 'PUBKEY_SSH_FIRST_USER' to a valid SSH public key if using PUBKEY_ONLY_SSH"
- exit 1
- fi
- RASPI_DIR="${EXTER}/packages/raspi"
- if [[ ${BUILD_DESKTOP} == "yes" ]]; then
- rm -r ${RASPI_DIR}/stage3/SKIP ${RASPI_DIR}/stage4/SKIP ${RASPI_DIR}/stage5/SKIP 2>/dev/null
- touch ${RASPI_DIR}/stage5/SKIP
- else
- rm -r ${RASPI_DIR}/stage1/SKIP ${RASPI_DIR}/stage2/SKIP 2>/dev/null
- touch ${RASPI_DIR}/stage3/SKIP ${RASPI_DIR}/stage4/SKIP ${RASPI_DIR}/stage5/SKIP
- export FIRST_USER_PASS="pi"
- fi
- STAGE_LIST=${RASPI_DIR}/stage*
- for STAGE_DIR in $STAGE_LIST; do
- STAGE_DIR=$(realpath "${STAGE_DIR}")
- run_stage
- done
- STAGE_DIR=${RASPI_DIR}/export-image
- run_stage
- rm -rf ${SDCARD}/boot/*
- rm -rf ${SDCARD}/lib/firmware
- rm -rf ${SDCARD}/lib/modules/*
- }
|