linux内核完全注释(ppt课件)第六章.ppt
《linux内核完全注释(ppt课件)第六章.ppt》由会员分享,可在线阅读,更多相关《linux内核完全注释(ppt课件)第六章.ppt(55页珍藏版)》请在三一办公上搜索。
1、Linux操作系统内核分析,湘潭大学信息工程学院,讲课内容,设备管理简介硬盘驱动虚拟盘驱动,块设备的操作方式,P132图6-2,设备管理模块读处理过程,进程向缓冲区模块提出读块(2扇区)请求。缓冲区模块检查该块是否已经被缓冲。如果已经被缓冲,则直接返回缓冲的块;否则,向设备管理模块提出读请求。设备管理模块接受请求。如果设备不忙,则向设备发送命令;否则,把请求插入到设备的请求队列中。缓冲区模块挂起进程。设备控制器从设备中读入数据到自己的缓冲区中,并产生中断。设备中断处理程序把数据从控制器缓冲区读到内存缓冲区,然后唤醒进程。P248第267,设备管理模块写处理过程,缓冲区模块决定要回写被缓冲的块。
2、如果该块是脏的,向设备管理模块提出写请求。设备管理模块接受请求。如果设备不忙,则向设备发送命令和数据;否则,把请求插入到设备的请求队列中。缓冲区模块挂起进程。设备控制器把数据写入到设备并产生中断。设备中断处理程序唤醒进程。,低级读写流程,根据缓冲区头创建一个请求,队列中没有请求,把请求插入到设备的请求队列中,向设备发送命令,是,否,说明设备空闲,设备号,设备是通过主设备号和次设备号(两者构成了物理设备号)来进行区分的主设备号: 区分不同类型的设备(P131表6-2)次设备号: 区分相同类型设备中的个体逻辑设备号用于区分不同的设备,逻辑设备号=主设备号8)#define MINOR(a) (a)
3、&0 xff),P395第33、34行,逻辑设备号,块设备请求项,struct request int dev; /逻辑设备号,-1表示是自由的请求项int cmd; /命令(P395第2629)int errors; /如果超过MAX_ERRORS,要重置设备unsigned long sector; /要读或写的开始扇区unsigned long nr_sectors; /要读或写的数量char * buffer; /数据缓冲区指针struct task_struct * waiting; /等待请求完成的进程队列struct buffer_head * bh; /缓冲区头指针struct
4、 request * next; /同一设备的下一个请求项;,P131或P134第23行,块设备请求项数组,为方便查找空闲请求项,建立了请求项数组。struct request requestNR_REQUEST; /定义在ll_rw_blk.c(P150第21行)#define NR_REQUEST32 /定义在blk.h(P134第15行),块设备结构,每个块设备都有自己的独立的请求队列。为方便管理队列,建立了块设备结构。struct blk_dev_struct void (*request_fn)(void); /设备独有的请求处理函数指针struct request * curren
5、t_request;/请求队列头指针 ;/blk.h(P134第45行或P130),块设备结构,Linux支持多种块设备,为所有这些块设备结构建立了一个数组,数组下标就是设备的主设备号。struct blk_dev_struct blk_devNR_BLK_DEV/P151第32行#define NR_BLK_DEV7,数据结构间的关系,P132图6-1,设备管理模块接口,设备管理模块,文件管理模块(缓冲区),ll_rw_block,中断管理模块,hd_interruptfloppy_interrupt,初始化模块,blk_dev_inithd_initfloppy_initsetup,初始化
6、,void blk_dev_init(void)/定义在ll_rw_blk.c(P153第157行)作用:完成请求项数组的初始化void hd_init(void)/定义在hd.c(P146第343行)void floppy_init(void)/定义在floppy.c(P168第457行)long rd_init(long mem_start, int length)/定义在ramdisk.c(P155第52行),低级读写操作,void ll_rw_block (int rw, struct buffer_head * bh)/定义在ll_rw_blk.c(P153第145行)作用:完成低级
7、读写操作参数:rw读写命令 bh缓冲区头指针,电梯算法,磁头朝一个方向运动来满足该方向上最近的请求。当该方向上所有的请求都处理完之后,则反方向来处理其它请求。,例如:磁头正在第5柱面处理请求,磁头向内运动,其后有5个请求到达,分别是第7、2、6、1、8柱面上的请求。则处理顺序是: 5 6 7 8 2 1,电梯算法,在一般情况下,所有请求都能获得合适的处理。但是,在极端情况下仍然会造成饿死现象。例如:上例中,如果不断的有第5柱面之后的处理请求,则第1、2柱面的处理请求会饿死。,电梯算法改进,5 7 5 7 2 5 6 7 2 5 6 7 1 2 5 6 7 1 2 8,对于请求Q,如果队列中存在
8、A1和A2,1、满足A1QA2,则把Q插入到A1和A2中2、满足QA2A1,则把Q插入到A1和A2中3、否则插入到队列最后,IN_ORDER,#define IN_ORDER(s1,s2) (s1)-cmdcmd | (s1)-cmd=(s2)-cmd & (s1)-dev dev | (s1)-dev = (s2)-dev & (s1)-sector sector),P134第40行,read、write、reada、writea,宏可以简单理解为s1s2是否为真,add_request,(IN_ORDER(tmp,req) | !IN_ORDER(tmp,tmp-next)& IN_ORD
9、ER(req,tmp-next)IN_ORDER(tmp,req)&IN_ORDER(req,tmp-next)|!IN_ORDER(tmp,tmp-next)& IN_ORDER(req,tmp-next),tmpnext,reqnext tmp,ll_rw_block,根据缓冲区头创建一个请求,队列中没有请求,把请求插入到设备的请求队列中,向设备发送命令,是,否,说明设备空闲,make_request,P150图6-4,讲课内容,设备管理简介硬盘驱动虚拟盘驱动,硬盘分类,按照接口分,硬盘可以分为IDE(ATA)硬盘SCSI硬盘FC硬盘SATA硬盘,硬盘内部结构,硬盘参数表,在setup.s
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- linux 内核 完全 注释 ppt 课件 第六
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-1481124.html