X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=utils%2Fmount%2Fmount.c;h=251394380e76b49763119e2c307ef43cf1fd8b1c;hp=ec57d847dd02079745bd28b054123b93a316e3dc;hb=60fd6cd0ada4f501d6d6bcbc3e14950d453c428d;hpb=d876c93b7646f878ef774553611d8ad9ad8f15aa diff --git a/utils/mount/mount.c b/utils/mount/mount.c index ec57d84..2513943 100644 --- a/utils/mount/mount.c +++ b/utils/mount/mount.c @@ -550,15 +550,19 @@ int main(int argc, char *argv[]) mnt_err = try_mount(spec, mount_point, flags, fs_type, &extra_opts, mount_opts, fake, nomtab, FOREGROUND); if (mnt_err == EX_BG) { - printf(_("mount: backgrounding \"%s\"\n"), spec); + printf(_("%s: backgrounding \"%s\"\n"), + progname, spec); fflush(stdout); /* - * Parent exits immediately with success. Make - * sure not to free "mount_point" + * Parent exits immediately with success. */ - if (fork() > 0) - exit(0); + if (daemon(0, 0)) { + nfs_error(_("%s: failed to start " + "background process: %s\n"), + progname, strerror(errno)); + exit(EX_FAIL); + } mnt_err = try_mount(spec, mount_point, flags, fs_type, &extra_opts, mount_opts, fake, @@ -566,7 +570,6 @@ int main(int argc, char *argv[]) if (verbose && mnt_err) printf(_("%s: giving up \"%s\"\n"), progname, spec); - exit(0); } out: