⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dexinmeng_drive.c

📁 Linux下的驱动编程
💻 C
字号:
/*Linux2.4 驱动编程实例功能简述:实现一个简单的设备驱动,没有具体设备也可以实现测试,故:当实现设备驱动程序接口的open、release和ioctl函数时,利用printk函数向内核空间输出标志信息;当实现设备驱动程序接口的read函数时, 用户空间读进程会向内核空间请求length个字符数据,那么内核空间会给用户空间length个相同的字符数据;当实现设备驱动程序接口的write函数时,用户空间写进程会向内核空间写入length个字符数据,那么内核空间会利用printk函数向内核空间输出该数据。作者:时间:2008/12/24*/#ifndef MODULE#define MODULE#endif#ifndef __KERNEL__#define __KERNEL__#endif#include <linux/module.h>   	// Needed by all modules#include <linux/fs.h> 			// struct file_operations#include <linux/kernel.h>   	// Needed for KERN_ALERT#include <linux/init.h>     	// Needed for the macros#include <linux/poll.h> 		// for copy_to_user,有的用#include <asm/uaccess.h>#include <asm/uaccess.h>#define DEXINMENG_MAJOR 999						//主设备号#define DEXINMENG_NAME  "dexinmeng"				//设备名MODULE_LICENSE("GPL");/* 实现驱动程序接口的open函数 */int dexin_open(struct inode *inode, struct file *filp){	/* 用户自定义的函数 */	//利用printk函数向内核空间输出标志信息	printk("dexin_open!\n");		MOD_INC_USE_COUNT;	//增加模块计数器,防止在打开设备的情况下删除模块	return (0);          /* success */		 }/* 实现驱动程序接口的release函数 */int dexin_release(struct inode *inode, struct file *filp){	/* 用户自定义的函数 */	//利用printk函数向内核空间输出标志信息	printk("dexin_release!\n");		MOD_DEC_USE_COUNT;	//减模块计数器	return (0);}/* 实现驱动程序接口的ioctl函数 */int dexin_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,unsigned long arg){	/*switch(cmd)	{		case XXX:			...			break;		case YYY:			...			break;		...		default:			...			break;	}*/	printk("dexin_ioctl!\n");		return 0;}/* 实现驱动程序接口的read函数 */ssize_t dexin_read(struct file *filp, char *Userbuf, size_t length, loff_t *f_pos){	/* 其它语句 */	//用户空间读进程会向内核空间请求length个字符数据,那么内核空间会给用户空间length个相同的字符数据	char Kernelbuf[256];	int i;	for(i = 0; i < length; ++i)		Kernelbuf[i] = 'A';		/* 将内核空间的数据Kernelbuf复制到用户空间Userbuf中 */	/* length参数是读进程请求读取的数据量 */	copy_to_user(Userbuf, Kernelbuf, length);		return length;}/* 实现驱动程序接口的write函数 */ssize_t dexin_write(struct file *filp, const char *Userbuf, size_t length, loff_t *f_pos){	/* 其它语句 */	//用户空间写进程会向内核空间写入length个字符数据,那么内核空间会利用printk函数向内核空间输出该数据	char Kernelbuf[256];	  	/* 将用户空间Userbuf的数据复制到内核空间Kernelbuf中 */	/* length参数是写进程请求写入的数据量 */  	copy_from_user(Kernelbuf, Userbuf, length);  	  	//利用printk函数向内核空间输出该数据  	Kernelbuf[length] = 0;  	printk("%s\n",Kernelbuf);		return length;	}/* 定义一个struct file_operations变量,作为驱动程序的接口 */struct file_operations dexin_fops = {	open:       dexin_open,	read:       dexin_read,	write:      dexin_write,	ioctl:      dexin_ioctl,	release:    dexin_release};/*struct file_operations dexin_fops = {	.read = dexin_read,	.write = dexin_write,	.open = dexin_open,	.release = dexin_release};*//* 在模块初始化函数中注册该模块 */int init_module(void){	/* register_chrdev有三个参数:主设备号、设备名以及struct file_operations变量*/	int result;	result = register_chrdev(DEXINMENG_MAJOR,DEXINMENG_NAME,&dexin_fops);	/*  其它自定义函数 */	printk("dexinmeng_init!\n");	return 0;}/* 在模块清除函数中注销该模块 */void cleanup_module(void){  	/* unregister_chrdev 有二个参数:主设备号、设备名*/	unregister_chrdev(DEXINMENG_MAJOR,DEXINMENG_NAME); 		/*  其它自定义函数 */      		printk("dexinmeng_exit!\n");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -