add cname section
[openwrt/svn-archive/archive.git] / package / base-files / files / etc / init.d / network
index 950b33726a4fd7ddf3fcd7d1f98319401e6097ff..fc512216f8e08c7299ad55b514cc0efb0418945c 100755 (executable)
@@ -1,23 +1,44 @@
 #!/bin/sh /etc/rc.common
-# Copyright (C) 2006 OpenWrt.org
+# Copyright (C) 2006-2011 OpenWrt.org
 
 START=40
+STOP=90
+
 boot() {
        setup_switch() { return 0; }
 
        include /lib/network
        setup_switch
-       [ -e /etc/config/wireless ] || \
-               /sbin/wifi detect > /etc/config/wireless
-       /sbin/wifi up
-}
 
-start() {
-       ifup -a
-       /sbin/wifi up
+       /sbin/wifi detect > /tmp/wireless.tmp
+       [ -s /tmp/wireless.tmp ] && {
+               cat /tmp/wireless.tmp >> /etc/config/wireless
+       }
+       rm -f /tmp/wireless.tmp
+       grep -qs config /etc/config/wireless && {
+               /sbin/wifi up
+       }
+
+       scan_interfaces
+
+       local ifc
+       for ifc in $interfaces; do
+               local proto
+               config_get proto "$ifc" proto
+
+               local auto
+               config_get_bool auto "$ifc" auto 1
+
+               type "coldplug_interface_$proto" >/dev/null && [ "$auto" = 1 ] && \
+                       coldplug_interface_$proto "$ifc"
+       done
 }
 
-restart() {
+start() {
+       setup_switch() { return 0; }
+       
+       include /lib/network
+       setup_switch
        ifup -a
        /sbin/wifi up
 }
@@ -25,3 +46,7 @@ restart() {
 stop() {
        ifdown -a
 }
+
+restart() {
+       start
+}