Linux内核系列设备模型(一) Kobject与Kset

1、Kobject

Kobject是设备驱动模型的核心结构,它使所有设备在底层都有统一的接口。在内核注册的kobject对象都会对应sysfs文件系统中的一个目录(目录名称有Kobject结构中k_name指定)

struct kobject {
    const char        * k_name; // 指向设备名称的指针
    char            name[KOBJ_NAME_LEN]; // 设备名称
    struct kref        kref; //引用计数
    struct list_head    entry; //所属kset集合列表成员
    struct kobject        * parent; // 指向父节点对象
    struct kset        * kset; //所属kset集合
    struct kobj_type    * ktype; //设备类型
    struct dentry        * dentry; //与该对象对应的文件节点指针
    wait_queue_head_t    poll; //等待队列
};

相关操作函数:

extern void kobject_put(struct kobject *);

kobject引用计数减1(即kref减1),当kef的值为0时,将调用release函数释放该kobject对象;

struct kobject * kobject_get(struct kobject * kobj)

kobject引用计数增1;

extern int kobject_add(struct kobject *);

将kobject对象添加到所属的kset集合中,同时创建对应的文件目录(具体实现看kobject.c中的源码);
extern void kobject_del(struct kobject *);

删除kobject对象;

extern int kobject_register(struct kobject *);

注册kobject对象,先调用kobject_init进行初始化 ,然后调用kobject_add完成对象的注册,最后调用kobject_uevent注册kobject增加事件;

extern void kobject_unregister(struct kobject *);

注销kobject对象;先调用kobject_uevent注册KOBJ_REMOVE事件(事件通知作用),然后调用kobject_del删除对象,最后调用kobject_put减少该对象的引用计数,同样当引用计数为0时将会调用release销毁函数;

2、Kset

struct kset {
    struct subsystem    * subsys;  // 所属子系统
    struct kobj_type    * ktype; // 所属Kset集合的Kobject的类型
    struct list_head    list; // 所属Kset的Kobject对象链表头
    spinlock_t        list_lock; //Kset的互斥锁
    struct kobject        kobj; // 所属Kset的Kobject对象的父节点
    struct kset_uevent_ops    * uevent_ops; // Kset相关事件处理函数
};

相关操作函数:

static inline void kset_put(struct kset * k);

kset的引用计数减1,实际kset的引用计数使用的内嵌的Kobject对象的引用计数;

static inline struct kset * kset_get(struct kset * k)

kset的引用计数加1;

int kset_add(struct kset * k)

kset_add内部调用的是kobject_add,其实就是将kset的内嵌的kobject对象挂接到上层子系统中;

kset_register、kset_unregister与Kobject中对应操作函数实现比较类似(源码详情Kobject.c)

Kobject与Kset的关系图如下:

3、Kobj_type

struct kobj_type {
    void (*release)(struct kobject *); //释放kobject函数
    struct sysfs_ops    * sysfs_ops; //属性操作字段(读和写)
    struct attribute    ** default_attrs; // 默认的属性字段,该字段指定的属性结构将以文件的形式输出到sysfs目录;

struct sysfs_ops {
    ssize_t    (*show)(struct kobject *, struct attribute *,char *buf); // 处理用户对属性值的读取,属性读取后的值保存在参数buf中;
    ssize_t    (*store)(struct kobject *,struct attribute *,const char *, size_t); // 处理用户设置的属性值
};

struct attribute {
    const char        * name; // 文件名
    struct module         * owner; // 所属模块
    mode_t            mode;
};

 

时间: 2024-08-25 19:52:53

Linux内核系列设备模型(一) Kobject与Kset的相关文章

Linux内核(7) - 设备模型(上)

对于驱动开发来说,设备模型的理解是根本,毫不夸张得说,理解了设备模型,再去看那些五花八门的驱动程序,你会发现自己站在了另一个高度,从而有了一种俯视的感觉,就像凤姐俯视知音和故事会,韩峰同志俯视女下属. 顾名而思义就知道设备模型是关于设备的模型,既不是任小强们的房模,也不是张导的炮模.对咱们写驱动的和不写驱动的人来说,设备的概念就是总线和与其相连的各种设备了.电脑城的IT工作者都会知道设备是通过总线连到计算机上的,而且还需要对应的驱动才能用,可是总线是如何发现设备的,设备又是如何和驱动对应起来的,

Linux内核(8) - 设备模型(下)

设备模型拍得再玄幻,它也只是个模型,必须得落实在具体的子系统,否则就只能抱着个最佳技术奖空遗恨.既然前面已经以USB子系统的实现分析示例了分析内核源码应该如何入手,那么这里就仍然以USB子系统为例,看看设备模型是如何软着陆的. 内核中USB子系统的结构 我们已经知道了USB子系统的代码都位于drivers/usb目录下面,也认识了一个很重要的目录--core子目录.现在,我们再来看一个很重要的模块--usbcore.你可以使用"lsmod"命令看一下,在显示的结果里能够找到有一个模块叫

linux设备模型之kobject

kobject 结构 在Linux内核里,kobject是组成Linux设备模型的基础,一个kobject对应sysfs里的 一个目录.从面向对象的角度来说,kobject可以看作是所有设备对象的基类,因为C 语言并没有面向对象的语法,所以一般是把kobject内嵌到其他结构体里来实现类似的 作用,这里的其他结构体可以看作是kobject的派生类.Kobject为Linux设备模型提 供了很多有用的功能,比如引用计数,接口抽象,父子关系等等.引用计数本质上就 是利用kref实现的. 另外,Lin

Linux 设备模型之 kobject 内嵌结构

问题描述:前文我们知道了/sys是包含内核和驱动的实施信息的,用户可以通过 /sys 这个接口,用户通过这个接口可以一览内核设备的全貌.本文将从Linux内核的角度来看一看这个设备模型是如何构建的. 1.kobject 结构 在Linux内核里,kobject是组成Linux设备模型的基础,一个kobject对应sysfs里的一个目录.从面向对象的角度来说,kobject可以看作是所有设备对象的基类,因为C语言并没有面向对象的语法,所以一般是把kobject内嵌到其他结构体里来实现类似的作用,这

内核设备模型从kobject到子系统

   内核设备模型 目的:表示设备和设备在系统中的拓扑关系 优点:1减少内核代码量,2可以统一查看所有设备状态和所连接的总线,3可以联系好设备和其对应的驱动,或者驱动对应的设备.4可以按类型分类,可以沿着叶子节点方向向根节点访问来保证正确关闭设备电源(先关目的节点的所有子节点,再关闭该节点) 设备模型的样子: 已经被用数据结构抽象了一遍.用户的角度可以从sys目录鸟瞰内核中的设备模型关系 通常sys下打开的 一级目录是不同的类型的子系统, ----------------------------

基于tiny4412的Linux内核移植 -- 设备树的展开

作者信息 作者: 彭东林 邮箱:[email protected] QQ:405728433 平台简介 开发板:tiny4412ADK + S700 + 4GB Flash 要移植的内核版本:Linux-4.4.0 (支持device tree) u-boot版本:友善之臂自带的 U-Boot 2010.12 (为支持uImage启动,做了少许改动) busybox版本:busybox 1.25 交叉编译工具链: arm-none-linux-gnueabi-gcc (gcc version 4

设备模型之kobject,kset及其关系

Linux2.6以后的设备驱动,都是在设备模型的基础上构建的,因此,要编写linux下的设备驱动程序,不论是usb设备,pci设备等,都需要了解设备模型. 设备模型的基础结构体主要是kobject,kset这两个结构体: struct kobject {    char      * k_name;    char      name[KOBJ_NAME_LEN];    struct kref    kref;    struct list_head  entry;    struct kob

linux内核系列(一)编译安装Linux内核 2.6.18

1.配置环境 操作系统:CentOS 5.2 下载linux-2.6.18版本的内核,网址:http://www.kernel.org 说明:该编译文档适合2.6.18以上的Linux内核版本,只需所编译的 Linux内核版本不能低于Linux操作系统自身的内核版本,不然会遇到很多问题:   2.开始编译 cp  ./ linux-2.6.18.tar.gz  /usr/src/ tar –zxvf ./linux-2.6.18.tar.gz cd /usr/src/linux-2.6.18 /

linux内核系列(一)内核数据结构之链表

双向链表 传统链表与linu内核链表的区别图: 图一 图二 从上图中看出在传统链表中各种不同链表间没有通用性,因为各个数据域不同,而在linux内核中巧妙将链表结构内嵌到数据域结构中使得不同结构之间能连接起来: 链表的常用操作 内核中链表实现文件路径:include/linux/list.h 链表结构定义 struct list_head {     struct list_head *next, *prev; }; 获取结构入口地址(list_entry) #define list_entry