链表
struct list {
int data; /*有效数据*/
struct list *next; /*指向下一个元素的指针*/
};
struct list {
int data; /*有效数据*/
struct list *next; /*指向下一个元素的指针*/
struct list *prev; /*指向上一个元素的指针*/
};
<include/linux/types.h>
struct list_head {
struct list_head *next, *prev;
};
<include/linux/mm_types.h>
struct page {
...
struct list_head lru;
...
}
<include/linux/list.h>
/*静态初始化*/
#define LIST_HEAD_INIT(name) { &(name), &(name) }
#define LIST_HEAD(name)
struct list_head name = LIST_HEAD_INIT(name)
/*动态初始化*/
static inline void INIT_LIST_HEAD(struct list_head *list)
{
list->next = list;
list->prev = list;
}
<include/linux/list.h>
void list_add(struct list_head *new, struct list_head *head)
list_add_tail(struct list_head *new, struct list_head *head)
#define list_for_each(pos, head)
for (pos = (head)->next; pos != (head); pos = pos->next)
#define list_entry(ptr, type, member)
container_of(ptr, type, member)
//container_of()宏的定义在kernel.h头文件中。
#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)
<drivers/block/osdblk.c>
static ssize_t class_osdblk_list(struct class *c,
struct class_attribute *attr,
char *data)
{
int n = 0;
struct list_head *tmp;
list_for_each(tmp, &osdblkdev_list) {
struct osdblk_device *osdev;
osdev = list_entry(tmp, struct osdblk_device, node);
n += sprintf(data+n, "%d %d %llu %llu %s ",
osdev->id,
osdev->major,
osdev->obj.partition,
osdev->obj.id,
osdev->osd_path);
}
return n;
}
红黑树
-
每个节点或红或黑。 -
每个叶节点是黑色的。 -
如果结点都是红色,那么两个子结点都是黑色。 -
从一个内部结点到叶结点的简单路径上,对所有叶节点来说,黑色结点的数目都是相同的。
#include <linux/init.h>
#include <linux/list.h>
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/slab.h>
#include <linux/mm.h>
#include <linux/rbtree.h>
MODULE_AUTHOR("figo.zhang");
MODULE_DESCRIPTION(" ");
MODULE_LICENSE("GPL");
struct mytype {
struct rb_node node;
int key;
};
/*红黑树根节点*/
struct rb_root mytree = RB_ROOT;
/*根据key来查找节点*/
struct mytype *my_search(struct rb_root *root, int new)
{
struct rb_node *node = root->rb_node;
while (node) {
struct mytype *data = container_of(node, struct mytype, node);
if (data->key > new)
node = node->rb_left;
else if (data->key < new)
node = node->rb_right;
else
return data;
}
return NULL;
}
/*插入一个元素到红黑树中*/
int my_insert(struct rb_root *root, struct mytype *data)
{
struct rb_node **new = &(root->rb_node), *parent=NULL;
/* 寻找可以添加新节点的地方 */
while (*new) {
struct mytype *this = container_of(*new, struct mytype, node);
parent = *new;
if (this->key > data->key)
new = &((*new)->rb_left);
else if (this->key < data->key) {
new = &((*new)->rb_right);
} else
return -1;
}
/* 添加一个新节点 */
rb_link_node(&data->node, parent, new);
rb_insert_color(&data->node, root);
return 0;
}
static int __init my_init(void)
{
int i;
struct mytype *data;
struct rb_node *node;
/*插入元素*/
for (i =0; i < 20; i+=2) {
data = kmalloc(sizeof(struct mytype), GFP_KERNEL);
data->key = i;
my_insert(&mytree, data);
}
/*遍历红黑树,打印所有节点的key值*/
for (node = rb_first(&mytree); node; node = rb_next(node))
printk("key=%d ", rb_entry(node, struct mytype, node)->key);
return 0;
}
static void __exit my_exit(void)
{
struct mytype *data;
struct rb_node *node;
for (node = rb_first(&mytree); node; node = rb_next(node)) {
data = rb_entry(node, struct mytype, node);
if (data) {
rb_erase(&data->node, &mytree);
kfree(data);
}
}
}
module_init(my_init);
module_exit(my_exit);
无锁环形缓冲区
<include/linux/kfifo.h>
int kfifo_alloc(fifo, size, gfp_mask)
#define DEFINE_KFIFO(fifo, type, size)
#define INIT_KFIFO(fifo)
int kfifo_in(fifo, buf, n)
#define kfifo_out(fifo, buf, n)
#define kfifo_size(fifo)
#define kfifo_len(fifo)
#define kfifo_is_empty(fifo)
#define kfifo_is_full(fifo)
#define kfifo_from_user(fifo, from, len, copied)
#define kfifo_to_user(fifo, to, len, copied)
文章来源于:单片机与嵌入式 原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。
相关文章
从前沿探索到应用落地,英特尔研究院为未来计算“插上翅膀”(2023-09-26)
管理。
•异构编程:C++中的分布式数据结构、算法和视图
分布式和异构系统——例如每个节点有多个GPU的集群——已经变得越来越普遍。目前,这类系统的编程通常使用多个低级编程模型。为了......
探寻后摩尔时代 | 异构集成已成“未来之选”,然后呢……(2021-07-09)
异构集成技术的发展,英特尔则提出XPU的概念。宋继强表示:“对于英特尔而言,我们推动异构计算的创新,就是通过对不同架构XPU的异构整合,和统一的跨架构编程模型oneAPI实现软硬协同,满足更多工作负载,实现......
Linux内核代码中常用的数据结构(2024-10-20 12:02:30)
区需要一套链表。
为此,Linux内核把所有链表操作方法的共同部分提取出来,把不同的部分留给代码编程者自己去处理。
Linux内核实现了一套纯链表的封装,链表节点数据结构只有指针区而没有数据......
从前沿探索到应用落地,英特尔研究院为未来计算“插上翅膀”(2023-09-26)
研究正在通过基于机器学习的创新方法开辟新方向。从自组织的数据容器和自动优化的查询引擎到DBMS内基于机器学习模型的低级数据结构,一切都清晰明确。在该专题论坛中,英特尔研究院介绍了未来采用自优化系统的数据管理。
•异构编程:C......
stm32f103 flash模拟eeprom(2024-08-19)
理安排程序的执行顺序。同时,也可以通过合理设计数据结构和算法来减少对Flash存储器的编程和擦除操作。
为了提高Flash存储器的读取速度,可以使用读取缓冲区的方式来进行读取操作。例如,可以将需要读取的数据......
英特尔通过AI参考套件加速AI发展(2023-07-26)
加速的处理器和系统,加以对开放AI软件生态的投入,推动构建一个让AI触手可及的未来。该参考套件采用了英特尔AI软件产品组合的丰富组件并基于开放、基于标准的oneAPI多架构编程模型所打造。”
——李炜......
英特尔通过AI参考套件加速AI发展(2023-07-26 16:05)
的处理器和系统,加以对开放AI软件生态的投入,推动构建一个让AI触手可及的未来。该参考套件采用了英特尔AI软件产品组合的丰富组件并基于开放、基于标准的oneAPI多架构编程模型所打造。”
——李炜......
英特尔AI参考套件,助力企业高效运行AI工作负载(2023-07-27)
生态的投入,推动构建一个让AI触手可及的未来。该参考套件采用了英特尔AI软件产品组合的丰富组件并基于开放、基于标准的oneAPI多架构编程模型所打造。”
——李炜博士,英特......
英特尔通过AI参考套件加速AI发展(2023-07-26)
可及的未来。该参考套件采用了英特尔AI软件产品组合的丰富组件并基于开放、基于标准的oneAPI多架构编程模型所打造。”
——李炜博士,英特尔副总裁兼人工智能和分析部门总经理
重要意义:英特尔AI参考......
英特尔通过AI参考套件加速AI发展(2023-07-26)
的处理器和系统,加以对开放AI软件生态的投入,推动构建一个让AI触手可及的未来。该参考套件采用了英特尔AI软件产品组合的丰富组件并基于开放、基于标准的oneAPI多架构编程模型所打造。”
——李炜......