- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
磁盘调度算法资料
实 验 磁盘调度算法 实 验 目 的 通过学习EOS实现磁盘调度算法的机制,掌握磁盘调度算法执行的条件和时机。 观察EOS实现的FCFS、SSTF和SCAN磁盘调度算法,了解常用的磁盘调度算法。 编写CSCAN和N-Step-SCAN磁盘调度算法,加深对各种扫描算法的理解。 多线程并发访问软盘 磁盘调度算法在EOS中的位置 磁盘调度算法执行的条件、执行的时机、操作的对象 当多个线程并发访问磁盘时,只能有一个线程访问磁盘(独占磁盘),而其它的线程会被阻塞,待独占磁盘的线程结束访问操作后,才能唤醒一个阻塞的线程,令其继续独占访问磁盘。 这里提到的唤醒一个阻塞的线程的过程,就是磁盘调度算法工作的过程。可能会有多个线程由于并发访问磁盘而被阻塞,磁盘调度算法就是根据不同的策略,从中选择一个合适的线程来唤醒。 准确的说,磁盘调度算法操作的对象是——由于并发访问同一个磁盘设备而被阻塞的多个线程。 执行的条件、执行的时机、操作的对象 条件:多个线程并发访问同一个磁盘设备才会触发磁盘调度算法。单个线程访问磁盘不会触发磁盘调度算法。 时机:将阻塞线程唤醒时执行调度,而不是将线程阻塞时执行调度。 对象:由于并发访问同一个磁盘设备而被阻塞的多个线程。 EOS中实现的磁盘调度算法 目前EOS只管理了一个块设备——软盘驱动器,为了尽量简单,EOS只考虑对这个唯一的块设备进行磁盘调度。 为每个访问磁盘的线程创建一个对应的请求,并将这些请求放入一个请求队列中。 在块设备读写函数IopReadWriteSector中依次处理请求队列中的请求,各个请求被处理的顺序由磁盘调度算法决定。 在函数IopDiskSchedule中实现各种磁盘调度算法。 控制台命令“ds”专门用来测试磁盘调度算法。 磁盘调度算法使用的重要结构体和全局变量 typedef struct _REQUEST { ULONG Cylinder; LIST_ENTRY ListEntry; EVENT Event; }REQUEST, *PREQUEST; 还未实现磁盘调度算法时IopReadWriteSector函数的流程图 在函数IopReadWriteSector中调用磁盘调度算法相关函数 STATUS IopReadWriteSector(……) { PREQUEST pCurrentRequest; pCurrentRequest = IopReceiveRequest(SectorNumber); ……// 处理请求。与原有操作完全相同。 IopProcessNextRequest(pCurrentRequest); } IopReceiveRequest函数 PREQUEST IopReceiveRequest( IN ULONG SectorNumber ) { PREQUEST pRequest; pRequest = (PREQUEST)MmAllocateSystemPool( sizeof(REQUEST) ); pRequest-Cylinder = SectorNumber / 18 / 2; PsInitializeEvent(pRequest-Event, TRUE, TRUE); PsWaitForMutex(DiskScheduleMutex, INFINITE); // 进入临界区 if (IsDeviceBusy) { PsResetEvent(pRequest-Event); } else { IsDeviceBusy = TRUE; } ListInsertTail(RequestListHead, pRequest-ListEntry); PsReleaseMutex(DiskScheduleMutex); // 退出临界区 PsWaitForEvent(pRequest-Event, INFINITE); return pRequest; } IopProcessNextRequest函数 VOID IopProcessNextRequest( IN PREQUEST pCurrentRequest ) { PREQUEST pNextRequest; PsWaitForMutex(DiskScheduleMutex, INFINITE); // 进入临界区 CurrentCylinder = pCurrentRequest-Cylinder; ListRemoveEntry(pCurrentRequest-ListEntry); MmFreeSystemPool(pCurrentR
您可能关注的文档
最近下载
- 登革热诊疗方案(2024年版).pdf VIP
- 人教版PEP小学英语六年级上册第一单元测试卷.pdf VIP
- 《装配式装修标准化模块化设计 》课件——模块七:装配式装修卫浴部品体系设计.ppt VIP
- 《全装饰住宅部品集成技术》课件——模块六:集成厨房部品体系设计装配式装修.pptx VIP
- 破晓剧本(红色剧目).docx VIP
- 《装配式装修标准化模块化设计 》课件——模块六:集成厨房部品体系设计装配式装修.ppt VIP
- 国际投资(第六版)课件 SolMcL_6e_ch10.ppt VIP
- 《装配式建筑装饰装修》习题-04收纳系统设计.docx VIP
- 装配式建筑装饰装修-标准化.pptx VIP
- 常用电子管参数及脚位5.doc VIP
文档评论(0)