Commit 477576a0 authored by Henrique de Moraes Holschuh's avatar Henrique de Moraes Holschuh Committed by John W. Linville

rfkill: add the WWAN radio type

Unfortunately, instead of adding a generic Wireless WAN type, a technology-
specific type (WiMAX) was added.  That's useless for other WWAN devices,
such as EDGE, UMTS, X-RTT and other such radios.

Add a WWAN rfkill type for generic wireless WAN devices.  No keys are added
as most devices really want to use KEY_WLAN for WWAN control (in a cycle of
none, WLAN, WWAN, WLAN+WWAN) and need no specific keycode added.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Acked-by: default avatarIvo van Doorn <IvDoorn@gmail.com>
Cc: Iñaky Pérez-González <inaky.perez-gonzalez@intel.com>
Cc: David S. Miller <davem@davemloft.net>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 801e49af
...@@ -34,12 +34,14 @@ ...@@ -34,12 +34,14 @@
* RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device. * RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device.
* RFKILL_TYPE_UWB: switch is on a ultra wideband device. * RFKILL_TYPE_UWB: switch is on a ultra wideband device.
* RFKILL_TYPE_WIMAX: switch is on a WiMAX device. * RFKILL_TYPE_WIMAX: switch is on a WiMAX device.
* RFKILL_TYPE_WWAN: switch is on a wireless WAN device.
*/ */
enum rfkill_type { enum rfkill_type {
RFKILL_TYPE_WLAN , RFKILL_TYPE_WLAN ,
RFKILL_TYPE_BLUETOOTH, RFKILL_TYPE_BLUETOOTH,
RFKILL_TYPE_UWB, RFKILL_TYPE_UWB,
RFKILL_TYPE_WIMAX, RFKILL_TYPE_WIMAX,
RFKILL_TYPE_WWAN,
RFKILL_TYPE_MAX, RFKILL_TYPE_MAX,
}; };
......
...@@ -101,6 +101,7 @@ static DEFINE_RFKILL_TASK(rfkill_wlan, RFKILL_TYPE_WLAN); ...@@ -101,6 +101,7 @@ static DEFINE_RFKILL_TASK(rfkill_wlan, RFKILL_TYPE_WLAN);
static DEFINE_RFKILL_TASK(rfkill_bt, RFKILL_TYPE_BLUETOOTH); static DEFINE_RFKILL_TASK(rfkill_bt, RFKILL_TYPE_BLUETOOTH);
static DEFINE_RFKILL_TASK(rfkill_uwb, RFKILL_TYPE_UWB); static DEFINE_RFKILL_TASK(rfkill_uwb, RFKILL_TYPE_UWB);
static DEFINE_RFKILL_TASK(rfkill_wimax, RFKILL_TYPE_WIMAX); static DEFINE_RFKILL_TASK(rfkill_wimax, RFKILL_TYPE_WIMAX);
static DEFINE_RFKILL_TASK(rfkill_wwan, RFKILL_TYPE_WWAN);
static void rfkill_event(struct input_handle *handle, unsigned int type, static void rfkill_event(struct input_handle *handle, unsigned int type,
unsigned int code, int data) unsigned int code, int data)
...@@ -126,6 +127,9 @@ static void rfkill_event(struct input_handle *handle, unsigned int type, ...@@ -126,6 +127,9 @@ static void rfkill_event(struct input_handle *handle, unsigned int type,
switch (code) { switch (code) {
case SW_RFKILL_ALL: case SW_RFKILL_ALL:
/* EVERY radio type. data != 0 means radios ON */ /* EVERY radio type. data != 0 means radios ON */
rfkill_schedule_set(&rfkill_wwan,
(data)? RFKILL_STATE_ON:
RFKILL_STATE_OFF);
rfkill_schedule_set(&rfkill_wimax, rfkill_schedule_set(&rfkill_wimax,
(data)? RFKILL_STATE_ON: (data)? RFKILL_STATE_ON:
RFKILL_STATE_OFF); RFKILL_STATE_OFF);
......
...@@ -180,6 +180,9 @@ static ssize_t rfkill_type_show(struct device *dev, ...@@ -180,6 +180,9 @@ static ssize_t rfkill_type_show(struct device *dev,
case RFKILL_TYPE_WIMAX: case RFKILL_TYPE_WIMAX:
type = "wimax"; type = "wimax";
break; break;
case RFKILL_TYPE_WWAN:
type = "wwan";
break;
default: default:
BUG(); BUG();
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment