-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathmodule.3.18.c
More file actions
245 lines (229 loc) · 6.31 KB
/
module.3.18.c
File metadata and controls
245 lines (229 loc) · 6.31 KB
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
// Header files which is accessible via include folder
#include <net/sch_generic.h>
#include <net/tcp.h>
#include <linux/utsname.h>
#include <net/inet_sock.h>
#include <linux/notifier.h>
#include <net/af_unix.h>
#include <net/sock.h>
#include <linux/fs.h>
#include <linux/fs_struct.h>
#include <net/route.h>
#include <linux/fdtable.h>
#include <linux/proc_fs.h>
#include <asm-generic/int-ll64.h>
#include <linux/pid_namespace.h>
#include <linux/wait.h>
#include <net/protocol.h>
#include <linux/mount.h>
#include <linux/ioport.h>
#include <net/ip.h>
#include <uapi/asm-generic/int-ll64.h>
#include <linux/module.h>
#include <net/ip_fib.h>
#include <linux/timekeeper_internal.h>
#include <linux/types.h>
#include <linux/path.h>
#include <linux/netfilter.h>
#include <net/udp.h>
#include <linux/pid.h>
#include <linux/un.h>
#include <linux/sysfs.h>
#include <linux/version.h>
#include <net/net_namespace.h>
#include <linux/tty_driver.h>
#include <linux/uidgid.h>
#include <linux/inetdevice.h>
#include <linux/compiler.h>
#include <linux/termios.h>
#include <linux/tty.h>
#include <asm/termbits.h>
#include <linux/netfilter/x_tables.h>
#include <linux/lockref.h>
#include <linux/radix-tree.h>
#include <linux/spinlock_types.h>
// Local definition for included structure
struct Qdisc qdisc;
struct atomic_notifier_head atomic_notifier_head;
struct fib_table fib_table;
struct files_struct files_struct;
struct in_device in_device;
struct inet_protosw inet_protosw;
struct inet_sock inet_sock;
struct lockref lockref;
struct module_kobject module_kobject;
struct nf_hook_ops nf_hook_ops;
struct nf_sockopt_ops nf_sockopt_ops;
struct pid pid;
struct pid_namespace pid_namespace;
struct radix_tree_root radix_tree_root;
struct resource resource;
struct sock sock;
struct tcp_seq_afinfo tcp_seq_afinfo;
struct timekeeper my_timekeeper;
struct tty_driver tty_driver;
struct tty_struct tty_struct;
struct udp_seq_afinfo udp_seq_afinfo;
struct unix_sock unix_sock;
struct uts_namespace uts_namespace;
struct vfsmount vfsmount;
struct xt_table xt_table;
// Source level struct definition
// Forward-declare
struct array_cache;
struct fib_alias;
struct kthread_create_info;
struct mnt_namespace;
struct mnt_pcp;
struct module_sect_attr;
struct module_sect_attrs;
struct mount;
struct proc_dir_entry;
// struct array_cache
// File: mm/slab.c
struct array_cache {
unsigned int avail;
unsigned int limit;
unsigned int batchcount;
unsigned int touched;
void *entry[]; /*
* Must have this definition in here for the proper
* alignment of array_cache. Also simplifies accessing
* the entries.
*
* Entries should not be directly dereferenced as
* entries belonging to slabs marked pfmemalloc will
* have the lower bits set SLAB_OBJ_PFMEMALLOC
*/
};
// struct fib_alias
// File: net/ipv4/fib_lookup.h
struct fib_alias {
struct list_head fa_list;
struct fib_info *fa_info;
u8 fa_tos;
u8 fa_type;
u8 fa_state;
struct rcu_head rcu;
};
// struct kthread_create_info
// File: kernel/kthread.c
struct kthread_create_info
{
/* Information passed to kthread() from kthreadd. */
int (*threadfn)(void *data);
void *data;
int node;
/* Result passed back to kthread_create() from kthreadd. */
struct task_struct *result;
struct completion *done;
struct list_head list;
};
// struct mnt_namespace
// File: fs/mount.h
struct mnt_namespace {
atomic_t count;
unsigned int proc_inum;
struct mount * root;
struct list_head list;
struct user_namespace *user_ns;
u64 seq; /* Sequence number to prevent loops */
wait_queue_head_t poll;
u64 event;
};
// struct mnt_pcp
// File: fs/mount.h
struct mnt_pcp {
int mnt_count;
int mnt_writers;
};
// struct module_sect_attr
// File: kernel/module.c
struct module_sect_attr
{
struct module_attribute mattr;
char *name;
unsigned long address;
};
// struct module_sect_attrs
// File: kernel/module.c
struct module_sect_attrs
{
struct attribute_group grp;
unsigned int nsections;
struct module_sect_attr attrs[0];
};
// struct mount
// File: fs/mount.h
struct mount {
struct hlist_node mnt_hash;
struct mount *mnt_parent;
struct dentry *mnt_mountpoint;
struct vfsmount mnt;
union {
struct rcu_head mnt_rcu;
struct llist_node mnt_llist;
};
#ifdef CONFIG_SMP
struct mnt_pcp __percpu *mnt_pcp;
#else
int mnt_count;
int mnt_writers;
#endif
struct list_head mnt_mounts; /* list of children, anchored here */
struct list_head mnt_child; /* and going through their mnt_child */
struct list_head mnt_instance; /* mount instance on sb->s_mounts */
const char *mnt_devname; /* Name of device e.g. /dev/dsk/hda1 */
struct list_head mnt_list;
struct list_head mnt_expire; /* link in fs-specific expiry list */
struct list_head mnt_share; /* circular list of shared mounts */
struct list_head mnt_slave_list;/* list of slave mounts */
struct list_head mnt_slave; /* slave list entry */
struct mount *mnt_master; /* slave is on master->mnt_slave_list */
struct mnt_namespace *mnt_ns; /* containing namespace */
struct mountpoint *mnt_mp; /* where is it mounted */
struct hlist_node mnt_mp_list; /* list mounts with the same mountpoint */
#ifdef CONFIG_FSNOTIFY
struct hlist_head mnt_fsnotify_marks;
__u32 mnt_fsnotify_mask;
#endif
int mnt_id; /* mount identifier */
int mnt_group_id; /* peer group identifier */
int mnt_expiry_mark; /* true if marked for expiry */
struct hlist_head mnt_pins;
struct path mnt_ex_mountpoint;
};
// struct proc_dir_entry
// File: fs/proc/internal.h
struct proc_dir_entry {
unsigned int low_ino;
umode_t mode;
nlink_t nlink;
kuid_t uid;
kgid_t gid;
loff_t size;
const struct inode_operations *proc_iops;
const struct file_operations *proc_fops;
struct proc_dir_entry *next, *parent, *subdir;
void *data;
atomic_t count; /* use count */
atomic_t in_use; /* number of callers into module in progress; */
/* negative -> it's going away RSN */
struct completion *pde_unload_completion;
struct list_head pde_openers; /* who did ->open, but not ->release */
spinlock_t pde_unload_lock; /* proc_fops checks and pde_users bumps */
u8 namelen;
char name[];
};
// Local definition for source structure
struct fib_alias fib_alias;
struct kthread_create_info kthread_create_info;
struct module_sect_attrs module_sect_attrs;
// Unknown or undefined struct in this kernel version:
// struct fib_node
// struct fn_hash
// struct fn_zone
// struct kmem_list3
// struct log
// struct rt_hash_bucket
// struct slab