base-files: board.d: support specifiying the protocol of lan and wan
Some boards, e.g. the Sheeva Plug, require the lan interface to be set to DHCP instead of a static address, therfore support that. Signed-off-by: Jo-Philipp Wich <jow@openwrt.org> SVN-Revision: 47732
This commit is contained in:
parent
ac9bed4bc0
commit
f611358870
2 changed files with 47 additions and 21 deletions
|
@ -20,12 +20,13 @@ generate_static_network() {
|
|||
EOF
|
||||
}
|
||||
|
||||
addr_offset=2
|
||||
generate_network() {
|
||||
local ifname macaddr type
|
||||
local ifname macaddr protocol type
|
||||
|
||||
json_select network
|
||||
json_select "$1"
|
||||
json_get_vars ifname macaddr
|
||||
json_get_vars ifname macaddr protocol
|
||||
json_select ..
|
||||
json_select ..
|
||||
|
||||
|
@ -45,23 +46,32 @@ generate_network() {
|
|||
set network.$1.macaddr='$macaddr'
|
||||
EOF
|
||||
|
||||
case "$protocol" in
|
||||
static)
|
||||
local ipaddr
|
||||
case "$1" in
|
||||
lan)
|
||||
lan) ipaddr="192.168.1.1" ;;
|
||||
*) ipaddr="192.168.$((addr_offset++)).1" ;;
|
||||
esac
|
||||
|
||||
uci -q batch <<-EOF
|
||||
set network.$1.proto='static'
|
||||
set network.$1.ipaddr='192.168.1.1'
|
||||
set network.$1.ipaddr='$ipaddr'
|
||||
set network.$1.netmask='255.255.255.0'
|
||||
set network.$1.ip6assign='60'
|
||||
EOF
|
||||
;;
|
||||
wan)
|
||||
|
||||
dhcp)
|
||||
# fixup IPv6 slave interface if parent is a bridge
|
||||
[ "$type" = "bridge" ] && ifname="br-$1"
|
||||
|
||||
uci -q batch <<-EOF
|
||||
set network.$1.proto='dhcp'
|
||||
delete network.wan6
|
||||
set network.wan6='interface'
|
||||
set network.wan6.type='$type'
|
||||
set network.wan6.ifname='$ifname'
|
||||
set network.wan6.proto='dhcpv6'
|
||||
delete network.${1}6
|
||||
set network.${1}6='interface'
|
||||
set network.${1}6.ifname='$ifname'
|
||||
set network.${1}6.proto='dhcpv6'
|
||||
EOF
|
||||
;;
|
||||
esac
|
||||
|
|
|
@ -32,9 +32,26 @@ json_select_object() {
|
|||
_ucidef_set_interface() {
|
||||
local name="$1"
|
||||
local iface="$2"
|
||||
local proto="$3"
|
||||
|
||||
json_select_object "$name"
|
||||
json_add_string ifname "$iface"
|
||||
|
||||
if ! json_is_a protocol string; then
|
||||
case "$proto" in
|
||||
static|dhcp|none) : ;;
|
||||
*)
|
||||
case "$name" in
|
||||
lan) proto="static" ;;
|
||||
wan) proto="dhcp" ;;
|
||||
*) proto="none" ;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
|
||||
json_add_string protocol "$proto"
|
||||
fi
|
||||
|
||||
json_select ..
|
||||
}
|
||||
|
||||
|
@ -57,18 +74,14 @@ ucidef_set_interface_loopback()
|
|||
}
|
||||
|
||||
ucidef_set_interface_lan() {
|
||||
local lan_if="$1"
|
||||
|
||||
json_select_object network
|
||||
_ucidef_set_interface lan "$lan_if"
|
||||
_ucidef_set_interface lan "$@"
|
||||
json_select ..
|
||||
}
|
||||
|
||||
ucidef_set_interface_wan() {
|
||||
local wan_if="$1"
|
||||
|
||||
json_select_object network
|
||||
_ucidef_set_interface wan "$wan_if"
|
||||
_ucidef_set_interface wan "$@"
|
||||
json_select ..
|
||||
}
|
||||
|
||||
|
@ -164,14 +177,17 @@ _ucidef_finish_switch_roles() {
|
|||
json_select ..
|
||||
|
||||
json_select_object network
|
||||
local devices
|
||||
|
||||
json_select_object "$role"
|
||||
# attach previous interfaces (for multi-switch devices)
|
||||
local devices; json_get_var devices ifname
|
||||
json_get_var devices ifname
|
||||
if ! list_contains devices "$device"; then
|
||||
devices="${devices:+$devices }$device"
|
||||
fi
|
||||
json_add_string ifname "$devices"
|
||||
json_select ..
|
||||
|
||||
_ucidef_set_interface "$role" "$devices"
|
||||
json_select ..
|
||||
done
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue