Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef __CODA_PSDEV_H |
| 2 | #define __CODA_PSDEV_H |
| 3 | |
Jeff Garzik | e18fa70 | 2006-09-24 11:13:19 -0400 | [diff] [blame] | 4 | #include <linux/magic.h> |
| 5 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | #define CODA_PSDEV_MAJOR 67 |
| 7 | #define MAX_CODADEVS 5 /* how many do we allow */ |
| 8 | |
Jaswinder Singh Rajput | f2cddb2 | 2009-02-03 19:21:38 +0530 | [diff] [blame] | 9 | #ifdef __KERNEL__ |
Jens Axboe | 33f60e9 | 2010-04-28 09:20:33 +0200 | [diff] [blame] | 10 | #include <linux/backing-dev.h> |
Yoshihisa Abe | da47c19 | 2010-10-25 02:03:46 -0400 | [diff] [blame] | 11 | #include <linux/mutex.h> |
Jens Axboe | 33f60e9 | 2010-04-28 09:20:33 +0200 | [diff] [blame] | 12 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | struct kstatfs; |
| 14 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | /* communication pending/processing queues */ |
| 16 | struct 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 Axboe | 5163d9007 | 2010-04-22 12:12:40 +0200 | [diff] [blame] | 23 | struct backing_dev_info bdi; |
Yoshihisa Abe | da47c19 | 2010-10-25 02:03:46 -0400 | [diff] [blame] | 24 | struct mutex vc_mutex; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | }; |
| 26 | |
| 27 | |
Jan Harkes | a1b0aa8 | 2007-07-19 01:48:50 -0700 | [diff] [blame] | 28 | static inline struct venus_comm *coda_vcp(struct super_block *sb) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 29 | { |
Jan Harkes | a1b0aa8 | 2007-07-19 01:48:50 -0700 | [diff] [blame] | 30 | return (struct venus_comm *)((sb)->s_fs_info); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | } |
| 32 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 33 | /* upcalls */ |
| 34 | int venus_rootfid(struct super_block *sb, struct CodaFid *fidp); |
| 35 | int venus_getattr(struct super_block *sb, struct CodaFid *fid, |
| 36 | struct coda_vattr *attr); |
| 37 | int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *); |
| 38 | int venus_lookup(struct super_block *sb, struct CodaFid *fid, |
| 39 | const char *name, int length, int *type, |
| 40 | struct CodaFid *resfid); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 41 | int venus_close(struct super_block *sb, struct CodaFid *fid, int flags, |
| 42 | vuid_t uid); |
| 43 | int venus_open(struct super_block *sb, struct CodaFid *fid, int flags, |
| 44 | struct file **f); |
| 45 | int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid, |
| 46 | const char *name, int length, |
| 47 | struct CodaFid *newfid, struct coda_vattr *attrs); |
| 48 | int 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) ; |
| 51 | int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid, |
| 52 | const char *name, int length); |
| 53 | int venus_remove(struct super_block *sb, struct CodaFid *dirfid, |
| 54 | const char *name, int length); |
| 55 | int venus_readlink(struct super_block *sb, struct CodaFid *fid, |
| 56 | char *buffer, int *length); |
| 57 | int 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); |
| 61 | int venus_link(struct super_block *sb, struct CodaFid *fid, |
| 62 | struct CodaFid *dirfid, const char *name, int len ); |
| 63 | int venus_symlink(struct super_block *sb, struct CodaFid *fid, |
| 64 | const char *name, int len, const char *symname, int symlen); |
| 65 | int venus_access(struct super_block *sb, struct CodaFid *fid, int mask); |
| 66 | int venus_pioctl(struct super_block *sb, struct CodaFid *fid, |
| 67 | unsigned int cmd, struct PioctlData *data); |
Yoshihisa Abe | f7cc02b8 | 2010-10-25 02:03:45 -0400 | [diff] [blame] | 68 | int coda_downcall(struct venus_comm *vcp, int opcode, union outputArgs *out); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 69 | int venus_fsync(struct super_block *sb, struct CodaFid *fid); |
David Howells | 726c334 | 2006-06-23 02:02:58 -0700 | [diff] [blame] | 70 | int venus_statfs(struct dentry *dentry, struct kstatfs *sfs); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | |
Jaswinder Singh Rajput | 7e7f4ea | 2009-02-02 21:40:10 +0530 | [diff] [blame] | 72 | /* |
| 73 | * Statistics |
| 74 | */ |
| 75 | |
| 76 | extern struct venus_comm coda_comms[]; |
| 77 | #endif /* __KERNEL__ */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 78 | |
| 79 | /* messages between coda filesystem in kernel and Venus */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 80 | struct 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 Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 89 | }; |
| 90 | |
Jens Axboe | 4aeefdc | 2010-08-03 13:22:51 +0200 | [diff] [blame] | 91 | #define CODA_REQ_ASYNC 0x1 |
| 92 | #define CODA_REQ_READ 0x2 |
| 93 | #define CODA_REQ_WRITE 0x4 |
| 94 | #define CODA_REQ_ABORT 0x8 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 95 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 96 | #endif |