Hello, I've send this to Karel Zak first, but I'm not sure if he's the right person to send patches to, so I just forward the mail to the mailing list to make sure it reaches someone. Regards, Jonas ----- Forwarded message from Jonas Kramer <jkramer@xxxxxxxxxxxxxxxx> ----- Date: Tue, 30 Sep 2008 22:36:18 +0200 From: Jonas Kramer <jkramer@xxxxxxxxxxxxxxxx> Subject: [PATCH] mount: mtab created multiple times with -a option To: kzak@xxxxxxxxxx User-Agent: Mutt/1.5.18 (2008-05-17) Ahoy. Since util-linux-ng 2.14.1, the following problem occurs with mount. When /etc/mtab does not exist and mount is called with -a, for every mount point that is mounted a root-fs record is added to mtab. This is because get_mtab_info() sets the flag mtab_does_not_exist to 1 when it doesn't find /etc/mtab. However, if it actually finds /etc/mtab, the variable is not reset to 0. So on every subsequent call to get_mtab_info() (as it is the case when mounting several mount points with the -a option), mount will think that /etc/mtab does not exist, even if it was created in the meantime by mount itself. Additionally, create_mtab() does open /etc/mtab with "a+" even though it is only called when mount thinks that /etc/mtab does not exist. So for every mount point that is mounted with -a, another root-fs entry is added to /etc/mtab. The attached patch seems to fix that. Regards, Jonas Kramer -- diff --git a/mount/fstab.c b/mount/fstab.c index 895fd2c..eb38822 100644 --- a/mount/fstab.c +++ b/mount/fstab.c @@ -30,13 +30,20 @@ static int var_mtab_is_a_symlink = 0; static void get_mtab_info(void) { - struct stat mtab_stat; - if (!have_mtab_info) { + struct stat mtab_stat; + if (lstat(_PATH_MOUNTED, &mtab_stat)) var_mtab_does_not_exist = 1; - else if (S_ISLNK(mtab_stat.st_mode)) - var_mtab_is_a_symlink = 1; + else { + var_mtab_does_not_exist = 0; + + if (S_ISLNK(mtab_stat.st_mode)) + var_mtab_is_a_symlink = 1; + else + var_mtab_is_a_symlink = 0; + } + have_mtab_info = 1; } } ----- End forwarded message ----- --
Attachment:
pgpiZ8WCaPeVU.pgp
Description: PGP signature