X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fstaging%2Fyousong.git;a=blobdiff_plain;f=package%2Ftrelay%2Ffiles%2Ftrelay.init;fp=package%2Ftrelay%2Ffiles%2Ftrelay.init;h=c812e12c694ee278f49d4a36f6f1e6342c341608;hp=0000000000000000000000000000000000000000;hb=c3bba7f8c61ee98265bcffef8ee86e22aa89bbe9;hpb=15757646c5733b8a658f20f2ca377503cfabbb63 diff --git a/package/trelay/files/trelay.init b/package/trelay/files/trelay.init new file mode 100644 index 0000000000..c812e12c69 --- /dev/null +++ b/package/trelay/files/trelay.init @@ -0,0 +1,32 @@ +#!/bin/sh /etc/rc.common +START=80 + +check_relay() { + local cfg="$1" + + config_get_bool enabled "$cfg" enabled 1 + [ "$enabled" -gt 0 ] || return + + config_get dev1 "$cfg" dev1 + config_get dev2 "$cfg" dev2 + + [ -d "/sys/kernel/debug/trelay/${dev1}-${dev2}" ] && return + [ -d "/sys/class/net/${dev1}" -a -d "/sys/class/net/${dev2}" ] || return + + ifconfig "$dev1" up + ifconfig "$dev2" up + echo "${dev1}-${dev2},${dev1},${dev2}" > /sys/kernel/debug/trelay/add +} + +start() { + config_load trelay + config_foreach check_relay trelay + touch /var/run/trelay.active +} + +stop() { + rm -f /var/run/trelay.active + for relay in /sys/kernel/debug/trelay/*; do + [ -d "$relay" ] && echo > "$relay/remove" + done +}