]> bbs.cooldavid.org Git - net-next-2.6.git/blame - include/linux/coda_psdev.h
coda: add bdi backing to mount session
[net-next-2.6.git] / include / linux / coda_psdev.h
CommitLineData
1da177e4
LT
1#ifndef __CODA_PSDEV_H
2#define __CODA_PSDEV_H
3
5163d900 4#include <linux/backing-dev.h>
e18fa700
JG
5#include <linux/magic.h>
6
1da177e4
LT
7#define CODA_PSDEV_MAJOR 67
8#define MAX_CODADEVS 5 /* how many do we allow */
9
f2cddb29 10#ifdef __KERNEL__
1da177e4
LT
11struct kstatfs;
12
1da177e4
LT
13/* communication pending/processing queues */
14struct venus_comm {
15 u_long vc_seq;
16 wait_queue_head_t vc_waitq; /* Venus wait queue */
17 struct list_head vc_pending;
18 struct list_head vc_processing;
19 int vc_inuse;
20 struct super_block *vc_sb;
5163d900 21 struct backing_dev_info bdi;
1da177e4
LT
22};
23
24
a1b0aa87 25static inline struct venus_comm *coda_vcp(struct super_block *sb)
1da177e4 26{
a1b0aa87 27 return (struct venus_comm *)((sb)->s_fs_info);
1da177e4
LT
28}
29
1da177e4
LT
30/* upcalls */
31int venus_rootfid(struct super_block *sb, struct CodaFid *fidp);
32int venus_getattr(struct super_block *sb, struct CodaFid *fid,
33 struct coda_vattr *attr);
34int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *);
35int venus_lookup(struct super_block *sb, struct CodaFid *fid,
36 const char *name, int length, int *type,
37 struct CodaFid *resfid);
1da177e4
LT
38int venus_close(struct super_block *sb, struct CodaFid *fid, int flags,
39 vuid_t uid);
40int venus_open(struct super_block *sb, struct CodaFid *fid, int flags,
41 struct file **f);
42int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid,
43 const char *name, int length,
44 struct CodaFid *newfid, struct coda_vattr *attrs);
45int venus_create(struct super_block *sb, struct CodaFid *dirfid,
46 const char *name, int length, int excl, int mode,
47 struct CodaFid *newfid, struct coda_vattr *attrs) ;
48int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid,
49 const char *name, int length);
50int venus_remove(struct super_block *sb, struct CodaFid *dirfid,
51 const char *name, int length);
52int venus_readlink(struct super_block *sb, struct CodaFid *fid,
53 char *buffer, int *length);
54int venus_rename(struct super_block *, struct CodaFid *new_fid,
55 struct CodaFid *old_fid, size_t old_length,
56 size_t new_length, const char *old_name,
57 const char *new_name);
58int venus_link(struct super_block *sb, struct CodaFid *fid,
59 struct CodaFid *dirfid, const char *name, int len );
60int venus_symlink(struct super_block *sb, struct CodaFid *fid,
61 const char *name, int len, const char *symname, int symlen);
62int venus_access(struct super_block *sb, struct CodaFid *fid, int mask);
63int venus_pioctl(struct super_block *sb, struct CodaFid *fid,
64 unsigned int cmd, struct PioctlData *data);
65int coda_downcall(int opcode, union outputArgs *out, struct super_block *sb);
66int venus_fsync(struct super_block *sb, struct CodaFid *fid);
726c3342 67int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
1da177e4 68
7e7f4eae
JSR
69/*
70 * Statistics
71 */
72
73extern struct venus_comm coda_comms[];
74#endif /* __KERNEL__ */
1da177e4
LT
75
76/* messages between coda filesystem in kernel and Venus */
1da177e4
LT
77struct upc_req {
78 struct list_head uc_chain;
79 caddr_t uc_data;
80 u_short uc_flags;
81 u_short uc_inSize; /* Size is at most 5000 bytes */
82 u_short uc_outSize;
83 u_short uc_opcode; /* copied from data to save lookup */
84 int uc_unique;
85 wait_queue_head_t uc_sleep; /* process' wait queue */
1da177e4
LT
86};
87
88#define REQ_ASYNC 0x1
89#define REQ_READ 0x2
90#define REQ_WRITE 0x4
91#define REQ_ABORT 0x8
92
1da177e4 93#endif