西电Pintos操作系统课程设计 实验三

实验三:Priority Scheduling

一、实验目的

原始Pintos系统中对于线程的调度,没有考虑优先级问题,采用的是最为简单的FCFS策略。本实验要求为Pintos建立优先级调度机制,并确保任何时刻CPU上运行的都是最高优先级线程。

二、详细实现

  1. 修改thread.c中的thread_create()函数,在结尾处加上比较语句,若该新建的线程的优先级高于正在执行的线程的优先级,则用thread_yield()函数把正在运行的线程送入ready_list。在这里插入图片描述
  2. 修改thread_yield()函数,使其具有将ready_list中的线程按优先级降序排列的功能。在这里插入图片描述
  3. 修改thread_unblock()函数,同样地,使其具有将ready_list中的线程按优先级降序排列的功能。在这里插入图片描述
  4. 在thread.c中增加优先级比较函数thread_cmp(),以便被插入排序函数list_insert_ordered()作为参数调用。此外,还需在thread.h中声明该函数。在这里插入图片描述
  5. 修改thread_set_priority()函数,使其在为当前运行的线程t赋新优先级后,比较新优先级与ready_list中队首线程的优先级,若t的新优先级低于队首线程优先级,则用thread_yield()将t送入ready_list中。
    说明:第二个if语句中的list_entry()函数用于获取ready_list列表的头线程对应的结构体。在这里插入图片描述
  6. 在synch.c中修改sema_up()函数,在末尾添加thread_priority_check()函数,使其在执行V操作唤醒一个线程后,将当前运行的线程的优先级和ready_list队首线程的优先级进行比较。在这里插入图片描述
  7. 在thread.c中添加thread_check_priority()函数以实现步骤6中提到的优先级判断功能。然后再在thread.h中对该函数进行声明。在这里插入图片描述
  8. 在synch.c中修改sema_down()函数,使其在执行P操作阻塞一个线程然后将该线程插入该信号量的wait_list后,对wait_list中的线程按优先级降序排列。在这里插入图片描述
  9. 在synch.c中修改结构体semaphore_elem,添加priority属性,便于后续处理条件变量的wait_list中的线程时需要进行优先级比较。在这里插入图片描述
    10.在synch.c中定义cond_cmp()函数,作为条件变量的wait_list对线程进行插入排序时需要的参数。
    在这里插入图片描述
  10. 修改cond_wait()函数,利用插入排序函数对条件变量的wait_list中的线程按照优先级降序排列。在这里插入图片描述
    三、实验结果

在这里插入图片描述

西安电子科技大学 操作系统课程设计 (2021年度) 实 验 报 告 实验名称: Priority Scheduling 班 级: 姓 名: 学 号: 一、实验内容 为Pintos建立优先级调度机制,并确保任何时刻CPU上运行的都是最高优先级线程。 二、分析及设计 原始Pintos系统中对于线程的调度,没有考虑优先级问题,采用的是最为简单的FCFS策 略。 而默认的优先级顺序为31,那么就可以在起始时得到一个优先级,并在执行过程中通过 thread_set_priority( )函数修改优先级。在新的线程创立后,可以参加一个比较函数,假设新的线程优先级高 ,那么让出CPU,利用插入排序list_insert_ordered()函数将当前线程按优先级顺序插 入到等待的队列中,假设当前优先级被降低,那么让出CPU;假设优先级进步,那么继续 运行。假设遇到因为信号量进程被阻塞时,那么吧最高优先级的线程放入到队列中。假 设拥有线程的锁不满足当前的条件,那么要释放掉锁,当满足了条件后,优先级最高的 线程应该优先获得锁。 调用关系: 三、详细实现 thread_create( )函数中添加比较函数 2.修改init_thread〔〕函数,将ready-list采用插入排序的方式处理。 3.修改thread_yield ()函数,参加对ready队列的排序功能,实现插入排序。 4.修改thread_unblock()函数,假设唤醒的线程优先级顺序高,那么当前程序放弃CPU。 5.修改thread_set_priority( )函数,假设锁的占用为空闲,或者新的线程的优先级要大于原来的优先级,那么新的优 先级赋给当前的进程,正在运行的让出CPU。 6.假设涉及多个线程等待信号量的问题,那么当满足条件时,拥有最高优先级的线程应 被优先唤醒进入ready-list。修改sema_down()函数,参加插入排序的功能。 7.同6一样修改sema_up〔〕函数,对等待队列进展排序。 cond_signal〔〕函数中修改,改为优先级队列 cond_sema_cmp_priority〔〕 四、实验结果 通过实验,根本完成实验内容,结果如图: 五、心得体会 在实验中,可以通过亲自设计修改,让系统对线程进展不同的修改和占用CPU,通过设定 优先级,使系统的处理效率更高,对pintos修改实现优先级调度机制,让系统总是让最 高优先级的线程进展。 ----------------------- 西电计算机操作系统课程设计pintos-pro2全文共5页,当前为第1页。 西电计算机操作系统课程设计pintos-pro2全文共5页,当前为第2页。 西电计算机操作系统课程设计pintos-pro2全文共5页,当前为第3页。 西电计算机操作系统课程设计pintos-pro2全文共5页,当前为第4页。 西电计算机操作系统课程设计pintos-pro2全文共5页,当前为第5页。
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Polaris_T

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值