韦东山第二期——1.2_字符设备驱动程序之编写编译

作者:GWD 时间:2019.8.27

1、先写这两个,应用程序必须要告诉内核有这个程序,应用程序中需要什么接口, operation结构体中就有对应的接口,定义这个结构
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2、将这个结构告诉内核
在这里插入图片描述
在这里插入图片描述
内核怎么调用这个函数呢——第一个驱动的入口函数
3、但是每个驱动都有自己的入口函数,内核怎么知道哪个设备对应自己的入口呢?
答:要修饰一下,用module_init这个宏来修饰。这是一个结构体,里面有入口函数的指针,内核启动后会自动加载这个结构体。
4、使用设备类型+主设备号确定程序调用哪个设备,C表示字符型设备。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
4、再梳理一下驱动的流程
在这里插入图片描述
5、有入口就有出口,看一看出口(卸载)是怎样的,也是宏定义的结构体,在Linux中调用。
在这里插入图片描述
6、第一个驱动实现的功能就是打印一些信息
在这里插入图片描述
7、接下来编译加载
Makefile怎么写?
在这里插入图片描述
第一行,编译依赖linux内核,加载前内核要先编译一次linux2.6以支持编译驱动。
在这里插入图片描述
8、接下来拷到单板上测试一下
放到first_fs中
加载驱动用insmod命令
在这里插入图片描述
在这里插入图片描述
9、代码


#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/delay.h>
#include <asm/uaccess.h>
#include <asm/irq.h>
#include <asm/io.h>
#include <asm/arch/regs-gpio.h>
#include <asm/hardware.h>

static int first_drv_open(struct inode *inode, struct file *file)
{
	printk("first_drv_open\n");
	return 0;
}

static ssize_t first_drv_write(struct file *file, const char __user *buf, size_t count, loff_t * ppos)
{
	printk("first_drv_write\n");
	return 0;
}

static struct file_operations first_drv_fops = {
    .owner  =   THIS_MODULE,    /* 这是一个宏,推向编译模块时自动创建的__this_module变量 */
    .open   =   first_drv_open,     
	.write	=	first_drv_write,	   
};


static int first_drv_init(void)
{
	register_chrdev(111, "first_drv", &first_drv_fops); // 注册, 告诉内核
	return 0;
}

static void first_drv_exit(void)
{
	unregister_chrdev(111, "first_drv"); // 卸载

}

module_init(first_drv_init);
module_exit(first_drv_exit);


MODULE_LICENSE("GPL");


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值