linux系统中常见注册函数的使用方法

简介: linux系统中常见注册函数的使用方法

    大家好,今天给大家分享一下,linux系统中常见的注册函数register_chrdev_region()、register_chrdev()、 alloc_chrdev_region()的使用方法。

一、函数包含的头文件:

分配设备编号,注册设备与注销设备的函数均在fs.h中申明,如下:

extern int register_chrdev_region(dev_t, unsigned, const char *); //静态的申请和注册设备号

extern int  alloc_chrdev_region(dev_t, unsigned, const char *);     //动态的申请注册一个设备号

extern int register_chrdev(unsigned int, const char *,struct file_operations *);//int为0时候动态注册,非零时候静态注册。

extern int unregister_chrdev(unsigned int, const char *);   //注销设备号

extern void unregister_chrdev_region(dev_t, unsigned);   //注销设备号

二、注册设备号

静态注册:

使用register_chrdev_region()首先需要定义一个dev_t变量来作为一个设备号,

dev_t   dev_num;

要想注册一个设备则需要一个主设备号。

根据主设备号获取设备号:

dev_num=MKDEV(major,minor);  major是一个表示设备号的主设备号,minor次设备号

注册:

register_chrdev_region(dev_num,2,"dev_name");

第一个参数表示设备号,第二个参数表示注册的此设备数目,第三个表示设备名称。

动态注册:

如果我们提前知道设备的编号,那么就用register_chrdev_region(),但是如果我们不知道呢,我们就使用动态申请设备编号。

alloc_chrdev_region(&dev_num, minor, 2, "dev_name");

第一个参数保存生成的设备号,第二个参数注册设备的数目,第三个参数表示设备名称。

根据设备号获取主设备号:

dev_major = MAJOR(dev_num);

三、向内核中添加设备

struct cdev  devno;

cdev_init(&devno,&file_ops); //初始化设备

devno.owner = THIS_MODULE;   //.owner这表示谁拥有你这个驱动程序,

devno.ops = &mem_fops;

对于已经知道了主设备号,就用cdev_add(&devno, dev_num,count);来添加设备

如果是动态申请的设备号,就用cdev_add(&devno, MKDEV(mem_major, 0), count);

向内核添加设备,第一个参数是设备,第二个参数是设备号,第三个参数是要注册的次设备数目,mem_major在动态申请时候保存起来了。

四、注销设备

注销设备时候,使用unregister_chrdev_region(dev_t, unsigned);第一个参数设备号,和注册时候的要一致,因此如果是动态分配的就需要保存起来,第二个参数是次设备的个数。

五、register_chrdev()函数的不一致

register_chrdev(unsigned int, const char *,struct file_operations *); // 申请注册设备号以第一个参数来辨别动态与静态。

1、如果第一个参数是0,表示动态的分配给此驱动程序一个主设备号,

2、非零时候,表示备驱动程序向系统申请主设备号,

第二个是设备名,第三个file_operations,如果是动态分配的,则函数返回分配的主设备号。

对应的使用unregister_chrdev(unsigned int, const char *);来注销设备,第一个参数是主设备号,必须和注册时候的主设备号一致,如果注册时候是动态的分配的主设备号,就需要保存起来,第二个是设备名。

综上得出:register_chrdev_region()比register_chrdev()多了一步,就是想内核注册添加cdev设备的步骤。

register_chrdev_region()是register_chrdev()的升级版本。

目录
相关文章
|
6月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
569 3
Linux系统禁用swap
|
6月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
1081 3
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
676 3
Linux系统初始化脚本
|
7月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
485 18
|
6月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
736 1
|
6月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
1213 1
|
7月前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
2047 10
|
Linux
Linux0.11 文件打开open函数(五)
Linux0.11 文件打开open函数(五)
244 0
|
Linux 开发者
Linux文件编程(open read write close函数)
通过这些函数,开发者可以在Linux环境下进行文件的读取、写入和管理。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
373 4
|
存储 Linux
Linux文件编程(open read write close函数)
Linux文件编程(open read write close函数)
666 0