1 | /* $Id: vboxvfs_vnops.c 8155 2008-04-18 15:16:47Z vboxsync $ */
|
---|
2 | /** @file
|
---|
3 | * Description.
|
---|
4 | */
|
---|
5 |
|
---|
6 | /*
|
---|
7 | * Copyright (C) 2008 Sun Microsystems, Inc.
|
---|
8 | *
|
---|
9 | * This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
10 | * available from http://www.virtualbox.org. This file is free software;
|
---|
11 | * you can redistribute it and/or modify it under the terms of the GNU
|
---|
12 | * General Public License (GPL) as published by the Free Software
|
---|
13 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
14 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
15 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
16 | *
|
---|
17 | * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
|
---|
18 | * Clara, CA 95054 USA or visit http://www.sun.com if you need
|
---|
19 | * additional information or have any questions.
|
---|
20 | */
|
---|
21 |
|
---|
22 | #include "vboxvfs.h"
|
---|
23 | #include <sys/param.h>
|
---|
24 | #include <sys/systm.h>
|
---|
25 | #include <sys/namei.h>
|
---|
26 | #include <sys/kernel.h>
|
---|
27 | #include <sys/proc.h>
|
---|
28 | #include <sys/bio.h>
|
---|
29 | #include <sys/buf.h>
|
---|
30 | #include <sys/fcntl.h>
|
---|
31 | #include <sys/mount.h>
|
---|
32 | #include <sys/unistd.h>
|
---|
33 | #include <sys/vnode.h>
|
---|
34 | #include <sys/limits.h>
|
---|
35 | #include <sys/lockf.h>
|
---|
36 | #include <sys/stat.h>
|
---|
37 |
|
---|
38 | #include <vm/vm.h>
|
---|
39 | #include <vm/vm_extern.h>
|
---|
40 |
|
---|
41 | /*
|
---|
42 | * Prototypes for VBOXVFS vnode operations
|
---|
43 | */
|
---|
44 | static vop_create_t vboxvfs_create;
|
---|
45 | static vop_mknod_t vboxvfs_mknod;
|
---|
46 | static vop_open_t vboxvfs_open;
|
---|
47 | static vop_close_t vboxvfs_close;
|
---|
48 | static vop_access_t vboxvfs_access;
|
---|
49 | static vop_getattr_t vboxvfs_getattr;
|
---|
50 | static vop_setattr_t vboxvfs_setattr;
|
---|
51 | static vop_read_t vboxvfs_read;
|
---|
52 | static vop_write_t vboxvfs_write;
|
---|
53 | static vop_fsync_t vboxvfs_fsync;
|
---|
54 | static vop_remove_t vboxvfs_remove;
|
---|
55 | static vop_link_t vboxvfs_link;
|
---|
56 | static vop_lookup_t vboxvfs_lookup;
|
---|
57 | static vop_rename_t vboxvfs_rename;
|
---|
58 | static vop_mkdir_t vboxvfs_mkdir;
|
---|
59 | static vop_rmdir_t vboxvfs_rmdir;
|
---|
60 | static vop_symlink_t vboxvfs_symlink;
|
---|
61 | static vop_readdir_t vboxvfs_readdir;
|
---|
62 | static vop_strategy_t vboxvfs_strategy;
|
---|
63 | static vop_print_t vboxvfs_print;
|
---|
64 | static vop_pathconf_t vboxvfs_pathconf;
|
---|
65 | static vop_advlock_t vboxvfs_advlock;
|
---|
66 | static vop_getextattr_t vboxvfs_getextattr;
|
---|
67 | static vop_ioctl_t vboxvfs_ioctl;
|
---|
68 | static vop_getpages_t vboxvfs_getpages;
|
---|
69 | static vop_inactive_t vboxvfs_inactive;
|
---|
70 | static vop_putpages_t vboxvfs_putpages;
|
---|
71 | static vop_reclaim_t vboxvfs_reclaim;
|
---|
72 |
|
---|
73 | struct vop_vector vboxvfs_vnodeops = {
|
---|
74 | .vop_default = &default_vnodeops,
|
---|
75 |
|
---|
76 | .vop_access = vboxvfs_access,
|
---|
77 | .vop_advlock = vboxvfs_advlock,
|
---|
78 | .vop_close = vboxvfs_close,
|
---|
79 | .vop_create = vboxvfs_create,
|
---|
80 | .vop_fsync = vboxvfs_fsync,
|
---|
81 | .vop_getattr = vboxvfs_getattr,
|
---|
82 | .vop_getextattr = vboxvfs_getextattr,
|
---|
83 | .vop_getpages = vboxvfs_getpages,
|
---|
84 | .vop_inactive = vboxvfs_inactive,
|
---|
85 | .vop_ioctl = vboxvfs_ioctl,
|
---|
86 | .vop_link = vboxvfs_link,
|
---|
87 | .vop_lookup = vboxvfs_lookup,
|
---|
88 | .vop_mkdir = vboxvfs_mkdir,
|
---|
89 | .vop_mknod = vboxvfs_mknod,
|
---|
90 | .vop_open = vboxvfs_open,
|
---|
91 | .vop_pathconf = vboxvfs_pathconf,
|
---|
92 | .vop_print = vboxvfs_print,
|
---|
93 | .vop_putpages = vboxvfs_putpages,
|
---|
94 | .vop_read = vboxvfs_read,
|
---|
95 | .vop_readdir = vboxvfs_readdir,
|
---|
96 | .vop_reclaim = vboxvfs_reclaim,
|
---|
97 | .vop_remove = vboxvfs_remove,
|
---|
98 | .vop_rename = vboxvfs_rename,
|
---|
99 | .vop_rmdir = vboxvfs_rmdir,
|
---|
100 | .vop_setattr = vboxvfs_setattr,
|
---|
101 | .vop_strategy = vboxvfs_strategy,
|
---|
102 | .vop_symlink = vboxvfs_symlink,
|
---|
103 | .vop_write = vboxvfs_write,
|
---|
104 | };
|
---|
105 |
|
---|
106 | static int vboxvfs_access(struct vop_access_args *ap)
|
---|
107 | {
|
---|
108 | return 0;
|
---|
109 | }
|
---|
110 |
|
---|
111 | static int vboxvfs_open(struct vop_open_args *ap)
|
---|
112 | {
|
---|
113 | return 0;
|
---|
114 | }
|
---|
115 |
|
---|
116 | static int vboxvfs_close(struct vop_close_args *ap)
|
---|
117 | {
|
---|
118 | return 0;
|
---|
119 | }
|
---|
120 |
|
---|
121 | static int vboxvfs_getattr(struct vop_getattr_args *ap)
|
---|
122 | {
|
---|
123 | return 0;
|
---|
124 | }
|
---|
125 |
|
---|
126 | static int vboxvfs_setattr(struct vop_setattr_args *ap)
|
---|
127 | {
|
---|
128 | return 0;
|
---|
129 | }
|
---|
130 |
|
---|
131 | static int vboxvfs_read(struct vop_read_args *ap)
|
---|
132 | {
|
---|
133 | return 0;
|
---|
134 | }
|
---|
135 |
|
---|
136 | static int vboxvfs_write(struct vop_write_args *ap)
|
---|
137 | {
|
---|
138 | return 0;
|
---|
139 | }
|
---|
140 |
|
---|
141 | static int vboxvfs_create(struct vop_create_args *ap)
|
---|
142 | {
|
---|
143 | return 0;
|
---|
144 | }
|
---|
145 |
|
---|
146 | static int vboxvfs_remove(struct vop_remove_args *ap)
|
---|
147 | {
|
---|
148 | return 0;
|
---|
149 | }
|
---|
150 |
|
---|
151 | static int vboxvfs_rename(struct vop_rename_args *ap)
|
---|
152 | {
|
---|
153 | return 0;
|
---|
154 | }
|
---|
155 |
|
---|
156 | static int vboxvfs_link(struct vop_link_args *ap)
|
---|
157 | {
|
---|
158 | return EOPNOTSUPP;
|
---|
159 | }
|
---|
160 |
|
---|
161 | static int vboxvfs_symlink(struct vop_symlink_args *ap)
|
---|
162 | {
|
---|
163 | return EOPNOTSUPP;
|
---|
164 | }
|
---|
165 |
|
---|
166 | static int vboxvfs_mknod(struct vop_mknod_args *ap)
|
---|
167 | {
|
---|
168 | return EOPNOTSUPP;
|
---|
169 | }
|
---|
170 |
|
---|
171 | static int vboxvfs_mkdir(struct vop_mkdir_args *ap)
|
---|
172 | {
|
---|
173 | return 0;
|
---|
174 | }
|
---|
175 |
|
---|
176 | static int vboxvfs_rmdir(struct vop_rmdir_args *ap)
|
---|
177 | {
|
---|
178 | return 0;
|
---|
179 | }
|
---|
180 |
|
---|
181 | static int vboxvfs_readdir(struct vop_readdir_args *ap)
|
---|
182 | {
|
---|
183 | return 0;
|
---|
184 | }
|
---|
185 |
|
---|
186 | static int vboxvfs_fsync(struct vop_fsync_args *ap)
|
---|
187 | {
|
---|
188 | return 0;
|
---|
189 | }
|
---|
190 |
|
---|
191 | static int vboxvfs_print (struct vop_print_args *ap)
|
---|
192 | {
|
---|
193 | return 0;
|
---|
194 | }
|
---|
195 |
|
---|
196 | static int vboxvfs_pathconf (struct vop_pathconf_args *ap)
|
---|
197 | {
|
---|
198 | return 0;
|
---|
199 | }
|
---|
200 |
|
---|
201 | static int vboxvfs_strategy (struct vop_strategy_args *ap)
|
---|
202 | {
|
---|
203 | return 0;
|
---|
204 | }
|
---|
205 |
|
---|
206 | static int vboxvfs_ioctl(struct vop_ioctl_args *ap)
|
---|
207 | {
|
---|
208 | return ENOTTY;
|
---|
209 | }
|
---|
210 |
|
---|
211 | static int vboxvfs_getextattr(struct vop_getextattr_args *ap)
|
---|
212 | {
|
---|
213 | return 0;
|
---|
214 | }
|
---|
215 |
|
---|
216 | static int vboxvfs_advlock(struct vop_advlock_args *ap)
|
---|
217 | {
|
---|
218 | return 0;
|
---|
219 | }
|
---|
220 |
|
---|
221 | static int vboxvfs_lookup(struct vop_lookup_args *ap)
|
---|
222 | {
|
---|
223 | return 0;
|
---|
224 | }
|
---|
225 |
|
---|
226 | static int vboxvfs_inactive(struct vop_inactive_args *ap)
|
---|
227 | {
|
---|
228 | return 0;
|
---|
229 | }
|
---|
230 |
|
---|
231 | static int vboxvfs_reclaim(struct vop_reclaim_args *ap)
|
---|
232 | {
|
---|
233 | return 0;
|
---|
234 | }
|
---|
235 |
|
---|
236 | static int vboxvfs_getpages(struct vop_getpages_args *ap)
|
---|
237 | {
|
---|
238 | return 0;
|
---|
239 | }
|
---|
240 |
|
---|
241 | static int vboxvfs_putpages(struct vop_putpages_args *ap)
|
---|
242 | {
|
---|
243 | return 0;
|
---|
244 | }
|
---|
245 |
|
---|