public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* console.c unblank_screen problem
@ 2001-03-25 16:40 Benjamin Herrenschmidt
  2001-03-31  0:15 ` Recent problems with APM and XFree86-4.0.1 Jamie Lokier
  0 siblings, 1 reply; 8+ messages in thread
From: Benjamin Herrenschmidt @ 2001-03-25 16:40 UTC (permalink / raw)
  To: Linux Frame Buffer Device Development, Linux Kernel Development

There is a problem with the power management code for console.c

The current code calls do_blank_screen(0); on PM_SUSPEND, and
unblank_screen() on PM_RESUME.

The problem happens when X is the current display while putting the
machine to sleep. The do_blank_screen(0) code will do nothing as
the console is not in KD_TEXT mode.
However, unblank_screen has no such protection. That means that
on wakeup, the cursor timer & console blank timers will be re-enabled
while X is frontmost, causing the blinking cursor to be displayed on
top of X, and other possible issues.

I hacked the following pacth to work around this. It appear to work
fine, but since the console code is pretty complex, I'm not sure about
possible side effects and I'd like some comments before submiting it
to Linus:

(Don't worry about the {} I added, I just noticed them and will remove
them before submitting ;)

--- 1.2/drivers/char/console.c	Sat Feb 10 18:54:15 2001
+++ edited/drivers/char/console.c	Sun Mar 25 17:57:46 2001
@@ -2595,8 +2595,9 @@
 	int currcons = fg_console;
 	int i;
 
-	if (console_blanked)
+	if (console_blanked) {
 		return;
+	}
 
 	/* entering graphics mode? */
 	if (entering_gfx) {
@@ -2660,12 +2661,16 @@
 		printk("unblank_screen: tty %d not allocated ??\n", fg_console+1);
 		return;
 	}
+	currcons = fg_console;
+	if (vcmode != KD_TEXT) {
+		console_blanked = 0;
+		return;
+	}
 	console_timer.function = blank_screen;
 	if (blankinterval) {
 		mod_timer(&console_timer, jiffies + blankinterval);
 	}
 
-	currcons = fg_console;
 	console_blanked = 0;
 	if (console_blank_hook)
 		console_blank_hook(0);



^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2001-04-03  6:36 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2001-03-25 16:40 console.c unblank_screen problem Benjamin Herrenschmidt
2001-03-31  0:15 ` Recent problems with APM and XFree86-4.0.1 Jamie Lokier
2001-03-31  5:37   ` Stephen Rothwell
2001-03-31 14:25     ` Jamie Lokier
2001-04-01 21:41       ` Jamie Lokier
2001-04-01 22:31         ` Rafael E. Herrera
2001-04-02 12:42           ` Jamie Lokier
2001-04-03  6:35     ` Alain E.

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox