linux设备模型之ktype

ktyperelease方法

关于kobject引用计数重要的一点是当这个引用计数归0时,kobject会发生什么。创建kobject的代码通常不知道引用计数什么时候归0。即使object的生命周期是可以预测的,但是linux其他模块引入sysfs使情况变得复杂,其他模块可以获取任何注册到系统中的kobject

 

最后的结果是通过kobject保护的包含它的结构在引用计数归0之前不能被释放。创建kobject的代码不直接控制引用计数。所以在引用计数归0时要异步通知创建kobject的代码,也就是回调它所提供的release方法。

 

一旦通过kobject_add()函数注册kobject,就不能使用kfree()直接释放它。唯一安全的方法是调用kobject_put()函数。在kobject_init()后,总是调用kobject_put()释放它是一个好的习惯,防止错误发生蔓延。

 

这样的通知通过kobjectrelease()方法来完成。通常如下:

  void my_object_release(struct kobject *kobj)

{

   struct my_object *mine = container_of(kobj, struct my_object, kobj);

     /* Perform any additional cleanup on this object, then... */

     kfree(mine);

  }

 

再着重强调一下:每个kobject必须有一个release方法,这个kobjectrelease()方法调用之前必须一直存在。如果你忘记提供release方法,内核会警告你。不要试图赋空值去除这个警告,如果这么做会被kojbect维护者无情的嘲笑。

 

注意,在提供的release函数中kobject的名字是可用的,但是在回调时不能改变这个名字。否则会造成kobject核心的内存泄漏,这样会让别人不高兴。

 

有趣的是,kobject本身不包含release方法,而是包含在与之关联的ktype中。看一下ktype结构kobj_type:

struct kobj_type

{

     void (*release)(struct kobject *);

       const struct sysfs_ops  *sysfs_ops;

       struct attribute    **default_attrs;

  };

这个结构用来描述一个特定类型的kobject(更确切的说是包含它的对象)。每个kobject需要一个对应的kobj_type结构;在调用kobject_init() kobject_init_and_add()的时候必须给这个结构的指针赋值。

 

kobj_typerelease域是指向服务于这种类型的kobjectrelease方法的指针,其他两个域(sysfs_ops and default_attrs)控制了包含这个类型的对象在sysfs中怎样去呈现,超出这个文档的范围。

 

default_attrs 成员指针是一个会自动创建的用这个ktype注册的任何kobject的默认属性列表。

 

参考文档:

/Documentation/kobject.txt

http://blog.chinaunix.net/uid-20522771-id-3447116.html


为了更方便查看相关文章,可以关注我的个人微信公众号:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值