X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Ffsck%2Ffsck.c;h=8facc88bb43149fbbd4233051c36e6aab1d86002;hp=c2e1c741d571382ba7f593986cd1bb0e57a96161;hb=c8a202b7d47f9d6bba3100a208abdadfc383499e;hpb=e375825da0cbdbf3be755c277f9c0dec35b41a09 diff --git a/src/fsck/fsck.c b/src/fsck/fsck.c index c2e1c741d..8facc88bb 100644 --- a/src/fsck/fsck.c +++ b/src/fsck/fsck.c @@ -73,7 +73,8 @@ static void start_target(const char *target) { } static int parse_proc_cmdline(void) { - char *line, *w, *state; + _cleanup_free_ char *line = NULL; + char *w, *state; size_t l; int r; @@ -104,7 +105,6 @@ static int parse_proc_cmdline(void) { #endif } - free(line); return 0; } @@ -155,7 +155,7 @@ static int process_progress(int fd) { return -errno; } - console = fopen("/dev/console", "w"); + console = fopen("/dev/console", "we"); if (!console) return -ENOMEM; @@ -212,10 +212,11 @@ int main(int argc, char *argv[]) { siginfo_t status; _cleanup_udev_unref_ struct udev *udev = NULL; _cleanup_udev_device_unref_ struct udev_device *udev_device = NULL; - const char *device; + const char *device, *type; bool root_directory; int progress_pipe[2] = { -1, -1 }; char dash_c[2+10+1]; + struct stat st; if (argc > 2) { log_error("This program expects one or no arguments."); @@ -234,11 +235,27 @@ int main(int argc, char *argv[]) { if (!arg_force && arg_skip) return 0; + udev = udev_new(); + if (!udev) { + log_oom(); + return EXIT_FAILURE; + } + if (argc > 1) { device = argv[1]; root_directory = false; + + if (stat(device, &st) < 0) { + log_error("Failed to stat '%s': %m", device); + return EXIT_FAILURE; + } + + udev_device = udev_device_new_from_devnum(udev, 'b', st.st_rdev); + if (!udev_device) { + log_error("Failed to detect device %s", device); + return EXIT_FAILURE; + } } else { - struct stat st; struct timespec times[2]; /* Find root device */ @@ -260,12 +277,6 @@ int main(int argc, char *argv[]) { return EXIT_SUCCESS; } - udev = udev_new(); - if (!udev) { - log_oom(); - return EXIT_FAILURE; - } - udev_device = udev_device_new_from_devnum(udev, 'b', st.st_dev); if (!udev_device) { log_error("Failed to detect root device."); @@ -281,6 +292,19 @@ int main(int argc, char *argv[]) { root_directory = true; } + type = udev_device_get_property_value(udev_device, "ID_FS_TYPE"); + if (type) { + const char *checker = strappenda("/sbin/fsck.", type); + r = access(checker, X_OK); + if (r < 0) { + if (errno == ENOENT) { + log_info("%s doesn't exist, not checking file system.", checker); + return EXIT_SUCCESS; + } else + log_warning("%s cannot be used: %m", checker); + } + } + if (arg_show_progress) if (pipe(progress_pipe) < 0) { log_error("pipe(): %m");