[LINUX内核编程]学习笔记(一)

22 篇文章 0 订阅
11 篇文章 0 订阅

linux内核使用bitmap相关
 1,声明一个bitmap数组,可以表示100个bit,数组名字是bitmap

 DECLARE_BITMAP(bitmap,100)
 相关宏定义如下:
 #define DECLARE_BITMAP(name,bits) unsigned long name[BITS_TO_LONGS(bits)]
 #define BITS_TO_LONGS(nr) DIV_ROUND_UP(nr,BITS_PER_BYTE*sizeof(long))
 #define DIV_ROUND_UP(n,d) (((n)+(d)-1)/(d))
 #define BITS_PER_BYTE 8

 2,使用以上定义的bitmap数组
 检测bitmap某一位是否为1,用test_bit()函数,如检测第一个bit,则调用test_bit(0,bitmap)
 static int test_bit(unsigned int nr,const unsigned long *addr)
 {
  return ((1UL<<(nr%BITS_PER_LONG))&(((unsigned*)addr)[nr/BITS_PER_LONG])) !=0)
 }
 #define BITS_PER_LONG 32

 使用实例:bootmem分配器~~

 

内核使用双向链表相关

 struct list_head{
  struct list_head *next;
  struct list_head *priv;
 };

 list_entry()函数可以返回包含双向链表的结构, 指针ptr指向结构体type中的member成员,通过ptr返回结构体type的起始地址
 #define list_entry(ptr,type,member) container_of(ptr,type,member) 
 list_add(struct list_head *new ,struct list_head *head)
 该函数向指定链表的head节点后插入new节点,
 list_for_each_entry(pos,head,member)
 pos是一个指向包含list_head节点对象的指针,可以看成是list_entry()返回的值,head是遍历开始的位置,

 

#define container_of(ptr, type, member) ({                      \ 
const typeof( ((type *)0)->member ) *__mptr = (ptr);    \ 
(type *)( (char *)__mptr - offsetof(type,member) );})
#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
第一步,首先定义一个临时的数据类型(通过typeof( ((type *)0)->member )获得)与ptr相同的指针变量__mptr,然后用它来保存ptr的值。第二步,用(char *)__mptr减去member在结构体中的偏移量,得到的值就是整个结构体变量的首地址(整个宏的返回值就是这个首地址)。

typeof的解释如下:

const typeof( ((type *)0)->member ) *__mptr = (ptr);
是定义一个叫做__mptr的指针。这个指针指向的内容是不可变的,指向的类型是一个type类型结构体中member的类型。


两个取反 !!的作用,

答:确保所得的结果为0或者1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值