# --- 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 };
|