2014-11-26 12:33:58 +01:00
|
|
|
#!/bin/bash
|
2014-10-08 07:39:24 +02:00
|
|
|
|
|
|
|
### BEGIN INIT INFO
|
|
|
|
# Provides: firstrun
|
2014-10-12 20:39:42 +02:00
|
|
|
# Required-Start: $all
|
2014-10-08 07:39:24 +02:00
|
|
|
# Required-Stop:
|
2015-12-02 20:33:32 +01:00
|
|
|
# Should-Start: armhwinfo
|
2014-10-12 09:22:50 +02:00
|
|
|
# Default-Start: 2 3 4 5
|
|
|
|
# Default-Stop: 0 1 6
|
2016-03-17 20:16:26 +01:00
|
|
|
# Short-Description: PLEASE BE PATIENT AND DO NOT INTERRUPT THE FIRST REBOOT
|
2014-10-08 07:39:24 +02:00
|
|
|
# Description: Something needs to be done when is
|
|
|
|
# starting at first time.
|
2014-10-12 09:22:50 +02:00
|
|
|
# regenerate ssh host key
|
2014-10-08 07:39:24 +02:00
|
|
|
### END INIT INFO
|
2016-01-13 12:10:21 +01:00
|
|
|
#
|
|
|
|
# Create this file to speed up boot process
|
|
|
|
#
|
2016-02-23 13:10:14 +01:00
|
|
|
|
2016-02-29 16:13:15 +01:00
|
|
|
# Immediately exit if not called by init system
|
2016-02-23 13:10:14 +01:00
|
|
|
if [ "X$1" != "Xstart" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
2016-06-08 22:04:12 +02:00
|
|
|
Log=/var/log/armhwinfo.log
|
2016-02-23 13:10:14 +01:00
|
|
|
|
|
|
|
# create helper script to set swap settings
|
2016-01-13 12:10:21 +01:00
|
|
|
cat > /tmp/create_swap.sh <<EOT
|
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# create swap and adds it into fstab
|
|
|
|
#
|
2016-02-19 14:15:09 +01:00
|
|
|
# SSH Keys creation
|
|
|
|
rm -f /etc/ssh/ssh_host*
|
|
|
|
dpkg-reconfigure openssh-server >/dev/null 2>&1
|
2016-06-08 22:04:12 +02:00
|
|
|
echo -e "\n### [firstrun] Recreated SSH keys" >>${Log}
|
2016-02-22 12:10:38 +01:00
|
|
|
MEMTOTAL=$(( $(awk -F" " '/^MemTotal/ {print $2}' </proc/meminfo) / 1024 ))
|
2016-01-30 19:31:48 +01:00
|
|
|
FREESIZE=\$(df -hm / | awk '/\// {print \$(NF-2)}')
|
2016-06-08 22:04:12 +02:00
|
|
|
SWAPFILE=/var/swap
|
|
|
|
if [[ ! -f "$SWAPFILE" && "\$FREESIZE" -gt "132" ]]; then
|
|
|
|
fallocate -l 128M $SWAPFILE >/dev/null 2>&1
|
|
|
|
if [ $? -eq 1 ]; then dd if=/dev/zero of=$SWAPFILE bs=1M count=128 status=noxfer >/dev/null 2>&1; fi
|
|
|
|
chown root:root $SWAPFILE
|
|
|
|
chmod 0600 $SWAPFILE
|
|
|
|
mkswap $SWAPFILE >/dev/null 2>&1
|
|
|
|
swapon $SWAPFILE >/dev/null 2>&1
|
|
|
|
if ! grep -q swap /etc/fstab; then echo "$SWAPFILE none swap sw 0 0" >> /etc/fstab; fi
|
|
|
|
if ! grep -q swap /etc/sysctl.conf; then echo "vm.swappiness=0" >> /etc/sysctl.conf; fi
|
|
|
|
echo -e "\n### [firstrun] Created 128MB emergency swap as $SWAPFILE" >>${Log}
|
2016-01-13 12:10:21 +01:00
|
|
|
fi
|
|
|
|
# RAMLOG
|
|
|
|
if [[ "$(apt-cache policy ramlog | grep Installed)" != "" ]]; then
|
|
|
|
service ramlog enable
|
|
|
|
# if we have 1G ram reduce RAMLOG size
|
2016-02-22 12:10:38 +01:00
|
|
|
if [[ "\$MEMTOTAL" -lt "1100" ]]; then
|
2016-01-13 12:10:21 +01:00
|
|
|
if [ -f "/etc/default/ramlog" ]; then
|
|
|
|
sed -e 's/TMPFS_RAMFS_SIZE=512m/TMPFS_RAMFS_SIZE=256m/g' -i /etc/default/ramlog
|
|
|
|
fi
|
2016-02-22 12:10:38 +01:00
|
|
|
elif [[ "\$MEMTOTAL" -lt "600" ]]; then
|
|
|
|
if [ -f "/etc/default/ramlog" ]; then
|
|
|
|
sed -e 's/TMPFS_RAMFS_SIZE=512m/TMPFS_RAMFS_SIZE=192m/g' -i /etc/default/ramlog
|
|
|
|
fi
|
2016-01-13 12:10:21 +01:00
|
|
|
fi
|
|
|
|
fi
|
2016-03-13 10:34:25 +02:00
|
|
|
while [ -f /tmp/firstrun_running ]; do sleep 1; done
|
2016-01-13 12:10:21 +01:00
|
|
|
if [ -f "/var/run/reboot" ]; then reboot; fi
|
|
|
|
rm -f /tmp/create_swap.sh
|
|
|
|
EOT
|
|
|
|
chmod +x /tmp/create_swap.sh
|
|
|
|
|
2016-05-31 16:07:07 +02:00
|
|
|
collect_information() {
|
2016-02-23 13:10:14 +01:00
|
|
|
# get some info about the board
|
|
|
|
DISTRIBUTION=$(lsb_release -cs)
|
|
|
|
HARDWARE=$(awk '/Hardware/ {print $3}' </proc/cpuinfo)
|
2016-02-25 18:23:24 +01:00
|
|
|
# Mainline kernel fix
|
2016-06-08 12:37:24 +02:00
|
|
|
[ "X${HARDWARE}" = "XAllwinner" ] && HARDWARE=$(awk '/Hardware/ {print $4}' </proc/cpuinfo)
|
2016-03-26 18:27:37 +01:00
|
|
|
case ${DISTRIBUTION} in
|
|
|
|
wheezy)
|
|
|
|
root_device=$(mountpoint -d /)
|
|
|
|
for file in /dev/* ; do
|
|
|
|
CURRENT_DEVICE=$(printf "%d:%d" $(stat --printf="0x%t 0x%T" $file))
|
|
|
|
if [ $CURRENT_DEVICE = $root_device ]; then
|
|
|
|
root_partition=$file
|
|
|
|
break;
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
rootfstype=$(blkid -s TYPE -o value $root_partition)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
ROOTFS=$(findmnt / | awk -F" " '/\/dev\// {print $2"\t"$3}')
|
|
|
|
set ${ROOTFS}
|
|
|
|
root_partition=$1
|
|
|
|
rootfstype=$2
|
|
|
|
;;
|
|
|
|
esac
|
2016-05-31 16:07:07 +02:00
|
|
|
} # collect_information
|
2014-10-08 07:39:24 +02:00
|
|
|
|
2016-02-22 12:10:38 +01:00
|
|
|
display_alert() {
|
2016-03-26 18:27:37 +01:00
|
|
|
if [ "${DISTRIBUTION}" == "wheezy" ]; then
|
|
|
|
echo -e "[\e[0;32m ok \x1B[0m] ${1}" > /dev/tty1
|
2016-03-28 09:24:53 +02:00
|
|
|
elif [ "${DISTRIBUTION}" == "jessie" ]; then
|
|
|
|
echo -e "[\e[0;32m OK \x1B[0m] ${1}" > /dev/tty1
|
2016-02-22 12:10:38 +01:00
|
|
|
else
|
2016-03-26 18:27:37 +01:00
|
|
|
echo -e " * ${1}" > /dev/tty1
|
2016-02-22 12:10:38 +01:00
|
|
|
fi
|
2016-01-13 12:10:21 +01:00
|
|
|
}
|
|
|
|
|
2016-05-31 16:07:07 +02:00
|
|
|
adjust_sunxi_settings() {
|
2016-06-06 17:08:56 +02:00
|
|
|
# set some mac address for wifi
|
2016-06-08 22:04:12 +02:00
|
|
|
[[ "$(lsmod | grep 8189fs)" != "" ]] && \
|
|
|
|
(MACADDR=$(printf '43:29:B1:%02X:%02X:%02X\n' $[RANDOM%256] $[RANDOM%256] $[RANDOM%256]) ; \
|
2016-06-08 22:40:33 +02:00
|
|
|
echo "options 8189fs rtw_initmac=${MACADDR}" > /etc/modprobe.d/8189fs.conf ; \
|
2016-06-08 22:04:12 +02:00
|
|
|
echo -e "\n### [firstrun] Use MAC address ${MACADDR} for Wi-Fi from now" >>${Log})
|
2016-06-06 17:08:56 +02:00
|
|
|
|
|
|
|
# set some mac address for BT
|
|
|
|
[[ "$(lsmod | grep bcmdhd)" != "" ]] && \
|
|
|
|
(MACADDR=$(printf '43:29:B1:%02X:%02X:%02X\n' $[RANDOM%256] $[RANDOM%256] $[RANDOM%256]) ; \
|
2016-06-08 22:04:12 +02:00
|
|
|
sed -i "s/^MAC_ADDR=.*/MAC_ADDR=${MACADDR}/" /etc/default/brcm40183 \
|
|
|
|
echo -e "\n### [firstrun] Use MAC address ${MACADDR} for Bluetooth from now" >>${Log})
|
2016-05-31 18:19:22 +02:00
|
|
|
|
2016-03-23 13:33:19 +01:00
|
|
|
# trigger red or blue LED as user feedback
|
2016-05-31 10:14:39 +02:00
|
|
|
echo heartbeat >/sys/class/leds/*red*/trigger 2>/dev/null || echo heartbeat >/sys/class/leds/*blue*/trigger 2>/dev/null
|
2016-03-07 16:41:03 +01:00
|
|
|
[ -f /etc/wicd/wired-settings.conf ] && \
|
2016-05-31 16:07:07 +02:00
|
|
|
read HOSTNAME </etc/hostname
|
|
|
|
sed -i "s/^dhcphostname =.*/dhcphostname = ${HOSTNAME}/" /etc/wicd/wired-settings.conf && \
|
2016-06-08 22:04:12 +02:00
|
|
|
sed -i "s/wpa_driver =.*/wpa_driver = none/" /etc/wicd/manager-settings.conf \
|
|
|
|
echo -e "\n### [firstrun] Use ${HOSTNAME} for wicd settings" >>${Log}
|
2016-05-31 16:07:07 +02:00
|
|
|
} # adjust_sunxi_settings
|
2016-02-22 12:10:38 +01:00
|
|
|
|
|
|
|
do_expand_rootfs() {
|
2016-03-26 18:27:37 +01:00
|
|
|
# get device node for boot media
|
2016-04-14 18:45:11 +02:00
|
|
|
DEVICE="/dev/"$(lsblk -idn -o NAME | grep -w mmcblk0)
|
2016-03-26 18:27:37 +01:00
|
|
|
if [ "${DEVICE}" = "/dev/" ]; then return ; fi
|
|
|
|
QUOTED_DEVICE=$(echo "${DEVICE}" | sed 's:/:\\\/:g')
|
|
|
|
|
|
|
|
# get count of partitions and their boundaries
|
2016-04-14 18:45:11 +02:00
|
|
|
PARTITIONS=$(( $(grep -c ${DEVICE##*/}p /proc/partitions) ))
|
2016-03-26 18:27:37 +01:00
|
|
|
PARTSTART=$(parted ${DEVICE} unit s print -sm | tail -1 | cut -d: -f2 | sed 's/s//') # start of first partition
|
|
|
|
PARTEND=$(parted ${DEVICE} unit s print -sm | head -3 | tail -1 | cut -d: -f3 | sed 's/s//') # end of first partition
|
|
|
|
STARTFROM=$(( ${PARTEND} + 1 ))
|
|
|
|
[[ ${PARTITIONS} == 1 ]] && STARTFROM=${PARTSTART}
|
|
|
|
|
|
|
|
# check whether a resizing rule is defined. We will take this value if it's not too low. In
|
|
|
|
# this case the value will be ignored and resizing to the whole card size happens.
|
|
|
|
if [ -f "/root/.rootfs_resize" ]; then
|
|
|
|
read RESIZE_VALUE <"/root/.rootfs_resize"
|
2016-06-08 22:04:12 +02:00
|
|
|
ResizeLog="Resize rule ${RESIZE_VALUE} defined for ${root_partition}"
|
2016-03-26 18:27:37 +01:00
|
|
|
case ${RESIZE_VALUE} in
|
|
|
|
*%)
|
|
|
|
# percentage value, we try to use 16MiB to align partitions since this is
|
|
|
|
# the erase block size of more recent SD cards (512 byte sectors, so we use 32
|
|
|
|
# as divider and substract 1)
|
|
|
|
PERCENTAGE=$(echo ${RESIZE_VALUE} | tr -c -d '[:digit:]')
|
|
|
|
LASTSECTOR=$(( 32 * $(parted ${DEVICE} unit s print -sm | awk -F":" "/^${QUOTED_DEVICE}/ {printf (\"%0d\", ( \$2 * ${PERCENTAGE} / 3200))}") -1 ))
|
|
|
|
if [ ${LASTSECTOR} -lt ${PARTEND} ]; then unset LASTSECTOR ; fi
|
|
|
|
;;
|
|
|
|
*s)
|
|
|
|
# sector value, we use it directly
|
|
|
|
LASTSECTOR=$(echo ${RESIZE_VALUE} | tr -c -d '[:digit:]')
|
|
|
|
if [ ${LASTSECTOR} -lt ${PARTEND} ]; then unset LASTSECTOR ; fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
else
|
2016-06-06 17:08:56 +02:00
|
|
|
# Unattended mode. We run a q&d benchmark to be able to identify cards way too slow easily
|
|
|
|
cd /root
|
|
|
|
echo -e "\n### quick iozone test:\c" >>/var/log/armhwinfo.log
|
|
|
|
iozone -e -I -a -s 1M -r 4k -i 0 -i 1 -i 2 | grep '^ 1024' | sed 's/ 1024 //' >>/var/log/armhwinfo.log
|
|
|
|
|
2016-03-26 18:27:37 +01:00
|
|
|
# check device capacity. If 4GB or below do not use whole card but leave a 5% spare area
|
|
|
|
# to help older cards with wear leveling and garbage collection. In case this reduced card
|
|
|
|
# capacity is less than the actual image capacity this is a clear sign that someone wants
|
|
|
|
# to use Armbian on a card of inappropriate size so he gets what he deserves (at least he
|
|
|
|
# should know what he's doing)
|
|
|
|
CAPACITY=$(parted ${DEVICE} unit s print -sm | awk -F":" "/^${QUOTED_DEVICE}/ {printf (\"%0d\", \$2 / ( 1024 / \$4 ))}")
|
|
|
|
if [ ${CAPACITY} -lt 4000000 ]; then
|
|
|
|
SPAREAREA=$(( ${CAPACITY} / 20000 ))
|
|
|
|
LASTSECTOR=$(parted ${DEVICE} unit s print -sm | awk -F":" "/^${QUOTED_DEVICE}/ {print \$2 - (${SPAREAREA} * 1024 * ( 1024 / \$4 ))}")
|
2016-06-08 22:04:12 +02:00
|
|
|
if [ ${LASTSECTOR} -lt ${PARTEND} ]; then
|
|
|
|
unset LASTSECTOR
|
|
|
|
else
|
|
|
|
ResizeLog="4GB media so leaving 200MB spare area on ${root_partition}"
|
|
|
|
fi
|
2016-06-06 17:08:56 +02:00
|
|
|
elif [ ${CAPACITY} -lt 8000000 ]; then
|
|
|
|
# Leave 2 percent unpartitioned
|
|
|
|
LASTSECTOR=$(( 32 * $(parted ${DEVICE} unit s print -sm | awk -F":" "/^${QUOTED_DEVICE}/ {printf (\"%0d\", ( \$2 * 98 / 3200))}") -1 ))
|
2016-06-08 22:04:12 +02:00
|
|
|
if [ ${LASTSECTOR} -lt ${PARTEND} ]; then
|
|
|
|
unset LASTSECTOR
|
|
|
|
else
|
|
|
|
ResizeLog="8GB media so leaving 2 percent spare area on ${root_partition}"
|
|
|
|
fi
|
2016-06-06 17:08:56 +02:00
|
|
|
else
|
|
|
|
# Leave 1 percent unpartitioned
|
2016-06-08 22:04:12 +02:00
|
|
|
LASTSECTOR=$(( 32 * $(parted ${DEVICE} unit s print -sm | awk -F":" "/^${QUOTED_DEVICE}/ {printf (\"%0d\", ( \$2 * 99 / 3200))}") -1 ))
|
|
|
|
if [ ${LASTSECTOR} -lt ${PARTEND} ]; then
|
|
|
|
unset LASTSECTOR
|
|
|
|
else
|
|
|
|
ResizeLog="Leaving 1 percent spare area on ${root_partition}"
|
|
|
|
fi
|
2016-03-26 18:27:37 +01:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Start resizing
|
2016-06-08 22:40:33 +02:00
|
|
|
echo -e "\n### [firstrun] ${ResizeLog}. Start resizing Partition now:\n" >>${Log}
|
2016-06-08 22:04:12 +02:00
|
|
|
cat /proc/partitions >>${Log}
|
2016-06-08 23:30:58 +02:00
|
|
|
echo -e "\nExecuting fdisk, fsck and partprobe:\n" >>${Log}
|
|
|
|
if [ "X${DISTRIBUTION}" = "Xxenial" -a "X${PARTITIONS}" = "X1" ]; then
|
|
|
|
((echo d; echo n; echo p; echo ; echo $STARTFROM; echo ${LASTSECTOR} ; echo w;) | fdisk ${DEVICE}) >>${Log} 2>&1 || true
|
|
|
|
else
|
|
|
|
((echo d; echo $PARTITIONS; echo n; echo p; echo ; echo $STARTFROM; echo ${LASTSECTOR} ; echo w;) | fdisk ${DEVICE}) >>${Log} 2>&1 || true
|
|
|
|
fi
|
|
|
|
echo -e "\nNew partition table:\n" >>${Log}
|
2016-02-22 12:10:38 +01:00
|
|
|
s=0
|
2016-06-08 23:30:58 +02:00
|
|
|
fsck -f $root_partition >>${Log} ll 2>&1 || true
|
|
|
|
partprobe ${DEVICE} >>${Log} ll 2>&1 || s=$?
|
|
|
|
echo -e "\nNew partition table:\n" >>${Log}
|
2016-06-08 22:04:12 +02:00
|
|
|
cat /proc/partitions >>${Log}
|
|
|
|
echo -e "\nNow executing resize2fs to enlarge ${root_partition} to the maximum\n:" >>${Log}
|
|
|
|
resize2fs $root_partition >>${Log} 2>&1 || true
|
2016-03-26 18:27:37 +01:00
|
|
|
|
|
|
|
# check whether reboot is necessary for resize2fs to take effect
|
2016-02-22 12:10:38 +01:00
|
|
|
FREESIZE=$(df -hm / | awk '/\// {print $(NF-2)}')
|
|
|
|
if [[ "$DISTRIBUTION" == "wheezy" || "$s" != "0" || "$FREESIZE" -lt "152" ]]; then
|
|
|
|
touch /var/run/reboot
|
|
|
|
display_alert "Automatic reboot is needed. Please wait"
|
2016-06-08 22:04:12 +02:00
|
|
|
update-rc.d resize2fs defaults >/dev/null 2>&1
|
2016-06-08 22:40:33 +02:00
|
|
|
echo -e "\n### [firstrun] Automated reboot needed to let /etc/init.d/resize2fs do the job\n" >>${Log}
|
2016-02-22 12:10:38 +01:00
|
|
|
fi
|
2016-02-23 13:10:14 +01:00
|
|
|
return 0
|
2016-05-31 16:07:07 +02:00
|
|
|
} # do_expand_rootfs
|
2014-10-08 07:39:24 +02:00
|
|
|
|
2016-02-29 16:13:15 +01:00
|
|
|
check_prerequisits() {
|
|
|
|
for needed_tool in fdisk parted partprobe resize2fs ; do
|
|
|
|
which ${needed_tool} >/dev/null 2>&1 || exit 1
|
|
|
|
done
|
|
|
|
} # check_prerequisits
|
|
|
|
|
2016-02-23 13:10:14 +01:00
|
|
|
main() {
|
2016-02-29 16:13:15 +01:00
|
|
|
check_prerequisits
|
2016-05-31 16:07:07 +02:00
|
|
|
collect_information
|
2016-02-23 13:10:14 +01:00
|
|
|
|
|
|
|
if [[ "$rootfstype" == "ext4" && ! -f "/root/.no_rootfs_resize" ]]; then
|
2016-03-28 09:24:53 +02:00
|
|
|
display_alert "Resizing root filesystem."
|
2016-02-23 13:10:14 +01:00
|
|
|
do_expand_rootfs
|
|
|
|
fi
|
|
|
|
|
2016-03-28 09:24:53 +02:00
|
|
|
display_alert "Starting 128Mb emergency swap area creation."
|
|
|
|
display_alert "Starting SSH keys recreation."
|
|
|
|
|
2016-03-13 10:34:25 +02:00
|
|
|
touch /tmp/firstrun_running
|
2016-02-23 13:10:14 +01:00
|
|
|
/tmp/create_swap.sh &
|
|
|
|
|
2016-05-31 10:14:39 +02:00
|
|
|
if [ "X${HARDWARE}" = "Xsun8i" -o "X${HARDWARE}" = "Xsun7i" ]; then
|
2016-05-31 16:07:07 +02:00
|
|
|
adjust_sunxi_settings
|
2016-05-31 10:14:39 +02:00
|
|
|
fi
|
2016-02-23 13:10:14 +01:00
|
|
|
|
2016-05-05 16:49:46 +03:00
|
|
|
# pine64 temp workaround
|
2016-06-08 12:37:24 +02:00
|
|
|
if [ "X${HARDWARE}" = "Xsun50iw1p1" ] && [ -z "$(grep ethaddr /boot/uEnv.txt)" ] && [ -f "/sys/class/net/eth0/address" ]; then
|
2016-05-05 16:49:46 +03:00
|
|
|
echo "ethaddr=$(cat /sys/class/net/eth0/address)" >> /boot/uEnv.txt
|
|
|
|
fi
|
|
|
|
|
2016-02-23 13:10:14 +01:00
|
|
|
update-rc.d -f firstrun remove >/dev/null 2>&1
|
|
|
|
sed -i 's/allow-hotplug\ eth0/auto eth0/' /etc/network/interfaces.default
|
2016-03-13 10:34:25 +02:00
|
|
|
rm /tmp/firstrun_running
|
2016-02-23 13:10:14 +01:00
|
|
|
} # main
|
2014-10-08 07:39:24 +02:00
|
|
|
|
2016-06-08 22:40:33 +02:00
|
|
|
main
|