
Linux内核数据结构
xie0812
这个作者很懒,什么都没留下…
展开
-
话说Linux内核链表之“container_of“(二)
一、"container_of"简介 Linux内核中,"container_of“宏的使用时无处不在的。它的功能是:通过传入的结构体成员的地址、结构体类型以及成员的名字,返回对应结构体变量的起始地址。对于内核"list"来说,”container_of"使得把对链表的操作与链表管理的对象分离开来。好吧,先看一下定义吧,注意内核版本是Linux4.14.10,后面我们的分析都是基于这个版本,定义具体如下://linux4.原创 2020-08-20 08:07:15 · 790 阅读 · 0 评论 -
话说linux内核链表(一)
一、内容介绍链表作为一种基础的数据结构,分为:单链表、双链表以及循环链表,在日常的编程中很常用。在C语言的编程中,通常情况下,我们根据实际的需求来实现对应的链表。链表有:初始化、插入、删除、判空等操作。在linux内核中,对链表的使用真是无处不在的,比如设备、总线、驱动模型中,对挂载在总线上的设备和驱动就是分别各用一个链表进行管理的;又比如一个驱动可以作用于多个设备,那么"struct device_driver"中也有一个用于管理设备的链表。所以理解链表的实现原理以及熟练使用对理解内核代码、驱动开发至原创 2020-08-17 23:34:06 · 429 阅读 · 0 评论