blob: 52da08c770b079a8c13516ba7c734c80733ffc18 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef __CODA_PSDEV_H
3#define __CODA_PSDEV_H
4
Jens Axboe33f60e92010-04-28 09:20:33 +02005#include <linux/backing-dev.h>
Jan Harkes6dc280e2019-07-16 16:28:51 -07006#include <linux/magic.h>
Yoshihisa Abeda47c192010-10-25 02:03:46 -04007#include <linux/mutex.h>
Jan Harkes6dc280e2019-07-16 16:28:51 -07008
9#define CODA_PSDEV_MAJOR 67
10#define MAX_CODADEVS 5 /* how many do we allow */
Jens Axboe33f60e92010-04-28 09:20:33 +020011
Linus Torvalds1da177e2005-04-16 15:20:36 -070012struct kstatfs;
13
Mikko Rapelif90fb3c2019-07-16 16:28:10 -070014/* messages between coda filesystem in kernel and Venus */
15struct upc_req {
16 struct list_head uc_chain;
17 caddr_t uc_data;
18 u_short uc_flags;
19 u_short uc_inSize; /* Size is at most 5000 bytes */
20 u_short uc_outSize;
21 u_short uc_opcode; /* copied from data to save lookup */
22 int uc_unique;
23 wait_queue_head_t uc_sleep; /* process' wait queue */
24};
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Jan Harkes2fe74912019-07-16 16:28:26 -070026#define CODA_REQ_ASYNC 0x1
27#define CODA_REQ_READ 0x2
28#define CODA_REQ_WRITE 0x4
29#define CODA_REQ_ABORT 0x8
30
David Howells8fc8b9d2019-07-16 16:28:47 -070031/* communication pending/processing queues */
32struct venus_comm {
33 u_long vc_seq;
34 wait_queue_head_t vc_waitq; /* Venus wait queue */
35 struct list_head vc_pending;
36 struct list_head vc_processing;
37 int vc_inuse;
38 struct super_block *vc_sb;
39 struct mutex vc_mutex;
40};
41
Jan Harkesa1b0aa82007-07-19 01:48:50 -070042static inline struct venus_comm *coda_vcp(struct super_block *sb)
Linus Torvalds1da177e2005-04-16 15:20:36 -070043{
Jan Harkesa1b0aa82007-07-19 01:48:50 -070044 return (struct venus_comm *)((sb)->s_fs_info);
Linus Torvalds1da177e2005-04-16 15:20:36 -070045}
46
Linus Torvalds1da177e2005-04-16 15:20:36 -070047/* upcalls */
48int venus_rootfid(struct super_block *sb, struct CodaFid *fidp);
49int venus_getattr(struct super_block *sb, struct CodaFid *fid,
50 struct coda_vattr *attr);
51int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *);
David Howells8fc8b9d2019-07-16 16:28:47 -070052int venus_lookup(struct super_block *sb, struct CodaFid *fid,
53 const char *name, int length, int *type,
Linus Torvalds1da177e2005-04-16 15:20:36 -070054 struct CodaFid *resfid);
Linus Torvalds1da177e2005-04-16 15:20:36 -070055int venus_close(struct super_block *sb, struct CodaFid *fid, int flags,
Eric W. Biedermand83f5902013-01-30 19:21:14 -080056 kuid_t uid);
Linus Torvalds1da177e2005-04-16 15:20:36 -070057int venus_open(struct super_block *sb, struct CodaFid *fid, int flags,
58 struct file **f);
David Howells8fc8b9d2019-07-16 16:28:47 -070059int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid,
60 const char *name, int length,
Linus Torvalds1da177e2005-04-16 15:20:36 -070061 struct CodaFid *newfid, struct coda_vattr *attrs);
David Howells8fc8b9d2019-07-16 16:28:47 -070062int venus_create(struct super_block *sb, struct CodaFid *dirfid,
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 const char *name, int length, int excl, int mode,
David Howells8fc8b9d2019-07-16 16:28:47 -070064 struct CodaFid *newfid, struct coda_vattr *attrs);
65int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid,
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 const char *name, int length);
David Howells8fc8b9d2019-07-16 16:28:47 -070067int venus_remove(struct super_block *sb, struct CodaFid *dirfid,
Linus Torvalds1da177e2005-04-16 15:20:36 -070068 const char *name, int length);
David Howells8fc8b9d2019-07-16 16:28:47 -070069int venus_readlink(struct super_block *sb, struct CodaFid *fid,
Linus Torvalds1da177e2005-04-16 15:20:36 -070070 char *buffer, int *length);
David Howells8fc8b9d2019-07-16 16:28:47 -070071int venus_rename(struct super_block *sb, struct CodaFid *new_fid,
72 struct CodaFid *old_fid, size_t old_length,
73 size_t new_length, const char *old_name,
Linus Torvalds1da177e2005-04-16 15:20:36 -070074 const char *new_name);
David Howells8fc8b9d2019-07-16 16:28:47 -070075int venus_link(struct super_block *sb, struct CodaFid *fid,
Linus Torvalds1da177e2005-04-16 15:20:36 -070076 struct CodaFid *dirfid, const char *name, int len );
77int venus_symlink(struct super_block *sb, struct CodaFid *fid,
78 const char *name, int len, const char *symname, int symlen);
79int venus_access(struct super_block *sb, struct CodaFid *fid, int mask);
80int venus_pioctl(struct super_block *sb, struct CodaFid *fid,
81 unsigned int cmd, struct PioctlData *data);
Jan Harkes6e51f8a2019-07-16 16:28:16 -070082int coda_downcall(struct venus_comm *vcp, int opcode, union outputArgs *out,
83 size_t nbytes);
Linus Torvalds1da177e2005-04-16 15:20:36 -070084int venus_fsync(struct super_block *sb, struct CodaFid *fid);
David Howells726c3342006-06-23 02:02:58 -070085int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
Pedro Cuadraa9fba242019-07-16 16:29:13 -070086int venus_access_intent(struct super_block *sb, struct CodaFid *fid,
87 bool *access_intent_supported,
88 size_t count, loff_t ppos, int type);
Linus Torvalds1da177e2005-04-16 15:20:36 -070089
Jaswinder Singh Rajput7e7f4ea2009-02-02 21:40:10 +053090/*
91 * Statistics
92 */
93
94extern struct venus_comm coda_comms[];
Linus Torvalds1da177e2005-04-16 15:20:36 -070095#endif