]>
Commit | Line | Data |
---|---|---|
19d337df JB |
1 | rfkill - RF kill switch support |
2 | =============================== | |
dac24ab3 | 3 | |
19d337df JB |
4 | 1. Introduction |
5 | 2. Implementation details | |
ce0879e3 JB |
6 | 3. Kernel API |
7 | 4. Userspace support | |
dac24ab3 | 8 | |
dc288520 | 9 | |
19d337df | 10 | 1. Introduction |
dac24ab3 | 11 | |
19d337df JB |
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. | |
f3146aff | 15 | |
19d337df JB |
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. | |
f7983f73 | 20 | |
ce0879e3 JB |
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: | |
24 | - hard block: read-only radio block that cannot be overriden by software | |
25 | - soft block: writable radio block (need not be readable) that is set by | |
26 | the system software. | |
f3146aff | 27 | |
dac24ab3 | 28 | |
19d337df | 29 | 2. Implementation details |
dc288520 | 30 | |
ce0879e3 JB |
31 | The rfkill subsystem is composed of three main components: |
32 | * the rfkill core, | |
33 | * the deprecated rfkill-input module (an input layer handler, being | |
34 | replaced by userspace policy code) and | |
35 | * the rfkill drivers. | |
bed7aac9 | 36 | |
ce0879e3 JB |
37 | The rfkill core provides API for kernel drivers to register their radio |
38 | transmitter with the kernel, methods for turning it on and off and, letting | |
39 | the system know about hardware-disabled states that may be implemented on | |
40 | the device. | |
bed7aac9 | 41 | |
ce0879e3 JB |
42 | The rfkill core code also notifies userspace of state changes, and provides |
43 | ways for userspace to query the current states. See the "Userspace support" | |
44 | section below. | |
bed7aac9 | 45 | |
19d337df | 46 | When the device is hard-blocked (either by a call to rfkill_set_hw_state() |
ce0879e3 JB |
47 | or from query_hw_block) set_block() will be invoked for additional software |
48 | block, but drivers can ignore the method call since they can use the return | |
49 | value of the function rfkill_set_hw_state() to sync the software state | |
50 | instead of keeping track of calls to set_block(). In fact, drivers should | |
51 | use the return value of rfkill_set_hw_state() unless the hardware actually | |
52 | keeps track of soft and hard block separately. | |
f7983f73 | 53 | |
f7983f73 | 54 | |
ce0879e3 | 55 | 3. Kernel API |
f7983f73 | 56 | |
f7983f73 | 57 | |
ce0879e3 | 58 | Drivers for radio transmitters normally implement an rfkill driver. |
f7983f73 | 59 | |
19d337df JB |
60 | Platform drivers might implement input devices if the rfkill button is just |
61 | that, a button. If that button influences the hardware then you need to | |
ce0879e3 | 62 | implement an rfkill driver instead. This also applies if the platform provides |
19d337df | 63 | a way to turn on/off the transmitter(s). |
f7983f73 | 64 | |
ce0879e3 JB |
65 | For some platforms, it is possible that the hardware state changes during |
66 | suspend/hibernation, in which case it will be necessary to update the rfkill | |
67 | core with the current state is at resume time. | |
f7983f73 | 68 | |
ce0879e3 | 69 | To create an rfkill driver, driver's Kconfig needs to have |
f7983f73 | 70 | |
ce0879e3 | 71 | depends on RFKILL || !RFKILL |
dc288520 | 72 | |
ce0879e3 JB |
73 | to ensure the driver cannot be built-in when rfkill is modular. The !RFKILL |
74 | case allows the driver to be built when rfkill is not configured, which which | |
75 | case all rfkill API can still be used but will be provided by static inlines | |
76 | which compile to almost nothing. | |
dc288520 | 77 | |
19d337df JB |
78 | Calling rfkill_set_hw_state() when a state change happens is required from |
79 | rfkill drivers that control devices that can be hard-blocked unless they also | |
80 | assign the poll_hw_block() callback (then the rfkill core will poll the | |
81 | device). Don't do this unless you cannot get the event in any other way. | |
dac24ab3 | 82 | |
5005657c | 83 | |
5005657c | 84 | |
19d337df | 85 | 5. Userspace support |
dac24ab3 | 86 | |
ce0879e3 JB |
87 | The recommended userspace interface to use is /dev/rfkill, which is a misc |
88 | character device that allows userspace to obtain and set the state of rfkill | |
89 | devices and sets of devices. It also notifies userspace about device addition | |
90 | and removal. The API is a simple read/write API that is defined in | |
91 | linux/rfkill.h, with one ioctl that allows turning off the deprecated input | |
92 | handler in the kernel for the transition period. | |
93 | ||
94 | Except for the one ioctl, communication with the kernel is done via read() | |
95 | and write() of instances of 'struct rfkill_event'. In this structure, the | |
96 | soft and hard block are properly separated (unlike sysfs, see below) and | |
97 | userspace is able to get a consistent snapshot of all rfkill devices in the | |
98 | system. Also, it is possible to switch all rfkill drivers (or all drivers of | |
99 | a specified type) into a state which also updates the default state for | |
100 | hotplugged devices. | |
101 | ||
102 | After an application opens /dev/rfkill, it can read the current state of | |
103 | all devices, and afterwards can poll the descriptor for hotplug or state | |
104 | change events. | |
105 | ||
106 | Applications must ignore operations (the "op" field) they do not handle, | |
107 | this allows the API to be extended in the future. | |
108 | ||
109 | Additionally, each rfkill device is registered in sysfs and there has the | |
110 | following attributes: | |
dac24ab3 ID |
111 | |
112 | name: Name assigned by driver to this key (interface or driver name). | |
ce0879e3 | 113 | type: Driver type string ("wlan", "bluetooth", etc). |
464902e8 AJ |
114 | persistent: Whether the soft blocked state is initialised from |
115 | non-volatile storage at startup. | |
5005657c HMH |
116 | state: Current state of the transmitter |
117 | 0: RFKILL_STATE_SOFT_BLOCKED | |
19d337df | 118 | transmitter is turned off by software |
5005657c | 119 | 1: RFKILL_STATE_UNBLOCKED |
f71fea23 | 120 | transmitter is (potentially) active |
5005657c HMH |
121 | 2: RFKILL_STATE_HARD_BLOCKED |
122 | transmitter is forced off by something outside of | |
19d337df | 123 | the driver's control. |
ce0879e3 JB |
124 | This file is deprecated because it can only properly show |
125 | three of the four possible states, soft-and-hard-blocked is | |
126 | missing. | |
127 | claim: 0: Kernel handles events | |
128 | This file is deprecated because there no longer is a way to | |
129 | claim just control over a single rfkill instance. | |
19d337df JB |
130 | |
131 | rfkill devices also issue uevents (with an action of "change"), with the | |
132 | following environment variables set: | |
133 | ||
134 | RFKILL_NAME | |
135 | RFKILL_STATE | |
136 | RFKILL_TYPE | |
137 | ||
138 | The contents of these variables corresponds to the "name", "state" and | |
139 | "type" sysfs files explained above. |