Commit graph

2570 commits

Author SHA1 Message Date
Kate Hsuan
98cf5fa56a plugins: splash: two-step: Secure boot check and a warning image
Secure boot is used against several security threats when malware tries to
infect the firmware of the system. Users may inadvertently disable or
software may intentionally disable the secure boot. Consequently, the
system is running on an insecure platform with incorrect configuration. If
Plymouth could offer a warning to the user, the user could reboot and
reconfigure their system or asks for help immediately.

This work can be used to check the secure boot configuration and put a red
warning image on the screen if the secure boot is disabled. Also, this
check can be utterly disabled through the kernel parameter for testing.
If the parameter "secure_boot.warn_if_disabled=false" appears in the
kernel parameter, the secure boot check will be disabled.

Signed-off-by: Kate Hsuan <hpa@redhat.com>
2022-08-11 22:24:51 +08:00
Kate Hsuan
25f0932cba libply: ply-utils: Add ply_is_secure_boot_enabled () helper
This checks the secure boot status. If the secure boot are enabled,
return true. Otherwise, return false.

The system secure boot settings is at
/sys/firmware/efi/efivars/SecureBoot* and the fifth byte should be
0x1 which means the system secure boot is enabled.

Signed-off-by: Kate Hsuan <hpa@redhat.com>
2022-08-11 22:24:40 +08:00
Ray Strode
52b0494de7 Merge branch 'move-ci-to-f37' into 'main'
ci: Update to fedora 37

See merge request plymouth/plymouth!185
2022-08-03 19:48:31 +00:00
Ray Strode
9dff465f0c ci: Update to fedora 37
It seems like uncrustify is changed slightly incompatibly between
35 and 37, so just move to 37.
2022-08-03 15:32:04 -04:00
Ray Strode
eb6d33782d scripts: Add -B to interdiff in check-format
It's currently complaining about an extra blank line in each file.
That's a little extreme.  Add -B.
2022-08-03 15:32:04 -04:00
Ray Strode
5f1e43c000 ply-utils: Drop linux/fs.h include
It was needed long ago for a function we no longer even have.

Now it's causing compile errors on Fedora 37 because it's conflicting
with sys/mount.h.

This commit drops it.
2022-08-03 15:32:04 -04:00
Ray Strode
98cb6ccbdb Merge branch 'drop-vim-lines' into 'main'
src: Drop vim: lines

See merge request plymouth/plymouth!184
2022-08-03 19:15:18 +00:00
Ray Strode
b849a3c54d src: Drop vim: lines
Many of the source files in tree have "vim:" lines to tell vim a
hint about our coding style.

Unfortunately, they were written when plymouth used the GNU coding
style, and it, of course, doesn't anymore.

This commit just drops them since the default vim indentation options
match pretty well with the plymouth coding style now, anyway.
2022-08-03 15:10:20 -04:00
Ray Strode
eb1b8935db Merge branch 'update-uncrustify-config' into 'main'
scripts: Update uncrustify config

See merge request plymouth/plymouth!183
2022-08-01 14:34:39 +00:00
Ray Strode
cd809faf9d scripts: Update uncrustify config
It looks like I forgot to merge the latest uncrustify config last
time I did an uncrustify run.

This commit puts it in place.
2022-08-01 14:32:08 +00:00
Ray Strode
4e40d8a49b Merge branch 'diff-less' into 'main'
scripts: Diff less

See merge request plymouth/plymouth!182
2022-07-29 19:07:17 +00:00
Ray Strode
26fde15195 scripts: Diff less
I think check-format.sh might get into trouble in some cases when
a non source file gets changed.

This commit makes the diffing more targeted
2022-07-29 15:03:43 -04:00
Ray Strode
0d30fe5957 Merge branch 'cut-the-crust' into 'main'
src: Run through uncrustify

See merge request plymouth/plymouth!181
2022-07-29 13:21:10 +00:00
Ray Strode
e483f0c4fe src: Run through uncrustify
I was going to fix the preexisting style issues piecewise as they're
changed, but it's actually making reviewing patchsets noisy.

This commit just bites the bullet and does a full run through
uncrustify.
2022-07-29 09:16:44 -04:00
Ray Strode
9e72df3d8a Merge branch 'runtimedir-fix' into 'main'
Make use of standard --runstatedir flag vs custom --with-runtimedir

See merge request plymouth/plymouth!178
2022-07-19 18:32:22 +00:00
Ben Brown
4c90a66fb7 Fix daemon install ignoring configured runstatedir 2022-07-19 19:09:44 +01:00
Ben Brown
97012d2c38 Use standard runstatedir vs custom flag 2022-07-19 19:09:33 +01:00
Ray Strode
e96011133a Merge branch 'fix-exit-crash' into 'main'
client: Free command parser after event loop

Closes #175

See merge request plymouth/plymouth!175
2022-04-12 23:46:01 +00:00
Ray Strode
13799d9d84 script: Don't crash for scripts without input validation functions
commit 5d1b49c601 adds support for
filtering input to plymouthd and the script plugin.

The script plugin additions, unfortunately, fail to properly handle
scripts that don't add a validation function.

This commit fixes that by assuming no validation function means
no filtering.

Closes: https://gitlab.freedesktop.org/plymouth/plymouth/-/issues/175
2022-04-12 17:25:50 -04:00
Ray Strode
a1996600eb command-parser: Don't add duplicate command to command list
ply_command_parser_get_options inexplicably adds a duplicate
command to the list of available subcommands every time it's
called. This must be some sort of cut and paste bug, it shouldn't
be modifying the list.

That leads to double frees when freeing the command parser.

This commit fixes that.

Related: https://gitlab.freedesktop.org/plymouth/plymouth/-/issues/175
2022-04-12 16:20:20 -04:00
Ray Strode
ac631853a8 client: Free command parser after event loop
commit ed7b1690f0 added an explicit
command parser free call on exit to make memory analysis tools
give better results.

That commit freed the command parser a little too early, though,
before the event loop gets freed and the event loop exit handlers
are run.

The command parser uses an exit handler to clear a weak reference
on the event loop, so freeing the command parser before the event
loop can lead to crash.

This commit moves the free call a little lower.

Related: https://gitlab.freedesktop.org/plymouth/plymouth/-/issues/175
2022-04-12 16:20:20 -04:00
Ray Strode
b603ac17e3 Merge branch 'wip/uncrustify-updates' into 'main'
.gitlab-ci: Don't regress formatting

See merge request plymouth/plymouth!174
2022-04-06 17:28:22 +00:00
Ray Strode
25523a2f87 .gitlab-ci: Don't regress formatting
The formatting in the codebase isn't perfect, but there's no
reason to make it worse.

This commit adds a CI check to make sure new code is styled
right.
2022-04-04 20:24:06 -04:00
Ray Strode
651c22f11a .gitlab-ci: Make it work better on merge requests
gitlab CI apparently exposes more useful environment variables
if `only: merge_requests` is put on each job, so do that.
2022-04-04 16:25:07 -04:00
Ray Strode
02bc090ce7 .gitlab-ci: Update Fedora version to 35
30 is ancient at this point.
2022-04-04 15:51:09 -04:00
Ray Strode
36f451f4f1 script: Enforce separate lines for function parameters
The moment it's possible to sneak in functions like:

static void
foo (int param1, int param2)
{
}

when the style requires parameters on separate lines.

This updates the uncrustify config to account for that.
2022-04-04 15:44:20 -04:00
Ray Strode
d021553e55 Merge branch 'check-shell-before-merge' into 'main'
.gitlab-ci: Check for shell errors in CI

See merge request plymouth/plymouth!172
2022-04-01 16:17:03 +00:00
Ray Strode
a586e59834 .gitlab-ci: Check for shell errors in CI
Recently a shell error snuck into CI and I didn't notice it because
it was in the tail end of a short-circuited conditional.

This commit adds a little shell validation to CI to avoid that
sort of thing in the future.
2022-04-01 12:11:00 -04:00
Ray Strode
fb2721bd82 Merge branch 'plymouth-set-default-theme' into 'main'
scripts: plymouth-set-default-theme reporting missing right brace

See merge request plymouth/plymouth!171
2022-04-01 14:47:58 +00:00
Eric Curtin
123ca59cf2 scripts: plymouth-set-default-theme reporting missing right brace
Fixes issue:

/usr/sbin/plymouth-set-default-theme: line 199: [: missing `]'

when executed as plymouth-set-default-theme spinner
2022-04-01 14:13:23 +01:00
Ray Strode
e40a59d2c2 Merge branch 'tt-keyfilter' into 'main'
core, script: add support for filtering input characters in plugins

See merge request plymouth/plymouth!169
2022-03-29 17:49:52 +00:00
Timo Teräs
5d1b49c601 core, script: add support for validating input characters in plugins
This adds also '\e' to be parsed as escape character in script strings.

Together these allow possibility to create scripts that allow only
numeric PINs, and prevent switching to text mode.
2022-03-29 17:28:00 +03:00
Ray Strode
88c54ffbee Merge branch 'set-default-theme-improvements' into 'main'
Improve plymouth-set-default-theme a bit

Closes #174

See merge request plymouth/plymouth!167
2022-03-28 16:26:46 +00:00
Ray Strode
fd961ef391 scripts: Support -R with -r and standalone for plymouth-set-default-theme
Right now plymouth-set-default-theme only supports rebuilding the initrd if a theme
is passed explicitly.

This commit improves the script to also work for --reset and even in a
standalone mode where no theme is passed at all.

Closes https://gitlab.freedesktop.org/plymouth/plymouth/-/issues/174
2022-03-28 16:24:06 +00:00
Ray Strode
63cfc4eff5 scripts: Support short options being squished togethers for plymouth-set-default-theme
People expect to be able to squish short options together, so
this commit adds some glob matching to support that feature.
2022-03-28 16:24:06 +00:00
Ray Strode
28b8b4909f Merge branch 'mem-leak' into 'main'
client: fix memory leak state.client and state.loop

See merge request plymouth/plymouth!170
2022-03-28 15:30:38 +00:00
Eric Curtin
740c3b3370 event-loop: change assert to just check for is_running
Simlify assert in ply_event_loop_free, to check that the event loop is
not running.
2022-03-28 15:25:50 +00:00
Eric Curtin
8a7cf6e013 command-parser: add more free's
A couple of resources not free'd
2022-03-28 15:25:50 +00:00
Eric Curtin
ed7b1690f0 client: call cleanup functions everytime we return from main
We were not cleaning up allocated resources in many of the code
execution paths in main()
2022-03-28 15:25:50 +00:00
Ray Strode
bce1856745 Merge branch 'script-password-argument' into 'main'
script: add password argument to display password callback

Closes #150

See merge request plymouth/plymouth!166
2022-03-25 20:00:49 +00:00
Mateusz Piórkowski
29c1511738 script: add String.Length function
Add String.Length function which returns the length of a string.
It will make it possible to get the number of bullets from the
display prompt callback inside scripts.
2022-03-25 19:48:26 +01:00
Mateusz Piórkowski
853ec9c290 Add display_prompt function
Add display_prompt function which will be called for both passwords
and questions. This will make it possible to get a plaintext password
string.
SetDisplayPromptFunction will make it possible to set this callback
from a theme script.

Closes #150
2022-03-25 19:48:26 +01:00
Ray Strode
76c1bb6b2f Merge branch 'device-manager-fbdev-add-after-timeout' into 'main'
ply-device-manager: Accept new simpledrm/fbdev devices from udev events after timeout

Closes #167

See merge request plymouth/plymouth!165
2022-03-07 18:34:10 +00:00
Hans de Goede
9a48b3b532 ply-device-manager: Accept new simpledrm/fbdev devices from udev events after timeout
Before the device-timeout elapses verify_add_or_change () blocks new
simpledrm and fbdev getting added through udev add events because we
really only want native drm devices.

Then when the timeout triggers the list of udev devices existing at
that point int time is rescanned and any drm (including simpledrm) and
fbdev devices are added (filtering out duplicates).

But what if a simpledrm or fbdev device for some reason only shows
up after the timeout? Before this change those would then be ignored
for ever.

Add a manager->device_timeout_elapsed check and make verify_add_or_change ()
accept any drm + fbdev devices after the timeout. Note this addresses
a mostly theoretically issue since in practice a simpledrm or fbdev device
showing up later is very unlikely.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
2022-03-07 15:12:09 +01:00
Hans de Goede
5acb3ceee3 ply-device-manager: verify_add_or_change(): Move local_console_is_text check
Move the local_console_is_text check outside of the
"if (subsytem == SUBSYSTEM_DRM)" block.

This check is equally relevant for SUBSYSTEM_FRAME_BUFFER.

Note by itself this is a no-op since verify_add_or_change() *always*
returns false for SUBSYSTEM_FRAME_BUFFER devices.

This is a preparation patch for making verify_add_or_change() not
return false when manager->device_timeout_elapsed is set.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
2022-03-07 15:12:09 +01:00
Ray Strode
9ae5b7e760 Merge branch 'simpledrm-enumeration' into 'main'
ply-device-manager: Treat SimpleDRM drm devices as fbdev devices

Closes #167

See merge request plymouth/plymouth!163
2022-03-07 13:34:00 +00:00
Hans de Goede
83b385061c ply-device-manager: Treat SimpleDRM drm devices as fbdev devices
Simple-framebuffer devices driven by simpledrm lack information
like panel-rotation info and physical size, causing the splash
to briefly render on its side / without HiDPI scaling, switching
to the correct rendering when the native driver loads.

To avoid this treat simpledrm devices as fbdev devices and only
use them after the timeout.

Also adds 2 exceptions to this:

1. If nomodeset is passed on the kernel commandline then no native
drivers will load, so in this case it is best to immediately use
SimpleDRM devices when they are detected.

2. On some devics the firmware leave the panel black at boot. In this
case it is desirable to show the splash to the user ASAP so that there
is some visual feedback that the device is booting. Add a support for a
"plymouth.use-simpledrm" kernel cmdline option to show the splash
immediately on SimpleDRM devices rather then waiting for the native
driver to load.

Closes #167

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
2022-03-07 12:30:12 +01:00
Hans de Goede
ab4238d548 ply-utils: Reintroduce ply_string_has_prefix helper
ply_string_has_prefix was dropped in commit c7965ea19a ("ply-utils:
Drop unused ply_string_has_prefix helper"). We have a need for this
helper again, so reintroduce it.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
2022-03-07 12:28:29 +01:00
Ray Strode
aef728a83d Merge branch 'misc-cleanups' into 'main'
Misc. cleanups

See merge request plymouth/plymouth!164
2022-02-28 18:56:25 +00:00
Hans de Goede
083763e9e5 ply-device-manager: Remove unnecessary subsystem != NULL check
The ply-device-manager.c already assumes that the return value of
udev_device_get_subsystem () is never NULL in many places, including
in the condition of the "else if" just below the check which is
being removed.

Remove the one lonely check for it being NULL for consistency.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
2022-02-28 16:28:41 +01:00