ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:111KB ,
资源ID:2246572      下载积分:20 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-2246572.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(嵌入式操作系统内核原理和开发(改进型优先级调度)new.doc)为本站会员(dzzj200808)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

嵌入式操作系统内核原理和开发(改进型优先级调度)new.doc

1、 软件英才网 软件行业驰名招聘网站有需要请联系我们嵌入式操作系统内核原理和开发(改进型优先级调度) 上面的一篇博客说到了优先级调度,但是那个优先级调度算法比较极端。打个比方说,现在王先生有三个小孩,分别是老大、老二、老三。假设现在到了饭点,王先生需要给三个小孩喂饭。此时如果是时间片轮转的话,那么就是绝对公平,王先生每人一口不停地进行喂饭。如果是优先级调度,那么王先生首先自己有一个优先级考量,比如说三个小孩按照年龄顺序优先级是逐渐提高的,毕竟小孩需要更多的照顾嘛。这个时候如果需要进行喂饭的话,那么王先生需要首先伺候好最小的那个小孩老三,才会有时间照顾老二,至于老大什么时候才能得到照顾那就看造化了

2、。现在,我们打算重新换一种方法。假设三个小孩的优先级分别是1、2、3,其中年龄越小优先级越高,3代表高优先级。接着,我们按照优先级给三个小孩安排时间片,分别是1、2、3。同时,这个时间片不光代表了当前可用的剩余时间,还代表了小孩此时的临时优先级。(1)首先王先生给老三喂饭,时间片降低1,即临时优先级为2;(2)接着王先生判断当前优先级最高的仍为老三,毕竟老二的优先级也没有超过老三,所以老三的时间片降1,临时优先级为1;(3)王先生获知当前优先级最高的为老二,老二获得时间片;(4)此时王先生发现三个孩子的临时优先级都一样,那么就会按照固定优先级的大小依次对老三、老二、老大进行喂饭。我们发现,这中

3、间受益最大的就是老二。当然,我们可以做进一步推论,如果老王的孩子越多,那么优先级处于中间的孩子在时间片的分配上将更加均匀,响应也会更加及时,交互性也会变得很好。根据以上的想法,我们重新改写了优先级调度算法,修改为改进型优先级调度算法,cpp view plaincopy int find_next_thread() int index; int choice = THREAD_MAX_NUMBER -1; int value = gAllTaskchoice.time_slice; 软件英才网 软件行业驰名招聘网站有需要请联系我们 for(index = choice -1; index =

4、0; index -) if(value #include #include #include #include #include #include #define UINT32 unsigned int #define STACK_LENGTH 512 #define THREAD_MAX_NUMBER 10 #define TIME_ROUND_SCHEDULE 0 #define HARD_PRIORITY_SCHEDULE 0 #define SOFT_PRIORITY_SCHEDULE 1 typedef struct _TASK_INFO 软件英才网 软件行业驰名招聘网站有需要请联

5、系我们 UINT32 id; UINT32* stack; UINT32 size; UINT32 context; UINT32 priority; UINT32 time_slice; void (*func)(); TASK_INFO; static struct itimerval oldtv; UINT32 old = 0; UINT32 count = 0; UINT32 task_stackTHREAD_MAX_NUMBERSTACK_LENGTH = 0; TASK_INFO gAllTaskTHREAD_MAX_NUMBER = 0; UINT32 current_threa

6、d_id = 0; void set_timer() struct itimerval itv; itv.it_interval.tv_sec = 1; itv.it_interval.tv_usec = 0; itv.it_value.tv_sec = 1; itv.it_value.tv_usec = 0; setitimer(ITIMER_REAL, void swap(UINT32* prev, UINT32* next) _asm(“push %eaxnt“ “push %ebxnt“ “push %ecxnt“ “push %edxnt“ “push %esint“ “push %

7、edint“ “push %ebpnt“ “push %espnt“ “lea 0x8(%ebp), %eaxnt“ “mov (%eax), %eaxnt“ “mov %esp, (%eax)nt“ “lea 0xc(%ebp), %eaxnt“ “mov (%eax), %eaxnt“ 软件英才网 软件行业驰名招聘网站有需要请联系我们 “mov (%eax), %espnt“ “pop %espnt“ “pop %ebpnt“ “pop %edint“ “pop %esint“ “pop %edxnt“ “pop %ecxnt“ “pop %ebxnt“ “pop %eaxnt“ :);

8、void hello() int temp = 0; while(1) printf(“id = %d, temp = %d, count = %d in thread!n“,current_thread_id, temp +, count +); swap( printf(“id = %d, temp = %d, count = %d in thread!n“,current_thread_id, temp +, count +); swap( #if HARD_PRIORITY_SCHEDULE int find_next_thread() int index; for(index = T

9、HREAD_MAX_NUMBER -1; index =0; index -) if(0 != gAllTaskindex.time_slice) break; return index; #endif 软件英才网 软件行业驰名招聘网站有需要请联系我们 #if SOFT_PRIORITY_SCHEDULE int find_next_thread() int index; int choice = THREAD_MAX_NUMBER -1; int value = gAllTaskchoice.time_slice; for(index = choice -1; index = 0; inde

10、x -) if(value gAllTaskindex.time_slice) choice = index; value = gAllTaskindex.time_slice; if(0 = value) choice = -1; return choice; #endif void reset_time_slice () int index; for(index = 0; index THREAD_MAX_NUMBER; index+) gAllTaskindex.time_slice = gAllTaskindex.priority + 1; void task_init(int ind

11、ex) UINT32 unit = gAllTaskindex.size; UINT32* pData = gAllTaskindex.stack; memset(void*)pData,(int) 0, unit * sizeof(UINT32); pDataunit -1 = (UINT32) gAllTaskindex.func; pDataunit -2 = 0; pDataunit -3 = 0; pDataunit -4 = 0; 软件英才网 软件行业驰名招聘网站有需要请联系我们 pDataunit -5 = 0; pDataunit -6 = 0; pDataunit -7 =

12、0; pDataunit -8 = 0; pDataunit -9 = 0; pDataunit -10 = (UINT32) gAllTaskindex.context = (UINT32) #if TIME_ROUND_SCHEDULE void signal_handler(int m) current_thread_id = current_thread_id % THREAD_MAX_NUMBER; swap( current_thread_id +; #else void signal_handler(int m) int index; start: index = find_ne

13、xt_thread(); if(-1 = index) reset_time_slice(); goto start; gAllTaskindex.time_slice -; current_thread_id = index; swap( #endif void set_all_task() int index; memset(gAllTask, 0, sizeof(gAllTask); for(index = 0; index THREAD_MAX_NUMBER; index +) 软件英才网 软件行业驰名招聘网站有需要请联系我们 gAllTaskindex.id = index; gAl

14、lTaskindex.stack = task_stackindex; gAllTaskindex.size = STACK_LENGTH; gAllTaskindex.context = 0; gAllTaskindex.func = hello; gAllTaskindex.priority = index; gAllTaskindex.time_slice = index + 1; task_init(index); int main() char val; set_all_task(); set_timer(); signal(SIGALRM, signal_handler); while(1) scanf(“%c“, exit(0); return 1;

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报