[systemd-devel] [PATCH] cryptsetup-generator: auto add deps for device as password

Zbigniew Jędrzejewski-Szmek zbyszek at in.waw.pl
Sat Feb 8 10:31:28 PST 2014


On Sat, Feb 08, 2014 at 01:12:14PM -0500, Dave Reisner wrote:
> If the password is a device file, we can add Requires/After dependencies
> on the device rather than requiring the user to do so.
> ---
> This is based on a "bug" filed to Arch:
> 
> https://bugs.archlinux.org/task/38842
> 
> Assuming I'm correct about the race condition, this should be an easy way
> of closing it without user involvement.
> 
>  src/cryptsetup/cryptsetup-generator.c | 25 ++++++++++++++++++++-----
>  1 file changed, 20 insertions(+), 5 deletions(-)
> 
> diff --git a/src/cryptsetup/cryptsetup-generator.c b/src/cryptsetup/cryptsetup-generator.c
> index 9c98f0b..4542757 100644
> --- a/src/cryptsetup/cryptsetup-generator.c
> +++ b/src/cryptsetup/cryptsetup-generator.c
> @@ -130,11 +130,26 @@ static int create_disk(
>                      streq(password, "/dev/random") ||
>                      streq(password, "/dev/hw_random"))
>                          fputs("After=systemd-random-seed.service\n", f);
> -                else if (!streq(password, "-") &&
> -                         !streq(password, "none"))
> -                        fprintf(f,
> -                                "RequiresMountsFor=%s\n",
> -                                password);
> +                else {
> +                        _cleanup_free_ char *uu = fstab_node_to_udev_node(password);
> +                        if (uu == NULL)
> +                                return log_oom();
> +
> +                        if (is_device_path(uu)) {
> +                                _cleanup_free_ char *dd = unit_name_from_path(uu, ".device");
> +                                if (dd == NULL)
> +                                        return log_oom();
> +
> +                                fprintf(f,
> +                                                "After=%s\n"
> +                                                "Requires=%s\n",
> +                                                dd, dd);
> +                        } else if (!streq(password, "-") &&
> +                                         !streq(password, "none"))
> +                                        fprintf(f,
> +                                                "RequiresMountsFor=%s\n",
> +                                                password);
> +                }
Patch looks fine, but I don't really understand why you invert the order of conditions.
Something like this feels more natural:

                else if (!streq(password, "-") &&
                         !streq(password, "none")) {

                        _cleanup_free_ char *uu = fstab_node_to_udev_node(password);
                        if (uu == NULL)
                                return log_oom();

                        if (is_device_path(uu)) {
                                _cleanup_free_ char *dd = unit_name_from_path(uu, ".device");
                                if (dd == NULL)
                                        return log_oom();

                                fprintf(f, "After=%1$s\nRequires=%1$s\n", dd);
                        } else
				fprintf(f, "RequiresMountsFor=%s\n", password);
                }

Zbyszek


More information about the systemd-devel mailing list