Linux驱动开发--Linux字符设备驱动模板

本文深入探讨了Linux驱动开发中的字符设备驱动模板,详细介绍了如何创建、注册和使用字符设备驱动。通过实例解析了驱动程序的核心组件,包括设备文件、主次设备号、驱动模型、缓冲区管理和I/O控制。对于希望理解和实践Linux内核驱动开发的读者来说,是一份宝贵的参考资料。
摘要由CSDN通过智能技术生成
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/cdev.h>
#include <linux/fs.h>/*包含struct file_operations,MAJOR等*/
#include <linux/slab.h>/*kmalloc*/
#include <asm/io.h>/*ioread8...*/
#include <mach/map.h>
#include <mach/regs-gpio.h>
#include <mach/gpio-bank-l.h>/*端口操作用到的三个头文件*/


#define XXX_MAJOR 125
#define DEVICE_NAME "xxx_dev"
#define CMD_1 0;
#define CMD_2 1;

int xxx_major=XXX_MAJOR;
struct XXX_DEV{
	struct cdev cdev;
	int value;	
};

struct XXX_DEV *xxx_dev;

int  xxx_open(struct inode* inode,struct file* filp)
{
	struct XXX_DEV* dev;
	dev=container_of(inode->i_cdev,struct XXX_DEV,cdev);
	filp->private_data=dev;
	return 0;
}

int  xxx_release(struct inode* inode,struct file* filp)
{
	return 0;
}

ssize_t xxx_read(struct file* filp,char __user *buf,size_t count,loff_t *f_pos)
{
	return 0;
}

ssize_t xxx_write(struct file *filp,const char __user *buf,size_t count,loff_t *f_pos)
{
	return 0;
}

long xxx_ioctl(struct file *filp,unsigned int cmd,unsigned long arg)
{
	struct XXX_DEV *xxx_dev=filp->private_data;
	switch(cmd){
	case LED_0:{
		break;
	}
	case LED_1:{
		break;	
	}
	default:
		return -ENOTTY;
	}
	return 0;
}

struct file_operations xxx_fops={
	.owner=THIS_MODULE,
	.open=xxx_open,
	.read=xxx_read,
	.write=xxx_write,
	.unlocked_ioctl=xxx_ioctl,
	.release=xxx_release,
};

static int __init xxx_init(void)
{
	int result;
	dev_t devno;
	if(XXX_MAJOR){
		devno=MKDEV(XXX_MAJOR,0);
		result=register_chrdev_region(devno,1,DEVICE_NAME);
	}else{
		result=alloc_chrdev_region(&devno,0,1,DEVICE_NAME);
		xxx_major=MAJOR(devno);
	}
	if(result<0){
		printk(KERN_WARNING "ERROR: can not register\n");
		return result;
	}
	
	xxx_dev=kmalloc(sizeof(struct XXX_DEV),GFP_KERNEL);
	if(!xxx_dev){
		result=-ENOMEM;
		goto fail;
	}
	memset(xxx_dev,0,sizeof(struct XXX_DEV));
	cdev_init(&xxx_dev->cdev,&xxx_fops);
	xxx_dev->cdev.owner=THIS_MODULE;
	result=cdev_add(&xxx_dev->cdev,devno,1);
	if(result){
		printk(KERN_WARNING "ERROR: can not add cdev\n");
		goto fail;
	}
	return 0;
fail:
	unregister_chrdev_region(devno,1);
	return result;
}

static void __exit xxx_exit(void)
{
	dev_t devno=MKDEV(xxx_major,0);
	if(xxx_dev){
		cdev_del(&xxx_dev->cdev);
		kfree(xxx_dev);
	}
	unregister_chrdev_region(devno,1);
}

MODULE_LICENSE("Dual BSD/GPL");
MODULE_AUTHOR("yixuaning <yixuaning@sina.com>");
module_init(xxx_init);
module_exit(xxx_exit);


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值