mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-24 21:24:00 +08:00
52bad64d95
Separate delayable work items from non-delayable work items be splitting them into a separate structure (delayed_work), which incorporates a work_struct and the timer_list removed from work_struct. The work_struct struct is huge, and this limits it's usefulness. On a 64-bit architecture it's nearly 100 bytes in size. This reduces that by half for the non-delayable type of event. Signed-Off-By: David Howells <dhowells@redhat.com>
53 lines
1.2 KiB
C
53 lines
1.2 KiB
C
#ifndef _LINUX_SUNRPC_RPC_PIPE_FS_H
|
|
#define _LINUX_SUNRPC_RPC_PIPE_FS_H
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
struct rpc_pipe_msg {
|
|
struct list_head list;
|
|
void *data;
|
|
size_t len;
|
|
size_t copied;
|
|
int errno;
|
|
};
|
|
|
|
struct rpc_pipe_ops {
|
|
ssize_t (*upcall)(struct file *, struct rpc_pipe_msg *, char __user *, size_t);
|
|
ssize_t (*downcall)(struct file *, const char __user *, size_t);
|
|
void (*release_pipe)(struct inode *);
|
|
void (*destroy_msg)(struct rpc_pipe_msg *);
|
|
};
|
|
|
|
struct rpc_inode {
|
|
struct inode vfs_inode;
|
|
void *private;
|
|
struct list_head pipe;
|
|
struct list_head in_upcall;
|
|
int pipelen;
|
|
int nreaders;
|
|
int nwriters;
|
|
wait_queue_head_t waitq;
|
|
#define RPC_PIPE_WAIT_FOR_OPEN 1
|
|
int flags;
|
|
struct rpc_pipe_ops *ops;
|
|
struct delayed_work queue_timeout;
|
|
};
|
|
|
|
static inline struct rpc_inode *
|
|
RPC_I(struct inode *inode)
|
|
{
|
|
return container_of(inode, struct rpc_inode, vfs_inode);
|
|
}
|
|
|
|
extern int rpc_queue_upcall(struct inode *, struct rpc_pipe_msg *);
|
|
|
|
extern struct dentry *rpc_mkdir(char *, struct rpc_clnt *);
|
|
extern int rpc_rmdir(struct dentry *);
|
|
extern struct dentry *rpc_mkpipe(struct dentry *, const char *, void *, struct rpc_pipe_ops *, int flags);
|
|
extern int rpc_unlink(struct dentry *);
|
|
extern struct vfsmount *rpc_get_mount(void);
|
|
extern void rpc_put_mount(void);
|
|
|
|
#endif
|
|
#endif
|