首页 > 其他分享 >20201302姬正坤第十二章学习笔记

20201302姬正坤第十二章学习笔记

时间:2022-11-03 14:46:41浏览次数:50  
标签:算法 BUFFER 第十二章 dev 姬正坤 bp 缓冲区 20201302 设备

Linux第十二章——块设备I/O和缓冲区管理

块设备I/O缓冲区

  • 读写普通文件的算法依赖于两个关键操作,即:get_block和put_block,这两个操作将磁盘块读写到内存缓冲区中。
  • I/O缓冲的基本原理非常简单。文件系统使用一系列I/O缓冲区作为块设备的缓存内存。
  • 在讨论缓冲区管理算法之前,我们先来介绍以下术语:定义一个bread(dev,blk)函数,它会返回一个包含有效数据的缓冲区(指针)

从磁盘块中读取

点击查看代码
BUFFER *BREAD(dev,blk)
{
	BUFFER *bp = gerblk(dev,blk);
	if (bp data valid)
		return bp;
	bp -> opcode = READ;
	start_io(bp);
	wait for I/O completion;
	return bp;
}

写入磁盘块
1、同步写入——同步写入等待写操作完成,用于顺序块或可移动设备

点击查看代码
bwrite (BUFFER *bp){
	bp->opcode = WRITE;
	start_io(bp);
	wait for I/O completion;
	brelse(bp);
}

2、延迟写入——延迟写入无写操作,用于随机访问设备

点击查看代码
dwrite(BUFFER *bp){
	mark bp dirty for delay_write;
    brelse(bp);                       
}

3、同步写入操作等待写操作完成。它用于顺序块或可移动块设备,对于随机访问设备,例如硬盘,所有的写操作都是延迟写操作。在延迟写操作中,dwrite(dp)将缓冲区标记为脏,并将其释放到缓冲区缓存中。

脏缓冲区只有在被重新分配到不同的磁盘块时才会被写入磁盘,此时缓冲区将被以下代码写入:

点击查看代码
awrite(BUFFER *bp){
	bp -> opcode = ASYNC;
	start_io(bp);
}

  • 脏缓冲区只用在重新分配到不同的磁盘块时才会被写入磁盘
  • awrite()会调用start_io()在缓冲区开始I/O操作,但不会等待操作完成
  • 当异步ASYNC完成后,磁盘中断处理程序将释放缓冲区

Unix I/O缓冲区管理算法

缓冲区组成

  • I/O缓冲区:内核中的一系列NBUF缓冲区用作缓冲区缓存。每个缓冲区用一个结构体表示。缓冲区结构体由两部分组成:用于缓冲区管理的缓冲头部分和用于数据块的数据部分。
  • 设备表:每个块设备用一个设备表结构表示。每个设备表都有一个dev_lise,包含当前分配给该设备的I/O缓冲区,还有一个io_queue,包含设备上等待I/O操作的缓冲区。
  • 缓冲区初始化:当系统启动时,所有I/O缓冲区都在空闲列表中,所有设备列表和I/O队列均为空。
  • 缓冲区列表:当缓冲区分配给(dev,blk)时,它会被插入设备表的dev_list中。
  • Unix getblk/brelse算法

关于Unix算法

  1. Unix算法具有数据一致性:为了确保数据一致性,getblk一定不能给同一个(dev,blk)分配多个缓冲区。
  2. Unix算法的缓存效果可通过以下方法实现。释放的缓冲区保留在设备列表中,以便可能重用。标记为延迟写入的缓冲区不会立即产生I/O,并且可以重用。缓冲区会被释放到空闲列表的末尾,但分配是从空闲列表的前面开始的。
  3. 设备中断处理程序可操作缓冲区列表,例如从设备表的I/O队列中删除bp,更改其状态并调用brelse(bp)。
  4. Unix算法有以下缺点:
  • 效率低下:该算法依赖于重试循环。
  • 缓存效果不可预知:在Unix算法中,每个释放的缓冲区都可被获取。
  • 可能会出现饥饿:Unix算法基于“自由经济”原则,即每个进程都有尝试的机会,但不能保证成功。
  • 该算法使用只适用于单处理器系统的休眠/唤醒操作。

缓冲区结构体

点击查看代码
typdef struct buf{
    struct buf *next_free;
    struct buf *next_dev;
    int dev,blk;
    int opcode;
    int dirty;
  	int async;
  	int valid;
  	int busy;
  	int wanted;
  	struct semaphore lock = 1;
  	struct semaphore iodone = 0;
  	char buf[BLKSIZE];
}BUFFER;
BUFFER buf[NBUF], *freelist;

设备表

点击查看代码
struct devtab{
  	u16 dev;
  	BUFFER *dev_list;
  	BUFFER *io_queue;
}devtab[NDEV];

优化缓冲区管理算法

新的I/O缓冲区管理算法

在信号量上使用P/V来实现进程同步,而不是使用休眠/唤醒。

  • 信号量有以下优点:计数信号量可用来表示可用资源的数量;当多个进程等待一个资源时,信号量上的V操作只会释放只会释放一个等待进程,该进程不必重试,因为它保证拥有资源

信号量定义

点击查看代码
BUFFER buf[NBUF];
SEMAPHORE free = NBUF;
SEMAPHORE buf[i].sem = 1;

PV算法

使用计数信号量上的P/V来设计满足以下要求的新的缓冲区管理算法:

  1. 保证数据一致性
  2. 良好的缓存效果
  3. 高效率:没有重试循环,没有不必要的进程“唤醒”
  4. 无死锁和饥饿

PV算法伪代码

点击查看代码
BUFFER *getblk(dev,blk)
{
    while(1){
		p(free);
        if (bp in dev_list){
        	if (bp not BUSY){
            	remove from freelist;
                P(bp);
                return bp;
              	}
            //bp in cache but BUSY
                V(free);                          
            P(bp);                            
                return bp;
           }
            //bp not in cache, try to create a bp=(dev.blk)
       bp = first buffer taken out of freelist;
           P(bp);                             
       if (bp dirty){                    
              awrite(bp);                     
              continue;
           }
      	reassign bp to (dev,blk);          
           return bp;
      }
}
brelse (BUFFER *bp)
{
	if (bp queue has waiter) {
	V(bp); 		
	return; 
	}
  	if (bp dirty && freee queue has waiter){ 
	awrite(bp); 
	return;
	}
  	enter bp into (tail of) freelist; 
  	V(bp); 
  	V(free);
}

实践

PV信号量缓冲区算法

image
image
image

标签:算法,BUFFER,第十二章,dev,姬正坤,bp,缓冲区,20201302,设备
From: https://www.cnblogs.com/wafmr-123/p/16854398.html

相关文章

  • 《STM32MP1 M4裸机HAL库开发指南》第十二章 C语言LED灯实验
    第十二章C语言LED灯实验为了加深理解汇编语言以及汇编初始化过程,第十一章我们使用汇编来控制LED0。本章节我们来学习使用C语言来控制LED0,实际的开发中我们接触最多的就是C......
  • 《Unix/Linux系统编程》第十二章学习笔记
    第十二章  块设备I/O和缓冲区管理12.1块设备I/O缓冲区I/O缓冲的基本原理非常简单。文件系统使用一系列I/O缓冲区作为块设备的缓存内存。当进程试图读取(dev,blk)标识......
  • 20201306吴龙灿第十二章学习笔记
    知识点归纳1.块设备I/O缓冲区什么是块设备:块设备是i/o设备中的一类,是将信息存储在固定大小的块中,每个块都有自己的地址,还可以在设备的任意位置读取一定长度的数据,例如硬......
  • 20201302姬正坤第六章学习笔记
    Linux第六章——信号和信号处理一、信号和中断人员中断进程中断硬件中断进程的陷阱错误二、Unix/Linux中的信号处理1、信号的来源来自硬件中断的信号来自异常......
  • 20201302姬正坤cat user
    数据块:超级快用来储存文件系统本身的信息inode结点:存放节点,储存文件属性、所有者、权限等信息数据区:分块存储文件数据,不连续存储存储模式示意......
  • 第十二章学习总结
    第12章块设备I/O和缓冲区管理一、知识点总结12.1块设备I/O和缓冲区I/O缓冲的基本原理非常简单。文件系统使用一系列I/O缓冲区作为块设备的缓存内存。当进程试图读......
  • 20201302姬正坤第五章学习笔记
    LINUX第五章定时器及时钟服务硬件定时器定时器是由时钟源和可编程计数器组成的硬件设备。时钟源通常是一个晶体振荡器,会产生周期性电信号,以精确的频率驱动计数器。使用......
  • 【数据库】期末必知必会-----第十二章 数据库恢复
    第十二章数据库恢复1、故障的种类1)事务故障2)系统故障3)介质故障4)其他故障2、数据库备份恢复的原理冗余:冗余是基本原理,利用存储的冗余数据来重建数据库中已经被破坏或者不正......
  • 20201302姬正坤Linux第四章学习笔记
    第四章并发编程一、并行计算导论1、顺序算法与并行算法在描述顺序算法中,常用一个begin-end代码块列出算法。该代码块中的所有步骤都是通过某个任务依次执行的。而并行......
  • 20201302姬正坤第十一章学习笔记
    第十一章EXT2文件系统以下内容是我对本章部分内容的学习总结一、EXT2文件系统数据结构1、虚拟磁盘布局每当文件系统需要从包含它的块设备中读取信息或数据,就将请求底......