1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
/****************************************************************************
****************************************************************************
***
*** This header was automatically generated from a Linux kernel header
*** of the same name, to make information necessary for userspace to
*** call into the kernel available to libc. It contains only constants,
*** structures, and macros generated from the original header, and thus,
*** contains no copyrightable information.
***
****************************************************************************
****************************************************************************/
#ifndef _LINUX_RELAY_H
#define _LINUX_RELAY_H
#include <linux/types.h>
#include <linux/sched.h>
#include <linux/wait.h>
#include <linux/list.h>
#include <linux/fs.h>
#include <linux/poll.h>
#include <linux/kref.h>
#define FIX_SIZE(x) ((((x) - 1) & PAGE_MASK) + PAGE_SIZE)
#define RELAYFS_CHANNEL_VERSION 6
struct rchan_buf
{
void *start;
void *data;
size_t offset;
size_t subbufs_produced;
size_t subbufs_consumed;
struct rchan *chan;
wait_queue_head_t read_wait;
struct work_struct wake_readers;
struct dentry *dentry;
struct kref kref;
struct page **page_array;
unsigned int page_count;
unsigned int finalized;
size_t *padding;
size_t prev_padding;
size_t bytes_consumed;
unsigned int cpu;
} ____cacheline_aligned;
struct rchan
{
u32 version;
size_t subbuf_size;
size_t n_subbufs;
size_t alloc_size;
struct rchan_callbacks *cb;
struct kref kref;
void *private_data;
size_t last_toobig;
struct rchan_buf *buf[NR_CPUS];
};
struct rchan_callbacks
{
int (*subbuf_start) (struct rchan_buf *buf,
void *subbuf,
void *prev_subbuf,
size_t prev_padding);
void (*buf_mapped)(struct rchan_buf *buf,
struct file *filp);
void (*buf_unmapped)(struct rchan_buf *buf,
struct file *filp);
struct dentry *(*create_buf_file)(const char *filename,
struct dentry *parent,
int mode,
struct rchan_buf *buf,
int *is_global);
int (*remove_buf_file)(struct dentry *dentry);
};
struct rchan *relay_open(const char *base_filename,
struct dentry *parent,
size_t subbuf_size,
size_t n_subbufs,
struct rchan_callbacks *cb);
#endif
|