diff --git a/mk_mmc.sh b/mk_mmc.sh index 0f2f96c..07eddf2 100755 --- a/mk_mmc.sh +++ b/mk_mmc.sh @@ -48,6 +48,9 @@ DISTARCH="${DIST}-${ARCH}" BOOT_LABEL=boot PARTITION_PREFIX="" +MAVERICK_NETIMAGE="current" +MAVERICK_MD5SUM="12c0f04da6b8fb118939489f237e4c86" + NATTY_NETIMAGE="current" NATTY_MD5SUM="a88f348be5c94873be0d67a9ce8e485e" @@ -68,12 +71,10 @@ DIR=$PWD TEMPDIR=$(mktemp -d) function check_root { - if [[ $UID -ne 0 ]]; then echo "$0 must be run as sudo user or root" exit fi - } function find_issue { @@ -93,7 +94,6 @@ unset PARTED_ALIGN if parted -v | grep parted | grep 2.[1-3] >/dev/null ; then PARTED_ALIGN="--align cylinder" fi - } function detect_software { @@ -252,6 +252,13 @@ function dl_netinstall_image { unset UBOOTWRAPPER case "$DISTARCH" in + maverick-armel) + TEST_MD5SUM=$MAVERICK_MD5SUM + NETIMAGE=$MAVERICK_NETIMAGE + HTTP_IMAGE="http://ports.ubuntu.com/ubuntu-ports/dists" + BASE_IMAGE="versatile" + NETINSTALL="initrd.gz" + ;; natty-armel) TEST_MD5SUM=$NATTY_MD5SUM NETIMAGE=$NATTY_NETIMAGE @@ -318,6 +325,24 @@ function dl_firmware { fi case "$DIST" in + maverick) + rm -f ${TEMPDIR}/dl/index.html || true + wget --directory-prefix=${TEMPDIR}/dl/ http://ports.ubuntu.com/pool/main/l/linux-firmware/ + MAVERICK_FW=$(cat ${TEMPDIR}/dl/index.html | grep linux-firmware | grep _all.deb | tail -1 | awk -F"\"" '{print $8}') + wget -c --directory-prefix=${DIR}/dl/${DISTARCH} http://ports.ubuntu.com/pool/main/l/linux-firmware/${MAVERICK_FW} + MAVERICK_FW=${MAVERICK_FW##*/} + + rm -f ${TEMPDIR}/dl/index.html || true + wget --directory-prefix=${TEMPDIR}/dl/ http://ports.ubuntu.com/pool/multiverse/l/linux-firmware-nonfree/ + MAVERICK_NONF_FW=$(cat ${TEMPDIR}/dl/index.html | grep linux-firmware-nonfree | grep _all.deb | tail -1 | awk -F"\"" '{print $8}') + wget -c --directory-prefix=${DIR}/dl/${DISTARCH} http://ports.ubuntu.com/pool/multiverse/l/linux-firmware-nonfree/${MAVERICK_NONF_FW} + MAVERICK_NONF_FW=${MAVERICK_NONF_FW##*/} + + #V3.1 needs 1.9.4 for ar9170 + #wget -c --directory-prefix=${DIR}/dl/${DISTARCH} http://www.kernel.org/pub/linux/kernel/people/chr/carl9170/fw/1.9.4/carl9170-1.fw + wget -c --directory-prefix=${DIR}/dl/${DISTARCH} http://rcn-ee.net/firmware/carl9170/1.9.4/carl9170-1.fw + AR9170_FW="carl9170-1.fw" + ;; natty) rm -f ${TEMPDIR}/dl/index.html || true wget --directory-prefix=${TEMPDIR}/dl/ http://ports.ubuntu.com/pool/main/l/linux-firmware/ @@ -765,6 +790,12 @@ function extract_base_initrd { function initrd_add_firmware { echo "NetInstall: Adding Firmware" case "$DIST" in + maverick) + dpkg -x ${DIR}/dl/${DISTARCH}/${MAVERICK_FW} ${TEMPDIR}/initrd-tree + dpkg -x ${DIR}/dl/${DISTARCH}/${MAVERICK_NONF_FW} ${TEMPDIR}/initrd-tree + cp -v ${DIR}/dl/${DISTARCH}/${AR9170_FW} ${TEMPDIR}/initrd-tree/lib/firmware/ + cp -vr ${DIR}/dl/linux-firmware/ti-connectivity ${TEMPDIR}/initrd-tree/lib/firmware/ + ;; natty) dpkg -x ${DIR}/dl/${DISTARCH}/${NATTY_FW} ${TEMPDIR}/initrd-tree dpkg -x ${DIR}/dl/${DISTARCH}/${NATTY_NONF_FW} ${TEMPDIR}/initrd-tree @@ -862,6 +893,9 @@ function initrd_preseed_settings { echo "NetInstall: Adding Distro Tweaks and Preseed Configuration" cd ${TEMPDIR}/initrd-tree/ case "$DIST" in + maverick) + patch -p1 < ${DIR}/scripts/ubuntu-tweaks.diff + ;; natty) patch -p1 < ${DIR}/scripts/ubuntu-tweaks.diff ;; @@ -885,6 +919,13 @@ function initrd_preseed_settings { cd ${DIR}/ case "$DIST" in + maverick) + cp -v ${DIR}/scripts/flash-kernel.conf ${TEMPDIR}/initrd-tree/etc/flash-kernel.conf + cp -v ${DIR}/scripts/serial.conf ${TEMPDIR}/initrd-tree/etc/${SERIAL}.conf + chmod a+x ${TEMPDIR}/initrd-tree/usr/lib/finish-install.d/08rcn-omap + cp -v ${DIR}/scripts/${DIST}-preseed.cfg ${TEMPDIR}/initrd-tree/preseed.cfg + cp -v ${DIR}/scripts/ubuntu-finish.sh ${TEMPDIR}/initrd-tree/etc/finish-install.sh + ;; natty) cp -v ${DIR}/scripts/flash-kernel.conf ${TEMPDIR}/initrd-tree/etc/flash-kernel.conf cp -v ${DIR}/scripts/serial.conf ${TEMPDIR}/initrd-tree/etc/${SERIAL}.conf @@ -1159,24 +1200,26 @@ cat > ${TEMPDIR}/update_boot_files.sh </dev/null 2>&1;then +if [ ! -f /boot/initrd.img-\$(uname -r) ] ; then sudo update-initramfs -c -k \$(uname -r) else sudo update-initramfs -u -k \$(uname -r) fi -if ls /boot/initrd.img-\$(uname -r) >/dev/null 2>&1;then +if [ -f /boot/initrd.img-\$(uname -r) ] ; then sudo mkimage -A arm -O linux -T ramdisk -C none -a 0 -e 0 -n initramfs -d /boot/initrd.img-\$(uname -r) /boot/uboot/uInitrd fi -if ls /boot/uboot/boot.cmd >/dev/null 2>&1;then +if [ -f /boot/uboot/boot.cmd ] ; then sudo mkimage -A arm -O linux -T script -C none -a 0 -e 0 -n "Boot Script" -d /boot/uboot/boot.cmd /boot/uboot/boot.scr +sudo cp /boot/uboot/boot.scr /boot/uboot/boot.ini fi -if ls /boot/uboot/serial.cmd >/dev/null 2>&1;then + +if [ -f /boot/uboot/serial.cmd ] ; then sudo mkimage -A arm -O linux -T script -C none -a 0 -e 0 -n "Boot Script" -d /boot/uboot/serial.cmd /boot/uboot/boot.scr fi -sudo cp /boot/uboot/boot.scr /boot/uboot/boot.ini -if ls /boot/uboot/user.cmd >/dev/null 2>&1;then + +if [ -f /boot/uboot/user.cmd ] ; then sudo mkimage -A arm -O linux -T script -C none -a 0 -e 0 -n "Reset Nand" -d /boot/uboot/user.cmd /boot/uboot/user.scr fi @@ -1186,7 +1229,7 @@ cat > ${TEMPDIR}/minimal_xfce.sh < Ubuntu - natty - oneiric - precise-armel (alpha) - precise-armhf (alpha) + maverick (10.10) + natty (11.04) + oneiric (11.10) + precise-armel (12.04) + precise-armhf (12.04) --addon pico diff --git a/scripts/maverick-preseed.cfg b/scripts/maverick-preseed.cfg new file mode 100644 index 0000000..1d5293f --- /dev/null +++ b/scripts/maverick-preseed.cfg @@ -0,0 +1,36 @@ +### Apt setup +# You can choose to install non-free and contrib software. +#d-i apt-setup/non-free boolean true +#d-i apt-setup/contrib boolean true + +# If you select ftp, the mirror/country string does not need to be set. +#d-i mirror/protocol string ftp +d-i mirror/country string manual +d-i mirror/http/hostname string ports.ubuntu.com +d-i mirror/http/directory string /ubuntu-ports + +# Individual additional packages to install +d-i pkgsel/include string u-boot-tools pastebinit initramfs-tools wget linux-firmware linux-firmware-nonfree ntpdate bash + +# Whether to upgrade packages after debootstrap. +# Allowed values: none, safe-upgrade, full-upgrade +d-i pkgsel/upgrade select safe-upgrade + +# Controls whether to use NTP to set the clock during the install +d-i clock-setup/ntp boolean true + +# During installations from serial console, the regular virtual consoles +# (VT1-VT6) are normally disabled in /etc/inittab. Uncomment the next +# line to prevent this. +d-i finish-install/keep-consoles boolean true + +# Avoid that last message about the install being complete. +d-i finish-install/reboot_in_progress note + +# This command is run just before the install finishes, but when there is +# still a usable /target directory. You can chroot to /target and use it +# directly, or use the apt-install and in-target commands to easily install +# packages and run commands in the target system. +d-i preseed/late_command \ +string apt-install parted; in-target /sbin/parted /dev/mmcblk0 set 1 boot on ; +