130 lines
3.5 KiB

# --- SDE-COPYRIGHT-NOTE-BEGIN ---
# This copyright note is auto-generated by ./scripts/Create-CopyPatch.
#
# Filename: package/.../embutils/mount.patch
# Copyright (C) 2004 - 2006 The T2 SDE Project
#
# More information can be found in the files COPYING and README.
#
# This patch file is dual-licensed. It is available under the license the
# patched project is licensed under, as long as it is an OpenSource license
# as defined at http://www.opensource.org/ (e.g. BSD, X11) or 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.
# --- SDE-COPYRIGHT-NOTE-END ---
Hardened mount to not crash when the directory was not found in /etc/fstab and
improved the tokenizing to strip white spaces, since the files are often
indented in tabular form.
- Rene Rebe <rene@exactcode.de>
--- embutils-0.17/mount.c 2004-01-09 17:03:48.000000000 +0100
+++ embutils-0.17-fixed/mount.c 2005-02-09 12:34:56.222517672 +0100
@@ -142,12 +142,20 @@
* isn't really portable
*/
-/* tokenizes the string when a space appears (not thread safe) */
+/* tokenizes the string when a space appears and strip leading ones
+ (not thread safe) */
static char *spacetok(char *s) {
static char *buffer=NULL;
+ char *tmp;
+
if(s)
buffer=s;
- char *tmp=buffer;
+
+ /* skip leading spaces */
+ while(*buffer && isspace(*buffer))
+ ++buffer;
+
+ tmp=buffer;
for(;*buffer;++buffer) {
if(isspace(*buffer)) {
*buffer++=0;
@@ -463,13 +470,18 @@
if(fh) {
struct mntentry *mnt;
while((mnt=mnt_entry(fh)))
- if(!strcmp(mnt->dir,device)) {
+ if(mnt->dir && !strcmp(mnt->dir,device)) {
device=mnt->device;
dir=mnt->dir;
fs_type=mnt->fs_type;
parse_options(mnt->opts,&flags,data+data_size,DATA_BUFFER_SIZE-data_size);
break;
}
+ if (!dir) {
+ __write2(device);
+ write(2," no found in /etc/fstab\n",24);
+ return 1;
+ }
}
#ifdef CLEANUP
io_close(fh);
Added bind mount and fixed the option_parser to be able to parse options
with only one part and no , seperator ...
Rene Rebe <rene@exactcode.de>
--- embutils-0.17/mount.c 2004-01-09 17:03:48.000000000 +0100
+++ embutils-0.17-mount/mount.c 2005-06-19 15:13:34.000000000 +0200
@@ -26,6 +26,7 @@
#ifdef LINUX
#include <sys/mount.h>
#include <paths.h>
+#include <linux/fs.h> /* MS_MOVE */
#ifdef _PATH_MOUNTED
const char *const mtab=_PATH_MOUNTED;
#else
@@ -227,6 +228,9 @@
{"suid", ~MS_NOSUID, 0},
{"sync", ~0, MS_SYNCHRONOUS},
{"bind", ~0, MS_BIND},
+#ifdef LINUX
+ {"move", ~0, MS_MOVE},
+#endif
{0, 0, 0}
};
/*
@@ -240,10 +244,15 @@
size_t data_set=0;
for(;;) {
const struct mount_options *i;
- char *ptr=strchr(str,',');
- if(!ptr)
+ char *ptr;
+
+ if (!str || !*str)
break;
- *ptr=0;
+
+ ptr=strchr(str,',');
+ if(!ptr) ptr=(char*)str+strlen(str)-1;
+ else *ptr=0;
+
for(i=options; i->name; ++i)
if(!strcmp(str,i->name)) {
*flags&=i->and;
Do not segfault by default when no type was give, also none might be needed
due bind or move mounts.
- Rene Rebe <rene@exactcode.de>
--- embutils-0.17/mount.c 2005-12-18 23:49:12.000000000 +0100
+++ embutils-0.17-patched/mount.c 2005-12-19 10:02:38.000000000 +0100
@@ -414,7 +414,7 @@
int main(int argc, char **argv) {
unsigned long flags=0;
- const char *fs_type=NULL;
+ const char *fs_type="";
const char *device=NULL;
const char *dir=NULL;
enum { DATA_BUFFER_SIZE=100 };