diff options
author | Felix Fietkau <nbd@openwrt.org> | 2010-01-18 00:38:04 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2010-01-18 00:38:04 +0000 |
commit | 45b797478c52ca1408bf2a2d13b0c967b92f2bc1 (patch) | |
tree | 4852e7a6d22a337a7c3536452ed2b3a18dcec83c | |
parent | 764549aa545cb03a24ff41eabed91a2cab920d00 (diff) | |
download | upstream-45b797478c52ca1408bf2a2d13b0c967b92f2bc1.tar.gz upstream-45b797478c52ca1408bf2a2d13b0c967b92f2bc1.tar.bz2 upstream-45b797478c52ca1408bf2a2d13b0c967b92f2bc1.zip |
swconfig: support providing the switch device name in an option instead of the section name - necessary to support switches that contain characters such as "-"
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@19208 3c298f89-4303-0410-b956-a3cf2f4a3e73
-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 a7bed73174..72af8c735f 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 7078b2e823..18d5fbd2c3 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 2df837d278..e597acebfb 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; |