- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)