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
|
/* $OpenBSD: compat_linux.h,v 1.3 2005/01/14 08:10:17 uwe Exp $ */
/*
* Copyright (c) 2005 Uwe Stuehler <uwe@bsdx.de>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#if 0
/* Define these unconditionally to get the .modinfo section. */
#undef __KERNEL__
#undef MODULE
#define __KERNEL__
#define MODULE
/* Standard headers for Linux LKMs */
#include <linux/kernel.h>
#include <linux/modsetver.h>
#include <linux/module.h>
/*
* Include Linux 2.4.x headers.
*/
#include <linux/elf.h>
#include <linux/errno.h>
#include <linux/fs.h>
#include <linux/pagemap.h>
#include <linux/file.h>
#include <linux/slab.h>
#include <asm/mach/map.h>
#else
/*
* Declare the things that we need from the Linux headers.
*/
#define IS_ERR(ptr) ((unsigned long)(ptr) > (unsigned long)-1000L)
#define MKDEV(ma,mi) ((ma)<<8 | (mi))
#define S_IFBLK 0060000
#define S_IFCHR 0020000
struct file;
struct inode;
typedef long loff_t;
typedef int ssize_t;
typedef unsigned int size_t;
struct file_operations {
struct module *owner;
void (*llseek) (void);
ssize_t (*read) (struct file *, char *, size_t, loff_t *);
ssize_t (*write) (struct file *, const char *, size_t, loff_t *);
void (*readdir) (void);
void (*poll) (void);
void (*ioctl) (void);
void (*mmap) (void);
int (*open) (struct inode *, struct file *);
void (*flush) (void);
int (*release) (struct inode *, struct file *);
void (*fsync) (void);
void (*fasync) (void);
void (*lock) (void);
void (*readv) (void);
void (*writev) (void);
void (*sendpage) (void);
void (*get_unmapped_area)(void);
#ifdef MAGIC_ROM_PTR
void (*romptr) (void);
#endif /* MAGIC_ROM_PTR */
};
extern struct file * open_exec(const char *);
extern void fput(struct file *);
extern int kernel_read(struct file *, unsigned long, char *, unsigned long);
extern int memcmp(const void *, const void *, unsigned int);
extern int register_chrdev(unsigned int, const char *, struct file_operations *);
extern int unregister_chrdev(unsigned int, const char *);
extern void printk(const char *, ...);
extern void *memcpy(void *, const void *, size_t);
/* BSD headers */
#include <sys/exec_elf.h>
#include <errno.h>
/* Linux LKM support */
static const char __module_kernel_version[] __attribute__((section(".modinfo"))) =
"kernel_version=" UTS_RELEASE;
#if 1 /* def MODVERSIONS */
static const char __module_using_checksums[] __attribute__((section(".modinfo"))) =
"using_checksums=1";
#endif
/* procfs support */
struct proc_dir_entry {
unsigned short low_ino;
unsigned short namelen;
const char *name;
unsigned short mode;
unsigned short nlink;
unsigned short uid;
unsigned short gid;
unsigned long size;
void *proc_iops; /* inode operations */
struct file_operations * proc_fops;
void *get_info;
struct module *owner;
struct proc_dir_entry *next, *parent, *subdir;
void *data;
void *read_proc;
void *write_proc;
volatile int count;
int deleted;
unsigned short rdev;
};
extern struct proc_dir_entry proc_root;
extern struct proc_dir_entry *proc_mknod(const char*, unsigned short,
struct proc_dir_entry*, unsigned short);
extern void remove_proc_entry(const char *, struct proc_dir_entry *);
#endif
|