Commit e954b0b8 authored by Henrique de Moraes Holschuh's avatar Henrique de Moraes Holschuh Committed by John W. Linville
Browse files

rfkill: add parameter to disable radios by default



Currently, radios are always enabled when their rfkill interface is
registered.  This is not optimal, the safest state for a radio is to be
offline unless the user turns it on.

Add a module parameter that causes all radios to be disabled when their
rfkill interface is registered.  The module default is not changed so
unless the parameter is used, radios will still be forced to their enabled
state when they are registered.

The new rfkill module parameter is called "default_state".
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Acked-by: default avatarIvo van Doorn <IvDoorn@gmail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 28f089c1
...@@ -39,6 +39,11 @@ MODULE_LICENSE("GPL"); ...@@ -39,6 +39,11 @@ MODULE_LICENSE("GPL");
static LIST_HEAD(rfkill_list); /* list of registered rf switches */ static LIST_HEAD(rfkill_list); /* list of registered rf switches */
static DEFINE_MUTEX(rfkill_mutex); static DEFINE_MUTEX(rfkill_mutex);
static unsigned int rfkill_default_state = RFKILL_STATE_ON;
module_param_named(default_state, rfkill_default_state, uint, 0444);
MODULE_PARM_DESC(default_state,
"Default initial state for all radio types, 0 = radio off");
static enum rfkill_state rfkill_states[RFKILL_TYPE_MAX]; static enum rfkill_state rfkill_states[RFKILL_TYPE_MAX];
...@@ -436,8 +441,12 @@ static int __init rfkill_init(void) ...@@ -436,8 +441,12 @@ static int __init rfkill_init(void)
int error; int error;
int i; int i;
if (rfkill_default_state != RFKILL_STATE_OFF &&
rfkill_default_state != RFKILL_STATE_ON)
return -EINVAL;
for (i = 0; i < ARRAY_SIZE(rfkill_states); i++) for (i = 0; i < ARRAY_SIZE(rfkill_states); i++)
rfkill_states[i] = RFKILL_STATE_ON; rfkill_states[i] = rfkill_default_state;
error = class_register(&rfkill_class); error = class_register(&rfkill_class);
if (error) { if (error) {
......
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