From: Holger Hans Peter Freyther Date: Thu, 15 May 2014 17:07:43 +0000 (+0200) Subject: fsck: Allow to specify the fsck repair option in the cmdline X-Git-Tag: v213~125 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=f1f0198cb61a3398557cc9ec596e1e90ac731ed3;ds=sidebyside fsck: Allow to specify the fsck repair option in the cmdline Some unattended systems do not have a console attached and entering the default rescue mode will not be too helpful. Allow to specify the "-y" option to attempt to fix all filesystem errors. Manually verified by downloading an image.gz of e2fsprogs, using losetup and running systemd-fsck on the loop device and varying the fsck.repair=preen|yes|no option. --- diff --git a/man/kernel-command-line.xml b/man/kernel-command-line.xml index dbfec6128..a276b7141 100644 --- a/man/kernel-command-line.xml +++ b/man/kernel-command-line.xml @@ -192,6 +192,17 @@ + + fsck.repair= + + + Parameter understood by + the file system checker + services. For details, see + systemd-fsck@.service8. + + + quotacheck.mode= diff --git a/man/systemd-fsck@.service.xml b/man/systemd-fsck@.service.xml index c653dc59d..afd8d9b5e 100644 --- a/man/systemd-fsck@.service.xml +++ b/man/systemd-fsck@.service.xml @@ -98,6 +98,22 @@ skips any file system checks. + + + fsck.repair= + + One of + preen, + yes, + no. Controls the + mode of operation. The default is + preen, and will automatically repair + problems that can be safely fixed. yes + will answer yes to all questions by + fsck and no will answer no to + all questions. + + diff --git a/src/fsck/fsck.c b/src/fsck/fsck.c index 5ed837dff..594f21e07 100644 --- a/src/fsck/fsck.c +++ b/src/fsck/fsck.c @@ -4,6 +4,7 @@ This file is part of systemd. Copyright 2010 Lennart Poettering + Copyright 2014 Holger Hans Peter Freyther systemd is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by @@ -42,6 +43,7 @@ static bool arg_skip = false; static bool arg_force = false; static bool arg_show_progress = false; +static const char *arg_repair = "-a"; static void start_target(const char *target) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; @@ -85,6 +87,16 @@ static int parse_proc_cmdline_item(const char *key, const char *value) { arg_skip = true; else log_warning("Invalid fsck.mode= parameter. Ignoring."); + } else if (streq(key, "fsck.repair") && value) { + + if (streq(value, "preen")) + arg_repair = "-a"; + else if (streq(value, "yes")) + arg_repair = "-y"; + else if (streq(value, "no")) + arg_repair = "-n"; + else + log_warning("Invalid fsck.repair= parameter. Ignoring."); } else if (startswith(key, "fsck.")) log_warning("Invalid fsck parameter. Ignoring."); #ifdef HAVE_SYSV_COMPAT @@ -303,7 +315,7 @@ int main(int argc, char *argv[]) { } cmdline[i++] = "/sbin/fsck"; - cmdline[i++] = "-a"; + cmdline[i++] = arg_repair; cmdline[i++] = "-T"; cmdline[i++] = "-l";