summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJames Rayner <james@archlinux.org>2010-02-21 12:10:21 +0100
committerJames Rayner <james@archlinux.org>2010-02-21 12:10:21 +0100
commitabb0cfbf8f933471847ced6e546c8a192c1169d7 (patch)
treec39eb7f43a40683309d882962ca5806ae6354af2 /src
parent63e1e4c2155c17cea7ed80e83d5feae3a0e44fa5 (diff)
downloadnetctl-abb0cfbf8f933471847ced6e546c8a192c1169d7.tar.gz
netctl-abb0cfbf8f933471847ced6e546c8a192c1169d7.tar.xz
Fix FS#18391, FS#18385, broken rfkill, handle hard more appropriately
Diffstat (limited to 'src')
-rw-r--r--src/connections/wireless22
-rw-r--r--src/wireless23
2 files changed, 22 insertions, 23 deletions
diff --git a/src/connections/wireless b/src/connections/wireless
index 5c9091a..a95496a 100644
--- a/src/connections/wireless
+++ b/src/connections/wireless
@@ -4,24 +4,6 @@
. $SUBR_DIR/wireless
-
-enable_rf() {
- # Enable rfkill if necessary, or fail if it is hardware
- if [[ -n "$RFKILL" ]]; then
- local state=$(get_rf_state "$INTERFACE") || return 1
- if [[ "$state" != "up" ]]; then
- if [[ "$RFKILL" == "soft" ]]; then
- set_rf_state "$INTERFACE" up
- sleep 1
- else
- report_fail "radio is disabled on $INTERFACE"
- return 1
- fi
- fi
- fi
-}
-
-
iwconfig_up() {
quirk prescan && iwlist "$INTERFACE" scan &> /dev/null # bcm43xx
@@ -66,7 +48,7 @@ wireless_up() {
PROFILE="$1"
load_profile "$PROFILE"
- enable_rf || return 1
+ enable_rf $INTERFACE $RFKILL $RFKILL_NAME || return 1
# Check if interface exists
is_interface "$INTERFACE" || { report_fail "interface $INTERFACE does not exist"; return 1; }
@@ -168,7 +150,7 @@ wireless_down() {
# Any reason why a hardware switch should be considered on interface down?
if [[ "$RFKILL" == "soft" ]]; then
. "$SUBR_DIR/wireless"
- set_rf_state "$INTERFACE" down || return 1
+ set_rf_state "$INTERFACE" disabled $RFKILL_NAME || return 1
fi
}
diff --git a/src/wireless b/src/wireless
index 0bd4dc1..d6b8b39 100644
--- a/src/wireless
+++ b/src/wireless
@@ -117,7 +117,7 @@ wpa_supplicant_scan_info() {
}
set_rf_state() {
- local INTERFACE="$1" state="$2" PROFILE="$3"
+ local INTERFACE="$1" state="$2" RFKILL_NAME="$3"
if [[ "$RFKILL" == "hard" ]]; then
report_fail "Cannot set state on hardware rfkill switch"
@@ -125,10 +125,10 @@ set_rf_state() {
fi
local path=$(get_rf_path "$INTERFACE" "$RFKILL_NAME") || return 1
case "$state" in
- up)
+ enabled)
echo 1 > "$path/state"
;;
- down)
+ disabled)
echo 0 > "$path/state"
;;
esac
@@ -172,5 +172,22 @@ get_rf_state() {
esac
}
+enable_rf() {
+ local INTERFACE="$1" RFKILL="$2" RFKILL_NAME="$3"
+ # Enable rfkill if necessary, or fail if it is hardware
+ if [[ -n "$RFKILL" ]]; then
+ local state=$(get_rf_state "$INTERFACE") || return 1
+ if [[ "$state" != "enabled" ]]; then
+ if [[ "$RFKILL" == "soft" ]]; then
+ set_rf_state "$INTERFACE" enabled $RFKILL_NAME
+ sleep 1
+ else
+ report_fail "radio is disabled on $INTERFACE"
+ return 1
+ fi
+ fi
+ fi
+}
+
# vim: ft=sh ts=4 et sw=4: