Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 1 | =============================== |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 2 | rfkill - RF kill switch support |
| 3 | =============================== |
Ivo van Doorn | dac24ab | 2007-09-13 09:22:55 +0200 | [diff] [blame] | 4 | |
Ivo van Doorn | dac24ab | 2007-09-13 09:22:55 +0200 | [diff] [blame] | 5 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 6 | .. contents:: |
| 7 | :depth: 2 |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 8 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 9 | Introduction |
| 10 | ============ |
Ivo van Doorn | dac24ab | 2007-09-13 09:22:55 +0200 | [diff] [blame] | 11 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 12 | The rfkill subsystem provides a generic interface to disabling any radio |
| 13 | transmitter in the system. When a transmitter is blocked, it shall not |
| 14 | radiate any power. |
Henrique de Moraes Holschuh | f3146af | 2008-06-23 17:22:56 -0300 | [diff] [blame] | 15 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 16 | The subsystem also provides the ability to react on button presses and |
| 17 | disable all transmitters of a certain type (or all). This is intended for |
| 18 | situations where transmitters need to be turned off, for example on |
| 19 | aircraft. |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 20 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 21 | The rfkill subsystem has a concept of "hard" and "soft" block, which |
| 22 | differ little in their meaning (block == transmitters off) but rather in |
| 23 | whether they can be changed or not: |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 24 | |
| 25 | - hard block |
| 26 | read-only radio block that cannot be overridden by software |
| 27 | |
| 28 | - soft block |
| 29 | writable radio block (need not be readable) that is set by |
| 30 | the system software. |
Henrique de Moraes Holschuh | f3146af | 2008-06-23 17:22:56 -0300 | [diff] [blame] | 31 | |
Andrew Clausen | 0efbb78 | 2015-01-09 20:24:55 +0000 | [diff] [blame] | 32 | The rfkill subsystem has two parameters, rfkill.default_state and |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 33 | rfkill.master_switch_mode, which are documented in |
| 34 | admin-guide/kernel-parameters.rst. |
Andrew Clausen | 0efbb78 | 2015-01-09 20:24:55 +0000 | [diff] [blame] | 35 | |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 36 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 37 | Implementation details |
| 38 | ====================== |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 39 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 40 | The rfkill subsystem is composed of three main components: |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 41 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 42 | * the rfkill core, |
| 43 | * the deprecated rfkill-input module (an input layer handler, being |
| 44 | replaced by userspace policy code) and |
| 45 | * the rfkill drivers. |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 46 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 47 | The rfkill core provides API for kernel drivers to register their radio |
| 48 | transmitter with the kernel, methods for turning it on and off and, letting |
| 49 | the system know about hardware-disabled states that may be implemented on |
| 50 | the device. |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 51 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 52 | The rfkill core code also notifies userspace of state changes, and provides |
| 53 | ways for userspace to query the current states. See the "Userspace support" |
| 54 | section below. |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 55 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 56 | When the device is hard-blocked (either by a call to rfkill_set_hw_state() |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 57 | or from query_hw_block) set_block() will be invoked for additional software |
| 58 | block, but drivers can ignore the method call since they can use the return |
| 59 | value of the function rfkill_set_hw_state() to sync the software state |
| 60 | instead of keeping track of calls to set_block(). In fact, drivers should |
| 61 | use the return value of rfkill_set_hw_state() unless the hardware actually |
| 62 | keeps track of soft and hard block separately. |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 63 | |
Ivo van Doorn | dac24ab | 2007-09-13 09:22:55 +0200 | [diff] [blame] | 64 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 65 | Kernel API |
| 66 | ========== |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 67 | |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 68 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 69 | Drivers for radio transmitters normally implement an rfkill driver. |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 70 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 71 | Platform drivers might implement input devices if the rfkill button is just |
| 72 | that, a button. If that button influences the hardware then you need to |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 73 | implement an rfkill driver instead. This also applies if the platform provides |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 74 | a way to turn on/off the transmitter(s). |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 75 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 76 | For some platforms, it is possible that the hardware state changes during |
| 77 | suspend/hibernation, in which case it will be necessary to update the rfkill |
| 78 | core with the current state is at resume time. |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 79 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 80 | To create an rfkill driver, driver's Kconfig needs to have:: |
Henrique de Moraes Holschuh | f7983f7 | 2008-06-23 17:46:43 -0300 | [diff] [blame] | 81 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 82 | depends on RFKILL || !RFKILL |
Henrique de Moraes Holschuh | 5005657 | 2008-06-23 17:46:42 -0300 | [diff] [blame] | 83 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 84 | to ensure the driver cannot be built-in when rfkill is modular. The !RFKILL |
Xishi Qiu | c79a8d8 | 2013-11-06 13:18:21 -0800 | [diff] [blame] | 85 | case allows the driver to be built when rfkill is not configured, which |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 86 | case all rfkill API can still be used but will be provided by static inlines |
| 87 | which compile to almost nothing. |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 88 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 89 | Calling rfkill_set_hw_state() when a state change happens is required from |
| 90 | rfkill drivers that control devices that can be hard-blocked unless they also |
| 91 | assign the poll_hw_block() callback (then the rfkill core will poll the |
| 92 | device). Don't do this unless you cannot get the event in any other way. |
Henrique de Moraes Holschuh | 2fd9b22 | 2008-07-21 21:18:17 -0300 | [diff] [blame] | 93 | |
João Paulo Rechi Vita | 50ee738 | 2016-02-22 11:36:37 -0500 | [diff] [blame] | 94 | RFKill provides per-switch LED triggers, which can be used to drive LEDs |
| 95 | according to the switch state (LED_FULL when blocked, LED_OFF otherwise). |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 96 | |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 97 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 98 | Userspace support |
| 99 | ================= |
Henrique de Moraes Holschuh | 2fd9b22 | 2008-07-21 21:18:17 -0300 | [diff] [blame] | 100 | |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 101 | The recommended userspace interface to use is /dev/rfkill, which is a misc |
| 102 | character device that allows userspace to obtain and set the state of rfkill |
| 103 | devices and sets of devices. It also notifies userspace about device addition |
| 104 | and removal. The API is a simple read/write API that is defined in |
| 105 | linux/rfkill.h, with one ioctl that allows turning off the deprecated input |
| 106 | handler in the kernel for the transition period. |
| 107 | |
| 108 | Except for the one ioctl, communication with the kernel is done via read() |
| 109 | and write() of instances of 'struct rfkill_event'. In this structure, the |
| 110 | soft and hard block are properly separated (unlike sysfs, see below) and |
| 111 | userspace is able to get a consistent snapshot of all rfkill devices in the |
| 112 | system. Also, it is possible to switch all rfkill drivers (or all drivers of |
| 113 | a specified type) into a state which also updates the default state for |
| 114 | hotplugged devices. |
| 115 | |
florian@mickler.org | 69c8637 | 2010-02-24 12:05:16 +0100 | [diff] [blame] | 116 | After an application opens /dev/rfkill, it can read the current state of all |
| 117 | devices. Changes can be either obtained by either polling the descriptor for |
| 118 | hotplug or state change events or by listening for uevents emitted by the |
| 119 | rfkill core framework. |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 120 | |
florian@mickler.org | 69c8637 | 2010-02-24 12:05:16 +0100 | [diff] [blame] | 121 | Additionally, each rfkill device is registered in sysfs and emits uevents. |
Johannes Berg | ce0879e | 2009-06-15 15:36:38 +0200 | [diff] [blame] | 122 | |
florian@mickler.org | 69c8637 | 2010-02-24 12:05:16 +0100 | [diff] [blame] | 123 | rfkill devices issue uevents (with an action of "change"), with the following |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 124 | environment variables set:: |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 125 | |
Mauro Carvalho Chehab | 317a845 | 2017-05-17 06:38:02 -0300 | [diff] [blame^] | 126 | RFKILL_NAME |
| 127 | RFKILL_STATE |
| 128 | RFKILL_TYPE |
Henrique de Moraes Holschuh | dc28852 | 2008-06-23 17:23:08 -0300 | [diff] [blame] | 129 | |
Johannes Berg | 19d337d | 2009-06-02 13:01:37 +0200 | [diff] [blame] | 130 | The contents of these variables corresponds to the "name", "state" and |
| 131 | "type" sysfs files explained above. |
florian@mickler.org | 69c8637 | 2010-02-24 12:05:16 +0100 | [diff] [blame] | 132 | |
| 133 | |
Paul Bolle | 395cf96 | 2011-08-15 02:02:26 +0200 | [diff] [blame] | 134 | For further details consult Documentation/ABI/stable/sysfs-class-rfkill. |