[PATCH v3] fbcon: Silence fbcon logo on 'quiet' boots
Prarit Bhargava
prarit at redhat.com
Tue Oct 30 22:31:15 UTC 2018
On 10/30/2018 05:35 PM, Steven Rostedt wrote:
> I guess you we not very productive with that first patch ;-)
>
Hah :) It was a LONG day. :)
P.
> -- Steve
>
>
> On October 30, 2018 5:44:19 PM GMT+02:00, Prarit Bhargava <prarit at redhat.com> wrote:
>> On text-based systems the 'quiet' boot option will show printk levels
>> higher than CONSOLE_LOGLEVEL_QUIET. The displaying of the Tux logo
>> during boot can cause some consoles to lose display data and as a
>> result
>> confuse the end user.
>>
>> Do not display the Tux logo on systems that are in 'quiet' boot.
>>
>> v2: It helps to commit all my changes before sending them. Remove
>> extra
>> bracket.
>> v3: buildbot error fix: fbcon can be built as part of a module so
>> export console_printk
>>
>> Signed-off-by: Prarit Bhargava <prarit at redhat.com>
>> Cc: Hans de Goede <hdegoede at redhat.com>
>> Cc: Marko Myllynen <myllynen at redhat.com>
>> Cc: Steven Rostedt (VMware) <rostedt at goodmis.org>
>> Cc: Bartlomiej Zolnierkiewicz <b.zolnierkie at samsung.com>
>> Cc: Kees Cook <keescook at chromium.org>
>> Cc: Daniel Vetter <daniel.vetter at ffwll.ch>
>> Cc: Thierry Reding <treding at nvidia.com>
>> Cc: Yisheng Xie <ysxie at foxmail.com>
>> Cc: dri-devel at lists.freedesktop.org
>> ---
>> drivers/video/fbdev/core/fbcon.c | 13 ++++++++-----
>> kernel/printk/printk.c | 1 +
>> 2 files changed, 9 insertions(+), 5 deletions(-)
>>
>> diff --git a/drivers/video/fbdev/core/fbcon.c
>> b/drivers/video/fbdev/core/fbcon.c
>> index 8958ccc8b1ac..08e092eaf45c 100644
>> --- a/drivers/video/fbdev/core/fbcon.c
>> +++ b/drivers/video/fbdev/core/fbcon.c
>> @@ -649,11 +649,14 @@ static void fbcon_prepare_logo(struct vc_data
>> *vc, struct fb_info *info,
>> kfree(save);
>> }
>>
>> + if (logo_shown == FBCON_LOGO_DONTSHOW)
>> + return;
>> +
>> if (logo_lines > vc->vc_bottom) {
>> logo_shown = FBCON_LOGO_CANSHOW;
>> printk(KERN_INFO
>> "fbcon_init: disable boot-logo (boot-logo bigger than
>> screen).\n");
>> - } else if (logo_shown != FBCON_LOGO_DONTSHOW) {
>> + } else {
>> logo_shown = FBCON_LOGO_DRAW;
>> vc->vc_top = logo_lines;
>> }
>> @@ -1051,7 +1054,7 @@ static void fbcon_init(struct vc_data *vc, int
>> init)
>> struct vc_data **default_mode = vc->vc_display_fg;
>> struct vc_data *svc = *default_mode;
>> struct display *t, *p = &fb_display[vc->vc_num];
>> - int logo = 1, new_rows, new_cols, rows, cols, charcnt = 256;
>> + int new_rows, new_cols, rows, cols, charcnt = 256;
>> int cap, ret;
>>
>> if (info_idx == -1 || info == NULL)
>> @@ -1059,9 +1062,9 @@ static void fbcon_init(struct vc_data *vc, int
>> init)
>>
>> cap = info->flags;
>>
>> - if (vc != svc || logo_shown == FBCON_LOGO_DONTSHOW ||
>> + if (vc != svc || console_loglevel <= CONSOLE_LOGLEVEL_QUIET ||
>> (info->fix.type == FB_TYPE_TEXT))
>> - logo = 0;
>> + logo_shown = FBCON_LOGO_DONTSHOW;
>>
>> if (var_to_display(p, &info->var, info))
>> return;
>> @@ -1176,7 +1179,7 @@ static void fbcon_init(struct vc_data *vc, int
>> init)
>> } else
>> vc_resize(vc, new_cols, new_rows);
>>
>> - if (logo)
>> + if (logo_shown != FBCON_LOGO_DONTSHOW)
>> fbcon_prepare_logo(vc, info, cols, rows, new_cols, new_rows);
>>
>> if (vc == svc && softback_buf)
>> diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c
>> index b77150ad1965..391e390feac9 100644
>> --- a/kernel/printk/printk.c
>> +++ b/kernel/printk/printk.c
>> @@ -66,6 +66,7 @@ int console_printk[4] = {
>> CONSOLE_LOGLEVEL_MIN, /* minimum_console_loglevel */
>> CONSOLE_LOGLEVEL_DEFAULT, /* default_console_loglevel */
>> };
>> +EXPORT_SYMBOL(console_printk);
>>
>> atomic_t ignore_console_lock_warning __read_mostly = ATOMIC_INIT(0);
>> EXPORT_SYMBOL(ignore_console_lock_warning);
>
More information about the dri-devel
mailing list