题目二:处理机调度—实时调度算法EDF和.docVIP

题目二:处理机调度—实时调度算法EDF和.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
目录 一 . 设 计 目 的 ????????????????????????? ??????????? ?????????????? ??????????? ????????2 二 . 设 计 内 容 ????????????????????????? ??????????? ?????????????? ??????????? ????????2 三 . 设 计 准 备 ????????????????????????? ??????????? ?????????????? ??????????? ????????2 四 . 设 计 过 程 ????????????????????????? ??????????? ?????????????? ??????????? ????????3 五 . 设 计 结 果 并 分 析 ????????????????????????? ????????????????????????? ????????12 六.系统的结构,原理框图和模块等的详细说明 ??????????????14 七 . 用 户 使 用 说 明 书 和 参 考 资 料 ????????????????????????? ??????????????15 八 . 设 计 体 会 ????????????????????????? ??????????? ?????????????? ??????????? ???????16 一.设计目的 深入理解处理机调度算法,了解硬实时概念,掌握最早截止期 优先调度算法。 EDF(Earliest Deadline First) 和速率单调调度算法 RMS(Rate Monotonic Scheduling )的可调度条件,并能在可调度情 况下给出具体调度结果。 二. 设计内容 在 Linux 环境中采用用户级线程模拟实现 EDF和 RMS两种实时调 度算法。给定一组实时任务, 按照 EDF算法和 RMS算法分别判断是否 可调度。在可调度的情况下,创建一组用户级线程,分别代表各个实 时任务,并按算法所确定的调度次序安排各个线程运行, 运行时在终 端上画出其 Gantt 图。为避免图形绘制冲淡算法, Gantt 图可用字符 表示。 三. 设计准备(理论、技术) 算法和 RMS算法的可调度条件及调度原则。 (1)EDF为可抢占式调度算法,其调度条件为: sum(ci/ti )≤ 1 2)RMS算法为不可抢先调度算法,其调度条件为:sum(ci/ti )≤ n(exp(in (2)/n )-1 ) 在 linux 环境中创建用户级线程的函数。(1)创建用户级线程的库函数为: Int pthread_creat (pthread_t *THREAD, Pthread_attr_t *ATTR , Void * (*START_ROUTINE) void* ), Void *ARG) pthread_creat (tid ,NULL,func ,arg ); 其中第一个参数是 pthread_t 型的指针,用于保存线程 id ;第二个参数是 pthread_attr_t 的指针,用于说明要创建的线程的属性, NULL 表示使用缺省参数; 第三个参数指明了线程的入口, 是一个只有一个 (void * )参数的函数;第四个参数是传给线程入口函数的参数。 四. 设计过程(设计思想、代码实现) (1)实时任务用 task 数据结构描述,设计四个函数: Select_proc ()用于实现调度算法,被选中任务执行 proc (),在没有可执行任务时执行 idle (),主函数 main()初始化相关数据,创建实时任务并对任务进行调度。 2)为模拟调度算法,给每个线程设置一个等待锁,暂不执行的任 务等待在相应的锁变量上。 主线程按调度算法唤醒一个子线程, 被选中线程执行一个时间单位, 然后将控制权交给主线程判断是否需要重新调度。 (3)实验代码 #include #include #include #include #include #include typedef struct{  ask_id, tasks[i].ci, tasks[i].ti); tasks[i].ci_left=tasks[i].ci; tasks[i].ti_left=tasks[i].ti; tasks[i].flag=2; tasks[i].arg=i; tasks[i].call_num=1; sum=sum+(float)tasks[i].ci / (float)tasks[i].ti; while((c=getchar())!=\nc!=EOF);  h, NULL, (void*)proc, task

文档评论(0)

156****9082 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档