diff options
author | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-05-30 09:09:58 +0000 |
---|---|---|
committer | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-05-30 09:09:58 +0000 |
commit | b544d69e19c1c2f5261aad4c0795dcf297d47e4c (patch) | |
tree | a84b0b29ad86ed5bca304a5a794de7090bd702fe /openwrt/target/default/target_skeleton/etc | |
parent | c9c732afbfa99fbc3ef3209e04e9162d0a346098 (diff) |
make dnsmasq probe for dhcp servers before starting a dhcp server
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@1110 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'openwrt/target/default/target_skeleton/etc')
-rwxr-xr-x | openwrt/target/default/target_skeleton/etc/functions.sh | 28 | ||||
-rwxr-xr-x | openwrt/target/default/target_skeleton/etc/init.d/S50dnsmasq | 25 |
2 files changed, 50 insertions, 3 deletions
diff --git a/openwrt/target/default/target_skeleton/etc/functions.sh b/openwrt/target/default/target_skeleton/etc/functions.sh index 48f1191cc..60d6231f8 100755 --- a/openwrt/target/default/target_skeleton/etc/functions.sh +++ b/openwrt/target/default/target_skeleton/etc/functions.sh @@ -12,7 +12,7 @@ nvram () { . /etc/nvram.overrides # valid interface? -if_valid () { +if_valid () ( ifconfig "$1" >&- 2>&- || [ "${1%%[0-9]}" = "br" ] || { @@ -29,5 +29,29 @@ if_valid () { $DEBUG vconfig add $vif $i 2>&- ) } || - { debug "# missing interface '$if' ignored"; false; } + { debug "# missing interface '$1' ignored"; false; } +) + +bitcount () { + local c=$1 + echo $(( + c=((c>> 1)&0x55555555)+(c&0x55555555), + c=((c>> 2)&0x33333333)+(c&0x33333333), + c=((c>> 4)&0x0f0f0f0f)+(c&0x0f0f0f0f), + c=((c>> 8)&0x00ff00ff)+(c&0x00ff00ff), + c=((c>>16)&0x0000ffff)+(c&0x0000ffff) + )) +} + +valid_netmask () { + return $((-($1)&~$1)) +} + +ip2int () ( + set $(echo $1 | tr '\.' ' ') + echo $(($1<<24|$2<<16|$3<<8|$4)) +) + +int2ip () { + echo $(($1>>24&255)).$(($1>>16&255)).$(($1>>8&255)).$(($1&255)) } diff --git a/openwrt/target/default/target_skeleton/etc/init.d/S50dnsmasq b/openwrt/target/default/target_skeleton/etc/init.d/S50dnsmasq index 995c1b6e7..55bbc3719 100755 --- a/openwrt/target/default/target_skeleton/etc/init.d/S50dnsmasq +++ b/openwrt/target/default/target_skeleton/etc/init.d/S50dnsmasq @@ -1,2 +1,25 @@ #!/bin/sh -/usr/sbin/dnsmasq +. /etc/functions.sh + +# interface to use for DHCP +iface=lan + +ifname=$(nvram get ${iface}_ifname) +ipaddr=$(nvram get ${iface}_ipaddr) +netmask=$(nvram get ${iface}_netmask) + +# check for existing DHCP server +udhcpc -n -q -R -s /dev/zero -i $ifname >&- || { + + ipaddr=$(ip2int $ipaddr) + netmask=$(ip2int ${netmask:-255.255.255.0}) + network=$((ipaddr&netmask)) + + start=$(nvram get dhcp_start) + start=$((network+${start:-100})) + end=$(nvram get dhcp_num) + end=$((start+${end:-150})) + + args="-K -F $(int2ip $start),$(int2ip $end),$(int2ip $netmask),12h" +} +/usr/sbin/dnsmasq ${args} |