标签:
linux内核使用bitmap相关
1,声明一个bitmap数组,可以表示100个bit,数组名字是bitmap
相关宏定义如下:
2,使用以上定义的bitmap数组
检测bitmap某一位是否为1,用test_bit()函数,如检测第一个bit,则调用test_bit(0,bitmap)
使用实例:bootmem分配器~~
内核使用双向链表相关
list_entry()函数可以返回包含双向链表的结构, 指针ptr指向结构体type中的member成员,通过ptr返回结构体type的起始地址
该函数向指定链表的head节点后插入new节点,
pos是一个指向包含list_head节点对象的指针,可以看成是list_entry()返回的值,head是遍历开始的位置,
第一步,首先定义一个临时的数据类型(通过typeof( ((type *)0)->member )获得)与ptr相同的指针变量__mptr,然后用它来保存ptr的值。第二步,用(char *)__mptr减去member在结构体中的偏移量,得到的值就是整个结构体变量的首地址(整个宏的返回值就是这个首地址)。
typeof的解释如下:
是定义一个叫做__mptr的指针。这个指针指向的内容是不可变的,指向的类型是一个type类型结构体中member的类型。
两个取反 !!的作用,
答:确保所得的结果为0或者1
标签:
原文地址:http://www.cnblogs.com/zhiliao112/p/4237178.html