mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-23 15:32:33 +00:00
fix interface enumeration issues related to /var/state/network (thx to fish for debugging this)
SVN-Revision: 10715
This commit is contained in:
parent
1d3ed2fca0
commit
f4f7d687f0
@ -40,10 +40,11 @@ scan_interfaces() {
|
||||
append interfaces "$CONFIG_SECTION"
|
||||
config_get iftype "$CONFIG_SECTION" type
|
||||
config_get ifname "$CONFIG_SECTION" ifname
|
||||
config_set "$CONFIG_SECTION" device "$ifname"
|
||||
config_get device "$CONFIG_SECTION" device
|
||||
config_set "$CONFIG_SECTION" device "${device:-$ifname}"
|
||||
case "$iftype" in
|
||||
bridge)
|
||||
config_set "$CONFIG_SECTION" ifnames "$ifname"
|
||||
config_set "$CONFIG_SECTION" ifnames "${device:-$ifname}"
|
||||
config_set "$CONFIG_SECTION" ifname br-"$CONFIG_SECTION"
|
||||
;;
|
||||
esac
|
||||
@ -113,6 +114,15 @@ prepare_interface() {
|
||||
return 0
|
||||
}
|
||||
|
||||
set_interface_ifname() {
|
||||
local config="$1"
|
||||
local ifname="$2"
|
||||
|
||||
config_get device "$1" device
|
||||
uci_set_state "network.$config.ifname=$ifname"
|
||||
uci_set_state "network.$config.device=$device"
|
||||
}
|
||||
|
||||
setup_interface() {
|
||||
local iface="$1"
|
||||
local config="$2"
|
||||
@ -140,7 +150,7 @@ setup_interface() {
|
||||
config_get macaddr "$config" macaddr
|
||||
grep "$iface:" /proc/net/dev > /dev/null && \
|
||||
$DEBUG ifconfig "$iface" ${macaddr:+hw ether "$macaddr"} ${mtu:+mtu $mtu} up
|
||||
uci_set_state network "$config" ifname "$iface"
|
||||
set_interface_ifname "$config" "$iface"
|
||||
|
||||
pidfile="/var/run/$iface.pid"
|
||||
case "$proto" in
|
||||
|
@ -13,7 +13,7 @@ setup_interface_pppoe() {
|
||||
# make sure the network state references the correct ifname
|
||||
scan_ppp "$config"
|
||||
config_get ifname "$config" ifname
|
||||
uci set "/var/state/network.$config.ifname=$ifname"
|
||||
set_interface_ifname "$config" "$ifname"
|
||||
|
||||
config_get mtu "$cfg" mtu
|
||||
mtu=${mtu:-1492}
|
||||
|
Loading…
Reference in New Issue
Block a user