diff options
-rw-r--r-- | lib/libutil/gr_util.c | 6 | ||||
-rw-r--r-- | lib/libutil/pw_util.c | 13 |
2 files changed, 5 insertions, 14 deletions
diff --git a/lib/libutil/gr_util.c b/lib/libutil/gr_util.c index 1acbadb..80d9ee6 100644 --- a/lib/libutil/gr_util.c +++ b/lib/libutil/gr_util.c @@ -141,13 +141,13 @@ gr_tmp(int mfd) errno = ENAMETOOLONG; return (-1); } - if ((tfd = mkstemp(tempname)) == -1) + if ((tfd = mkostemp(tempname, O_SYNC)) == -1) return (-1); if (mfd != -1) { while ((nr = read(mfd, buf, sizeof(buf))) > 0) if (write(tfd, buf, (size_t)nr) != nr) break; - if (nr != 0 || fsync(tfd) != 0) { + if (nr != 0) { unlink(tempname); *tempname = '\0'; close(tfd); @@ -305,8 +305,6 @@ gr_copy(int ffd, int tfd, const struct group *gr, struct group *old_gr) done: if (line != NULL) free(line); - if (fsync(tfd) != 0) - goto err; return (0); err: if (line != NULL) diff --git a/lib/libutil/pw_util.c b/lib/libutil/pw_util.c index b369035..af749d5 100644 --- a/lib/libutil/pw_util.c +++ b/lib/libutil/pw_util.c @@ -226,13 +226,13 @@ pw_tmp(int mfd) errno = ENAMETOOLONG; return (-1); } - if ((tfd = mkstemp(tempname)) == -1) + if ((tfd = mkostemp(tempname, O_SYNC)) == -1) return (-1); if (mfd != -1) { while ((nr = read(mfd, buf, sizeof(buf))) > 0) if (write(tfd, buf, (size_t)nr) != nr) break; - if (nr != 0 || fsync(tfd) != 0) { + if (nr != 0) { unlink(tempname); *tempname = '\0'; close(tfd); @@ -289,7 +289,7 @@ pw_edit(int notsetuid) sigset_t oldsigset, nsigset; struct stat st1, st2; const char *editor; - int pstat, fd; + int pstat; if ((editor = getenv("EDITOR")) == NULL) editor = _PATH_VI; @@ -344,11 +344,6 @@ pw_edit(int notsetuid) sigprocmask(SIG_SETMASK, &oldsigset, NULL); if (stat(tempname, &st2) == -1) return (-1); - if ((fd = open(tempname, O_RDONLY)) == -1 || fsync(fd) == -1) { - close(fd); - return (-1); - } - close(fd); return (st1.st_mtim.tv_sec != st2.st_mtim.tv_sec || st1.st_mtim.tv_nsec != st2.st_mtim.tv_nsec); } @@ -575,8 +570,6 @@ pw_copy(int ffd, int tfd, const struct passwd *pw, struct passwd *old_pw) done: if (line != NULL) free(line); - if (fsync(tfd) != 0) - goto err; return (0); err: if (line != NULL) |