summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xscripts/install-rb532.sh102
-rw-r--r--target/config/Config.in1
-rw-r--r--target/mips/Makefile5
-rw-r--r--target/mips/kernel/mikrotik-rb5328
-rw-r--r--target/mips/sys-available/mikrotik-rb5321
5 files changed, 45 insertions, 72 deletions
diff --git a/scripts/install-rb532.sh b/scripts/install-rb532.sh
index 569360942..2e9e45e1f 100755
--- a/scripts/install-rb532.sh
+++ b/scripts/install-rb532.sh
@@ -7,48 +7,17 @@ if [ $(id -u) -ne 0 ];then
exit 1
fi
-printf "Checking if sfdisk is installed"
-sfdisk=$(which sfdisk)
-
-if [ ! -z $sfdisk -a -x $sfdisk ];then
- printf "...okay\n"
-else
- printf "...failed\n"
- exit 1
-fi
-
-printf "Checking if parted is installed"
-parted=$(which parted)
-
-if [ ! -z $parted -a -x $parted ];then
- printf "...okay\n"
-else
- printf "...failed\n"
- exit 1
-fi
-
-printf "Checking if mke2fs is installed"
-mke2fs=$(which mke2fs)
-
-if [ ! -z $mke2fs -a -x $mke2fs ];then
- printf "...okay\n"
-else
- printf "...failed\n"
- exit 1
-fi
-
-printf "Checking if tune2fs is installed"
-tune2fs=$(which tune2fs)
-
-if [ ! -z $tune2fs -a -x $tune2fs ];then
- printf "...okay\n"
-else
- printf "...failed\n"
- exit 1
-fi
+f=0
+for tool in parted sfdisk mkfs.ext4 tune2fs;do
+ if ! which $tool >/dev/null; then
+ echo "Checking if $tool is installed... failed"
+ f=1
+ fi
+done
+if [ $f -eq 1 ];then exit 1;fi
if [ -z $1 ];then
- printf "Please give your compact flash or USB device as first parameter\n"
+ printf "Please give your compact flash device as first parameter\n"
exit 1
else
if [ -z $2 ];then
@@ -72,13 +41,13 @@ else
exit 1
fi
if [ -b $1 ];then
- printf "Using $1 as CF/USB disk for installation\n"
- printf "This will destroy all data on $1, are you sure?\n"
- printf "Type "y" to continue\n"
+ printf "Using $1 as CF disk for installation\n"
+ echo "WARNING: This will destroy all data on $1 - type Yes to continue!"
read y
- if [ "$y" = "y" ];then
- $sfdisk -l $1 2>&1 |grep 'No medium'
+ if [ "$y" = "Yes" ];then
+ env LC_ALL=C sfdisk -l $1 2>&1 |grep 'No medium'
if [ $? -eq 0 ];then
+ echo "No medium found"
exit 1
else
printf "Starting with installation\n"
@@ -99,40 +68,31 @@ if [ $(mount | grep $1| wc -l) -ne 0 ];then
exit 1
fi
-
-if [ $($sfdisk -l $1 2>/dev/null|grep Empty|wc -l) -ne 4 ];then
- printf "Partitions already exist, should I wipe them?\n"
- printf "Type y to continue\n"
- read y
- if [ $y = "y" ];then
- printf "Wiping existing partitions\n"
- dd if=/dev/zero of=$1 bs=512 count=1 >/dev/null 2>&1
- else
- printf "Exiting.\n"
- exit 1
- fi
-fi
-
printf "Create partition and filesystem for rb532\n"
rootpart=${1}2
-$parted -s $1 mklabel msdos
+parted -s $1 mklabel msdos >/dev/null 2>&1
sleep 2
-maxsize=$(env LC_ALL=C $parted $1 -s unit cyl print |awk '/^Disk/ { print $3 }'|sed -e 's/cyl//')
+maxsize=$(env LC_ALL=C parted $1 -s unit cyl print |awk '/^Disk/ { print $3 }'|sed -e 's/cyl//')
rootsize=$(($maxsize-2))
-$parted -s $1 unit cyl mkpart primary ext2 0 2
-$parted -s $1 unit cyl mkpart primary ext2 2 $rootsize
-$parted -s $1 unit cyl mkpart primary fat32 $rootsize $maxsize
-$parted -s $1 set 1 boot on
-$sfdisk --change-id $1 1 27
-$sfdisk --change-id $1 3 88
+parted -s $1 unit cyl mkpart primary ext2 0 2 >/dev/null 2>&1
+parted -s $1 unit cyl mkpart primary ext2 2 $rootsize >/dev/null 2>&1
+parted -s $1 unit cyl mkpart primary fat32 $rootsize $maxsize >/dev/null 2>&1
+parted -s $1 set 1 boot on >/dev/null 2>&1
+sfdisk --change-id $1 1 27 >/dev/null 2>&1
+sfdisk --change-id $1 3 88 >/dev/null 2>&1
sleep 2
-$mke2fs ${1}2
+mkfs.ext4 -q -O ^huge_file ${1}2
sync
-dd if=$3 of=${1}1 bs=2048
+dd if=$3 of=${1}1 bs=2048 >/dev/null 2>&1
+if [ $? -eq 0 ];then
+ printf "Installation of kernel successful.\n"
+else
+ printf "Installation of kernel failed.\n"
+fi
sync
sleep 2
-$tune2fs -c 0 -i 0 -m 1 ${rootpart} >/dev/null
+tune2fs -c 0 -i 0 -m 1 ${rootpart} >/dev/null 2>&1
if [ $? -eq 0 ];then
printf "Successfully disabled filesystem checks on ${rootpart}\n"
else
@@ -141,7 +101,7 @@ else
fi
tmp=$(mktemp -d)
-mount -t ext2 ${rootpart} $tmp
+mount -t ext4 ${rootpart} $tmp
printf "Extracting install archive\n"
tar -C $tmp -xzpf $2
printf "Fixing permissions\n"
diff --git a/target/config/Config.in b/target/config/Config.in
index e082b5c4c..3c8be736b 100644
--- a/target/config/Config.in
+++ b/target/config/Config.in
@@ -205,6 +205,7 @@ config ADK_TARGET_KERNEL_MINICONFIG
default "raspberry-pi" if ADK_TARGET_SYSTEM_RASPBERRY_PI
default "sharp-zaurus" if ADK_TARGET_SYSTEM_SHARP_ZAURUS
default "lemote-yeelong" if ADK_TARGET_SYSTEM_LEMOTE_YEELONG
+ default "mikrotik-rb532" if ADK_TARGET_SYSTEM_MIKROTIK_RB532
default "generic-pc" if ADK_TARGET_SYSTEM_GENERIC_PC
choice
diff --git a/target/mips/Makefile b/target/mips/Makefile
index bd3a763b6..9029af155 100644
--- a/target/mips/Makefile
+++ b/target/mips/Makefile
@@ -111,6 +111,11 @@ ifeq ($(ADK_TARGET_SYSTEM_LEMOTE_YEELONG),y)
@echo "PMON> g root=/dev/sda1"
@echo "The root parameter have to be changed."
endif
+ifeq ($(ADK_TARGET_SYSTEM_MIKROTIK_RB532),y)
+ @cp $(KERNEL) $(FW_DIR)/$(TARGET_KERNEL)
+ @echo "Use following command to install it on CF card:"
+ @echo "sudo ./scripts/install-rb532.sh /dev/sdX $(FW_DIR)/$(ROOTFSTARBALL) $(FW_DIR)/$(TARGET_KERNEL)"
+endif
endif
ifeq ($(ADK_TARGET_FS),initramfsarchive)
imageinstall: $(FW_DIR)/$(ROOTFSUSERTARBALL)
diff --git a/target/mips/kernel/mikrotik-rb532 b/target/mips/kernel/mikrotik-rb532
new file mode 100644
index 000000000..57ef2e1ed
--- /dev/null
+++ b/target/mips/kernel/mikrotik-rb532
@@ -0,0 +1,8 @@
+CONFIG_MIPS=y
+CONFIG_MIKROTIK_RB532=y
+CONFIG_CPU_MIPS32_R1=y
+CONFIG_KORINA=y
+CONFIG_NET_VENDOR_VIA=y
+CONFIG_VIA_RHINE=y
+CONFIG_SERIAL_8250=y
+CONFIG_SERIAL_8250_CONSOLE=y
diff --git a/target/mips/sys-available/mikrotik-rb532 b/target/mips/sys-available/mikrotik-rb532
index 96ca4d46d..3ce7ca8f1 100644
--- a/target/mips/sys-available/mikrotik-rb532
+++ b/target/mips/sys-available/mikrotik-rb532
@@ -7,7 +7,6 @@ config ADK_TARGET_SYSTEM_MIKROTIK_RB532
select ADK_TARGET_WITH_WATCHDOG
select ADK_TARGET_WITH_NAND
select ADK_TARGET_WITH_LEDS
- depends on ADK_BROKEN
help
Support for Mikrotik RB532.