码迷,mamicode.com
首页 > 其他好文 > 详细

10、内核链表的学习

时间:2016-02-14 00:31:34      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:

技术分享

技术分享

技术分享

技术分享

技术分享

 

技术分享

首先是创建内核模块。

按照上面的那张图,我们知道,我们创建链是使用INIT_LIST_HEAD这个函数。现在我们来使用source insight查看该函数的结构。

技术分享

该函数是对我们的链表头进行初始化的。我们把链表头做一个参数传进来之后。我们分别用next和prev指针同时指向他本身。

可以看到,该函数是个内联函数。该函数只有一个参数,是struct list_head类型的指针,他就是我们要初始化的链表头。

所以我们得来创建这个链表头结构。Struct list_head list score_head;

添加节点函数结构:

技术分享

第一个参数是插入节点的指针域,第二个参数是链表头指针。

技术分享

上面看到list_for_each是一个宏。

技术分享

List_entry调用container_of()函数:

技术分享

首先看到ptr,实际就是list_head的地址。上面的offset就是我们下图的10.偏移地址。

技术分享

 

技术分享

从上面的图和函数知道,我们取指针的起始地址为0,那么他的offset的偏移就是他的地址。就是member的地址。Member是我们调用list_entry的时候,我们要把我们的list_head在score结构中的成员list传进去。

技术分享

 

技术分享

 

技术分享

List_add;

技术分享

他实际上是调用了一个__list_add()函数。

技术分享

 

 

Mylist.c的代码:

技术分享

技术分享

Makefile的代码:

技术分享

接下来make,把生成的.ko驱动文件拷贝到开发板.

技术分享

Insmod mylist.ko出现的错误:

技术分享

这说是版本不对,就是我使用的是210的内核。

换成6410的出现下面问题:

技术分享

技术分享

加上了之后,插入出现这问题:

技术分享

这是系统自身有这驱动,因为我是第一次插入驱动。然后,改了名字,重新编译烧写。插入成功。

然后使用dmesg | tail -n 1查看输出的第一行信息。

技术分享

上面的输出可以判断我们创建内核链表和实现内核链表成功。

技术分享

 

这套内核链表都是c实现的。

重点。自己实现一套内核链表。就是把内核里的这套聊表拷贝出来。

 

 

10、内核链表的学习

标签:

原文地址:http://www.cnblogs.com/FORFISH/p/5188441.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!