linux 内核中的container_of()如何使用

一、如何使用

我们先来分析一下container_of(ptr,type,member),这里面有ptr,type,member分别代表指针、类型、成员。看一个例子:
struct test
        {
                int i;
                int j;
                char k;
        };
        struct test temp;
如果通过temp变量找成员变量j,只用直接通过符号"."即可找到,但通过成员变量temp.j,需要要找到结构体变量temp的地址,该如何做呢?
这时候container_of就排上用场了。
Eg1:
struct test sensor_data;
sensor_data = container_of(&temp.j,struct test,j);

这样sensor_data就获得struct test temp的变量地址。


Eg2:


两次连续使用container_of(),先看下struct msm_sd_subdev和struct msm_sensor_ctrl_t的结构体定义


第一次container_of()传入sd,获得struct msm_sd_subdev 的变量地址,第二次container_of()传入struct msm_sd_subdev 的变量地址,最终获得struct msm_sensor_ctrl_t的变量地址

二、定义

在linux 内核中有一个宏container_of(),这个宏是用来干嘛的呢?我们先来看看它在内核中是怎样定义的。

#define container_of(ptr, type, member) ({      \  
    const typeof( ((type *)0)->member ) *__mptr = (ptr);    \  
    (type *)( (char *)__mptr - offsetof(type,member) );}) 






三、原理


参看如下地址,讲的超级详细

http://www.embedu.org/Column/Column433.htm

http://blog.csdn.net/npy_lp/article/details/7010752


展开阅读全文

没有更多推荐了,返回首页