西装大叔gv资源:如何在proc目录下增加设备文件 - farsky16的专栏 - CSDN博客
来源:百度文库 编辑:九乡新闻网 时间:2024/04/28 06:11:41
如何在proc目录下增加设备文件
原文网址:
http://www.linuxforum.net/forum/gshowflat.php?Cat=&Board=linuxK&Number=335192&page=7&view=expanded&sb=5&o=all&vc=1
因为原来的代码编译时存在错误,因此我作了改动,并在redhat9.0(内核版本是2.4.20-8)上测试通过。分为三个文件:myproc.c,test.c,Makefile,测试流程很简单,在当前目录中输入"./test",首先将在/proc目录下创建一个"myproc"设备文件,然后向此文件写入一个字符串,接着读出来,在输出中应该看到前后字符串是一样的。代码如下:
/* myproc.c - create a "myproc" file in /proc
*
* Copyright (C) 2005 by linfeng12
*/
#ifndef __KERNEL__
#define __KERNEL__
#endif
#ifndef MODULE
#define MODULE
#endif
#ifndef __KERNEL_SYSCALLS__
#define __KERNEL_SYSCALLS__
#endif
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
static char msg[512];
static struct proc_dir_entry *myproc_DevEntry;
static int
myproc_DevOpen(struct inode *inode, // IN: Inode of the proc file
struct file *file) // IN: File for this process' proc file access
{
printk("myproc_DevOpen()\n");
return 0;
}
static int
myproc_DevRelease(struct inode *inode, // IN: Inode of released file
struct file *file) // IN: Released file
{
printk("myproc_DevRelease()\n");
return 0;
}
static ssize_t
myproc_DevRead(struct file *file, // IN: File pointer of file user is reading
char *buf, // OUT: User buffer to copy to
size_t count, // IN: Number of bytes to copy to user
loff_t *offset) // IN: Offset to read from. ignored.
{
printk("myproc_DevRead(): count=%d\n", count);
int i=0;
/* Copy bytes out to the user from a kernel buffer -- msg */
for (i=0; i
put_user(msg[i], buf+i);
}
return count;
}
static ssize_t
myproc_DevWrite(struct file *file, // IN: File pointer of file user is writing to
const char *buf, // IN: User buffer to copy from
size_t count, // IN: Number of bytes to copy
loff_t *offset) // IN: Offset in the file to write to. ignored.
{
printk("myproc_DevWrite(): count=%d\n", count);
int i=0;
memset(msg, 0, sizeof(msg));
/* Copy bytes in from a user buffer to a kernel buffer -- msg */
for (i=0; i
get_user(msg[i], buf+i);
}
return count;
}
struct file_operations fop = {
owner: THIS_MODULE,
open: myproc_DevOpen,
read: myproc_DevRead,
write: myproc_DevWrite,
release: myproc_DevRelease,
};
int init_module(void)
{
printk("myproc: init_module()\n");
myproc_DevEntry = create_proc_entry("myproc", S_IRUSR | S_IWUSR, NULL);
myproc_DevEntry->owner = THIS_MODULE;
myproc_DevEntry->proc_fops = &fop;
return 0;
}
void cleanup_module(void)
{
printk("myproc: cleanup_module()\n");
remove_proc_entry("myproc", myproc_DevEntry);
}
/* test.c - test the "myproc" file in /proc
*
* Copyright (C) 2005 by linfeng12
*/
#include
#include
#include
int main(void)
{
int fd, len;
char buf[16] = "test myproc";
fd = open("/proc/myproc", O_RDWR);
if (fd < 0)
{
printf("open proc file err!\n");
return -1;
}
len = write(fd, buf, strlen(buf));
printf("write the buf : %s, len: %d\n", buf, len);
memset(buf, 0, sizeof(buf));
len = read(fd, buf, sizeof(buf));
printf("read the buf : %s, len: %d\n", buf, len);
close(fd);
return 0;
}
# Makefile for a multifile kernel module
CC=gcc
MODCFLAGS := -Wall -DMODULE -D__KERNEL__ -DLINUX -I/usr/src/linux/include
all: test myproc.o
myproc.o: myproc.c
$(CC) -O2 $(MODCFLAGS) -c myproc.c -o myproc.o
insmod myproc.o
test:
$(CC) -O2 $(MODCFLAGS) test.c -o test
clean:
rm -f test *.o
rmmod myproc