linux内核中的几种链表

简介: linux内核中的几种链表

参考

双向循环链表 list_head

  • 相关文件:
    include/linux/list.h
  • 数据结构:
struct list_head {
  struct list_head *next, *prev;
};
  • 接口
static inline void INIT_LIST_HEAD(struct list_head *list);
static inline void list_add(struct list_head *new, struct list_head *head);
static inline void list_del(struct list_head *entry);

哈希链表 hlist

  • 相关文件:
    include/linux/list.h
    include/linux/hashtable.h
  • 数据结构
struct hlist_head {
  struct hlist_node *first;
};
struct hlist_node {
  struct hlist_node *next, **pprev;
};
  • 接口
static inline void hlist_del(struct hlist_node *n);
static inline void hlist_add_head(struct hlist_node *n, struct hlist_head *h);
hlist_for_each_entry(pos, head, member)

kernel/cgroup/cgroup.c

无锁链表llist

  • 相关文件
    lib/llist.c

降序优先排序的双向链表 plist

  • 相关文件
    include/linux/plist.h
    lib/plist.c
  • 数据结构
struct plist_head {
  struct list_head node_list;
};
struct plist_node {
  int     prio;
  struct list_head  prio_list;
  struct list_head  node_list;
};
  • 接口
static inline void plist_head_init(struct plist_head *head);
static inline void plist_node_init(struct plist_node *node, int prio);
void plist_add(struct plist_node *node, struct plist_head *head);
void plist_del(struct plist_node *node, struct plist_head *head);

mm/swapfile.c

/*
 * all active swap_info_structs
 * protected with swap_lock, and ordered by priority.
 */
PLIST_HEAD(swap_active_head);
static void setup_swap_info(struct swap_info_struct *p, int prio,
          unsigned char *swap_map,
          struct swap_cluster_info *cluster_info)
{
  int i;
  if (prio >= 0)
    p->prio = prio;
  else
    p->prio = --least_priority;
  /*
   * the plist prio is negated because plist ordering is
   * low-to-high, while swap ordering is high-to-low
   */
  p->list.prio = -p->prio;
  for_each_node(i) {
    if (p->prio >= 0)
      p->avail_lists[i].prio = -p->prio;
    else {
      if (swap_node(p) == i)
        p->avail_lists[i].prio = 1;
      else
        p->avail_lists[i].prio = -p->prio;
    }
  }
  p->swap_map = swap_map;
  p->cluster_info = cluster_info;
}
static void _enable_swap_info(struct swap_info_struct *p)
{
  p->flags |= SWP_WRITEOK | SWP_VALID;
  atomic_long_add(p->pages, &nr_swap_pages);
  total_swap_pages += p->pages;
  plist_add(&p->list, &swap_active_head);
  add_to_avail_list(p);
}


相关文章
|
8月前
|
安全 网络协议 Linux
深入理解Linux内核模块:加载机制、参数传递与实战开发
本文深入解析了Linux内核模块的加载机制、参数传递方式及实战开发技巧。内容涵盖模块基础概念、加载与卸载流程、生命周期管理、参数配置方法,并通过“Hello World”模块和字符设备驱动实例,带领读者逐步掌握模块开发技能。同时,介绍了调试手段、常见问题排查、开发规范及高级特性,如内核线程、模块间通信与性能优化策略。适合希望深入理解Linux内核机制、提升系统编程能力的技术人员阅读与实践。
731 1
|
8月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
880 0
|
8月前
|
Web App开发 缓存 Rust
|
8月前
|
Ubuntu 安全 Linux
Ubuntu 发行版更新 Linux 内核,修复 17 个安全漏洞
本地攻击者可以利用上述漏洞,攻击 Ubuntu 22.10、Ubuntu 22.04、Ubuntu 20.04 LTS 发行版,导致拒绝服务(系统崩溃)或执行任意代码。
|
8月前
|
Ubuntu Linux
Ubuntu 23.04 用上 Linux 6.2 内核,预计下放到 22.04 LTS 版本
Linux 6.2 带来了多项内容更新,修复了 AMD 锐龙处理器设备在启用 fTPM 后的运行卡顿问题,还增强了文件系统。
|
8月前
|
Ubuntu Linux
Ubuntu 23.10 现在由Linux内核6.3提供支持
如果你想在你的个人电脑上测试一下Ubuntu 23.10的最新开发快照,你可以从官方下载服务器下载最新的每日构建ISO。然而,请记住,这是一个预发布版本,所以不要在生产机器上使用或安装它。
|
8月前
|
传感器 监控 Ubuntu
10 月发布,Ubuntu 23.10 已升级到 Linux Kernel 6.3 内核
硬件方面,Linux 6.3 引入了在 HID 中引入了原生的 Steam Deck 控制器接口,允许罗技 G923 Xbox 版赛车方向盘在 Linux 上运行;改善 8BitDo Pro 2 有线控制器的行为;并为一系列华硕 Ryzen 主板添加传感器监控。
|
8月前
|
Ubuntu Linux
Ubuntu24.04LTS默认采用Linux 6.8内核,实验性版本可通过PPA获得
IT之家提醒,当下的 Ubuntu 23.10 也是一个“短期支持版本”,该版本将在今年 7 月终止支持,而今年 4 月推出的 Ubuntu 24.04 LTS 长期支持版本将获得 5 年的更新支持。
|
8月前
|
Ubuntu 机器人 物联网
Linux Ubuntu 22.04 LTS 测试版实时内核已可申请
请注意,在启用实时内核后您需要手动配置 grub 以恢复到原始内核。更多内容请参考: