1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
--- cmds.c.orig Mon Jul 22 00:28:19 2002
+++ cmds.c Fri Sep 3 16:35:01 2004
@@ -17,9 +17,18 @@
#include <utime.h>
#include <errno.h>
+#if __FreeBSD__
+#include <ufs/ufs/ufsmount.h>
+#include <isofs/cd9660/cd9660_mount.h>
+#include <fs/msdosfs/msdosfsmount.h>
+#if __FreeBSD_version < 1000000
+#include <fs/ntfs/ntfsmount.h>
+#define HAVE_BSD_NTFSMOUNT
+#endif
+#endif
+
#if HAVE_LINUX_MOUNT
#include <linux/fs.h>
-#endif
/* Need to tell loop.h what the actual dev_t type is. */
#undef dev_t
@@ -32,6 +41,7 @@
#undef dev_t
#define dev_t dev_t
+#endif
int
do_echo(int argc, const char ** argv)
@@ -716,6 +726,10 @@
flags |= MNT_RDONLY;
break;
+ case 'u':
+ flags |= MNT_UPDATE;
+ break;
+
case 's':
flags |= MNT_NOSUID;
break;
@@ -748,46 +762,58 @@
#elif HAVE_BSD_MOUNT
{
struct ufs_args ufs;
- struct adosfs_args adosfs;
struct iso_args iso;
- struct mfs_args mfs;
struct msdosfs_args msdosfs;
+#ifdef HAVE_BSD_NTFSMOUNT
+ struct ntfs_args ntfs;
+#endif
void * args;
if (!strcmp(type, "ffs") || !strcmp(type, "ufs"))
{
+ memset(&ufs, 0, sizeof(ufs));
ufs.fspec = (char*) argv[0];
args = &ufs;
}
- else if (!strcmp(type, "adosfs"))
- {
- adosfs.fspec = (char*) argv[0];
- adosfs.uid = 0;
- adosfs.gid = 0;
- args = &adosfs;
- }
else if (!strcmp(type, "cd9660"))
{
+ memset(&iso, 0, sizeof(iso));
iso.fspec = (char*) argv[0];
args = &iso;
}
- else if (!strcmp(type, "mfs"))
- {
- mfs.fspec = (char*) argv[0];
- args = &mfs;
- }
else if (!strcmp(type, "msdos"))
{
+ memset(&msdosfs, 0, sizeof(msdosfs));
msdosfs.fspec = (char*) argv[0];
- msdosfs.uid = 0;
- msdosfs.gid = 0;
+ if (flags & MNT_RDONLY) {
+ msdosfs.export.ex_flags = MNT_EXRDONLY;
+ msdosfs.mask = msdosfs.dirmask = 0555;
+ } else {
+ msdosfs.mask = msdosfs.dirmask = 7555;
+ }
args = &msdosfs;
+#ifdef HAVE_BSD_NTFSMOUNT
+ } else if(!strcmp(type, "ntfs")) {
+ memset(&ntfs, 0, sizeof(ntfs));
+ ntfs.fspec = (char*) argv[0];
+ if (flags & MNT_RDONLY) {
+ ntfs.export.ex_flags = MNT_EXRDONLY;
+ ntfs.mode = 0555;
+ } else {
+ ntfs.mode = 0755;
+ }
+ args = &ntfs;
+#endif
}
else
{
fprintf(stderr, "Unknown filesystem type: %s", type);
fprintf(stderr,
- "Supported: ffs ufs adosfs cd9660 mfs msdos\n");
+#ifdef HAVE_BSD_NTFSMOUNT
+ "Supported: ffs ufs cd9660 ext2fs msdos ntfs\n");
+#else
+ "Supported: ffs ufs cd9660 ext2fs msdos\n");
+#endif
return 1;
}
|