summaryrefslogtreecommitdiff
path: root/libbb/mtab.c
diff options
context:
space:
mode:
authorDenis Vlasenko2006-11-27 17:29:09 +0000
committerDenis Vlasenko2006-11-27 17:29:09 +0000
commitf1a6c6b362c8b529a3118d52dde1821be441e626 (patch)
treea50b391e7a9e4a001856aeb5b98bc1b52c8ef2b8 /libbb/mtab.c
parent097c324f59e00182c9a2ca9e7a8b2fe06a078c6c (diff)
downloadbusybox-f1a6c6b362c8b529a3118d52dde1821be441e626.zip
busybox-f1a6c6b362c8b529a3118d52dde1821be441e626.tar.gz
erase_mtab: do not limit ourself to 40 mtab entries
Diffstat (limited to 'libbb/mtab.c')
-rw-r--r--libbb/mtab.c53
1 files changed, 21 insertions, 32 deletions
diff --git a/libbb/mtab.c b/libbb/mtab.c
index cce1aac..18386ef 100644
--- a/libbb/mtab.c
+++ b/libbb/mtab.c
@@ -7,53 +7,42 @@
* Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
*/
-#include <stdlib.h>
-#include <unistd.h>
-#include <errno.h>
-#include <string.h>
-#include <stdio.h>
#include <mntent.h>
#include "libbb.h"
-#define MTAB_MAX_ENTRIES 40
-
-#ifdef CONFIG_FEATURE_MTAB_SUPPORT
+#if ENABLE_FEATURE_MTAB_SUPPORT
void erase_mtab(const char *name)
{
- struct mntent entries[MTAB_MAX_ENTRIES];
- int count = 0;
- FILE *mountTable = setmntent(bb_path_mtab_file, "r");
+ struct mntent *entries = NULL;
+ int i, count = 0;
+ FILE *mountTable;
struct mntent *m;
- /* Check if reading the mtab file failed */
- if (mountTable == 0
- /* Bummer. fall back on trying the /proc filesystem */
- && (mountTable = setmntent("/proc/mounts", "r")) == 0) {
+ mountTable = setmntent(bb_path_mtab_file, "r");
+ /* Bummer. Fall back on trying the /proc filesystem */
+ if (!mountTable) mountTable = setmntent("/proc/mounts", "r");
+ if (!mountTable) {
bb_perror_msg(bb_path_mtab_file);
return;
}
- while (((m = getmntent(mountTable)) != 0) && (count < MTAB_MAX_ENTRIES))
- {
- entries[count].mnt_fsname = strdup(m->mnt_fsname);
- entries[count].mnt_dir = strdup(m->mnt_dir);
- entries[count].mnt_type = strdup(m->mnt_type);
- entries[count].mnt_opts = strdup(m->mnt_opts);
- entries[count].mnt_freq = m->mnt_freq;
- entries[count].mnt_passno = m->mnt_passno;
- count++;
+ while ((m = getmntent(mountTable)) != 0) {
+ i = count++;
+ entries = xrealloc(entries, count * sizeof(entries[0]));
+ entries[i].mnt_fsname = xstrdup(m->mnt_fsname);
+ entries[i].mnt_dir = xstrdup(m->mnt_dir);
+ entries[i].mnt_type = xstrdup(m->mnt_type);
+ entries[i].mnt_opts = xstrdup(m->mnt_opts);
+ entries[i].mnt_freq = m->mnt_freq;
+ entries[i].mnt_passno = m->mnt_passno;
}
endmntent(mountTable);
- if ((mountTable = setmntent(bb_path_mtab_file, "w"))) {
- int i;
+ mountTable = setmntent(bb_path_mtab_file, "w");
+ if (mountTable) {
for (i = 0; i < count; i++) {
- int result = (strcmp(entries[i].mnt_fsname, name) == 0
- || strcmp(entries[i].mnt_dir, name) == 0);
-
- if (result)
- continue;
- else
+ if (strcmp(entries[i].mnt_fsname, name) != 0
+ && strcmp(entries[i].mnt_dir, name) != 0)
addmntent(mountTable, &entries[i]);
}
endmntent(mountTable);