summaryrefslogtreecommitdiffstats
path: root/package/base-files/default/sbin/wifi
blob: 759cfb0a84930c46fd798ac96c4b16efcc71c8ee (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/bin/sh
# Copyright (C) 2006 OpenWrt.org

. /etc/functions.sh

wifi_up() {
	for device in ${2:-$DEVICES}; do (
		config_get iftype "$device" type
		if eval "type enable_$iftype" 2>/dev/null >/dev/null; then
			eval "scan_$iftype '$device'"
			eval "enable_$iftype '$device'" || echo "$device($iftype): Setup failed"
		else
			echo "$device($iftype): Interface type not supported"
		fi
	); done
}

wifi_down() {
	for device in ${2:-$DEVICES}; do (
		config_get iftype "$device" type
		if eval "type disable_$iftype" 2>/dev/null >/dev/null; then
			eval "scan_$iftype '$device'"
			eval "disable_$iftype '$device'" || echo "$device($iftype): Setup failed"
		else
			echo "$device($iftype): Interface type not supported"
		fi
	); done
}

wifi_detect() {
	for driver in ${2:-$DRIVERS}; do (
		if eval "type detect_$driver" 2>/dev/null >/dev/null; then
			eval "detect_$driver" || echo "$driver: Detect failed" >&2
		else
			echo "$driver: Hardware detection not supported" >&2
		fi
	); done
}

start_net() {(
	local iface="$1"
	local config="$2"

	include /lib/network
	scan_interfaces
	setup_interface "$1" "$2"
)}

config_get_bool() {
	local _tmp
	config_get "$1" "$2" "$3"
	eval "_tmp=\$$1"
	case "$_tmp" in
		1|on|enabled) eval "$1=1";;
		0|off|disabled) eval "$1=0";;
		*) eval "$1=${4:-0}";;
	esac
}

config_cb() {
	config_get TYPE "$CONFIG_SECTION" TYPE
	case "$TYPE" in
		wifi-device)
			append DEVICES "$CONFIG_SECTION"
		;;
		wifi-iface)
			config_get device "$CONFIG_SECTION" device
			config_get vifs "$device" vifs 
			append vifs "$CONFIG_SECTION"
			config_set "$device" vifs "$vifs"
		;;
	esac
}

DEVICES=
DRIVERS=
config_load wireless
include /lib/wifi

case "$1" in
	down) wifi_down "$2";;
	detect) wifi_detect "$2";;
	*) wifi_up "$2";;
esac