Linux驱动程序设计--字符设备设备号

         字符设备通过字符设备文件来存取。字符设备文件由使用ls -l 的输出的第一列的“c”标识。如果使用ls -l命令,会看到在设备文件项中有2个数(由一个逗号分隔)这些数字就是设备文件的主次设备编号。

          那么就出现一个问题,这些设备文件的主次设备号主要是起什么作用的呢?首先看看下图的内容:

          

       正如上图所描述的一样,字符设备文件与字符驱动程序如何建立起对应关系的呢?答案是主设备号。字符设备文件会去对应一个主设备号,字符设备驱动程序也会对应一个主设备号,当设备文件对应的主设备号和驱动程序的主设备好一致的时候,该设备文件就对应相应的设备驱动。主设备号用来标识与设备文件相连的驱动程序。次编号被驱动程序用来辨认操作的是哪个设备。主设备号用来反映设备类型,次设备号用来区分同类型的设备。

     内核中是通过dev_t来描述设备号的,其实质是unsigned int 32位整数,其中高12位为主设备号,低20位为次设备号。可以通过MAJOR(dev_t)来分解出主设备号,通过MINOR(dev_t)来分解出次设备号。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux设备驱动程序是一种软件模块,它允许操作系统与硬件设备进行通信。设备驱动程序的设计需要遵循一定的规范和流程,包括以下几个步骤: 1. 确定设备类型:设备可以是字符设备、块设备或网络设备等。每种设备类型都有不同的驱动程序接口和操作方法。 2. 编写设备驱动程序:设备驱动程序是一个内核模块,它包含了设备的初始化、读写操作、中断处理等函数。驱动程序需要遵循Linux内核的编程规范和API。 3. 注册设备驱动程序:驱动程序需要在内核中注册,以便操作系统能够识别和加载它。注册过程包括分配设备、初始化设备结构体、注册字符设备或块设备等。 4. 测试设备驱动程序:测试设备驱动程序需要使用一些工具和技术,例如ioctl命令、proc文件系统、sysfs文件系统等。测试过程需要验证设备的正确性、性能和稳定性。 以下是一个简单的字符设备驱动程序的例子: ```c #include <linux/module.h> #include <linux/fs.h> #include <linux/uaccess.h> #define DEVICE_NAME "mydevice" #define BUF_LEN 1024 static int Major; static char msg[BUF_LEN]; static char *msg_ptr; static int device_open(struct inode *inode, struct file *file) { msg_ptr = msg; try_module_get(THIS_MODULE); return 0; } static int device_release(struct inode *inode, struct file *file) { module_put(THIS_MODULE); return 0; } static ssize_t device_read(struct file *filp, char *buffer, size_t length, loff_t *offset) { int bytes_read = 0; if (*msg_ptr == 0) return 0; while (length && *msg_ptr) { put_user(*(msg_ptr++), buffer++); length--; bytes_read++; } return bytes_read; } static ssize_t device_write(struct file *filp, const char *buffer, size_t length, loff_t *offset) { int i; for (i = 0; i < length && i < BUF_LEN; i++) get_user(msg[i], buffer + i); msg_ptr = msg; return i; } static struct file_operations fops = { .read = device_read, .write = device_write, .open = device_open, .release = device_release }; static int __init init_module(void) { Major = register_chrdev(0, DEVICE_NAME, &fops); if (Major < 0) { printk(KERN_ALERT "Registering char device failed with %d\n", Major); return Major; } printk(KERN_INFO "I was assigned major number %d. To talk to\n", Major); printk(KERN_INFO "the driver, create a dev file with\n"); printk(KERN_INFO "'mknod /dev/%s c %d 0'.\n", DEVICE_NAME, Major); return 0; } static void __exit cleanup_module(void) { unregister_chrdev(Major, DEVICE_NAME); } MODULE_LICENSE("GPL"); MODULE_AUTHOR("Your Name"); MODULE_DESCRIPTION("A simple example Linux module."); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值