blob: 07ae8f846055a5b9004d30fec723ffd18b4d3bc0 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __CODA_PSDEV_H
2#define __CODA_PSDEV_H
3
Jeff Garzike18fa702006-09-24 11:13:19 -04004#include <linux/magic.h>
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006#define CODA_PSDEV_MAJOR 67
7#define MAX_CODADEVS 5 /* how many do we allow */
8
Linus Torvalds1da177e2005-04-16 15:20:36 -07009struct kstatfs;
10
Linus Torvalds1da177e2005-04-16 15:20:36 -070011/* communication pending/processing queues */
12struct venus_comm {
13 u_long vc_seq;
14 wait_queue_head_t vc_waitq; /* Venus wait queue */
15 struct list_head vc_pending;
16 struct list_head vc_processing;
17 int vc_inuse;
18 struct super_block *vc_sb;
19};
20
21
Jan Harkesa1b0aa82007-07-19 01:48:50 -070022static inline struct venus_comm *coda_vcp(struct super_block *sb)
Linus Torvalds1da177e2005-04-16 15:20:36 -070023{
Jan Harkesa1b0aa82007-07-19 01:48:50 -070024 return (struct venus_comm *)((sb)->s_fs_info);
Linus Torvalds1da177e2005-04-16 15:20:36 -070025}
26
27
28/* upcalls */
29int venus_rootfid(struct super_block *sb, struct CodaFid *fidp);
30int venus_getattr(struct super_block *sb, struct CodaFid *fid,
31 struct coda_vattr *attr);
32int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *);
33int venus_lookup(struct super_block *sb, struct CodaFid *fid,
34 const char *name, int length, int *type,
35 struct CodaFid *resfid);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036int venus_close(struct super_block *sb, struct CodaFid *fid, int flags,
37 vuid_t uid);
38int venus_open(struct super_block *sb, struct CodaFid *fid, int flags,
39 struct file **f);
40int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid,
41 const char *name, int length,
42 struct CodaFid *newfid, struct coda_vattr *attrs);
43int venus_create(struct super_block *sb, struct CodaFid *dirfid,
44 const char *name, int length, int excl, int mode,
45 struct CodaFid *newfid, struct coda_vattr *attrs) ;
46int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid,
47 const char *name, int length);
48int venus_remove(struct super_block *sb, struct CodaFid *dirfid,
49 const char *name, int length);
50int venus_readlink(struct super_block *sb, struct CodaFid *fid,
51 char *buffer, int *length);
52int venus_rename(struct super_block *, struct CodaFid *new_fid,
53 struct CodaFid *old_fid, size_t old_length,
54 size_t new_length, const char *old_name,
55 const char *new_name);
56int venus_link(struct super_block *sb, struct CodaFid *fid,
57 struct CodaFid *dirfid, const char *name, int len );
58int venus_symlink(struct super_block *sb, struct CodaFid *fid,
59 const char *name, int len, const char *symname, int symlen);
60int venus_access(struct super_block *sb, struct CodaFid *fid, int mask);
61int venus_pioctl(struct super_block *sb, struct CodaFid *fid,
62 unsigned int cmd, struct PioctlData *data);
63int coda_downcall(int opcode, union outputArgs *out, struct super_block *sb);
64int venus_fsync(struct super_block *sb, struct CodaFid *fid);
David Howells726c3342006-06-23 02:02:58 -070065int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
Linus Torvalds1da177e2005-04-16 15:20:36 -070066
67
68/* messages between coda filesystem in kernel and Venus */
Linus Torvalds1da177e2005-04-16 15:20:36 -070069struct upc_req {
70 struct list_head uc_chain;
71 caddr_t uc_data;
72 u_short uc_flags;
73 u_short uc_inSize; /* Size is at most 5000 bytes */
74 u_short uc_outSize;
75 u_short uc_opcode; /* copied from data to save lookup */
76 int uc_unique;
77 wait_queue_head_t uc_sleep; /* process' wait queue */
Linus Torvalds1da177e2005-04-16 15:20:36 -070078};
79
80#define REQ_ASYNC 0x1
81#define REQ_READ 0x2
82#define REQ_WRITE 0x4
83#define REQ_ABORT 0x8
84
85
86/*
87 * Statistics
88 */
89
90extern struct venus_comm coda_comms[];
91
92#endif