Mauro Carvalho Chehab | baa293e | 2019-06-27 15:39:22 -0300 | [diff] [blame] | 1 | .. SPDX-License-Identifier: GPL-2.0 |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 2 | |
| 3 | =============== |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 4 | Console Drivers |
| 5 | =============== |
| 6 | |
Randy Dunlap | 3d83d31 | 2018-08-06 16:24:55 -0700 | [diff] [blame] | 7 | The Linux kernel has 2 general types of console drivers. The first type is |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 8 | assigned by the kernel to all the virtual consoles during the boot process. |
| 9 | This type will be called 'system driver', and only one system driver is allowed |
| 10 | to exist. The system driver is persistent and it can never be unloaded, though |
| 11 | it may become inactive. |
| 12 | |
| 13 | The second type has to be explicitly loaded and unloaded. This will be called |
| 14 | 'modular driver' by this document. Multiple modular drivers can coexist at |
| 15 | any time with each driver sharing the console with other drivers including |
| 16 | the system driver. However, modular drivers cannot take over the console |
| 17 | that is currently occupied by another modular driver. (Exception: Drivers that |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 18 | call do_take_over_console() will succeed in the takeover regardless of the type |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 19 | of driver occupying the consoles.) They can only take over the console that is |
| 20 | occupied by the system driver. In the same token, if the modular driver is |
| 21 | released by the console, the system driver will take over. |
| 22 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 23 | Modular drivers, from the programmer's point of view, have to call:: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 24 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 25 | do_take_over_console() - load and bind driver to console layer |
Randy Dunlap | 3d83d31 | 2018-08-06 16:24:55 -0700 | [diff] [blame] | 26 | give_up_console() - unload driver; it will only work if driver |
| 27 | is fully unbound |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 28 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 29 | In newer kernels, the following are also available:: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 30 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 31 | do_register_con_driver() |
| 32 | do_unregister_con_driver() |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 33 | |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 34 | If sysfs is enabled, the contents of /sys/class/vtconsole can be |
| 35 | examined. This shows the console backends currently registered by the |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 36 | system which are named vtcon<n> where <n> is an integer from 0 to 15. |
| 37 | Thus:: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 38 | |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 39 | ls /sys/class/vtconsole |
| 40 | . .. vtcon0 vtcon1 |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 41 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 42 | Each directory in /sys/class/vtconsole has 3 files:: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 43 | |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 44 | ls /sys/class/vtconsole/vtcon0 |
| 45 | . .. bind name uevent |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 46 | |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 47 | What do these files signify? |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 48 | |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 49 | 1. bind - this is a read/write file. It shows the status of the driver if |
| 50 | read, or acts to bind or unbind the driver to the virtual consoles |
| 51 | when written to. The possible values are: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 52 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 53 | 0 |
| 54 | - means the driver is not bound and if echo'ed, commands the driver |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 55 | to unbind |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 56 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 57 | 1 |
| 58 | - means the driver is bound and if echo'ed, commands the driver to |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 59 | bind |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 60 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 61 | 2. name - read-only file. Shows the name of the driver in this format:: |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 62 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 63 | cat /sys/class/vtconsole/vtcon0/name |
| 64 | (S) VGA+ |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 65 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 66 | '(S)' stands for a (S)ystem driver, i.e., it cannot be directly |
| 67 | commanded to bind or unbind |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 68 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 69 | 'VGA+' is the name of the driver |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 70 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 71 | cat /sys/class/vtconsole/vtcon1/name |
| 72 | (M) frame buffer device |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 73 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 74 | In this case, '(M)' stands for a (M)odular driver, one that can be |
| 75 | directly commanded to bind or unbind. |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 76 | |
| 77 | 3. uevent - ignore this file |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 78 | |
| 79 | When unbinding, the modular driver is detached first, and then the system |
| 80 | driver takes over the consoles vacated by the driver. Binding, on the other |
| 81 | hand, will bind the driver to the consoles that are currently occupied by a |
| 82 | system driver. |
| 83 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 84 | NOTE1: |
| 85 | Binding and unbinding must be selected in Kconfig. It's under:: |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 86 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 87 | Device Drivers -> |
| 88 | Character devices -> |
| 89 | Support for binding and unbinding console drivers |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 90 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 91 | NOTE2: |
| 92 | If any of the virtual consoles are in KD_GRAPHICS mode, then binding or |
| 93 | unbinding will not succeed. An example of an application that sets the |
| 94 | console to KD_GRAPHICS is X. |
Antonino A. Daplas | 6690075 | 2006-06-26 00:27:14 -0700 | [diff] [blame] | 95 | |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 96 | How useful is this feature? This is very useful for console driver |
| 97 | developers. By unbinding the driver from the console layer, one can unload the |
| 98 | driver, make changes, recompile, reload and rebind the driver without any need |
| 99 | for rebooting the kernel. For regular users who may want to switch from |
| 100 | framebuffer console to VGA console and vice versa, this feature also makes |
| 101 | this possible. (NOTE NOTE NOTE: Please read fbcon.txt under Documentation/fb |
Randy Dunlap | 3d83d31 | 2018-08-06 16:24:55 -0700 | [diff] [blame] | 102 | for more details.) |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 103 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 104 | Notes for developers |
| 105 | ==================== |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 106 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 107 | do_take_over_console() is now broken up into:: |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 108 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 109 | do_register_con_driver() |
| 110 | do_bind_con_driver() - private function |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 111 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 112 | give_up_console() is a wrapper to do_unregister_con_driver(), and a driver must |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 113 | be fully unbound for this call to succeed. con_is_bound() will check if the |
| 114 | driver is bound or not. |
| 115 | |
Mauro Carvalho Chehab | 8db8ace | 2019-04-14 08:44:17 -0300 | [diff] [blame] | 116 | Guidelines for console driver writers |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 117 | ===================================== |
| 118 | |
| 119 | In order for binding to and unbinding from the console to properly work, |
| 120 | console drivers must follow these guidelines: |
| 121 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 122 | 1. All drivers, except system drivers, must call either do_register_con_driver() |
Randy Dunlap | 3d83d31 | 2018-08-06 16:24:55 -0700 | [diff] [blame] | 123 | or do_take_over_console(). do_register_con_driver() will just add the driver |
| 124 | to the console's internal list. It won't take over the |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 125 | console. do_take_over_console(), as it name implies, will also take over (or |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 126 | bind to) the console. |
| 127 | |
| 128 | 2. All resources allocated during con->con_init() must be released in |
| 129 | con->con_deinit(). |
| 130 | |
| 131 | 3. All resources allocated in con->con_startup() must be released when the |
| 132 | driver, which was previously bound, becomes unbound. The console layer |
| 133 | does not have a complementary call to con->con_startup() so it's up to the |
| 134 | driver to check when it's legal to release these resources. Calling |
| 135 | con_is_bound() in con->con_deinit() will help. If the call returned |
| 136 | false(), then it's safe to release the resources. This balance has to be |
| 137 | ensured because con->con_startup() can be called again when a request to |
| 138 | rebind the driver to the console arrives. |
| 139 | |
| 140 | 4. Upon exit of the driver, ensure that the driver is totally unbound. If the |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 141 | condition is satisfied, then the driver must call do_unregister_con_driver() |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 142 | or give_up_console(). |
| 143 | |
Wang YanQing | 6b5f146 | 2013-05-21 23:29:11 +0800 | [diff] [blame] | 144 | 5. do_unregister_con_driver() can also be called on conditions which make it |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 145 | impossible for the driver to service console requests. This can happen |
| 146 | with the framebuffer console that suddenly lost all of its drivers. |
| 147 | |
| 148 | The current crop of console drivers should still work correctly, but binding |
| 149 | and unbinding them may cause problems. With minimal fixes, these drivers can |
| 150 | be made to work correctly. |
| 151 | |
Antonino A. Daplas | 79062a0 | 2006-06-26 00:27:11 -0700 | [diff] [blame] | 152 | Antonino Daplas <adaplas@pol.net> |