blob: 72f2d2f0af91efec0793a3fa202483d2383e82ac [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
Jaswinder Singh Rajputf2cddb22009-02-03 19:21:38 +05309#ifdef __KERNEL__
Jens Axboe33f60e92010-04-28 09:20:33 +020010#include <linux/backing-dev.h>
Yoshihisa Abeda47c192010-10-25 02:03:46 -040011#include <linux/mutex.h>
Jens Axboe33f60e92010-04-28 09:20:33 +020012
Linus Torvalds1da177e2005-04-16 15:20:36 -070013struct kstatfs;
14
Linus Torvalds1da177e2005-04-16 15:20:36 -070015/* communication pending/processing queues */
16struct venus_comm {
17 u_long vc_seq;
18 wait_queue_head_t vc_waitq; /* Venus wait queue */
19 struct list_head vc_pending;
20 struct list_head vc_processing;
21 int vc_inuse;
22 struct super_block *vc_sb;
Jens Axboe5163d90072010-04-22 12:12:40 +020023 struct backing_dev_info bdi;
Yoshihisa Abeda47c192010-10-25 02:03:46 -040024 struct mutex vc_mutex;
Linus Torvalds1da177e2005-04-16 15:20:36 -070025};
26
27
Jan Harkesa1b0aa82007-07-19 01:48:50 -070028static inline struct venus_comm *coda_vcp(struct super_block *sb)
Linus Torvalds1da177e2005-04-16 15:20:36 -070029{
Jan Harkesa1b0aa82007-07-19 01:48:50 -070030 return (struct venus_comm *)((sb)->s_fs_info);
Linus Torvalds1da177e2005-04-16 15:20:36 -070031}
32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033/* upcalls */
34int venus_rootfid(struct super_block *sb, struct CodaFid *fidp);
35int venus_getattr(struct super_block *sb, struct CodaFid *fid,
36 struct coda_vattr *attr);
37int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *);
38int venus_lookup(struct super_block *sb, struct CodaFid *fid,
39 const char *name, int length, int *type,
40 struct CodaFid *resfid);
Linus Torvalds1da177e2005-04-16 15:20:36 -070041int venus_close(struct super_block *sb, struct CodaFid *fid, int flags,
42 vuid_t uid);
43int venus_open(struct super_block *sb, struct CodaFid *fid, int flags,
44 struct file **f);
45int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid,
46 const char *name, int length,
47 struct CodaFid *newfid, struct coda_vattr *attrs);
48int venus_create(struct super_block *sb, struct CodaFid *dirfid,
49 const char *name, int length, int excl, int mode,
50 struct CodaFid *newfid, struct coda_vattr *attrs) ;
51int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid,
52 const char *name, int length);
53int venus_remove(struct super_block *sb, struct CodaFid *dirfid,
54 const char *name, int length);
55int venus_readlink(struct super_block *sb, struct CodaFid *fid,
56 char *buffer, int *length);
57int venus_rename(struct super_block *, struct CodaFid *new_fid,
58 struct CodaFid *old_fid, size_t old_length,
59 size_t new_length, const char *old_name,
60 const char *new_name);
61int venus_link(struct super_block *sb, struct CodaFid *fid,
62 struct CodaFid *dirfid, const char *name, int len );
63int venus_symlink(struct super_block *sb, struct CodaFid *fid,
64 const char *name, int len, const char *symname, int symlen);
65int venus_access(struct super_block *sb, struct CodaFid *fid, int mask);
66int venus_pioctl(struct super_block *sb, struct CodaFid *fid,
67 unsigned int cmd, struct PioctlData *data);
Yoshihisa Abef7cc02b82010-10-25 02:03:45 -040068int coda_downcall(struct venus_comm *vcp, int opcode, union outputArgs *out);
Linus Torvalds1da177e2005-04-16 15:20:36 -070069int venus_fsync(struct super_block *sb, struct CodaFid *fid);
David Howells726c3342006-06-23 02:02:58 -070070int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
Linus Torvalds1da177e2005-04-16 15:20:36 -070071
Jaswinder Singh Rajput7e7f4ea2009-02-02 21:40:10 +053072/*
73 * Statistics
74 */
75
76extern struct venus_comm coda_comms[];
77#endif /* __KERNEL__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -070078
79/* messages between coda filesystem in kernel and Venus */
Linus Torvalds1da177e2005-04-16 15:20:36 -070080struct upc_req {
81 struct list_head uc_chain;
82 caddr_t uc_data;
83 u_short uc_flags;
84 u_short uc_inSize; /* Size is at most 5000 bytes */
85 u_short uc_outSize;
86 u_short uc_opcode; /* copied from data to save lookup */
87 int uc_unique;
88 wait_queue_head_t uc_sleep; /* process' wait queue */
Linus Torvalds1da177e2005-04-16 15:20:36 -070089};
90
Jens Axboe4aeefdc2010-08-03 13:22:51 +020091#define CODA_REQ_ASYNC 0x1
92#define CODA_REQ_READ 0x2
93#define CODA_REQ_WRITE 0x4
94#define CODA_REQ_ABORT 0x8
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
Linus Torvalds1da177e2005-04-16 15:20:36 -070096#endif