|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
From caf058da753c7aae6fbf03feb68e689a8d8265c6 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
From: Dave Reisner <dreisner@archlinux.org>
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
Date: Sat, 8 Feb 2014 12:54:58 -0500
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
Subject: [PATCH] cryptsetup-generator: auto add deps for device as password
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
If the password is a device file, we can add Requires/After dependencies
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
on the device rather than requiring the user to do so.
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
src/cryptsetup/cryptsetup-generator.c | 20 +++++++++++++++-----
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
1 file changed, 15 insertions(+), 5 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
diff --git a/src/cryptsetup/cryptsetup-generator.c b/src/cryptsetup/cryptsetup-generator.c
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
index e1798a3..00891f1 100644
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
--- a/src/cryptsetup/cryptsetup-generator.c
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+++ b/src/cryptsetup/cryptsetup-generator.c
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
@@ -131,11 +131,21 @@ static int create_disk(
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
streq(password, "/dev/random") ||
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
streq(password, "/dev/hw_random"))
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
fputs("After=systemd-random-seed.service\n", f);
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
- else if (!streq(password, "-") &&
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
- !streq(password, "none"))
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
- fprintf(f,
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
- "RequiresMountsFor=%s\n",
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
- password);
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ else if (!streq(password, "-") && !streq(password, "none")) {
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ _cleanup_free_ char *uu = fstab_node_to_udev_node(password);
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ if (uu == NULL)
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ if (is_device_path(uu)) {
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ _cleanup_free_ char *dd = unit_name_from_path(uu, ".device");
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ if (dd == NULL)
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ fprintf(f, "After=%1$s\nRequires=%1$s\n", dd);
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ } else
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ fprintf(f, "RequiresMountsFor=%s\n", password);
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
|
|
Zbigniew Jędrzejewski-Szmek |
ca73a2 |
if (is_device_path(u))
|