153 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| 
 | |
| ===============
 | |
| Console Drivers
 | |
| ===============
 | |
| 
 | |
| The Linux kernel has 2 general types of console drivers.  The first type is
 | |
| assigned by the kernel to all the virtual consoles during the boot process.
 | |
| This type will be called 'system driver', and only one system driver is allowed
 | |
| to exist. The system driver is persistent and it can never be unloaded, though
 | |
| it may become inactive.
 | |
| 
 | |
| The second type has to be explicitly loaded and unloaded. This will be called
 | |
| 'modular driver' by this document. Multiple modular drivers can coexist at
 | |
| any time with each driver sharing the console with other drivers including
 | |
| the system driver. However, modular drivers cannot take over the console
 | |
| that is currently occupied by another modular driver. (Exception: Drivers that
 | |
| call do_take_over_console() will succeed in the takeover regardless of the type
 | |
| of driver occupying the consoles.) They can only take over the console that is
 | |
| occupied by the system driver. In the same token, if the modular driver is
 | |
| released by the console, the system driver will take over.
 | |
| 
 | |
| Modular drivers, from the programmer's point of view, have to call::
 | |
| 
 | |
| 	 do_take_over_console() - load and bind driver to console layer
 | |
| 	 give_up_console() - unload driver; it will only work if driver
 | |
| 			     is fully unbound
 | |
| 
 | |
| In newer kernels, the following are also available::
 | |
| 
 | |
| 	 do_register_con_driver()
 | |
| 	 do_unregister_con_driver()
 | |
| 
 | |
| If sysfs is enabled, the contents of /sys/class/vtconsole can be
 | |
| examined. This shows the console backends currently registered by the
 | |
| system which are named vtcon<n> where <n> is an integer from 0 to 15.
 | |
| Thus::
 | |
| 
 | |
|        ls /sys/class/vtconsole
 | |
|        .  ..  vtcon0  vtcon1
 | |
| 
 | |
| Each directory in /sys/class/vtconsole has 3 files::
 | |
| 
 | |
|      ls /sys/class/vtconsole/vtcon0
 | |
|      .  ..  bind  name  uevent
 | |
| 
 | |
| What do these files signify?
 | |
| 
 | |
|      1. bind - this is a read/write file. It shows the status of the driver if
 | |
|         read, or acts to bind or unbind the driver to the virtual consoles
 | |
|         when written to. The possible values are:
 | |
| 
 | |
| 	0
 | |
| 	  - means the driver is not bound and if echo'ed, commands the driver
 | |
| 	    to unbind
 | |
| 
 | |
|         1
 | |
| 	  - means the driver is bound and if echo'ed, commands the driver to
 | |
| 	    bind
 | |
| 
 | |
|      2. name - read-only file. Shows the name of the driver in this format::
 | |
| 
 | |
| 	  cat /sys/class/vtconsole/vtcon0/name
 | |
| 	  (S) VGA+
 | |
| 
 | |
| 	      '(S)' stands for a (S)ystem driver, i.e., it cannot be directly
 | |
| 	      commanded to bind or unbind
 | |
| 
 | |
| 	      'VGA+' is the name of the driver
 | |
| 
 | |
| 	  cat /sys/class/vtconsole/vtcon1/name
 | |
| 	  (M) frame buffer device
 | |
| 
 | |
| 	      In this case, '(M)' stands for a (M)odular driver, one that can be
 | |
| 	      directly commanded to bind or unbind.
 | |
| 
 | |
|      3. uevent - ignore this file
 | |
| 
 | |
| When unbinding, the modular driver is detached first, and then the system
 | |
| driver takes over the consoles vacated by the driver. Binding, on the other
 | |
| hand, will bind the driver to the consoles that are currently occupied by a
 | |
| system driver.
 | |
| 
 | |
| NOTE1:
 | |
|   Binding and unbinding must be selected in Kconfig. It's under::
 | |
| 
 | |
|     Device Drivers ->
 | |
| 	Character devices ->
 | |
| 		Support for binding and unbinding console drivers
 | |
| 
 | |
| NOTE2:
 | |
|   If any of the virtual consoles are in KD_GRAPHICS mode, then binding or
 | |
|   unbinding will not succeed. An example of an application that sets the
 | |
|   console to KD_GRAPHICS is X.
 | |
| 
 | |
| How useful is this feature? This is very useful for console driver
 | |
| developers. By unbinding the driver from the console layer, one can unload the
 | |
| driver, make changes, recompile, reload and rebind the driver without any need
 | |
| for rebooting the kernel. For regular users who may want to switch from
 | |
| framebuffer console to VGA console and vice versa, this feature also makes
 | |
| this possible. (NOTE NOTE NOTE: Please read fbcon.txt under Documentation/fb
 | |
| for more details.)
 | |
| 
 | |
| Notes for developers
 | |
| ====================
 | |
| 
 | |
| do_take_over_console() is now broken up into::
 | |
| 
 | |
|      do_register_con_driver()
 | |
|      do_bind_con_driver() - private function
 | |
| 
 | |
| give_up_console() is a wrapper to do_unregister_con_driver(), and a driver must
 | |
| be fully unbound for this call to succeed. con_is_bound() will check if the
 | |
| driver is bound or not.
 | |
| 
 | |
| Guidelines for console driver writers
 | |
| =====================================
 | |
| 
 | |
| In order for binding to and unbinding from the console to properly work,
 | |
| console drivers must follow these guidelines:
 | |
| 
 | |
| 1. All drivers, except system drivers, must call either do_register_con_driver()
 | |
|    or do_take_over_console(). do_register_con_driver() will just add the driver
 | |
|    to the console's internal list. It won't take over the
 | |
|    console. do_take_over_console(), as it name implies, will also take over (or
 | |
|    bind to) the console.
 | |
| 
 | |
| 2. All resources allocated during con->con_init() must be released in
 | |
|    con->con_deinit().
 | |
| 
 | |
| 3. All resources allocated in con->con_startup() must be released when the
 | |
|    driver, which was previously bound, becomes unbound.  The console layer
 | |
|    does not have a complementary call to con->con_startup() so it's up to the
 | |
|    driver to check when it's legal to release these resources. Calling
 | |
|    con_is_bound() in con->con_deinit() will help.  If the call returned
 | |
|    false(), then it's safe to release the resources.  This balance has to be
 | |
|    ensured because con->con_startup() can be called again when a request to
 | |
|    rebind the driver to the console arrives.
 | |
| 
 | |
| 4. Upon exit of the driver, ensure that the driver is totally unbound. If the
 | |
|    condition is satisfied, then the driver must call do_unregister_con_driver()
 | |
|    or give_up_console().
 | |
| 
 | |
| 5. do_unregister_con_driver() can also be called on conditions which make it
 | |
|    impossible for the driver to service console requests.  This can happen
 | |
|    with the framebuffer console that suddenly lost all of its drivers.
 | |
| 
 | |
| The current crop of console drivers should still work correctly, but binding
 | |
| and unbinding them may cause problems. With minimal fixes, these drivers can
 | |
| be made to work correctly.
 | |
| 
 | |
| Antonino Daplas <adaplas@pol.net>
 |