[PATCH 1/3] base-files: failsafe: Fix IP configuration
Hauke Mehrtens
hauke at hauke-m.de
Sat Jun 19 11:36:09 PDT 2021
Adapt the preinit_config_board() to the board.json network changes. It
now looks for the device and the ports variables to configure the LAN
network.
This works with swconfig configurations.
Fixes: FS#3866
Fixes: d42640e389a8 ("base-files: use "ports" array in board.json network for bridges")
Signed-off-by: Hauke Mehrtens <hauke at hauke-m.de>
---
.../files/lib/preinit/10_indicate_preinit | 18 ++++++++++++------
1 file changed, 12 insertions(+), 6 deletions(-)
diff --git a/package/base-files/files/lib/preinit/10_indicate_preinit b/package/base-files/files/lib/preinit/10_indicate_preinit
index 3c5992979016..ae9fcfecc89e 100644
--- a/package/base-files/files/lib/preinit/10_indicate_preinit
+++ b/package/base-files/files/lib/preinit/10_indicate_preinit
@@ -72,28 +72,34 @@ preinit_config_board() {
json_select network
json_select "lan"
- json_get_vars ifname
+ json_get_vars device
+ json_get_values ports ports
json_select ..
json_select ..
- [ -n "$ifname" ] || return
+ [ -n "$device" -o -n "$ports" ] || return
+
+ # swconfig uses $device and DSA uses ports
+ [ -z "$ports" ] && {
+ ports="$device"
+ }
# only use the first one
- ifname=${ifname%% *}
+ ports=${ports%% *}
if [ -x /sbin/swconfig ]; then
# configure the switch, if present
json_get_keys keys switch
for key in $keys; do
- preinit_config_switch $key $ifname
+ preinit_config_switch $key $ports
done
else
# trim any vlan ids
- ifname=${ifname%\.*}
+ ports=${ports%\.*}
fi
- pi_ifname=$ifname
+ pi_ifname=$ports
preinit_ip_config $pi_ifname
}
--
2.30.2
More information about the openwrt-devel
mailing list