aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files/default/lib/network
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2006-10-24 23:59:08 +0000
committerFelix Fietkau <nbd@openwrt.org>2006-10-24 23:59:08 +0000
commit85926fd54776578737ae2463b3f64ef733c76dea (patch)
treeaf1827b34df373e91cb217e7fb8d6f78e87a575d /package/base-files/default/lib/network
parent145ed685731972bce9a7dee08fd22af137ac5555 (diff)
downloadmaster-187ad058-85926fd54776578737ae2463b3f64ef733c76dea.tar.gz
master-187ad058-85926fd54776578737ae2463b3f64ef733c76dea.tar.bz2
master-187ad058-85926fd54776578737ae2463b3f64ef733c76dea.zip
make network scripts more robust, prevent multiple instances of pppd and udhcpc for the same interface
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@5290 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/default/lib/network')
-rwxr-xr-xpackage/base-files/default/lib/network/config.sh3
1 files changed, 2 insertions, 1 deletions
diff --git a/package/base-files/default/lib/network/config.sh b/package/base-files/default/lib/network/config.sh
index a66c92bc03..25c7278e99 100755
--- a/package/base-files/default/lib/network/config.sh
+++ b/package/base-files/default/lib/network/config.sh
@@ -120,8 +120,9 @@ setup_interface() {
env -i ACTION="ifup" INTERFACE="config" DEVICE="$iface" PROTO=static /sbin/hotplug "iface" &
;;
dhcp)
+ # prevent udhcpc from starting more than once
pid="$(cat "$pidfile" 2>/dev/null)"
- [ -n "$pid" -a -d "/proc/$pid" ] && kill -9 "$pid"
+ [ -d "/proc/$pid" ] && grep udhcpc "/proc/${pid}/cmdline" >/dev/null 2>/dev/null && return 0
config_get ipaddr "$config" ipaddr
config_get netmask "$config" netmask