aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/rtl838x/base-files
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/rtl838x/base-files')
-rwxr-xr-xtarget/linux/rtl838x/base-files/etc/board.d/01_leds15
-rwxr-xr-xtarget/linux/rtl838x/base-files/etc/board.d/02_network87
-rw-r--r--target/linux/rtl838x/base-files/etc/inittab3
-rw-r--r--target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8214fc.fwbin0 -> 1676 bytes
-rw-r--r--target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8218b.fwbin0 -> 1168 bytes
-rw-r--r--target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8380.fwbin0 -> 1184 bytes
-rw-r--r--target/linux/rtl838x/base-files/lib/upgrade/platform.sh19
7 files changed, 124 insertions, 0 deletions
diff --git a/target/linux/rtl838x/base-files/etc/board.d/01_leds b/target/linux/rtl838x/base-files/etc/board.d/01_leds
new file mode 100755
index 0000000000..7991b832f6
--- /dev/null
+++ b/target/linux/rtl838x/base-files/etc/board.d/01_leds
@@ -0,0 +1,15 @@
+#!/bin/sh
+
+. /lib/functions/uci-defaults.sh
+
+board=$(board_name)
+boardname="${board##*,}"
+
+board_config_update
+
+case $board in
+esac
+
+board_config_flush
+
+exit 0
diff --git a/target/linux/rtl838x/base-files/etc/board.d/02_network b/target/linux/rtl838x/base-files/etc/board.d/02_network
new file mode 100755
index 0000000000..a79869d8c3
--- /dev/null
+++ b/target/linux/rtl838x/base-files/etc/board.d/02_network
@@ -0,0 +1,87 @@
+#!/bin/sh
+
+. /lib/functions.sh
+. /lib/functions/uci-defaults.sh
+. /lib/functions/system.sh
+
+rtl838x_setup_switch()
+{
+ local switchid net portid master device lan_role lan_list
+
+ json_select_object switch
+ # Find slave ports
+ for net in $(ls -d /sys/class/net/*); do
+ switchid=$(cat $net/phys_switch_id 2>/dev/null)
+ [ -z "$switchid" ] && continue
+ device=$(basename $net)
+ portid=$(cat $net/phys_port_name)
+ lan_role="$lan_role ${portid##p}"
+ lan_list="$lan_list $device"
+ json_select_object "switch$((switchid))"
+ json_add_boolean enable 1
+ json_add_boolean reset 0
+ json_add_boolean dsa 1
+ json_select_array ports
+ json_add_object
+ json_add_int num "${portid##p}"
+ json_add_string role "lan"
+ json_add_string device "$device"
+ json_close_object
+ json_select ..
+ json_select ..
+ done
+ # Add switch master device
+ for net in $(ls -d /sys/class/net/*/dsa); do
+ master=$(dirname $net)
+ device=$(basename $master)
+ portid=$(cat $master/phys_port_name)
+ lan_role="$lan_role ${portid##p}"
+ json_select_object "switch$((switchid))"
+ json_select_array ports
+ json_add_object
+ json_add_int num "${portid##p}"
+ json_add_string device "$device"
+ json_add_boolean need_tag 0
+ json_add_boolean want_untag 0
+ json_add_boolean master 1
+ json_close_object
+ json_select ..
+ json_select_array roles
+ json_add_object
+ json_add_string role "lan"
+ lan_role=$(echo $lan_role | xargs -n1 | sort -n | xargs)
+ json_add_string ports "$lan_role"
+ json_close_object
+ json_select ..
+ json_select ..
+ done
+ json_select ..
+ lan_list=$(echo $lan_list | xargs -n1 | sort -V | xargs)
+ ucidef_set_interface_lan "$lan_list"
+}
+
+rtl838x_setup_macs()
+{
+ local board="$1"
+ local lan_mac
+ local wan_mac
+ local label_mac
+
+ case $board in
+ allnet,all-sg8208m)
+ lan_mac=$(mtd_get_mac_ascii u-boot-env ethaddr)
+ label_mac=$lan_mac
+ esac
+
+ [ -n "$lan_mac" ] && ucidef_set_interface_macaddr "lan" $lan_mac
+ [ -n "$wan_mac" ] && ucidef_set_interface_macaddr "wan" $wan_mac
+ [ -n "$label_mac" ] && ucidef_set_label_macaddr $label_mac
+}
+
+board_config_update
+board=$(board_name)
+rtl838x_setup_switch
+rtl838x_setup_macs $board
+board_config_flush
+
+exit 0
diff --git a/target/linux/rtl838x/base-files/etc/inittab b/target/linux/rtl838x/base-files/etc/inittab
new file mode 100644
index 0000000000..9820e7144b
--- /dev/null
+++ b/target/linux/rtl838x/base-files/etc/inittab
@@ -0,0 +1,3 @@
+::sysinit:/etc/init.d/rcS S boot
+::shutdown:/etc/init.d/rcS K shutdown
+::askconsole:/usr/libexec/login.sh
diff --git a/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8214fc.fw b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8214fc.fw
new file mode 100644
index 0000000000..035c02d804
--- /dev/null
+++ b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8214fc.fw
Binary files differ
diff --git a/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8218b.fw b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8218b.fw
new file mode 100644
index 0000000000..a907849fb9
--- /dev/null
+++ b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8218b.fw
Binary files differ
diff --git a/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8380.fw b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8380.fw
new file mode 100644
index 0000000000..ef84c71753
--- /dev/null
+++ b/target/linux/rtl838x/base-files/lib/firmware/rtl838x_phy/rtl838x_8380.fw
Binary files differ
diff --git a/target/linux/rtl838x/base-files/lib/upgrade/platform.sh b/target/linux/rtl838x/base-files/lib/upgrade/platform.sh
new file mode 100644
index 0000000000..927aadbe31
--- /dev/null
+++ b/target/linux/rtl838x/base-files/lib/upgrade/platform.sh
@@ -0,0 +1,19 @@
+PART_NAME=firmware
+REQUIRE_IMAGE_METADATA=1
+
+RAMFS_COPY_BIN='fw_printenv fw_setenv'
+RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock'
+
+platform_check_image() {
+ return 0
+}
+
+platform_do_upgrade() {
+ local board=$(board_name)
+
+ case "$board" in
+ *)
+ default_do_upgrade "$1"
+ ;;
+ esac
+}