diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2009-07-05 04:50:36 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2009-07-05 04:50:36 +0200 |
commit | 09e63bb81f12707d31c8c4570931af0196b53a46 (patch) | |
tree | 1b550ca677e6cd4fdd70eabda1fd402684b8ec7d /libbb/find_mount_point.c | |
parent | 9b1b62adc4e4c1e80d9f72180c6b7b1eaef9f95a (diff) | |
download | busybox-w32-09e63bb81f12707d31c8c4570931af0196b53a46.tar.gz busybox-w32-09e63bb81f12707d31c8c4570931af0196b53a46.tar.bz2 busybox-w32-09e63bb81f12707d31c8c4570931af0196b53a46.zip |
df: fix "df /"
also, clean up mount checks in mkfs/fsck.
function old new delta
find_mount_point 243 261 +18
sha1_process_block64 497 510 +13
find_main 436 444 +8
display_speed 85 90 +5
df_main 795 793 -2
parse_command 1463 1460 -3
static.ignored_mounts 8 - -8
mkfs_minix_main 2962 2937 -25
fsck_minix_main 3065 2970 -95
------------------------------------------------------------------------------
(add/remove: 0/1 grow/shrink: 4/4 up/down: 44/-133) Total: -89 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb/find_mount_point.c')
-rw-r--r-- | libbb/find_mount_point.c | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/libbb/find_mount_point.c b/libbb/find_mount_point.c index 4cd6b1618..12b2cfce4 100644 --- a/libbb/find_mount_point.c +++ b/libbb/find_mount_point.c | |||
@@ -17,7 +17,7 @@ | |||
17 | * Given any other file (or directory), find the mount table entry for its | 17 | * Given any other file (or directory), find the mount table entry for its |
18 | * filesystem. | 18 | * filesystem. |
19 | */ | 19 | */ |
20 | struct mntent* FAST_FUNC find_mount_point(const char *name, const char *table) | 20 | struct mntent* FAST_FUNC find_mount_point(const char *name) |
21 | { | 21 | { |
22 | struct stat s; | 22 | struct stat s; |
23 | dev_t mountDevice; | 23 | dev_t mountDevice; |
@@ -25,27 +25,35 @@ struct mntent* FAST_FUNC find_mount_point(const char *name, const char *table) | |||
25 | struct mntent *mountEntry; | 25 | struct mntent *mountEntry; |
26 | 26 | ||
27 | if (stat(name, &s) != 0) | 27 | if (stat(name, &s) != 0) |
28 | return 0; | 28 | return NULL; |
29 | 29 | ||
30 | if ((s.st_mode & S_IFMT) == S_IFBLK) | 30 | if (S_ISBLK(s.st_mode)) |
31 | mountDevice = s.st_rdev; | 31 | mountDevice = s.st_rdev; |
32 | else | 32 | else |
33 | mountDevice = s.st_dev; | 33 | mountDevice = s.st_dev; |
34 | 34 | ||
35 | 35 | ||
36 | mountTable = setmntent(table ? table : bb_path_mtab_file, "r"); | 36 | mountTable = setmntent(bb_path_mtab_file, "r"); |
37 | if (!mountTable) | 37 | if (!mountTable) |
38 | return 0; | 38 | return 0; |
39 | 39 | ||
40 | while ((mountEntry = getmntent(mountTable)) != 0) { | 40 | while ((mountEntry = getmntent(mountTable)) != NULL) { |
41 | /* rootfs mount in Linux 2.6 exists always, | ||
42 | * and it makes sense to always ignore it. | ||
43 | * Otherwise people can't reference their "real" root! */ | ||
44 | if (strcmp(mountEntry->mnt_fsname, "rootfs") == 0) | ||
45 | continue; | ||
46 | |||
41 | if (strcmp(name, mountEntry->mnt_dir) == 0 | 47 | if (strcmp(name, mountEntry->mnt_dir) == 0 |
42 | || strcmp(name, mountEntry->mnt_fsname) == 0 | 48 | || strcmp(name, mountEntry->mnt_fsname) == 0 |
43 | ) { /* String match. */ | 49 | ) { /* String match. */ |
44 | break; | 50 | break; |
45 | } | 51 | } |
46 | if (stat(mountEntry->mnt_fsname, &s) == 0 && s.st_rdev == mountDevice) /* Match the device. */ | 52 | /* Match the device. */ |
53 | if (stat(mountEntry->mnt_fsname, &s) == 0 && s.st_rdev == mountDevice) | ||
47 | break; | 54 | break; |
48 | if (stat(mountEntry->mnt_dir, &s) == 0 && s.st_dev == mountDevice) /* Match the directory's mount point. */ | 55 | /* Match the directory's mount point. */ |
56 | if (stat(mountEntry->mnt_dir, &s) == 0 && s.st_dev == mountDevice) | ||
49 | break; | 57 | break; |
50 | } | 58 | } |
51 | endmntent(mountTable); | 59 | endmntent(mountTable); |