mirror of
https://github.com/sheumann/hush.git
synced 2024-11-19 08:31:11 +00:00
a62665b72f
the hard coded limit on the number of mounts
117 lines
3.1 KiB
C
117 lines
3.1 KiB
C
/* vi: set sw=4 ts=4: */
|
|
/*
|
|
* Utility routines.
|
|
*
|
|
* Copyright (C) 1999-2004 by Erik Andersen <andersen@codepoet.org>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#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
|
|
static const int MS_RDONLY = 1; /* Mount read-only. */
|
|
|
|
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 *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) {
|
|
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++;
|
|
}
|
|
endmntent(mountTable);
|
|
if ((mountTable = setmntent(bb_path_mtab_file, "w"))) {
|
|
int i;
|
|
|
|
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
|
|
addmntent(mountTable, &entries[i]);
|
|
}
|
|
endmntent(mountTable);
|
|
} else if (errno != EROFS)
|
|
bb_perror_msg(bb_path_mtab_file);
|
|
}
|
|
|
|
void write_mtab(char *blockDevice, char *directory,
|
|
char *filesystemType, long flags, char *string_flags)
|
|
{
|
|
FILE *mountTable = setmntent(bb_path_mtab_file, "a+");
|
|
struct mntent m;
|
|
|
|
if (mountTable == 0) {
|
|
bb_perror_msg(bb_path_mtab_file);
|
|
return;
|
|
}
|
|
if (mountTable) {
|
|
int length = strlen(directory);
|
|
|
|
if (length > 1 && directory[length - 1] == '/')
|
|
directory[length - 1] = '\0';
|
|
|
|
if (filesystemType == 0) {
|
|
struct mntent *p = find_mount_point(blockDevice, "/proc/mounts");
|
|
|
|
if (p && p->mnt_type)
|
|
filesystemType = p->mnt_type;
|
|
}
|
|
m.mnt_fsname = blockDevice;
|
|
m.mnt_dir = directory;
|
|
m.mnt_type = filesystemType ? filesystemType : "default";
|
|
|
|
if (*string_flags) {
|
|
m.mnt_opts = string_flags;
|
|
} else {
|
|
if ((flags | MS_RDONLY) == flags)
|
|
m.mnt_opts = "ro";
|
|
else
|
|
m.mnt_opts = "rw";
|
|
}
|
|
|
|
m.mnt_freq = 0;
|
|
m.mnt_passno = 0;
|
|
addmntent(mountTable, &m);
|
|
endmntent(mountTable);
|
|
}
|
|
}
|