混杂设备驱动

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_27312943/article/details/79147987

1 定义

在Linux系统中,存在一类字符设备,它们拥有相同的主设备号(10),但次设备号不同,我们称这类设备为混杂设备(miscdevice)。所有的混杂设备形成一个链表,对设备访问时内核根据次设备号查找到相应的混杂设备

2 开发流程

3 相关结构体和函数

Linux内核使用struct miscdeivce来描述一个混杂设备



struct miscdevice  {

    int minor; /*次设备号*/

    const char *name; /*设备名*/

    const struct file_operations *fops; /*文件操作*/

    struct list_head list;

    struct device *parent;

    struct device *this_device;

    const char *nodename;

    mode_t mode;

};

注册函数

函数原型:int misc_register(struct miscdevice * misc)
函数参数:struct miscdevice
函数返回值:成功 0
          失败 -1

注销函数

函数原型:int  misc_deregister(struct miscdevice *misc)
函数参数:
函数返回值: 成功 0
           失败 -1

4 实例

/*混杂设备驱动模型*/
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/delay.h>
#include <linux/poll.h>
#include <linux/irq.h>
#include <asm/irq.h>
#include <asm/io.h>
#include <linux/interrupt.h>
#include <asm/uaccess.h>
#include <mach/hardware.h>
#include <linux/platform_device.h>
#include <linux/cdev.h>
#include <linux/miscdevice.h>


#define GPNCON 0x7F008830

#define DEVICE_NAME     "buttons"
#define MISC_DYNAMIC_MINOR 200 /*次设备号*/

/*响应按键中断函数*/
static irqreturn_t buttons_interrupt(int irq, void *dev_id)
{
    printk("key down\n");

    return 0;   
}



static struct file_operations key_fops = {
    .owner   =   THIS_MODULE,

};

/*混杂设备驱动的描述结构体*/
static struct miscdevice misc = {
    .minor = MISC_DYNAMIC_MINOR,
    .name = DEVICE_NAME,
    .fops = &key_fops, /*操作函数集*/
};



/*注册混杂设备*/
static int __init dev_init()
{
    int ret;
        unsigned int *gpio_config;  
        unsigned short data;

        int err;
    /*注册混杂设备驱动*/
    ret = misc_register(&misc);

    printk (DEVICE_NAME"\tinitialized\n");

        err=request_irq(IRQ_EINT(0),buttons_interrupt,IRQF_TRIGGER_FALLING,"mykey",0);

        if(err < 0)
        {
            printk("request_irq error\n");  
        }

        printk("request_irq success\n");

    gpio_config=ioremap(GPNCON,4);

    data=readw(gpio_config); 

    data &= ~0b11;
        data |= 0b10; 
    writew(data,gpio_config); 

    return ret;
}

/*卸载混杂设备*/
static void __exit dev_exit(void)
{
    misc_deregister(&misc);
}


module_init(dev_init);
module_exit(dev_exit);
MODULE_LICENSE("GPL");  //表明遵循GPL协议
MODULE_AUTHOR("FriendlyARM Inc.");

5 运行结果
这里写图片描述

猜你喜欢

转载自blog.csdn.net/qq_27312943/article/details/79147987
今日推荐