关闭

linux驱动结构之kobject及相关结构

975人阅读 评论(0) 收藏 举报

     kobject最初只是被理解为一个简单的引用计数,但现在也有了很多成员,它所能处理的任务以及它所支持的代码包括:对象的引用计数、sysfs表述、结构关联、热插拔事件处理等。kobject结构定义于linux/kobject:
        struct kobject {
            const char      *k_name;
            char            name[KOBJ_NAME_LEN];
 /*k_name指针指向kobject名称的起始位置,如果名称长度小于KOBJ_NAME_LEN,那么该kobject的名称便存放到name数组中,k_name指向数组头;如果名称大于20,则动态分配以讹足够大的缓冲区来存放kobject的名称,这时k_name指向缓冲区。*/
            struct kref     kref;   //该kobject的引用计数。
            struct list_head    entry;   //链表的节点,用于挂接到该kobject对象到kset;所有同一子系统下的所有相同类型的kobject被链接成一个链表组织在一起,成员kset就是嵌入相同类型结构的kobject集合
            struct kobject      *parent;  //指向该kobject所属分层结构中的上一层节点,所有内核模块的parent是module
            struct kset         *kset;   //所属的kest的指针  
            struct kobj_type    *ktype;  //指向对象类型描述符的指针
            struct dentry       *dentry;   //文件系统相关中雨该对象对应的文件节点入口
        };

 

调用函数:
1:void kobject_init(struct kobject *):
初始化kobject,设置引用计数为1,entry域指向自身,所属的kset引用计数加1
2:int kobject_set_name(struct kobject *, const char *, ...)
用于设置置顶的kobject名称
3:void kobject_cleanup(struct kobject *)
用于清除kobject,当引用计数为0的时候,释放对象占用的资源
4:struct kobject *kobject_get(struct kobject *)
增加一个引用计数,返回该对象指针
5:void kobject_put(struct kobject *)
减少引用计数
6:int kobject_add(struct kobject *)
将对象加入linux设备层次,挂接该对象到kset的list中,增加父目录各级kobject的引用计数;并在其父对象指向的目录下创建文件节点,并启用该类型内核对象的hotplug函数
7:int kobject_add(struct kobject *)
kobject_add()函数的反函数,操作相反
8:int kobject_register(struct kobject *)
用于注册kobject,先调用kobject_init()函数进行初始化,后调用kobject_add()完成对象增加
9:int kobject_unregister(struct kobject *)
先调用kobject_del从设备层次删除该对象,在调用kobject_put减少该对象的引用计数,如果引用计数降为0,则释放该对象

 

注:新创建的kobject被加入到kset时(调用kobject_init),引用计数被加1,然后kobject跟它的parent建立关联时,引用计数被加1,所以一个新创建的kobject,其引用计数总是为2。另外kobject通常是嵌入到其他结构中的,其单独意义其实并不大。相反,那些更为重要的结构体才真正需要用到kobject结构。比如struct cdev。

 

其他相关结构:

1:struct kset {
    struct subsystem    *subsys;  //所在的subsystem的指针
    struct kobj_type    *ktype;  //指向该kest的kobject对象类型描述符的指针,被该kset的所有kobject共享
    struct list_head    list;  //用于连接该kset所拥有的kobject的链表头
    spinlock_t          list_lock;  //用于同步的自旋锁
    struct kobject      kobj;  //嵌入的kobject对象,用于引用计数,这也是该kset的引用计数
    struct kset_uevent_ops  * uevent_ops;  //事件操作集,具体可看linux设备驱动开发详解P102
    };
注:起调用函数与kobject基本类似

 

2:struct kobj_type {
   void  (*release)(struct kobject *);  //kobject引用计数减至0时要调用的析构函数
   struct  sysfs_ops  * sysfs_ops;   //属性操作
   struct  attribute  ** default_attrs;   //默认属性
};
注:其属性操作函数由sysfs_ops定义:
struct sysfs_ops
   {
       ssize_t (*show)(struct kobject *kobj, struct attribute *attr, char *buffer);
       ssize_t (*store)(struct kobject *kobj, struct attribute *attr, const char *buffer, size_t size);
   };

 

 3:struct kset_uevent_ops {
   int (*filter)(struct kset *kset, struct kobject *kobj);
   const char *(*name)(struct kset *kset, struct kobject *kobj);
   int (*uevent)(struct kset *kset, struct kobject *kobj, char **envp,                       
                  int num_envp, char *buffer, int buffer_size);};

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:35530次
    • 积分:489
    • 等级:
    • 排名:千里之外
    • 原创:12篇
    • 转载:3篇
    • 译文:0篇
    • 评论:6条
    文章存档