summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenis Vlasenko2008-07-09 19:44:08 +0000
committerDenis Vlasenko2008-07-09 19:44:08 +0000
commit96c45b0e0bda5bf47c03682c8fcbeae7ade89386 (patch)
tree5c85d37b5e2dd9a28d547416638622f63e792e52
parent5606b1c4f36d6f4f467f85a417183a70bc00fe1d (diff)
downloadbusybox-96c45b0e0bda5bf47c03682c8fcbeae7ade89386.zip
busybox-96c45b0e0bda5bf47c03682c8fcbeae7ade89386.tar.gz
libbb/mtab: fix xrealloc_vector fallout
-rw-r--r--libbb/mtab.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/libbb/mtab.c b/libbb/mtab.c
index 2c17132..586a661 100644
--- a/libbb/mtab.c
+++ b/libbb/mtab.c
@@ -13,8 +13,8 @@
#if ENABLE_FEATURE_MTAB_SUPPORT
void FAST_FUNC erase_mtab(const char *name)
{
- struct mntent *entries = NULL;
- int i, count = 0;
+ struct mntent *entries;
+ int i, count;
FILE *mountTable;
struct mntent *m;
@@ -26,18 +26,21 @@ void FAST_FUNC erase_mtab(const char *name)
return;
}
+ entries = NULL;
+ count = 0;
while ((m = getmntent(mountTable)) != 0) {
- entries = xrealloc(entries, 3, count);
+ entries = xrealloc_vector(entries, 3, count);
entries[count].mnt_fsname = xstrdup(m->mnt_fsname);
entries[count].mnt_dir = xstrdup(m->mnt_dir);
entries[count].mnt_type = xstrdup(m->mnt_type);
entries[count].mnt_opts = xstrdup(m->mnt_opts);
entries[count].mnt_freq = m->mnt_freq;
entries[count].mnt_passno = m->mnt_passno;
- i = count++;
+ count++;
}
endmntent(mountTable);
+//TODO: make update atomic
mountTable = setmntent(bb_path_mtab_file, "w");
if (mountTable) {
for (i = 0; i < count; i++) {