《Linux内核设计的艺术:图解Linux操作系统架构设计与实现原理》——2.10 初始化缓冲区管理结构

简介: 本节书摘来自华章计算机《Linux内核设计的艺术:图解Linux操作系统架构设计与实现原理》一书中的第2章,第2.10节,作者:新设计团队著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.10 初始化缓冲区管理结构

缓冲区是内存与外设(如硬盘,以后以硬盘为例)进行数据交互的媒介。内存与硬盘最大的区别在于,硬盘的作用仅仅是对数据信息以很低的成本做大量数据的断电保存,并不参与运算(因为CPU无法到硬盘上进行寻址),而内存除了需要对数据进行保存以外,更重要的是要与CPU、总线配合进行数据运算。缓冲区则介于两者之间,它既对数据信息进行保存,也能够参与一些像查找、组织之类的间接、辅助性运算。有了缓冲区这个媒介以后,对外设而言,它仅需要考虑与缓冲区进行数据交互是否符合要求,而不需要考虑内存如何使用这些交互的数据;对内存而言,它也仅需要考虑与缓冲区交互的条件是否成熟,而不需要关心此时外设对缓冲区的交互情况。两者的组织、管理和协调将由操作系统统一操作。
操作系统通过hash_table[NR_HASH]、buffer_head双向环链表组成的复杂的哈希表管理缓冲区。
操作系统通过调用buffer_init()函数对缓冲区进行设置,执行代码如下:

//代码路径:init/main.c:
void main(void)
{
    …
    buffer_init(buffer_memory_end);
    …
}

在buffer_init()函数里,从内核的末端及缓冲区的末端同时开始,方向相对增长、配对地做出buffer_head、缓冲块,直到不足一对buffer_head、缓冲块。在第2章开始时设定的内存格局下,有3000多对buffer_head、缓冲块,buffer_head在低地址端,缓冲块在高地址端。
将buffer_head的成员设备号b_dev、引用次数b_count、“更新”标志b_uptodate、“脏”标志b_dirt、“锁定”标志b_lock设置为0。如图2-24所示,将b_data指针指向对应的缓冲块。利用buffer_head的b_prev_free、b_next_free,将所有的buffer_head形成双向链表。使free_list指向第一个buffer_head,并利用free_list将buffer_head形成双向链表链接成双向环链表,如图2-25所示。
注意图2-26顶部所示的内存的变化。在紧靠系统内核的部分,多出了一块用黑色表示的内存区域,那里面存储的就是缓冲区管理结构。由于它管理着3000多个缓冲块,因此它占用的内存空间的大小,与内核几乎差不多。图2-26中也对空闲表的双向链表结构给出了形象的说明。

image

最后,对hash_table[307]进行设置,将hash_table[307]的所有项全部设置为NULL,如图2-26第二步所示。

image

对应的代码如下:

//代码路径:fs/buffer.c:
    …
struct buffer_head * start_buffer= (struct buffer_head *) &end;
struct buffer_head * hash_table[NR_HASH];
static struct buffer_head * free_list;
    …
void buffer_init(long buffer_end)
{
    struct buffer_head * h= start_buffer;
    void * b;
    int i;

    if (buffer_end== 1<<20)
         b= (void *) (640*1024);
    else
         b= (void *) buffer_end;

//h、b分别从缓冲区的低地址端和高地址端开始,每次对进buffer_head、缓冲块各一个
//忽略剩余不足一对buffer_head、缓冲块的空间
    while ( (b -= BLOCK_SIZE) >= ((void *) (h + 1)) ) {
         h->b_dev= 0;
         h->b_dirt= 0;
         h->b_count= 0;
         h->b_lock= 0;
         h->b_uptodate= 0;
         h->b_wait= NULL;
         h->b_next= NULL;        //这两项初始化为空,后续的使用将与hash_table挂接
         h->b_prev= NULL;
         h->b_data= (char *) b;    //每个buffer_head关联一个缓冲块
         h->b_prev_free= h-1;    //这两项使buffer_head分别与前、
         h->b_next_free= h + 1;    // 后buffer_head挂接,形成双向链表
         h++;
         NR_BUFFERS++;
         if (b== (void *) 0x100000)    //避开ROMBIOS&VGA
               b= (void *) 0xA0000;
    }
    h--;
    free_list= start_buffer;        // free_list指向第一个buffer_head
    free_list->b_prev_free= h;        //使buffer_head双向链表
    h->b_next_free= free_list;        //形成双向环链表
    for (i=0;i<NR_HASH;i++)        //清空hash_table[307]
         hash_table[i]=NULL;
}

注意看代码中struct buffer_head * h = start_buffer这一行。这一行中的start_buffer确定了缓冲区的起始位置,这也就回答了2.2节中关于缓冲区起始点位置的这个问题。它是在buffer.c中定义的:

struct buffer_head * start_buffer= (s truct buffer_head *) &end;

这个end就是内核代码末端的地址。在代码编写阶段,设计者事先较难准确估算这个地址,于是就在内核模块链接期间设置end这个值,然后在这里使用。

相关文章
|
1天前
|
机器学习/深度学习 负载均衡 算法
深入探索Linux内核调度机制的优化策略###
本文旨在为读者揭开Linux操作系统中至关重要的一环——CPU调度机制的神秘面纱。通过深入浅出地解析其工作原理,并探讨一系列创新优化策略,本文不仅增强了技术爱好者的理论知识,更为系统管理员和软件开发者提供了实用的性能调优指南,旨在促进系统的高效运行与资源利用最大化。 ###
|
3天前
|
算法 Linux 开发者
深入探究Linux内核中的内存管理机制
本文旨在对Linux操作系统的内存管理机制进行深入分析,探讨其如何通过高效的内存分配和回收策略来优化系统性能。文章将详细介绍Linux内核中内存管理的关键技术点,包括物理内存与虚拟内存的映射、页面置换算法、以及内存碎片的处理方法等。通过对这些技术点的解析,本文旨在为读者提供一个清晰的Linux内存管理框架,帮助理解其在现代计算环境中的重要性和应用。
|
2天前
|
缓存 网络协议 Linux
Linux操作系统内核
Linux操作系统内核 1、进程管理: 进程调度 进程创建与销毁 进程间通信 2、内存管理: 内存分配与回收 虚拟内存管理 缓存管理 3、驱动管理: 设备驱动程序接口 硬件抽象层 中断处理 4、文件和网络管理: 文件系统管理 网络协议栈 网络安全及防火墙管理
18 4
|
1天前
|
Linux 数据库
Linux内核中的锁机制:保障并发操作的数据一致性####
【10月更文挑战第29天】 在多线程编程中,确保数据一致性和防止竞争条件是至关重要的。本文将深入探讨Linux操作系统中实现的几种关键锁机制,包括自旋锁、互斥锁和读写锁等。通过分析这些锁的设计原理和使用场景,帮助读者理解如何在实际应用中选择合适的锁机制以优化系统性能和稳定性。 ####
14 6
|
3天前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###
|
5天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
30 4
|
6天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
5天前
|
安全 Linux 数据安全/隐私保护
Vanilla OS:下一代安全 Linux 发行版
【10月更文挑战第30天】
16 0
Vanilla OS:下一代安全 Linux 发行版
|
8天前
|
人工智能 安全 Linux
|
28天前
|
Unix 物联网 大数据
操作系统的演化与比较:从Unix到Linux
本文将探讨操作系统的历史发展,重点关注Unix和Linux两个主要的操作系统分支。通过分析它们的起源、设计哲学、技术特点以及在现代计算中的影响,我们可以更好地理解操作系统在计算机科学中的核心地位及其未来发展趋势。

热门文章

最新文章