kernel下的设备分成了一些类,char block char。。

这里就贴出来一个样例能够建立一个char设备 ,抛砖引玉吧

这是kernel中的 drivers/char/msm_smd_pkt.c

先要启动初始化module

module_init(smd_pkt_init);

smd_pkt_init会在启动之后调用

static int __init smd_pkt_init(void)

{

    int i;

    int r;

创造char设备的结构体

    r = alloc_chrdev_region(&smd_pkt_number, 0,

                NUM_SMD_PKT_PORTS, DEVICE_NAME);

    if (r) {

        pr_err("alloc_chrdev_region() failed %d\n", r);

        return r;

    }

创造class下的设备机构提

    smd_pkt_classp = class_create(THIS_MODULE, DEVICE_NAME);

    if (IS_ERR(smd_pkt_classp)) {

        r = PTR_ERR(smd_pkt_classp);

        pr_err("class_create() failed %d\n", r);

        goto unreg_chardev;

    }



    for (i = 0; i < NUM_SMD_PKT_PORTS; ++i) {

        smd_pkt_devp[i] = kzalloc(sizeof(struct smd_pkt_dev),

                      GFP_KERNEL);

        if (IS_ERR(smd_pkt_devp[i])) {

            r = PTR_ERR(smd_pkt_devp[i]);

            pr_err("kmalloc() failed %d\n", r);

            goto clean_cdevs;

        }



        smd_pkt_devp[i]->i = i;

以下几行都是私有数据的赋值  我们不用关心   不须要能够删掉

        init_waitqueue_head(&smd_pkt_devp[i]->ch_read_wait_queue);

        smd_pkt_devp[i]->remote_open = 0;

        init_waitqueue_head(&smd_pkt_devp[i]->ch_opened_wait_queue);



        mutex_init(&smd_pkt_devp[i]->ch_lock);

        mutex_init(&smd_pkt_devp[i]->rx_lock);

        mutex_init(&smd_pkt_devp[i]->tx_lock);

关键地方就是这里了:

char设备的结构初始化

cdev_init(&smd_pkt_devp[i]->cdev, &smd_pkt_fops);

        smd_pkt_devp[i]->cdev.owner = THIS_MODULE;

char设备添加

        r = cdev_add(&smd_pkt_devp[i]->cdev,

                 (smd_pkt_number + i), 1);

        if (r) {

            pr_err("cdev_add() failed %d\n", r);

            kfree(smd_pkt_devp[i]);

            goto clean_cdevs;

        }

char设备在dev下创造一个节点设备   这个一定要有哦

        smd_pkt_devp[i]->devicep =

            device_create(smd_pkt_classp, NULL,

                      (smd_pkt_number + i), NULL,

                      smd_pkt_dev_name[i]);

        if (IS_ERR(smd_pkt_devp[i]->devicep)) {

            r = PTR_ERR(smd_pkt_devp[i]->devicep);

            pr_err("device_create() failed %d\n", r);

            cdev_del(&smd_pkt_devp[i]->cdev);

            kfree(smd_pkt_devp[i]);

            goto clean_cdevs;

        }



    }



    pr_info("SMD Packet Port Driver Initialized.\n");

    return 0;

后面就是错误处理了 无论了

clean_cdevs:

    if (i > 0) {

        while (--i >= 0) {

            mutex_destroy(&smd_pkt_devp[i]->ch_lock);

            mutex_destroy(&smd_pkt_devp[i]->rx_lock);

            mutex_destroy(&smd_pkt_devp[i]->tx_lock);

            cdev_del(&smd_pkt_devp[i]->cdev);

            kfree(smd_pkt_devp[i]);

            device_destroy(smd_pkt_classp,

                       MKDEV(MAJOR(smd_pkt_number), i));

        }

    }



    class_destroy(smd_pkt_classp);

unreg_chardev:

    unregister_chrdev_region(MAJOR(smd_pkt_number), NUM_SMD_PKT_PORTS);

    return r;

}

kernel-char设备的建立的更多相关文章

  1. linux kernel 字符设备详解

    有关Linux kernel 字符设备分析: 参考:http://blog.jobbole.com/86531/ 一.linux kernel 将设备分为3大类,字符设备,块设备,网络设备. 字符设备 ...

  2. [kernel]字符设备驱动、平台设备驱动、设备驱动模型、sysfs几者之间的比较和关联

    转自:http://www.2cto.com/kf/201510/444943.html Linux驱动开发经验总结,绝对干货! 学习Linux设备驱动开发的过程中自然会遇到字符设备驱动.平台设备驱动 ...

  3. 嵌入式 emmc 中 安装 烧录 内核 kernel,设备树 devicetree ,根文件系统 rootfs

    一般调试嵌入式开发板喜欢选择  利用 TFTP 传送  内核与 设备树,  利用 nfs 加载根文件系统. uboot 环境变量 设置如下: bootargs=root=/dev/nfs rw nfs ...

  4. i2c总线,设备,驱动之间的关系

    ------ 总线上先添加好所有具体驱动,i2c.c遍历i2c_boardinfo链表,依次建立i2c_client, 并对每一个i2c_client与所有这个线上的驱动匹配,匹配上,就调用这个驱动的 ...

  5. linux设备模型_转

    建议原博文查看,效果更佳. 转自:http://www.cnblogs.com/wwang/category/269350.html Linux设备模型 (1) 随着计算机的周边外设越来越丰富,设备管 ...

  6. Android系统启动过程-uBoot+Kernel+Android

    摘要:本文是参考大量网上资源在结合自己查看源代码总结出来的,让自己同时也让大家加深对Android系统启动过程有一个更加深入的了解!再次强调,本文的大多数功劳应归功于那些原创者们,同时一些必要的参考链 ...

  7. Smart210学习记录------块设备

    转自:http://bbs.chinaunix.net/thread-2017377-1-1.html 本章的目的用尽可能最简单的方法写出一个能用的块设备驱动.所谓的能用,是指我们可以对这个驱动生成的 ...

  8. Linux驱动编写(块设备驱动代码)

    [ 声明:版权所有,欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 按照ldd的说法,linux的设备驱动包括了char,block,net三种设备.char设备 ...

  9. linux 设备驱动概述

    linux 设备驱动概述 目前,Linux软件工程师大致可分为两个层次: (1)Linux应用软件工程师(Application Software Engineer):       主要利用C库函数和 ...

随机推荐

  1. 华为PUSH SDK 接入方法

    本文参考了华为推送平台官网及其Demo:http://developer.huawei.com/cn/consumer/wiki/index.php?title=%E6%8E%A5%E5%85%A5% ...

  2. ViewPager 入门一

    使用ViewPager能够得到不同view的切换效果 例如以下图,实现了四个view间的相互滑动 一.新建项目,引入ViewPager控件 ViewPager.它是google SDk中自带的一个附加 ...

  3. CMake设置生成vs工程的动态库输出路径

    作者:朱金灿 来源:http://blog.csdn.net/clever101 在网上搜了很多的资料,发现CMake不能设置一个动态库工程的输出目录和中间目录,难道除了VC之外其它编译器如gcc中没 ...

  4. 【问题】VUE 同一页面路由参数变化,数据不刷新

    依赖路由的params参数获取写在created生命周期里面,因为相同路由二次甚至多次加载的关系 没有达到监听,退出页面再进入另一个页面并不会运行created组件生命周期,导致数据还是第一次进入的数 ...

  5. 将vue-cli 2.x的项目升级到3.x

    尝试将vue-cli 2.x的项目升级到3.x,记录一下升级过程,和遇到的坑 1. 直接复制替换src文件夹 2. 安装项目需要的依赖 (可以将原来package.json dependencies下 ...

  6. [原创]react-vio-form 快速构建React表单应用

    react-vio-form 是一个react的快速轻量表单库,能快速实现表单构建.提供自定义表单格式.表单校验.表单信息反馈.表单信息隔离等功能.可采用组件声明或者API的形式来实现表单的功能 de ...

  7. 手动挂接NFS

     环境: 单板:s3c2440 内核:Linux-2.6.22.6 U-boot1.16 初始根文件系统Yaffs2 前提条件 1. 开发板上要烧写好文件系统 2. 能正常开机进入Linux系统 3. ...

  8. Python 之Numpy应用

    NumPy 数据类型 numpy 支持的数据类型比 Python 内置的类型要多很多,基本上可以和 C 语言的数据类型对应上,其中部分类型对应为 Python 内置的类型.下表列举了常用 NumPy ...

  9. 微信小程序仿微信运动步数排行-交互

    效果图如下: 图片.png wxml: <view class="item-box"> <view class="items"> < ...

  10. 【Educational Codeforces Round 35 A】 Nearest Minimums

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 找出最小的数字的位置. 最近的肯定是相邻的某对. [代码] #include <bits/stdc++.h> using ...