fbsplash is a Gentoo implementation of a bootsplash screen to provide some eye candy during boot up, shut down or while working on a terminal without X. It is currently available in portage as media-gfx/splashutils. A more modern alternative that also offers systemd support, but no eye-candy on the terminal is Plymouth.
- 1 Installation
- 2 Usage
- 2.1 Themes
- 2.2 Creating and updating an initramfs image
- 2.3 Bootloader
- 3 Screenshot
- 4 Troubleshooting
You can install media-gfx/splashutils with the following command:
To also install the Gentoo themes which are also used on the Live CD/DVD:
And more themes with:
The build might fail, because many libraries need to have static libraries to be available at boot time, here is a list of USE flags which could be put into /etc/portage/package.use (03/07/2012):
Remember to update the packages after changing the USE flags:
|hardened||No||No||activate default security enhancements for toolchain (gcc, glibc, binutils)|
|png||Yes||Yes||Adds support for libpng (PNG images)|
|truetype||Yes||Yes||Adds support for FreeType and/or FreeType2 fonts|
|mng||Yes||Yes||Adds support for libmng (MNG images)|
|gpm||No||Adds support for sys-libs/gpm (Console-based mouse driver)|
|fbcondecor||No||Yes||Support for the fbcondecor kernel patch.|
To use a splash image the kernel needs to support initramfs and it must also support framebuffer console decorations.
Normally, gentoo-sources have already been patched to support framebuffer console decorations. If you have picked a different kernel, you might have to patch it first using genpatches. Some other kernels like tuxonice-sources have already been patched and are ready to use, though. Enable framebuffer console decorations:
Remember that selecting the type of framebuffer device is important and affects your system. If you plan to use open-source graphics drivers, you can enable the appropriate device here, for example, for radeon driver you can enable ATI Radeon display support and so forth. However, if you are going to install proprietary drivers for your graphics card, you will likely have to rely on either Userspace VESA VGA graphics support or Simple framebuffer support. There is an option for EFI-based Framebuffer Support, too, in case you need it.
Thus, using either radeon, intel or nouveau drivers provides a framebuffer capable device which is well implemented into the operating system. For users with the binary nVidia or AMD driver, there are workarounds using uvesafb or simple framebuffer to get frambuffer support.
Next, enable Keyboard support for framebuffer themes:
General usage screnarios.
The different themes are stored in /etc/splash where the folder represents the theme name. To test some of them on the console use:
This will change the theme on tty1 to natural_gentoo. You can choose any theme in /etc/splash that matches your current resolution. Now to see the theme go to tty1 by pressing Ctrl+Alt+F1.
If you want to preview a theme in silent mode without reboot, then try
For more reference please refer to
Creating and updating an initramfs image
You should add fbcondecor service to boot:
This way fbsplash would start when the system starts. However, the eye-candy would not be available immadiately after boot and there would be some lag. Using an initramfs is the remedy to have it early at boot. Thus, we are going to make an initramfs.
Before you proceed, you must choose the theme and the resolution you want. While it seems trivial, the point is that not every theme you want might support your desired resolution. More important than this, the resolution that you want, might not be supported by the framebuffer device. So there are two steps to be done.
Finding the resolutions supported by the framebuffer device
Reveal the supported resolutions by your framebuffer device by issuing the following cammand:
If you have selected simple frame buffer device support in kernel, you do not need to do this step. Please refer to the troubleshooting section.
Finding a theme with the supported resolution
Next, choose a theme that supports the resolution you want. For example, to find out which themes support fullhd resolution:
If the initramfs is created using genkernel, the configuration in /etc/genkernel.conf should be changed to the theme used.
Alternatively the /etc/conf.d/splash could be used to configure the theme, which will be loaded after initramfs.
Updating an initramfs image without using genkernel
If you have an existing initramfs (like one you have created with dracut) you want to use this feature. To append the theme to an existing initramfs:
Creating an initramfs image without using genkernel
To create a new initramfs for our theme:
To create a new initramfs with the content of an existing one to add our theme:
In GRUB2 the parameters can be added to the variable GRUB_CMDLINE_LINUX_DEFAULT in /etc/default/grub.
This enables the verbose version of the emerge-world theme, a full list of parameters can be found in /usr/share/doc/splashutils*/kernel_parameters. The parameter video=1920x1080 is optional, but will choose the proper resolution for the image.
To make screenshots of the framebuffer console, the tool media-gfx/fbgrab can be used:
The theme does not load at boot
First, check if you have built the initramfs with the supported resolution. Maybe the device does not support it, or maybe the theme does not have any configuration files for it. Another possibility is that the initramfs is not loaded at boot.
The screen stays black until X starts
Disable every framebuffer device in kernel and enable only simple framebuffer one.
The device does not support the desired resolution
This is a limitation in the device if the reolution you want is not listed among the supported modes. Fortunately, there is a workaround -- simply disable every framebuffer device and enable simple frame buffer device.
Of course, replace the resolution with whatever you would like and rebuild grub2 configuration file by issuing:
Enjoy the eye-candy.