On Sat, Mar 27, 2010 at 11:49:34AM +0200, Anton Zinoviev wrote: > On Sat, Mar 27, 2010 at 08:48:17AM +0100, Daniel Baumann wrote: > > reassigning, hopefully the initscript can be fixed/updated/changed > > in keyboard-configuration. > There is nothing wrong in the script. It does what it is supposed to do > - it sets the console. Apparently loading a font on the console is > incompatible with graphical boot screens. Console-setup has some checks > disabling it when splashy or usplash are active and now plymouth is a > third case. Colin Watson has worked through the console-setup and plymouth incompatibilites in Ubuntu; the work won't directly apply because the implementation depends on upstart (splitting the init script into an upstart job + a udev rule), but perhaps the comments in the udev helper will be useful to you: # We have to do several basic things here, each of which has specific state # requirements: # # 1) Set Unicode/non-Unicode mode on each virtual console. # # The terminal line emulation on the virtual console must not be in raw # mode (as in cfmakeraw). # # 2) Set the font and ACM on each virtual console. # # The virtual console must not be in KD_GRAPHICS mode. If using vgacon, # the *foreground* virtual console must not be in KD_GRAPHICS mode either # as then we'll corrupt video memory. # # 3) Set the keyboard mode on each virtual console to K_XLATE or K_UNICODE # as appropriate. # # The virtual console must not be in K_RAW or K_MEDIUMRAW mode. # # We don't have to set the console keymap here. This only needs to be done # once after setting the keyboard mode, so it belongs in an Upstart job # instead. The full udev rule and helper are attached for reference. (OTOH, I'm not sure we ever saw the described hang in Ubuntu - my understanding is the fonts would simply fail to be set. Perhaps this is actually caused by the version of plymouth in experimental being significantly out of date.) Cheers, -- Steve Langasek Give me a lever long enough and a Free OS Debian Developer to set it on, and I can move the world. Ubuntu Developer http://www.debian.org/ slangasek@ubuntu.com vorlon@debian.org
#! /bin/sh
set -e
# Based on setupcon, but stripped down for use in a udev rule.
# We have to do several basic things here, each of which has specific state
# requirements:
#
# 1) Set Unicode/non-Unicode mode on each virtual console.
#
# The terminal line emulation on the virtual console must not be in raw
# mode (as in cfmakeraw).
#
# 2) Set the font and ACM on each virtual console.
#
# The virtual console must not be in KD_GRAPHICS mode. If using vgacon,
# the *foreground* virtual console must not be in KD_GRAPHICS mode either
# as then we'll corrupt video memory.
#
# 3) Set the keyboard mode on each virtual console to K_XLATE or K_UNICODE
# as appropriate.
#
# The virtual console must not be in K_RAW or K_MEDIUMRAW mode.
#
# We don't have to set the console keymap here. This only needs to be done
# once after setting the keyboard mode, so it belongs in an Upstart job
# instead.
export PATH="/bin:/sbin:$PATH"
. /etc/default/console-setup
setup_unicode () {
# Set up Unicode/non-Unicode mode.
# TODO: this will probably break something if terminal line emulation is
# in raw mode.
if [ "$CHARMAP" = UTF-8 ] || [ -z "$ACM$CHARMAP" ]; then
printf '\033%%G' >"$1"
else
printf '\033%%@' >"$1"
fi
}
setup_font () {
# Set the font and ACM. setfont will silently do nothing for a console
# in graphics mode.
SETFONT_ARGS=
if [ "$FONT" ]; then
FONT="/etc/console-setup/${FONT##*/}"
FONT="${FONT%.gz}"
else
FONT="/etc/console-setup/$CODESET-$FONTFACE$FONTSIZE.psf"
fi
if [ -f "$FONT" ]; then
SETFONT_ARGS="${SETFONT_ARGS:+$SETFONT_ARGS }$FONT"
fi
if [ "$ACM" ]; then
ACM="/etc/console-setup/${ACM##*/}"
ACM="${ACM%.gz}"
else
ACM="/etc/console-setup/$CHARMAP.acm"
fi
if [ -f "$ACM" ]; then
SETFONT_ARGS="${SETFONT_ARGS:+$SETFONT_ARGS }-m $ACM"
fi
if [ "$SETFONT_ARGS" ]; then
setfont -C "$1" $SETFONT_ARGS
fi
}
setup_keyboard_mode () {
# Set the keyboard mode.
# TODO: this will probably break something if the console is in K_RAW or
# K_MEDIUMRAW mode. There doesn't seem to be a non-racy way to say "set
# to K_UNICODE only if currently K_XLATE".
if [ "$CHARMAP" = UTF-8 ] || [ -z "$ACM" ]; then
kbd_mode -u <"$1"
else
kbd_mode -a <"$1"
fi
}
if [ "$1" = fbcon ]; then
# Technically we have to wait for /dev/tty[1-6] to appear; but these are
# created in vty_init, so I think it will always be early enough. If
# I'm wrong, then the -w test will fail and we end up with the wrong
# fonts on some virtual consoles; the user can run setupcon to fix it.
for console in $ACTIVE_CONSOLES; do
if [ -w "$console" ]; then
setup_font "$console"
fi
done
else
if [ -w "$1" ]; then
setup_unicode "$1"
setup_font "$1"
setup_keyboard_mode "$1"
fi
fi
exit 0
# Set up a single virtual console. SUBSYSTEM=="tty", KERNEL=="tty[1-6]", RUN+="console-setup-tty /dev/%k" # Framebuffer console created. Set up the font on all virtual consoles # again. This races with Plymouth if fbcon is built into the kernel; but # the worst case should simply be that fonts don't get set up properly. SUBSYSTEM=="graphics", KERNEL=="fbcon", RUN+="console-setup-tty fbcon"
Attachment:
signature.asc
Description: Digital signature