[systemd-commits] 2 commits - TODO man/crypttab.xml src/cryptsetup

Lennart Poettering lennart at kemper.freedesktop.org
Wed Sep 11 08:44:45 PDT 2013


 TODO                        |    2 ++
 man/crypttab.xml            |    4 +++-
 src/cryptsetup/cryptsetup.c |    7 +++----
 3 files changed, 8 insertions(+), 5 deletions(-)

New commits:
commit 4c3a31668e4f3be9a35177a35d5b9794cdff663e
Author: Lennart Poettering <lennart at poettering.net>
Date:   Wed Sep 11 17:44:25 2013 +0200

    Update TODO

diff --git a/TODO b/TODO
index b1006bf..5fd9a59 100644
--- a/TODO
+++ b/TODO
@@ -58,6 +58,8 @@ CGroup Rework Completion:
 
 Features:
 
+* document that in instead of FsckPassNo= people should just add a manual dep to systemd-fsck at .service to their mount units.
+
 * better error message if you run systemctl without systemd running
 
 * tiny tool that saves/restores backlight

commit 404dac4d96f4aaf66026e8b412c4b67e8773cffa
Author: Thomas Bächler <thomas at archlinux.org>
Date:   Sun Aug 18 18:24:13 2013 +0200

    cryptsetup: Retry indefinitely if tries=0 option has been set.
    
    When running from initrd, entering a wrong passphrase usually means that
    you cannot boot. Therefore, we allow trying indefinitely.

diff --git a/man/crypttab.xml b/man/crypttab.xml
index 15c86d3..90d8ce9 100644
--- a/man/crypttab.xml
+++ b/man/crypttab.xml
@@ -330,7 +330,9 @@
                                 <term><varname>tries=</varname></term>
 
                                 <listitem><para>Specifies the maximum number of
-                                times the user is queried for a password.</para></listitem>
+                                times the user is queried for a password.
+                                The default is 3. If set to 0, the user is
+                                queried for a password indefinitely.</para></listitem>
                         </varlistentry>
 
                         <varlistentry>
diff --git a/src/cryptsetup/cryptsetup.c b/src/cryptsetup/cryptsetup.c
index ba0fdbc..22b5eea 100644
--- a/src/cryptsetup/cryptsetup.c
+++ b/src/cryptsetup/cryptsetup.c
@@ -41,7 +41,7 @@ static unsigned opt_key_size = 0;
 static unsigned opt_keyfile_size = 0;
 static unsigned opt_keyfile_offset = 0;
 static char *opt_hash = NULL;
-static unsigned opt_tries = 0;
+static unsigned opt_tries = 3;
 static bool opt_readonly = false;
 static bool opt_verify = false;
 static bool opt_discards = false;
@@ -576,7 +576,6 @@ int main(int argc, char *argv[]) {
                 else
                         until = 0;
 
-                opt_tries = opt_tries > 0 ? opt_tries : 3;
                 opt_key_size = (opt_key_size > 0 ? opt_key_size : 256);
 
                 if (key_file) {
@@ -588,7 +587,7 @@ int main(int argc, char *argv[]) {
                                 log_warning("Key file %s is world-readable. This is not a good idea!", key_file);
                 }
 
-                for (tries = 0; tries < opt_tries; tries++) {
+                for (tries = 0; opt_tries == 0 || tries < opt_tries; tries++) {
                         _cleanup_strv_free_ char **passwords = NULL;
 
                         if (!key_file) {
@@ -616,7 +615,7 @@ int main(int argc, char *argv[]) {
                         log_warning("Invalid passphrase.");
                 }
 
-                if (tries >= opt_tries) {
+                if (opt_tries != 0 && tries >= opt_tries) {
                         log_error("Too many attempts; giving up.");
                         r = EXIT_FAILURE;
                         goto finish;



More information about the systemd-commits mailing list