blob: a7b422b33eda65583d175ccd494b58d23c7716ec [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _LINUX_SUNRPC_RPC_PIPE_FS_H
2#define _LINUX_SUNRPC_RPC_PIPE_FS_H
3
4#ifdef __KERNEL__
5
J. Bruce Fields4dceef92009-08-20 17:08:39 -04006#include <linux/workqueue.h>
7
Linus Torvalds1da177e2005-04-16 15:20:36 -07008struct rpc_pipe_msg {
9 struct list_head list;
10 void *data;
11 size_t len;
12 size_t copied;
13 int errno;
14};
15
16struct rpc_pipe_ops {
17 ssize_t (*upcall)(struct file *, struct rpc_pipe_msg *, char __user *, size_t);
18 ssize_t (*downcall)(struct file *, const char __user *, size_t);
19 void (*release_pipe)(struct inode *);
\"J. Bruce Fields\c3810602008-12-23 16:08:32 -050020 int (*open_pipe)(struct inode *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 void (*destroy_msg)(struct rpc_pipe_msg *);
22};
23
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030024struct rpc_pipe {
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 struct list_head pipe;
26 struct list_head in_upcall;
Trond Myklebust6e84c7b2007-06-07 15:31:36 -040027 struct list_head in_downcall;
Linus Torvalds1da177e2005-04-16 15:20:36 -070028 int pipelen;
29 int nreaders;
30 int nwriters;
Linus Torvalds1da177e2005-04-16 15:20:36 -070031#define RPC_PIPE_WAIT_FOR_OPEN 1
32 int flags;
David Howells52bad642006-11-22 14:54:01 +000033 struct delayed_work queue_timeout;
Trond Myklebustb693ba42009-08-09 15:14:15 -040034 const struct rpc_pipe_ops *ops;
Stanislav Kinsbursky766347b2011-12-26 15:43:23 +030035 spinlock_t lock;
Stanislav Kinsburskyc239d832011-12-26 15:44:06 +030036 struct dentry *dentry;
Linus Torvalds1da177e2005-04-16 15:20:36 -070037};
38
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030039struct rpc_inode {
40 struct inode vfs_inode;
41 void *private;
42 struct rpc_pipe *pipe;
Stanislav Kinsbursky591ad7f2012-02-27 22:05:54 +040043 wait_queue_head_t waitq;
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030044};
45
Linus Torvalds1da177e2005-04-16 15:20:36 -070046static inline struct rpc_inode *
47RPC_I(struct inode *inode)
48{
49 return container_of(inode, struct rpc_inode, vfs_inode);
50}
51
Stanislav Kinsburskyeee17322012-01-10 16:13:19 +040052enum {
53 SUNRPC_PIPEFS_NFS_PRIO,
54 SUNRPC_PIPEFS_RPC_PRIO,
55};
56
Stanislav Kinsbursky2d001312011-12-26 15:39:13 +030057extern int rpc_pipefs_notifier_register(struct notifier_block *);
58extern void rpc_pipefs_notifier_unregister(struct notifier_block *);
59
60enum {
61 RPC_PIPEFS_MOUNT,
62 RPC_PIPEFS_UMOUNT,
63};
64
Stanislav Kinsbursky432eb1a2011-12-26 15:39:22 +030065extern struct dentry *rpc_d_lookup_sb(const struct super_block *sb,
66 const unsigned char *dir_name);
Stanislav Kinsburskyc21a5882011-12-26 15:39:39 +030067extern void rpc_pipefs_init_net(struct net *net);
68extern struct super_block *rpc_get_sb_net(const struct net *net);
69extern void rpc_put_sb_net(const struct net *net);
Stanislav Kinsbursky432eb1a2011-12-26 15:39:22 +030070
Peng Taoc1225152011-09-22 21:50:10 -040071extern ssize_t rpc_pipe_generic_upcall(struct file *, struct rpc_pipe_msg *,
72 char __user *, size_t);
Stanislav Kinsburskyd706ed12011-12-26 15:43:49 +030073extern int rpc_queue_upcall(struct rpc_pipe *, struct rpc_pipe_msg *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
Trond Myklebust458adb8b2009-08-09 15:14:22 -040075struct rpc_clnt;
Trond Myklebust23ac6582009-08-09 15:14:25 -040076extern struct dentry *rpc_create_client_dir(struct dentry *, struct qstr *, struct rpc_clnt *);
Trond Myklebust458adb8b2009-08-09 15:14:22 -040077extern int rpc_remove_client_dir(struct dentry *);
Trond Myklebust8854e822009-08-09 15:14:30 -040078
79struct cache_detail;
80extern struct dentry *rpc_create_cache_dir(struct dentry *,
81 struct qstr *,
Al Viro64f14262011-07-25 00:35:13 -040082 umode_t umode,
Trond Myklebust8854e822009-08-09 15:14:30 -040083 struct cache_detail *);
84extern void rpc_remove_cache_dir(struct dentry *);
85
Stanislav Kinsburskyeee17322012-01-10 16:13:19 +040086extern int rpc_rmdir(struct dentry *dentry);
87
Stanislav Kinsburskyc239d832011-12-26 15:44:06 +030088struct rpc_pipe *rpc_mkpipe_data(const struct rpc_pipe_ops *ops, int flags);
89void rpc_destroy_pipe_data(struct rpc_pipe *pipe);
90extern struct dentry *rpc_mkpipe_dentry(struct dentry *, const char *, void *,
91 struct rpc_pipe *);
Trond Myklebust5d674762006-07-31 14:11:48 -070092extern int rpc_unlink(struct dentry *);
Trond Myklebust7531d692007-05-14 17:21:26 -040093extern int register_rpc_pipefs(void);
94extern void unregister_rpc_pipefs(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
96#endif
97#endif