linux写一个字符设备驱动程序,从零开始写linux字符设备驱动程序(一)(基于友善之臂tiny4412开发板)...

从这篇博文开始,我将开始手把手教会大家写linux设备驱动程序这是开篇,如何来写第一个字符设备驱动程序。首先,写一个最简单的字符设备驱动程序需要什么?或者说我们需要了解什么?1、每一个字符设备至少需要有一个设备号2、设备号 = 主设备号 + 次设备号3、同一类设备的主设备号一般是相同的,但不是绝对的。

那么,写一个简单的字符设备驱动程序,我们需要内核里的这几个头文件,因为我们需要调用一个基本的宏和一些基本的函数来给我们使用。#include #include #include打开linux内核源代码,进入include/linux/,找到cdev.h,打开,我们会看到这个结构体:struct cdev {

//设备模型相关的

struct kobject kobj;

//所属于哪个模块--->THIS MODULE

struct module *owner;

//利用file_operations跟用户态进行操作--->有open , read , write 等方法

const struct file_operations *ops;

//链表,将设备插入到一条链表里去

struct list_head list;

//通过设备号匹配对应的驱动

dev_t dev;

//要注册字符设备的个数

unsigned int count;

};还会看到以下的函数:void cdev_init(struct cdev *, const struct file_operations *);

struct cdev *cdev_alloc(void);

void cdev_put(struct cdev *p);

int cdev_add(struct cdev *, dev_t, unsigned);

void cdev_del(struct cdev *);

void cd_forget(struct inode *);这里我们需要的就是以上的这个结构体,还有cdev_init,cdev_add,cdev_del这三个函数,其余的暂时用不着。本节暂时不会用到以上的函数,下节将会使用。然后看到#include 这个头文件,这里面有我们需要的东西:#define MINORBITS20

#define MINORMASK((1U << MINORBITS) - 1)

//从设备号中取出主设备号

#define MAJOR(dev)((unsigned int) ((dev) >> MINORBITS))

//从设备号中取出次设备号

#define MINOR(dev)((unsigned int) ((dev) & MINORMASK))

//创建一个设备号

#define MKDEV(ma,mi)(((ma) << MINORBITS) | (mi))我们在接下来写的这个字符设备就需要创建一个设备号,所以我们需要MKDEV这个宏,第一个参数表示主设备号,第二个参数表示次设备号。我们知道如何去创建一个设备号,那么创建了设备号,还没有对这个设备进行注册,这时候就需要#include 这个头文件里的一个函数:extern int register_chrdev_region(dev_t, unsigned, const char *);既然有注册,当然就有释放,所以还需要:extern void unregister_chrdev_region(dev_t, unsigned);好了,有了这些基本知识,可以开始我们的第一个字符设备驱动程序的编写。

编写这个简单的字符设备需要以下步骤:1、创建设备号2、注册设备号3、如何驱动模块退出的时候,我们需要注销设备的操作。

好了,开始写代码:#include #include #include #include #include #include #include //定义一个结构体变量,用来表示设备号--->cdev.h--->dev_t

dev_t dev_no ;

static int __init cdev_test_init(void)

{

int ret ;

printk("HELLO KERNEL FOR CDEV!

");

//1、创建设备号-->第一个是主设备号,第二个是次设备号

//主设备号可以通过cat /proc/devices查看,如果设备号已经被占用,则需要使用没有使用过的设备号

dev_no = MKDEV(222,2);

//2、注册设备号

//count表示要分配多少个设备号

ret = register_chrdev_region(dev_no,1,"my_dev");

if(ret < 0){

//如果注册失败,跳转到对应的位置。

goto register_error ;

}

return 0 ;

register_error:

return ret ;

}

static int __exit cdev_test_exit(void)

{

//注销驱动-->后面写1表示从dev_no开始连续一个设备

unregister_chrdev_region(dev_no,1);

return 0 ;

}

module_init(cdev_test_init);

module_exit(cdev_test_exit);

MODULE_LICENSE("GPL");再和以前一样,写一个Kconfig和MakefileKconfigmenu "4412_CDEV_DRV"

config CDEV_TEST

bool "cdev_test"

default n

help

if you select , you can use it

endmenuMakefileobj-y += cdev_test.o再到上层的driver目录下Kconfig和Makefile中添加相应的语句,跟以往一样这里是在driver目录下创建了一个4char_dev的目录。

接下来在内核根目录下make menuconfig配置相应的驱动:

3f288ee285423cc6e29fa526842ca321.png

3f288ee285423cc6e29fa526842ca321.png将编译生成的zImage下载至开发板,打开串口调试,会看到以下log,说明驱动已经开始运行了:3f288ee285423cc6e29fa526842ca321.png接下来通过adb shell进入安卓系统的根目录下:cat /proc/devices我们成功的看到主设备号222的字符设备驱动my_dev已经成功装载了。3f288ee285423cc6e29fa526842ca321.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值