958b25be50
- Revise VFS-FS protocol and update VFS/MFS/ISOFS accordingly. - Clean up MFS by removing old, dead code (backwards compatibility is broken by the new VFS-FS protocol, anyway) and rewrite other parts. Also, make sure all functions have proper banners and prototypes. - VFS should always provide a (syntactically) valid path to the FS; no need for the FS to do sanity checks when leaving/entering mount points. - Fix several bugs in MFS: - Several path lookup bugs in MFS. - A link can be too big for the path buffer. - A mountpoint can become inaccessible when the creation of a new inode fails, because the inode already exists and is a mountpoint. - Introduce support for supplemental groups. - Add test 46 to test supplemental group functionality (and removed obsolete suppl. tests from test 2). - Clean up VFS (not everything is done yet). - ISOFS now opens device read-only. This makes the -r flag in the mount command unnecessary (but will still report to be mounted read-write). - Introduce PipeFS. PipeFS is a new FS that handles all anonymous and named pipes. However, named pipes still reside on the (M)FS, as they are part of the file system on disk. To make this work VFS now has a concept of 'mapped' inodes, which causes read, write, truncate and stat requests to be redirected to the mapped FS, and all other requests to the original FS.
34 lines
1.4 KiB
C
34 lines
1.4 KiB
C
|
|
|
|
EXTERN struct vnode {
|
|
endpoint_t v_fs_e; /* FS process' endpoint number */
|
|
endpoint_t v_mapfs_e; /* mapped FS process' endpoint number */
|
|
ino_t v_inode_nr; /* inode number on its (minor) device */
|
|
ino_t v_mapinode_nr; /* mapped inode number of mapped FS. */
|
|
mode_t v_mode; /* file type, protection, etc. */
|
|
uid_t v_uid; /* uid of inode. */
|
|
gid_t v_gid; /* gid of inode. */
|
|
off_t v_size; /* current file size in bytes */
|
|
int v_ref_count; /* # times vnode used; 0 means slot is free */
|
|
int v_fs_count; /* # reference at the underlying FS */
|
|
int v_mapfs_count; /* # reference at the underlying mapped FS */
|
|
#if 0
|
|
int v_ref_check; /* for consistency checks */
|
|
#endif
|
|
char v_pipe; /* set to I_PIPE if pipe */
|
|
off_t v_pipe_rd_pos;
|
|
off_t v_pipe_wr_pos;
|
|
endpoint_t v_bfs_e; /* endpoint number for the FS proces in case
|
|
of a block special file */
|
|
dev_t v_dev; /* device number on which the corresponding
|
|
inode resides */
|
|
dev_t v_sdev; /* device number for special files */
|
|
struct vmnt *v_vmnt; /* vmnt object of the partition */
|
|
} vnode[NR_VNODES];
|
|
|
|
#define NIL_VNODE (struct vnode *) 0 /* indicates absence of vnode slot */
|
|
|
|
/* Field values. */
|
|
#define NO_PIPE 0 /* i_pipe is NO_PIPE if inode is not a pipe */
|
|
#define I_PIPE 1 /* i_pipe is I_PIPE if inode is a pipe */
|
|
|