第一个 linux驱动程序


#include <linux/module.h>
#include <linux/fs.h>
#include <linux/uaccess.h>
#include <linux/device.h>

#if 1


static int major = 0;


static int key_val = 0x65666768;


ssize_t hello_write(struct file *file,const char __user *buf,size_t size, loff_t *offset)
{
	int err;
	printk("Hello_write\n");
	copy_from_user(&key_val,buf,4);

	return 4;
}

ssize_t hello_read(struct file *file , char __user * buf, size_t size, loff_t *offset)
{
	int err;
	copy_to_user(buf,&key_val,4);

	return 4;
}

static struct file_operations hello_funcs={

	.owner 	= THIS_MODULE,
	.read		=hello_read,
	.write 	=hello_write,
};


static struct class * qmcy;
static struct device * device;
int __init hello_init(void)
{
	printk("Hello QMCY enter\n");
	major = register_chrdev(0,"QMCY",&hello_funcs);
	qmcy = class_create(THIS_MODULE,"QMCY");	//sys/class/QMCY

	device_create(qmcy,NULL,MKDEV(major,0),NULL,"QMCY");//dev/QMCY
	return 0;	
}



void __exit hello_exit(void) 
{
	printk("Hello QMCY exit\n");
	device_destroy(qmcy,MKDEV(major,0));
	unregister_chrdev(major,"QMCY");
	class_destroy(qmcy);
}


module_init(hello_init);
module_exit(hello_exit);

#else

int init_module()
{
	printk("Hello first driver\n");
	return 0;
}


void cleanup_module()
{
	printk("Hello first exit\n");
}
#endif
 MODULE_LICENSE("GPL");


Makefile文件内容




KERNEL= $(shell uname -r)

KERNEL_DIR=/lib/modules/$(KERNEL)/build


all:
	make -C $(KERNEL_DIR) M=`pwd` modules

clean:
	make -C $(KERNEL_DIR) M=`pwd` modules clean
	rm -rf modules.order

obj-m 		+=hello.o

make 之后  

生成hello.ko

insmod hello.ko

rmmod.ko

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

QMCY_jason

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值