blob: 7f490bef9e99f9838294bbb674e3014a7128185b [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
Trond Myklebust6739ffb2013-08-26 15:38:11 -04008struct rpc_pipe_dir_head {
9 struct list_head pdh_entries;
10 struct dentry *pdh_dentry;
11};
12
13struct rpc_pipe_dir_object_ops;
14struct rpc_pipe_dir_object {
15 struct list_head pdo_head;
16 const struct rpc_pipe_dir_object_ops *pdo_ops;
17
18 void *pdo_data;
19};
20
21struct rpc_pipe_dir_object_ops {
22 int (*create)(struct dentry *dir,
23 struct rpc_pipe_dir_object *pdo);
24 void (*destroy)(struct dentry *dir,
25 struct rpc_pipe_dir_object *pdo);
26};
27
Linus Torvalds1da177e2005-04-16 15:20:36 -070028struct rpc_pipe_msg {
29 struct list_head list;
30 void *data;
31 size_t len;
32 size_t copied;
33 int errno;
34};
35
36struct rpc_pipe_ops {
37 ssize_t (*upcall)(struct file *, struct rpc_pipe_msg *, char __user *, size_t);
38 ssize_t (*downcall)(struct file *, const char __user *, size_t);
39 void (*release_pipe)(struct inode *);
\"J. Bruce Fields\c3810602008-12-23 16:08:32 -050040 int (*open_pipe)(struct inode *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070041 void (*destroy_msg)(struct rpc_pipe_msg *);
42};
43
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030044struct rpc_pipe {
Linus Torvalds1da177e2005-04-16 15:20:36 -070045 struct list_head pipe;
46 struct list_head in_upcall;
Trond Myklebust6e84c7b2007-06-07 15:31:36 -040047 struct list_head in_downcall;
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 int pipelen;
49 int nreaders;
50 int nwriters;
Linus Torvalds1da177e2005-04-16 15:20:36 -070051#define RPC_PIPE_WAIT_FOR_OPEN 1
52 int flags;
David Howells52bad642006-11-22 14:54:01 +000053 struct delayed_work queue_timeout;
Trond Myklebustb693ba42009-08-09 15:14:15 -040054 const struct rpc_pipe_ops *ops;
Stanislav Kinsbursky766347b2011-12-26 15:43:23 +030055 spinlock_t lock;
Stanislav Kinsburskyc239d832011-12-26 15:44:06 +030056 struct dentry *dentry;
Linus Torvalds1da177e2005-04-16 15:20:36 -070057};
58
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030059struct rpc_inode {
60 struct inode vfs_inode;
61 void *private;
62 struct rpc_pipe *pipe;
Stanislav Kinsbursky591ad7f2012-02-27 22:05:54 +040063 wait_queue_head_t waitq;
Stanislav Kinsburskyba9e0972011-12-26 15:43:32 +030064};
65
Linus Torvalds1da177e2005-04-16 15:20:36 -070066static inline struct rpc_inode *
67RPC_I(struct inode *inode)
68{
69 return container_of(inode, struct rpc_inode, vfs_inode);
70}
71
Stanislav Kinsburskyeee17322012-01-10 16:13:19 +040072enum {
73 SUNRPC_PIPEFS_NFS_PRIO,
74 SUNRPC_PIPEFS_RPC_PRIO,
75};
76
Stanislav Kinsbursky2d001312011-12-26 15:39:13 +030077extern int rpc_pipefs_notifier_register(struct notifier_block *);
78extern void rpc_pipefs_notifier_unregister(struct notifier_block *);
79
80enum {
81 RPC_PIPEFS_MOUNT,
82 RPC_PIPEFS_UMOUNT,
83};
84
Stanislav Kinsbursky432eb1a2011-12-26 15:39:22 +030085extern struct dentry *rpc_d_lookup_sb(const struct super_block *sb,
86 const unsigned char *dir_name);
Jeff Layton4b9a4452013-11-14 07:25:17 -050087extern int rpc_pipefs_init_net(struct net *net);
88extern void rpc_pipefs_exit_net(struct net *net);
Stanislav Kinsburskyc21a5882011-12-26 15:39:39 +030089extern struct super_block *rpc_get_sb_net(const struct net *net);
90extern void rpc_put_sb_net(const struct net *net);
Stanislav Kinsbursky432eb1a2011-12-26 15:39:22 +030091
Peng Taoc1225152011-09-22 21:50:10 -040092extern ssize_t rpc_pipe_generic_upcall(struct file *, struct rpc_pipe_msg *,
93 char __user *, size_t);
Stanislav Kinsburskyd706ed12011-12-26 15:43:49 +030094extern int rpc_queue_upcall(struct rpc_pipe *, struct rpc_pipe_msg *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
Trond Myklebust458adb8b2009-08-09 15:14:22 -040096struct rpc_clnt;
Al Viroa95e6912013-07-14 16:43:54 +040097extern struct dentry *rpc_create_client_dir(struct dentry *, const char *, struct rpc_clnt *);
Trond Myklebustc36dcfe12013-08-26 17:44:26 -040098extern int rpc_remove_client_dir(struct rpc_clnt *);
Trond Myklebust6739ffb2013-08-26 15:38:11 -040099
100extern void rpc_init_pipe_dir_head(struct rpc_pipe_dir_head *pdh);
101extern void rpc_init_pipe_dir_object(struct rpc_pipe_dir_object *pdo,
102 const struct rpc_pipe_dir_object_ops *pdo_ops,
103 void *pdo_data);
104extern int rpc_add_pipe_dir_object(struct net *net,
105 struct rpc_pipe_dir_head *pdh,
106 struct rpc_pipe_dir_object *pdo);
107extern void rpc_remove_pipe_dir_object(struct net *net,
108 struct rpc_pipe_dir_head *pdh,
109 struct rpc_pipe_dir_object *pdo);
Trond Myklebust298fc352013-08-27 16:27:04 -0400110extern struct rpc_pipe_dir_object *rpc_find_or_alloc_pipe_dir_object(
111 struct net *net,
112 struct rpc_pipe_dir_head *pdh,
113 int (*match)(struct rpc_pipe_dir_object *, void *),
114 struct rpc_pipe_dir_object *(*alloc)(void *),
115 void *data);
Trond Myklebust8854e822009-08-09 15:14:30 -0400116
117struct cache_detail;
118extern struct dentry *rpc_create_cache_dir(struct dentry *,
Al Viroa95e6912013-07-14 16:43:54 +0400119 const char *,
Al Viro64f14262011-07-25 00:35:13 -0400120 umode_t umode,
Trond Myklebust8854e822009-08-09 15:14:30 -0400121 struct cache_detail *);
122extern void rpc_remove_cache_dir(struct dentry *);
123
Stanislav Kinsburskyeee17322012-01-10 16:13:19 +0400124extern int rpc_rmdir(struct dentry *dentry);
125
Stanislav Kinsburskyc239d832011-12-26 15:44:06 +0300126struct rpc_pipe *rpc_mkpipe_data(const struct rpc_pipe_ops *ops, int flags);
127void rpc_destroy_pipe_data(struct rpc_pipe *pipe);
128extern struct dentry *rpc_mkpipe_dentry(struct dentry *, const char *, void *,
129 struct rpc_pipe *);
Trond Myklebust5d674762006-07-31 14:11:48 -0700130extern int rpc_unlink(struct dentry *);
Trond Myklebust7531d692007-05-14 17:21:26 -0400131extern int register_rpc_pipefs(void);
132extern void unregister_rpc_pipefs(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133
Jeff Layton89f84242013-11-14 07:25:18 -0500134extern bool gssd_running(struct net *net);
135
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136#endif
137#endif