Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751083AbVLIOda (ORCPT ); Fri, 9 Dec 2005 09:33:30 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751055AbVLIOda (ORCPT ); Fri, 9 Dec 2005 09:33:30 -0500 Received: from zproxy.gmail.com ([64.233.162.199]:62560 "EHLO zproxy.gmail.com") by vger.kernel.org with ESMTP id S1750782AbVLIOd3 (ORCPT ); Fri, 9 Dec 2005 09:33:29 -0500 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=beta; d=gmail.com; h=received:message-id:date:from:user-agent:mime-version:to:cc:subject:references:in-reply-to:content-type:content-transfer-encoding; b=fqdgQ6iJkSQ0l4xlSGqUXJdDRnjDOqBwI0z/zAqwbVBxX4uWJVerVesEpHY0wcrXiYYR7KcpF6MUHhd4eNcimFqkyZg6LPsG/FsS64tNeMMa80kY4O9o3BxQiYZPe3UxEz5ITgkUUFI4xsfQIhcnnb0t3sdSKmR8Z33D5LwouRs= Message-ID: <439995A0.7070505@gmail.com> Date: Fri, 09 Dec 2005 22:33:04 +0800 From: "Antonino A. Daplas" User-Agent: Thunderbird 1.5 (X11/20051025) MIME-Version: 1.0 To: Knut Petersen CC: linux-kernel@vger.kernel.org, linux-fbdev-devel@lists.sourceforge.net, Andrew Morton Subject: Re: [PATCH 1/1 2.6.15-rc4-git1] Fix switching to KD_TEXT References: <4398B888.50005@t-online.de> <4398CEAF.9050303@gmail.com> <43997037.4020206@t-online.de> In-Reply-To: <43997037.4020206@t-online.de> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 10091 Lines: 235 Knut Petersen wrote: > Hi Tony! > >> Sorry, NAK for now. Unless other people agree that it is okay for them >> to have an unconditional call to set_par() for every console switch. Note >> that the set_par() in some drivers is terribly slow (several seconds >> at least). >> >> Let's wait a few days, if nobody disagrees with you, so be it. >> >> >> > Which hardware needs several seconds? savagefb does it in 3 seconds. I do remember a few nvidia cards that takes longer. i810fb is okay, it's also in the millisecond range. I do run relatively slow hardware, > but a complete > set_par() needs less than 0.003 seconds with cyblafb. Good for you. > > If there really is hardware that needs _several_ seconds for _one_ > set_par(), then we should > really be more carefull when to call that function. People accept that when switching from X to console and vice versa, it will be slow. It's when switching from a text console to another that needs to be very fast. Inserting a set_par that can take a few to several seconds will eventually become frustrating for people who predominantly work in console mode. > > Let?s have a look at a switch from the framebuffer console to X and back. > > Kernel is a 2.6.15-rc4-git1 with my current cyblafb + your patches > needed for cyblafb > + the patch we are talking about. > > Framebuffer console is 1 with mode 1280x1024, X console is 7 and has > been set to 1024x768 > before X was activated. > > Now I do run "chvt 7;sleep 3;chvt 1" on the vt 1. > > [ 972.360841] [] cyblafb_set_par+0x31/0xd80 > [ 972.360898] [] fb_set_var+0x1e8/0x210 > [ 972.360925] [] fbcon_switch+0x16c/0x690 > [ 972.360951] [] redraw_screen+0xe5/0x1c0 > [ 972.360989] [] complete_change_console+0x2a/0xd0 > [ 972.361018] [] change_console+0x43/0x90 > [ 972.361043] [] console_callback+0xed/0x110 > [ 972.361101] [] worker_thread+0x1ba/0x260 > [ 972.361143] [] kthread+0x95/0xd0 > [ 972.361171] [] kernel_thread_helper+0x5/0x10 > [ 972.361212] cyblafb: Switching to new mode: fbset -g 1024 768 1024 > 768 8 -t 15385 160 24 29 3 136 6 > [ 972.363308] cyblafb: pixclock = 64.99 MHz, k/m/n 1 b 6e > > [ 972.363916] [] cyblafb_set_par+0x31/0xd80 > [ 972.363945] [] fbcon_switch+0x5c9/0x690 > [ 972.363969] [] redraw_screen+0xe5/0x1c0 > [ 972.363996] [] complete_change_console+0x2a/0xd0 > [ 972.364023] [] change_console+0x43/0x90 > [ 972.364047] [] console_callback+0xed/0x110 > [ 972.364093] [] worker_thread+0x1ba/0x260 > [ 972.364121] [] kthread+0x95/0xd0 > [ 972.364143] [] kernel_thread_helper+0x5/0x10 > [ 972.364181] cyblafb: Switching to new mode: fbset -g 1024 768 1024 > 768 8 -t 15385 160 24 29 3 136 6 > [ 972.366271] cyblafb: pixclock = 64.99 MHz, k/m/n 1 b 6e > [ 972.366325] cyblafb: Switching to KD_GRAPHICS > > Not so nice. Now let?s have a look at the log entries caused switching > back to > the framebuffer console: > > This call to set_par() is the result of my patch: > > [ 975.751407] [] cyblafb_set_par+0x31/0xd80 > [ 975.751437] [] fb_set_var+0x1e8/0x210 > [ 975.751462] [] fbcon_switch+0x16c/0x690 > [ 975.751486] [] redraw_screen+0xe5/0x1c0 > [ 975.751513] [] complete_change_console+0x2a/0xd0 > [ 975.751540] [] vt_ioctl+0x103d/0x19b0 > [ 975.751564] [] tty_ioctl+0x18b/0x3d0 > [ 975.751587] [] do_ioctl+0x5a/0x90 > [ 975.751613] [] vfs_ioctl+0x5b/0x1d0 > [ 975.751640] [] sys_ioctl+0x45/0x70 > [ 975.751666] [] syscall_call+0x7/0xb > [ 975.751702] cyblafb: Switching to new mode: fbset -g 1280 1024 > 2048 4096 8 -t 7407 232 16 39 0 160 3 > [ 975.753795] cyblafb: pixclock = 135.00 MHz, k/m/n 0 5 3a > > Without that prior set_par() that?s the point where the enhanced cyblafb > would > have serious problems: As I've mentioned above, this can be easily fixed. > > [ 975.753839] cyblafb_pan_display: entry > [ 975.753853] [] cyblafb_pan_display+0x9c/0xb0 > [ 975.753883] [] fb_pan_display+0x61/0xa0 > [ 975.753925] [] fb_set_var+0xff/0x210 > [ 975.753949] [] fbcon_switch+0x16c/0x690 > [ 975.753973] [] redraw_screen+0xe5/0x1c0 > [ 975.754000] [] complete_change_console+0x2a/0xd0 > [ 975.754027] [] vt_ioctl+0x103d/0x19b0 > [ 975.754051] [] tty_ioctl+0x18b/0x3d0 > [ 975.754074] [] do_ioctl+0x5a/0x90 > [ 975.754100] [] vfs_ioctl+0x5b/0x1d0 > [ 975.754127] [] sys_ioctl+0x45/0x70 > [ 975.754153] [] syscall_call+0x7/0xb > > Again a call to set_par: > > [ 975.754744] [] cyblafb_set_par+0x31/0xd80 > [ 975.754773] [] fbcon_switch+0x5c9/0x690 > [ 975.754796] [] redraw_screen+0xe5/0x1c0 > [ 975.754823] [] complete_change_console+0x2a/0xd0 > [ 975.754850] [] vt_ioctl+0x103d/0x19b0 > [ 975.754875] [] tty_ioctl+0x18b/0x3d0 > [ 975.754917] [] do_ioctl+0x5a/0x90 > [ 975.754943] [] vfs_ioctl+0x5b/0x1d0 > [ 975.754970] [] sys_ioctl+0x45/0x70 > [ 975.754996] [] syscall_call+0x7/0xb > [ 975.755032] cyblafb: Switching to new mode: fbset -g 1280 1024 > 2048 4096 8 -t 7407 232 16 39 0 160 3 > [ 975.757123] cyblafb: pixclock = 135.00 MHz, k/m/n 0 5 3a > > Now the save_state() function is called: > > [ 975.757745] cyblafb: Switching to KD_TEXT > > and again a call to set_par(): > > [ 975.757759] [] cyblafb_set_par+0x31/0xd80 > [ 975.757789] [] fb_set_var+0x1e8/0x210 > [ 975.757813] [] fbcon_blank+0x11a/0x1b0 > [ 975.757837] [] do_unblank_screen+0x67/0x120 > [ 975.757869] [] complete_change_console+0x40/0xd0 > [ 975.757955] [] vt_ioctl+0x103d/0x19b0 > [ 975.757979] [] tty_ioctl+0x18b/0x3d0 > [ 975.758002] [] do_ioctl+0x5a/0x90 > [ 975.758029] [] vfs_ioctl+0x5b/0x1d0 > [ 975.758055] [] sys_ioctl+0x45/0x70 > [ 975.758081] [] syscall_call+0x7/0xb > [ 975.758117] cyblafb: Switching to new mode: fbset -g 1280 1024 > 2048 4096 8 -t 7407 232 16 39 0 160 3 > [ 975.760205] cyblafb: pixclock = 135.00 MHz, k/m/n 0 5 3a > > And now, the be really shure, again, a call to set_par(): > > [ 975.760827] [] cyblafb_set_par+0x31/0xd80 > [ 975.760856] [] fbcon_switch+0x5c9/0x690 > [ 975.760880] [] redraw_screen+0xe5/0x1c0 > [ 975.760923] [] fbcon_blank+0x176/0x1b0 > [ 975.760947] [] do_unblank_screen+0x67/0x120 > [ 975.760976] [] complete_change_console+0x40/0xd0 > [ 975.761002] [] vt_ioctl+0x103d/0x19b0 > [ 975.761027] [] tty_ioctl+0x18b/0x3d0 > [ 975.761050] [] do_ioctl+0x5a/0x90 > [ 975.761076] [] vfs_ioctl+0x5b/0x1d0 > [ 975.761102] [] sys_ioctl+0x45/0x70 > [ 975.761129] [] syscall_call+0x7/0xb > [ 975.761164] cyblafb: Switching to new mode: fbset -g 1280 1024 > 2048 4096 8 -t 7407 232 16 39 0 160 3 > [ 975.763280] cyblafb: pixclock = 135.00 MHz, k/m/n 0 5 3a > > First of all: set_par is executed too often. With and without my patch. > > If we would know that vt x is nothing but the vt used for X, we could > introduce a policy > to completely ignore all framebuffer operations for that console. That > also would result > in a much nicer look of the modeswitch. Do we need a new kernel > parameter or should > this be implemented by detected which vt is switched to KD_GRAPHICS? I've tried this before, it is ugly. > > Switching from X to the console could be optimized a lot, I?m shure that > you do agree. > We do need _one_ call to set_par() etc, but this must be at the right > place. And the right > place is somewhere before any other driver operation is called, with the > exception of > check_var() and init functions obviously. The problem is that the console code has so many pathways that it is difficult to find the correct moment to call a set_par. Especially since there are so many cases where it's illegal for the console to write to the framebuffer. Think KD_GRAPHICS, hardware/software suspend, hardware initialization, etc. Think also that the hardware can be change by the kernel (via stty) and by the user (via fbset, etc). Yes, we can optimize the code pathways so we minimize calls to set_par and set_var, but remember that just a few kernel versions ago, fbcon/ fbdev was plagued with bugs, so bug fixing was the priority, not code optimization. Nowadays, core fbdev and fbcon looks pretty stable so we can redirect our effort towards this goal. > > Think about your NAK carefully. I might submit a patch to skeletonfb.c > that inserts > a warning at all places that might be unexpectedly called with a > hardware state different > to that set by set_par(). ;-)))) Go ahead. Only pan_display, I believe, currently has this problem. And again, the fix is simple. > > And please don?t argue that X or certain releases are broken. That is > true, but ordinary > users will use those broken versions for years. I'm not arguing that. However, we can always work around this buggy implementation. For example, one can do an echo 1 > /sys/class/graphics/fb0/state before kdm (the buggy one that forgets to set KD_GRAPHICS) is called. Tony - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/