OBS User unknown 2007-03-10 23:11:31 +00:00 committed by Git OBS Bridge
parent 442556f149
commit 5b2f241eb7
3 changed files with 134 additions and 61 deletions

View File

@ -1,86 +1,152 @@
--- util-linux-2.12q/mount/fstab.c Index: util-linux-2.12r/mount/fstab.c
+++ util-linux-2.12q/mount/fstab.c ===================================================================
@@ -395,6 +395,7 @@ --- util-linux-2.12r.orig/mount/fstab.c
+++ util-linux-2.12r/mount/fstab.c
@@ -395,6 +395,7 @@ getfsvolspec (const char *label) {
/* Flag for already existing lock file. */ /* Flag for already existing lock file. */
static int we_created_lockfile = 0; static int we_created_lockfile = 0;
+static int lock_file_desc = -1; +static int lockfile_fd = -1;
/* Flag to indicate that signals have been set up. */ /* Flag to indicate that signals have been set up. */
static int signals_have_been_setup = 0; static int signals_have_been_setup = 0;
@@ -417,6 +418,8 @@ @@ -416,6 +417,8 @@ setlkw_timeout (int sig) {
void
unlock_mtab (void) { unlock_mtab (void) {
if (we_created_lockfile) { if (we_created_lockfile) {
+ close(lockfile_fd);
+ lockfile_fd = -1;
unlink (MOUNTED_LOCK); unlink (MOUNTED_LOCK);
+ close(lock_file_desc);
+ lock_file_desc = -1;
we_created_lockfile = 0; we_created_lockfile = 0;
} }
} @@ -443,7 +446,7 @@ unlock_mtab (void) {
@@ -443,6 +446,7 @@
void void
lock_mtab (void) { lock_mtab (void) {
+ sigset_t sigmask; - int tries = 3;
int tries = 3; + int tries = 100000, i;
char linktargetfile[MOUNTLOCK_LINKTARGET_LTH]; char linktargetfile[MOUNTLOCK_LINKTARGET_LTH];
@@ -467,6 +471,10 @@ at_die = unlock_mtab;
signals_have_been_setup = 1; @@ -469,45 +472,48 @@ lock_mtab (void) {
}
+ /* Allow all signals while trying to lock mtab */
+ sigemptyset(&sigmask);
+ sigprocmask(SIG_SETMASK, &sigmask, &sigmask);
+
sprintf(linktargetfile, MOUNTLOCK_LINKTARGET, getpid ()); sprintf(linktargetfile, MOUNTLOCK_LINKTARGET, getpid ());
/* Repeat until it was us who made the link */ + i = open (linktargetfile, O_WRONLY|O_CREAT, 0);
@@ -521,12 +529,21 @@ + if (i < 0) {
if (j == 0) {
/* We made the link. Now claim the lock. */
if (fcntl (fd, F_SETLK, &flock) == -1) {
+ int errsv = errno; + int errsv = errno;
+ if (!tries--) + /* linktargetfile does not exist (as a file)
+ die(EX_FILEIO, + and we cannot create it. Read-only filesystem?
+ _("Can't lock lock file %s: %s\n"), + Too many files open in the system?
+ MOUNTED_LOCK, strerror (errsv)); + Filesystem full? */
if (verbose) { + die (EX_FILEIO, _("can't create lock file %s: %s "
+ "(use -n flag to override)"),
+ linktargetfile, strerror (errsv));
+ }
+ close(i);
+
/* Repeat until it was us who made the link */
while (!we_created_lockfile) {
struct flock flock;
- int errsv, fd, i, j;
-
- i = open (linktargetfile, O_WRONLY|O_CREAT, 0);
- if (i < 0) {
- int errsv = errno; - int errsv = errno;
printf(_("Can't lock lock file %s: %s\n"), - /* linktargetfile does not exist (as a file)
- and we cannot create it. Read-only filesystem?
- Too many files open in the system?
- Filesystem full? */
- die (EX_FILEIO, _("can't create lock file %s: %s "
- "(use -n flag to override)"),
- linktargetfile, strerror (errsv));
- }
- close(i);
+ int errsv, j;
j = link(linktargetfile, MOUNTED_LOCK);
errsv = errno;
- (void) unlink(linktargetfile);
-
if (j == 0)
we_created_lockfile = 1;
if (j < 0 && errsv != EEXIST) {
+ (void) unlink(linktargetfile);
die (EX_FILEIO, _("can't link lock file %s: %s "
"(use -n flag to override)"),
MOUNTED_LOCK, strerror (errsv)); MOUNTED_LOCK, strerror (errsv));
} }
- /* proceed anyway */
+ /* bummer - someone raced us to the file - fd = open (MOUNTED_LOCK, O_WRONLY);
+ * lock. Start all over again. */ + lockfile_fd = open (MOUNTED_LOCK, O_WRONLY);
+ unlink(MOUNTED_LOCK);
+ } else { - if (fd < 0) {
+ we_created_lockfile = 1; + if (lockfile_fd < 0) {
+ lock_file_desc = fd; int errsv = errno;
/* Strange... Maybe the file was just deleted? */
- if (errno == ENOENT && tries-- > 0)
+ if (errno == ENOENT && tries-- > 0) {
+ if (tries % 200 == 0)
+ usleep(30);
continue;
+ }
+ (void) unlink(linktargetfile);
die (EX_FILEIO, _("can't open lock file %s: %s "
"(use -n flag to override)"),
MOUNTED_LOCK, strerror (errsv));
@@ -520,7 +526,7 @@ lock_mtab (void) {
if (j == 0) {
/* We made the link. Now claim the lock. */
- if (fcntl (fd, F_SETLK, &flock) == -1) {
+ if (fcntl (lockfile_fd, F_SETLK, &flock) == -1) {
if (verbose) {
int errsv = errno;
printf(_("Can't lock lock file %s: %s\n"),
@@ -528,13 +534,15 @@ lock_mtab (void) {
} }
/* proceed anyway */
}
+ (void) unlink(linktargetfile);
} else { } else {
static int tries = 0; static int tries = 0;
@@ -551,8 +568,14 @@
}
}
/* Someone else made the link. Wait. */
alarm(LOCK_TIMEOUT);
- if (fcntl (fd, F_SETLKW, &flock) == -1) {
+ if (fcntl (lockfile_fd, F_SETLKW, &flock) == -1) {
int errsv = errno;
+ (void) unlink(linktargetfile);
die (EX_FILEIO, _("can't lock lock file %s: %s"),
MOUNTED_LOCK, (errno == EINTR) ?
_("timed out") : strerror (errsv));
@@ -542,16 +550,18 @@ lock_mtab (void) {
alarm(0);
/* Limit the number of iterations - maybe there
still is some old /etc/mtab~ */
- if (tries++ > 3) {
- if (tries > 5)
- die (EX_FILEIO, _("Cannot create link %s\n"
- "Perhaps there is a stale lock file?\n"),
- MOUNTED_LOCK);
- sleep(1);
- }
+ ++tries;
+ if (tries % 200 == 0)
+ usleep(30);
+ if (tries > 100000) {
+ (void) unlink(linktargetfile);
+ close(lockfile_fd);
+ die (EX_FILEIO, _("Cannot create link %s\n"
+ "Perhaps there is a stale lock file?\n"),
+ MOUNTED_LOCK);
+ }
+ close(lockfile_fd);
}
-
- close(fd); - close(fd);
+ /* If we created the lock file, keep the fd else
+ * our POSIX lock will go away immediately */
+ if (!we_created_lockfile)
+ close(fd);
} }
+
+ /* Restore original signal mask */
+ sigprocmask(SIG_SETMASK, &sigmask, NULL);
} }
/*
--- util-linux-2.12q/mount/paths.h
+++ util-linux-2.12q/mount/paths.h
@@ -7,4 +7,4 @@
#define MOUNTED_LOCK "/etc/mtab~"
#define MOUNTED_TEMP "/etc/mtab.tmp"
#endif
-#define LOCK_TIMEOUT 10
+#define LOCK_TIMEOUT 30

View File

@ -1,3 +1,8 @@
-------------------------------------------------------------------
Thu Mar 9 11:00:11 CET 2007 - mkoenig@suse.de
- mount: fix mtablock patch to avoid mtab corruption [#226783]
------------------------------------------------------------------- -------------------------------------------------------------------
Thu Mar 8 17:27:22 CET 2007 - mkoenig@suse.de Thu Mar 8 17:27:22 CET 2007 - mkoenig@suse.de

View File

@ -20,7 +20,7 @@ License: BSD License and BSD-like, GNU General Public License (GPL)
Group: System/Base Group: System/Base
Autoreqprov: on Autoreqprov: on
Version: 2.12r Version: 2.12r
Release: 78 Release: 80
Summary: A collection of basic system utilities Summary: A collection of basic system utilities
Source: ftp://ftp.kernel.org/pub/linux/utils/util-linux/%name-%version.tar.bz2 Source: ftp://ftp.kernel.org/pub/linux/utils/util-linux/%name-%version.tar.bz2
Source2: nologin.c Source2: nologin.c
@ -622,6 +622,8 @@ fi
%endif %endif
%changelog %changelog
* Fri Mar 09 2007 - mkoenig@suse.de
- mount: fix mtablock patch to avoid mtab corruption [#226783]
* Thu Mar 08 2007 - mkoenig@suse.de * Thu Mar 08 2007 - mkoenig@suse.de
- partx: fix warning for too long literal - partx: fix warning for too long literal
* Wed Mar 07 2007 - rguenther@suse.de * Wed Mar 07 2007 - rguenther@suse.de