blob: 644062e8d857d71443e932a73322269309d1ceb4 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __CODA_PSDEV_H
2#define __CODA_PSDEV_H
3
Jens Axboe5163d902010-04-22 12:12:40 +02004#include <linux/backing-dev.h>
Jeff Garzike18fa702006-09-24 11:13:19 -04005#include <linux/magic.h>
6
Linus Torvalds1da177e2005-04-16 15:20:36 -07007#define CODA_PSDEV_MAJOR 67
8#define MAX_CODADEVS 5 /* how many do we allow */
9
Jaswinder Singh Rajputf2cddb22009-02-03 19:21:38 +053010#ifdef __KERNEL__
Linus Torvalds1da177e2005-04-16 15:20:36 -070011struct kstatfs;
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013/* 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;
Jens Axboe5163d902010-04-22 12:12:40 +020021 struct backing_dev_info bdi;
Linus Torvalds1da177e2005-04-16 15:20:36 -070022};
23
24
Jan Harkesa1b0aa82007-07-19 01:48:50 -070025static inline struct venus_comm *coda_vcp(struct super_block *sb)
Linus Torvalds1da177e2005-04-16 15:20:36 -070026{
Jan Harkesa1b0aa82007-07-19 01:48:50 -070027 return (struct venus_comm *)((sb)->s_fs_info);
Linus Torvalds1da177e2005-04-16 15:20:36 -070028}
29
Linus Torvalds1da177e2005-04-16 15:20:36 -070030/* 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);
Linus Torvalds1da177e2005-04-16 15:20:36 -070038int 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);
David Howells726c3342006-06-23 02:02:58 -070067int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
Jaswinder Singh Rajput7e7f4ea2009-02-02 21:40:10 +053069/*
70 * Statistics
71 */
72
73extern struct venus_comm coda_comms[];
74#endif /* __KERNEL__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -070075
76/* messages between coda filesystem in kernel and Venus */
Linus Torvalds1da177e2005-04-16 15:20:36 -070077struct 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 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070086};
87
88#define REQ_ASYNC 0x1
89#define REQ_READ 0x2
90#define REQ_WRITE 0x4
91#define REQ_ABORT 0x8
92
Linus Torvalds1da177e2005-04-16 15:20:36 -070093#endif