diff options
| -rw-r--r-- | package/swconfig/Makefile | 2 | ||||
| -rw-r--r-- | package/swconfig/files/switch.sh | 6 | ||||
| -rw-r--r-- | package/swconfig/src/uci.c | 18 | 
3 files changed, 23 insertions, 3 deletions
| diff --git a/package/swconfig/Makefile b/package/swconfig/Makefile index a7bed7317..72af8c735 100644 --- a/package/swconfig/Makefile +++ b/package/swconfig/Makefile @@ -8,7 +8,7 @@  include $(TOPDIR)/rules.mk  PKG_NAME:=swconfig -PKG_RELEASE:=3 +PKG_RELEASE:=4  include $(INCLUDE_DIR)/package.mk  include $(INCLUDE_DIR)/kernel.mk diff --git a/package/swconfig/files/switch.sh b/package/swconfig/files/switch.sh index 7078b2e82..18d5fbd2c 100644 --- a/package/swconfig/files/switch.sh +++ b/package/swconfig/files/switch.sh @@ -2,8 +2,10 @@  # Copyright (C) 2009 OpenWrt.org  setup_switch_dev() { -	ifconfig "$1" 0.0.0.0 -	swconfig dev "$1" load network +	config_get name "$1" name +	name="${name:-$1}" +	[ -d "/sys/class/net/$name" ] && ifconfig "$name" up +	swconfig dev "$name" load network  }  setup_switch() { diff --git a/package/swconfig/src/uci.c b/package/swconfig/src/uci.c index 2df837d27..e597acebf 100644 --- a/package/swconfig/src/uci.c +++ b/package/swconfig/src/uci.c @@ -107,6 +107,7 @@ int swlib_apply_from_uci(struct switch_dev *dev, struct uci_package *p)  	struct uci_element *e;  	struct uci_section *s;  	struct uci_option *o; +	struct uci_ptr ptr;  	struct switch_val val;  	int i; @@ -114,11 +115,28 @@ int swlib_apply_from_uci(struct switch_dev *dev, struct uci_package *p)  	head = &settings;  	uci_foreach_element(&p->sections, e) { +		struct uci_element *n; +  		s = uci_to_section(e);  		if (strcmp(s->type, "switch") != 0)  			continue; +		uci_foreach_element(&s->options, n) { +			struct uci_option *o = uci_to_option(n); + +			if (strcmp(n->name, "name") != 0) +				continue; + +			if (o->type != UCI_TYPE_STRING) +				continue; + +			if (!strcmp(o->v.string, dev->dev_name)) +				goto found; + +			break; +		} +  		if (strcmp(e->name, dev->dev_name) != 0)  			continue; | 
