From 9290539ca9c7b296891b1b386052c0fe308e9a62 Mon Sep 17 00:00:00 2001 From: John Crispin Date: Sat, 28 Nov 2020 11:43:47 +0100 Subject: base-files: allow setting device and bridge macs Add code for setting mac addresses inside board.json and rendering them out to uci. On switches we want to have a unique MAC on each port. With 48 port switches that would require 48 device sections in /etc/config/network. Doing so via board.json is easier. Signed-off-by: John Crispin --- package/base-files/files/bin/config_generate | 33 +++++++++++++++++++++------- 1 file changed, 25 insertions(+), 8 deletions(-) (limited to 'package/base-files/files/bin/config_generate') diff --git a/package/base-files/files/bin/config_generate b/package/base-files/files/bin/config_generate index 79386d41b5..ee3958e733 100755 --- a/package/base-files/files/bin/config_generate +++ b/package/base-files/files/bin/config_generate @@ -9,11 +9,17 @@ CFG=/etc/board.json generate_bridge() { local name=$1 + local macaddr=$2 uci -q batch <<-EOF set network.$name=device set network.$name.name=$name set network.$name.type=bridge EOF + if [ -n "$macaddr" ]; then + uci -q batch <<-EOF + set network.$name.macaddr=$macaddr + EOF + fi } bridge_vlan_id=0 @@ -21,11 +27,11 @@ generate_bridge_vlan() { local name=$1_vlan local device=$2 local ports="$3" - bridge_vlan_id=$((bridge_vlan_id + 1)) + local vlan="$4" uci -q batch <<-EOF set network.$name=bridge-vlan set network.$name.device='$device' - set network.$name.vlan='$bridge_vlan_id' + set network.$name.vlan='$vlan' set network.$name.ports='$ports' EOF } @@ -85,12 +91,12 @@ generate_static_network() { addr_offset=2 generate_network() { - local ifname macaddr protocol type ipaddr netmask + local ifname macaddr protocol type ipaddr netmask vlan local bridge=$2 json_select network json_select "$1" - json_get_vars ifname macaddr protocol ipaddr netmask + json_get_vars ifname macaddr protocol ipaddr netmask vlan json_select .. json_select .. @@ -102,8 +108,12 @@ generate_network() { esac [ -n "$bridge" ] && { - generate_bridge_vlan $1 $bridge "$ifname" - ifname=$bridge.$bridge_vlan_id + if [ -z "$vlan" ]; then + bridge_vlan_id=$((bridge_vlan_id + 1)) + vlan=$bridge_vlan_id + fi + generate_bridge_vlan $1 $bridge "$ifname" $vlan + ifname=$bridge.$vlan type="" } @@ -465,14 +475,21 @@ json_load "$(cat ${CFG})" umask 077 if [ ! -s /etc/config/network ]; then + bridge_name="" touch /etc/config/network generate_static_network json_get_vars bridge - [ -n "$bridge" ] && generate_bridge $bridge + [ -n "$bridge" ] && { + json_select bridge + json_get_vars name macaddr + generate_bridge "$name" "$macaddr" + json_select .. + bridge_name=$name + } json_get_keys keys network - for key in $keys; do generate_network $key $bridge; done + for key in $keys; do generate_network $key $bridge_name; done json_get_keys keys switch for key in $keys; do generate_switch $key; done -- cgit v1.2.3