base-files: generate "device" UCI type section for bridge
authorRafał Miłecki <rafal@milecki.pl>
Sat, 15 May 2021 19:06:27 +0000 (21:06 +0200)
committerRafał Miłecki <rafal@milecki.pl>
Tue, 18 May 2021 18:07:51 +0000 (20:07 +0200)
This switches from the old way of defining bridges in an "interface" UCI
section type (that should be used for layer 3 only). From now a defualt
board switch will have its own "device" UCI section type. It's a new &
preferred way of defining L2 devices.

Before:

config interface 'lan'
        option type 'bridge'
        option ifname 'lan1 lan2 lan3 lan4'
        option proto 'static'
        option ipaddr '192.168.1.1'
        option netmask '255.255.255.0'

After:

config device
        option name 'lan'
        option type 'bridge'
        list ports 'lan1'
        list ports 'lan2'
        list ports 'lan3'
        list ports 'lan4'

config interface 'lan'
        option ifname 'lan'
        option proto 'static'
        option ipaddr '192.168.1.1'
        option netmask '255.255.255.0'

Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
package/base-files/files/bin/config_generate

index 56f6c4423b342b1866cdfe4f93025c09a3a5d802..0f6f280cf095e7ca367d0ac88c1857aaf57f08b8 100755 (executable)
@@ -110,8 +110,14 @@ generate_network() {
        }
 
        [ -n "$ports" ] && {
-               type="bridge"
-               ifname="$ports"
+               uci -q batch <<-EOF
+                       add network device
+                       set network.@device[-1].name='$1'
+                       set network.@device[-1].type='bridge'
+               EOF
+               for port in $ports; do uci add_list network.@device[-1].ports="$port"; done
+               ifname=$1
+               type=
        }
 
        [ -n "$bridge" ] && {