aboutsummaryrefslogtreecommitdiff
path: root/util-linux
diff options
context:
space:
mode:
authorRoman Borisov <ext-roman.borisov@nokia.com>2011-02-28 05:06:01 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2011-02-28 05:06:01 +0100
commitc8dc01dc8030a697cd3ee47da6381066d3142265 (patch)
tree970b139c7e39d29725b440efe39382a97c0b2a85 /util-linux
parent251962f20737c5138c7d33e90c68dfca856361e1 (diff)
downloadbusybox-w32-c8dc01dc8030a697cd3ee47da6381066d3142265.tar.gz
busybox-w32-c8dc01dc8030a697cd3ee47da6381066d3142265.tar.bz2
busybox-w32-c8dc01dc8030a697cd3ee47da6381066d3142265.zip
mount: update /etc/mtab properly on mount --move
Signed-off-by: Roman Borisov <ext-roman.borisov@nokia.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'util-linux')
-rw-r--r--util-linux/mount.c76
1 files changed, 67 insertions, 9 deletions
diff --git a/util-linux/mount.c b/util-linux/mount.c
index 0baa74c7c..0127f1958 100644
--- a/util-linux/mount.c
+++ b/util-linux/mount.c
@@ -279,6 +279,61 @@ enum { GETMNTENT_BUFSIZE = COMMON_BUFSIZE - offsetof(struct globals, getmntent_b
279#define fslist (G.fslist ) 279#define fslist (G.fslist )
280#define getmntent_buf (G.getmntent_buf ) 280#define getmntent_buf (G.getmntent_buf )
281 281
282#if ENABLE_FEATURE_MTAB_SUPPORT
283/*
284 * update_mtab_entry_on_move() is used to update entry in case of mount --move.
285 * we are looking for existing entries mnt_dir which is equal to mnt_fsname of
286 * input mntent and replace it by new one.
287 */
288static void FAST_FUNC update_mtab_entry_on_move(const struct mntent *mp)
289{
290 struct mntent *entries, *m;
291 int i, count;
292 FILE *mountTable;
293
294 mountTable = setmntent(bb_path_mtab_file, "r");
295 if (!mountTable) {
296 bb_perror_msg(bb_path_mtab_file);
297 return;
298 }
299
300 entries = NULL;
301 count = 0;
302 while ((m = getmntent(mountTable)) != NULL) {
303 entries = xrealloc_vector(entries, 3, count);
304 entries[count].mnt_fsname = xstrdup(m->mnt_fsname);
305 entries[count].mnt_dir = xstrdup(m->mnt_dir);
306 entries[count].mnt_type = xstrdup(m->mnt_type);
307 entries[count].mnt_opts = xstrdup(m->mnt_opts);
308 entries[count].mnt_freq = m->mnt_freq;
309 entries[count].mnt_passno = m->mnt_passno;
310 count++;
311 }
312 endmntent(mountTable);
313
314 mountTable = setmntent(bb_path_mtab_file, "w");
315 if (mountTable) {
316 for (i = 0; i < count; i++) {
317 if (strcmp(entries[i].mnt_dir, mp->mnt_fsname) != 0)
318 addmntent(mountTable, &entries[i]);
319 else
320 addmntent(mountTable, mp);
321 }
322 endmntent(mountTable);
323 } else if (errno != EROFS)
324 bb_perror_msg(bb_path_mtab_file);
325
326 if (ENABLE_FEATURE_CLEAN_UP) {
327 for (i = 0; i < count; i++) {
328 free(entries[i].mnt_fsname);
329 free(entries[i].mnt_dir);
330 free(entries[i].mnt_type);
331 free(entries[i].mnt_opts);
332 }
333 free(entries);
334 }
335}
336#endif
282 337
283#if ENABLE_FEATURE_MOUNT_VERBOSE 338#if ENABLE_FEATURE_MOUNT_VERBOSE
284static int verbose_mount(const char *source, const char *target, 339static int verbose_mount(const char *source, const char *target,
@@ -496,12 +551,11 @@ static int mount_it_now(struct mntent *mp, long vfsflags, char *filteropts)
496 int i; 551 int i;
497 552
498 if (!mountTable) { 553 if (!mountTable) {
499 bb_error_msg("no %s", bb_path_mtab_file); 554 bb_perror_msg(bb_path_mtab_file);
500 goto ret; 555 goto ret;
501 } 556 }
502 557
503 // Add vfs string flags 558 // Add vfs string flags
504
505 for (i = 0; mount_options[i] != MS_REMOUNT; i++) { 559 for (i = 0; mount_options[i] != MS_REMOUNT; i++) {
506 if (mount_options[i] > 0 && (mount_options[i] & vfsflags)) 560 if (mount_options[i] > 0 && (mount_options[i] & vfsflags))
507 append_mount_options(&(mp->mnt_opts), option_str); 561 append_mount_options(&(mp->mnt_opts), option_str);
@@ -509,24 +563,28 @@ static int mount_it_now(struct mntent *mp, long vfsflags, char *filteropts)
509 } 563 }
510 564
511 // Remove trailing / (if any) from directory we mounted on 565 // Remove trailing / (if any) from directory we mounted on
512
513 i = strlen(mp->mnt_dir) - 1; 566 i = strlen(mp->mnt_dir) - 1;
514 if (i > 0 && mp->mnt_dir[i] == '/') mp->mnt_dir[i] = '\0'; 567 while (i > 0 && mp->mnt_dir[i] == '/')
568 mp->mnt_dir[i] = '\0';
515 569
516 // Convert to canonical pathnames as needed 570 // Convert to canonical pathnames as needed
517
518 mp->mnt_dir = bb_simplify_path(mp->mnt_dir); 571 mp->mnt_dir = bb_simplify_path(mp->mnt_dir);
519 fsname = 0; 572 fsname = NULL;
520 if (!mp->mnt_type || !*mp->mnt_type) { // bind mount 573 if (!mp->mnt_type || !*mp->mnt_type) { // bind mount
521 mp->mnt_fsname = fsname = bb_simplify_path(mp->mnt_fsname); 574 mp->mnt_fsname = fsname = bb_simplify_path(mp->mnt_fsname);
522 mp->mnt_type = (char*)"bind"; 575 mp->mnt_type = (char*)"bind";
523 } 576 }
524 mp->mnt_freq = mp->mnt_passno = 0; 577 mp->mnt_freq = mp->mnt_passno = 0;
525 578
526 // Write and close. 579 // Write and close
527 580#if ENABLE_FEATURE_MTAB_SUPPORT
528 addmntent(mountTable, mp); 581 if (vfsflags & MS_MOVE)
582 update_mtab_entry_on_move(mp);
583 else
584#endif
585 addmntent(mountTable, mp);
529 endmntent(mountTable); 586 endmntent(mountTable);
587
530 if (ENABLE_FEATURE_CLEAN_UP) { 588 if (ENABLE_FEATURE_CLEAN_UP) {
531 free(mp->mnt_dir); 589 free(mp->mnt_dir);
532 free(fsname); 590 free(fsname);