Commit graph

1754 commits

Author SHA1 Message Date
Ray Strode
63737f30c8 systemd: add plymouth-switch-root.service
This service file is needed by systemdized dracut to ensure we properly
transition from the initrd to the root file system
2012-07-23 17:37:03 -04:00
Ray Strode
88c2e7dcf8 systemd: more updates to start service
The dashes next to the semi-colons seem to confuse systemd so drop them.
2012-07-23 17:37:03 -04:00
Frederic Crozat
edde4e0f2b systemd: create missing links various targets 2012-07-21 03:22:37 -04:00
Ray Strode
906477ce30 systemd: make sure plymouth-start never gets killed
systemd tries to bring down the world when going from
the initramfs to /

commit 9e5a276f32 tried
to prevent plymouthd from getting killed by settings
argv[0][0] to @

This isn't seemingly sufficient.  Throw some lines into
the plymouth-start service file that should hopefully help.
2012-07-17 17:12:03 -04:00
Ray Strode
6fac021e66 populate-initrd: put plymouthd in /sbin not /bin
This matches what we do post-boot better
2012-07-17 17:09:43 -04:00
Ray Strode
570f722106 configure: bump to 0.8.6.1 2012-07-10 10:18:13 -04:00
Ray Strode
d7aa800c39 systemd: unfoul up Makefile
The previous systemd commit introduced a file named

systemd-ask-password-plymouth.path.in

The makefile was only looking for .service.in files
when stripping the .in suffix, so it got installed
incorrectly.

This commit fixes up the Makefile.
2012-07-10 10:17:50 -04:00
Ray Strode
5039ab6866 configure: bump to 0.8.6 2012-07-10 10:16:13 -04:00
Ray Strode
76d0db51c2 systemd: add two more files
When plymouth service files were moved from systemd to plymouth
two files got lost in the shuffle.

This commit adds them.

http://bugzilla.freedesktop.org/51573
2012-07-09 11:59:59 -04:00
David Herrmann
72b7e73490 frame-buffer: fix flush_area fast-path
plymouth uses a shadow framebuffer to cache screen contents for
quick compositing.  This shadow framebuffer may or may not have
the same memory layout as the hardware framebuffer.  In cases
where the size and layout of pixels are the same between the shadow
framebuffer and the hardware framebuffer we can memcpy()
the pixels line-by-line to the hardware.  If the width of area being
flushed is the same number of bytes as the width of the hardware buffer,
then we can memcpy() the entire flush area in one call to memcpy.

The check for this latter fast-path has a miscalculation that tests
the number of pixels in the flush area width to number of bytes in the
buffer width. This commit adds the * 4 multiplier to correctly compare
bytes with bytes instead of pixels with bytes.

This commit also adds a sanity check to make sure the byte size of the
hardware framebuffer width is equal to the advertised row stride.
2012-06-25 11:32:56 -04:00
Ray Strode
675553481d systemd: more udev clean ups
The udev trigger calls that are there, are actually
spurious.  udev will coldplug those subsystems at
start up anyway, so doing it explicitly is wrong.

This commit drops those trigger calls.

What does matter is the udevadm settle call. It's
what makes things block until the graphics driver
is loaded.

udevadm settle is a big sledgehammer, though. It blocks
until all the triggered events (even stuff unrelated to
graphics) are finished.

This commit adds a --exit-if-exists argument to udevadm settle,
so it will bail early as soon as the graphics devices
are up.
2012-06-20 11:57:06 -04:00
Ray Strode
b8031858cd systemd: drop weird udev trigger --attr-match=class=0x030000
plymouth-start.service does this sort of hacky
"udevadm trigger" stuff before doing plymouth show-splash,
to ensure plymouth show-splash is called after the
graphcis subsystem is up.

It actually does two calls:

- one call that triggers any pci devices with the class
0x030000 (which is "vga compatible display device")
- another call that triggers the gpu subsystem

The first call is borrowed from dracut:

http://dracut.git.sourceforge.net/git/gitweb.cgi?p=dracut/dracut;a=commitdiff;h=2c02c8318

and I can't find any historical context on why its needed.  As I
understand things, the latter should be a superset of the former.
Furthermore, the first trigger is missing a --subsystem-match=pci call
so it's matching the "class" attribute in every subsystem, which is slow.

I'm going to drop the first trigger until I start hitting problems
and need to add it back.
2012-06-20 11:19:05 -04:00
Ray Strode
0fd2406991 Revert "systemd: add --subsystem=pci to udevadm trigger call"
This reverts commit cf90d3c7fa.

It was wrong. I misunderstood what Kay told me.
2012-06-20 11:01:07 -04:00
Ray Strode
cf90d3c7fa systemd: add --subsystem=pci to udevadm trigger call
plymouth-start.service does this sort of hacky
"udevadm trigger" call before doing plymouth show-splash,
to ensure plymouth show-splash is called after the
graphcis subsystem is up.  Because this udev trigger call
only passes --subsystem-match calls with no corresponding
--subsystem call, it will trawl through all subsystems in
/sys rather than just the pci subsystem (where all the matches
are guaranteed to be).

This commit adds --subsystem=pci to stop doing that extra work.

All of this will eventually be replaced with plymouthd either
listening for the udev  events itself (or potentially logind,
if logind gains a way to tag a "graphics" capability on a seat).
2012-06-20 10:48:26 -04:00
Ray Strode
57fab85b26 text-progress-bar: Initial os-string to "" when can't be read
get_os_string either returns a string describing the distribution,
or NULL on error.

This NULL later causes problems since we run strlen on it.

This commit makes get_os_string return "" instead of NULL for error
cases.

Spotted by Andreas Henriksson.
2012-06-13 06:58:40 -04:00
Richard Hughes
59e76062da two-step: implement the system-update command
https://bugs.freedesktop.org/show_bug.cgi?id=50876
2012-06-08 18:47:41 -04:00
Richard Hughes
cef67c3f5d main: add a system-update command that can pass update progress to the daemon
https://bugs.freedesktop.org/show_bug.cgi?id=50876
2012-06-08 18:47:41 -04:00
Richard Hughes
0880f04eab main: add a change-mode command to be able to switch the splash mode at runtime
https://bugs.freedesktop.org/show_bug.cgi?id=50847
2012-06-08 18:14:40 -04:00
Richard Hughes
d5ad5d3db8 main: add an 'updates' mode for installing offline updates
https://bugs.freedesktop.org/show_bug.cgi?id=50847
2012-06-08 18:14:39 -04:00
Richard Hughes
02c5967577 libply: remove the unused SPLASH_MODE_SUSPEND and SPLASH_MODE_RESUME
https://bugs.freedesktop.org/show_bug.cgi?id=50847
2012-06-08 18:14:38 -04:00
Richard Hughes
5437420a2e main: show the correct trace message if a message is supressed
https://bugs.freedesktop.org/show_bug.cgi?id=50845
2012-06-08 18:12:14 -04:00
Richard Hughes
e4a1a05e3c throbgress plugin: show messages in the top left corner
https://bugs.freedesktop.org/show_bug.cgi?id=50845
2012-06-08 18:12:13 -04:00
Richard Hughes
3c72dd09f2 space-flares plugin: show messages in the top left corner
https://bugs.freedesktop.org/show_bug.cgi?id=50845
2012-06-08 18:12:11 -04:00
Richard Hughes
b659612249 fade-throbber plugin: show messages in the top left corner
https://bugs.freedesktop.org/show_bug.cgi?id=50845
2012-06-08 18:12:07 -04:00
Ray Strode
8593c039ae configure: make gtk optional
https://bugs.freedesktop.org/show_bug.cgi?id=42047
2012-06-08 17:21:23 -04:00
Ray Strode
3f8bd998dc script: seed random number generator
Most splash plugins that use random numbers
seed the random number generator with the
current time, but script fails, too.

This commit fixes that.

https://bugs.freedesktop.org/show_bug.cgi?id=42632
2012-06-08 16:52:29 -04:00
Ray Strode
bb46ffb90a splash: drop SIGINT handlers
They serve no real purpose.

https://bugs.freedesktop.org/show_bug.cgi?id=42285
2012-06-08 15:11:52 -04:00
Ray Strode
251ddbfe7a configure: bump to 0.8.5.1 2012-06-06 16:21:53 -04:00
Ray Strode
c845948412 configure: allow building drm renderer without driver dependent backends
Since we support the dumb ioctl now, it's useful to build the drm
renderer without support for the individual drivers.

This commit allows for that.
2012-06-06 16:21:53 -04:00
Ray Strode
8e932e9895 configure: don't build intel/radeon/nouveau/libkms drivers by default
Now that we have the dumb ioctl there's little reason to build
these guys, since it's just as good.

I'll probably drop the code entirely soon.
2012-06-06 15:17:02 -04:00
Ray Strode
d80a23cb59 populate-initrd: don't depend on inst from mkinitrd/dracut
Having the dependency is awkward and causes problems, so
don't bother.

This commit just copy and pastes the relevant bits for
inst().

Ideally, this would be an installroot command implemented in
C in util-linux, but shrug
2012-06-06 15:10:35 -04:00
Ray Strode
f7f482174f two-step: set is_idle=TRUE at shutdown time
Right now, we do the end animation immediately if in
shutdown mode.  This is because shutdown is fast,
and we don't try to estimate how long it will take.

The code depends on is_idle being true after the end
animation is run, but we neglect to do that in the
shutdown case.

This commit makes shutdown mode just call
"become_idle" right away, and deletes the duplicated
shutdown code path.
2012-06-06 10:13:00 -04:00
Ray Strode
171c329f40 drm: flush pending draw to kernel buffer on vt switch
When plymouth's VT is not the foreground VT, we tell the
kernel not to scan out from the kernel buffer we manage.
Also, we don't bother dispatching rendering to the kernel
buffer (since it's not getting scanned out anyway).

When plymouth's VT becomes the foreground VT, we tell the
kernel to start scanning out from our buffer again.
Unfortunately, we neglect to flush all the pending drawing
that happens while VT switched away.

This means we briefly show stale contents.

This commit flushes all pending rendering to the kernel,
before resetting the scan out buffer, so we get a current
view of the splash shown immediately.
2012-06-06 10:13:00 -04:00
Ray Strode
64ccdadae8 drm: don't set mode initially if on different vt
In the shutdown path we start out on a different
vt than where the splash is drawn.  Make sure we
don't set a mode until the jump.

This prevents unnecessary flicker.
2012-06-06 10:13:00 -04:00
Ray Strode
4587ac4c31 Revert "main: force frame-buffer plugin at shutdown"
This reverts commit 3f14f2700e.

Forcing frame-buffer plugin makes multi-monitor look really bad.
Instead, depend on the init system to make sure we stay alive
until the end.
2012-06-06 10:13:00 -04:00
Ray Strode
29f832fc74 systemd: pull units from systemd tree
Kay and Lenny want the service files shipped with plymouth
instead of systemd, so toss them into the tree.
2012-06-06 10:12:59 -04:00
Ray Strode
9e5a276f32 main: rename process to be more systemd friendly
Systemd will cleanse the system of running processes
in the hand over from the initrd to the main root filesystem,
and at shutdown.

In both cases we want to keep on chugging, so we tag ourselves
in a way that systemd won't kill us.

See http://www.freedesktop.org/wiki/Software/systemd/RootStorageDaemons
2012-06-06 13:58:09 -04:00
Kevin Murphy
cdbfba5364 drm: for minimum buffer size to be greater than 0
The drm driver tells us the minimum dimensions it supports
for buffer objects.  We use this minimum for creating a
small temporary 32-bit buffer to test if 32-bit buffers
are supported.

Unfortunately, some drivers neglect to fill in
min_width/min_height and then we try to allocate a buffer
with 0 sized dimensions.

This commit checks for min_width/min_height being 0, and then
bumps them to 1.

Minor changes to initial patch by Ray Strode.
2012-05-11 11:54:05 -04:00
Steve Langasek
e274cda1ee client: add new flush api
In some cases, clients may need a way to ensure that all queued
messages have been flushed and are sent to the daemon
(before, for instance, exiting).

This commit adds an API to block until the outgoing request queue is
empty.
2012-05-11 08:48:02 -04:00
Dr. Tilmann Bubeck
23fa0e8eea docs: Add keyboard shortcuts
This commit adds four keyboard shortcuts to the developer
documentation that were found from reading the source:

Esc: Toggle between system console and plymouth boot animation.

Ctrl-V: Toogle verbose mode on and off.

Ctrl-U or Ctrl-W: erase a line
2012-05-10 00:44:30 -04:00
Ray Strode
bb8e3afe19 docs: do a pass over new development.txt
I just did a quick read through and made various changes here and
there.
2012-05-07 23:55:12 -04:00
Ray Strode
19f237b7cc docs: specify where to send contributions 2012-05-07 22:33:15 -04:00
Dr. Tilmann Bubeck
987672f234 docs: Start document for developers
This commit starts to document plymouth to help
new contributors get into the code.

The aim of the document is to provide useful information,
such as the overall architecture, the most
important data structures, and howto recipes for
typical user cases, like debugging.

The document is explicitly not meant to be detailed API documentation.
In the future, that type of documentation may be provided with gtk-doc
style annotations.

The documentation is written in asciidoc
(http://www.methods.co.nz/asciidoc/) and is therefore easily readable as
its ascii text and can also be translated into more rich formats
(like HTML).

For example, to get an HTML version of the document:

yum install asciidoc (or equivalent for your distribution)
cd docs
make development.html
2012-05-07 22:30:55 -04:00
Dr. Tilmann Bubeck
ecd2721f1e two-step: quit properly when boot finishes while waiting for password
When the computer is progressing through its boot up process, plymouth
calls into the splash plugin's on_boot_progress function at regular
intervals with increasing values for "percent_done".  At some point, it
gets to 90% done, and that's when two-step begins its finishing
animation sequence.  As soon as this sequence finishes, two-step pulls
its stop trigger, which

1) sets its "is_idle" flag to true and
2) pulls the core plymouthd code's idle trigger, to notify that
   code that it's at a good animation frame to quit (if the core
   plymouthd code has an idle trigger set up)

During the boot process, the user may need to enter a password
(the "plymouth ask-for-password" command).  When that happens,
the splash waits for the user to enter a password, but boot progresses
in the background.

If the user then enters a password, the boot animation restarts again
(from the display_normal function).  This restarting of the boot
animation will cause the "is_idle" flag of the splash to get set back
to false.

Later when plymouthd wants to quit, it calls the become_idle function
of the splash plugin. That function notices "is_idle" is false, and
the stop_trigger is not NULL.  The function isn't suited to work
with this combination, and so at this point the splash never
tells the code daemon code it's idle.

This commit changes on_boot_progress to return before looking at
percent_done, if the user is getting asked a question.  This way
the stop_trigger won't get created prematurely, and is_idle won't
get out of sync.

https://bugs.freedesktop.org/show_bug.cgi?id=49355
2012-05-07 21:34:03 -04:00
Ray Strode
1a19b4572a drm: rename ENABLE_GDM_TRANSITION to ENABLE_GDM_DEPRECATED_TRANSITION
Most distributions no longer use this transition, which relies
on plymouth quitting before X starts.

For clarity, rename the #define to include the word DEPRECATED
2012-05-03 16:52:52 -04:00
Dave Airlie
527400dc5a drm: add generic driver to drm renderer plugin
Since around 2.6.39, the kernel has offered a generic ioctl interface
for modesetting (the KMS 'dumb' interface).  This interface is now
provided by most all of the modesetting drivers.

Adding support for this interface means that plymouth will automatically
gain support for new modesetting drivers going forward.

This commit adds that support. Some changes made by Ray Strode.
2012-05-03 16:50:54 -04:00
Dr. Tilmann Bubeck
55939ac3a1 label: add alignment and width for labels.
A ply_label can now be alignment with ply_label_set_alignment()
taking one of PLY_LABEL_ALIGN_LEFT, PLY_LABEL_ALIGN_CENTER, or
PLY_LABEL_ALIGN_RIGHT.

This alignment is made within a horizontal box which width can be set with
ply_label_set_width().

Both functions are now used by the plugin "two-step" to make sure, that
the prompt for "ask-for-password" gets centered on the screen. Previously
the prompt started in the middle of the screen and was cropped at the right
border of the screen (fixes bz #681513). This lead to unreadable prompts
for disk encryption.
2012-05-01 19:18:01 -04:00
Ray Strode
0400dfeb11 drm: use queried minimum size, not 1x1 for dummy buffer
The previous commit tries to create a 32bpp 1x1 dummy buffer
to know whether or not the modesetting driver can handle
our needs.  It's concievable (though not realized in practice) that
the driver could support our needs fine, but not support buffers
as small as 1x1.

This commit uses the queried minimum buffer dimensions for the dummy
buffer instead of assuming 1x1.
2012-05-01 12:42:33 -04:00
Ray Strode
9f526a0af4 drm: ensure modesetting driver supports 32bpp fb
Now that more and more hardware is getting kms support,
we need to be more careful about what hardware we try to
run on.  Cirrus cards can't make 32bpp framebuffers, which
is all we support in the drm renderer.

This commit tries to create a small buffer up front, just
to see if the driver will allow it.  If the driver chokes,
then we bail and fall back to the /dev/fb renderer, which
is more tolerant of aging hardware.
2012-05-01 12:30:25 -04:00
Kevin Murphy
c20cd45346 main: corrected error in read_consoles_from_file 2012-04-27 11:22:19 -04:00