2  * drivers/power/process.c - Functions for saving/restoring console.
 
   4  * Originally from swsusp.
 
   7 #include <linux/vt_kern.h>
 
   8 #include <linux/kbd_kern.h>
 
   9 #include <linux/console.h>
 
  10 #include <linux/module.h>
 
  13 #if defined(CONFIG_VT) && defined(CONFIG_VT_CONSOLE)
 
  14 #define SUSPEND_CONSOLE (MAX_NR_CONSOLES-1)
 
  16 static int orig_fgconsole, orig_kmsg;
 
  17 static int disable_vt_switch;
 
  20  * Normally during a suspend, we allocate a new console and switch to it.
 
  21  * When we resume, we switch back to the original console.  This switch
 
  22  * can be slow, so on systems where the framebuffer can handle restoration
 
  23  * of video registers anyways, there's little point in doing the console
 
  24  * switch.  This function allows you to disable it by passing it '0'.
 
  26 void pm_set_vt_switch(int do_switch)
 
  28         acquire_console_sem();
 
  29         disable_vt_switch = !do_switch;
 
  30         release_console_sem();
 
  32 EXPORT_SYMBOL(pm_set_vt_switch);
 
  34 int pm_prepare_console(void)
 
  36         acquire_console_sem();
 
  38         if (disable_vt_switch) {
 
  39                 release_console_sem();
 
  43         orig_fgconsole = fg_console;
 
  45         if (vc_allocate(SUSPEND_CONSOLE)) {
 
  46           /* we can't have a free VC for now. Too bad,
 
  47            * we don't want to mess the screen for now. */
 
  48                 release_console_sem();
 
  52         if (set_console(SUSPEND_CONSOLE)) {
 
  54                  * We're unable to switch to the SUSPEND_CONSOLE.
 
  55                  * Let the calling function know so it can decide
 
  58                 release_console_sem();
 
  61         release_console_sem();
 
  63         if (vt_waitactive(SUSPEND_CONSOLE)) {
 
  64                 pr_debug("Suspend: Can't switch VCs.");
 
  67         orig_kmsg = kmsg_redirect;
 
  68         kmsg_redirect = SUSPEND_CONSOLE;
 
  72 void pm_restore_console(void)
 
  74         acquire_console_sem();
 
  75         if (disable_vt_switch) {
 
  76                 release_console_sem();
 
  79         set_console(orig_fgconsole);
 
  80         release_console_sem();
 
  81         kmsg_redirect = orig_kmsg;