Pintos—Project1思路框架
(UCB版本..单Proj 1而言, 就fix-pointed.h 不太一样。。其他都是一样的。)
分析整个运作的流程:
整体来说 就是不要急于出手= =,先花点时间理清整体的脉络,分析线程的切换是怎么进行的,就绪队列是怎么产生的/改变的——这些都握在你手里,之后要花些时间看test的文件,安静的debug,刚不住了 出去蹦跶几下,调整下思绪。
一些point: 写完一段就make || 画画图 || 谨慎考虑什么时候该加锁,而什么时候又不应该加锁 || 记得初始化 || 保证一些值在范围内
主要的几个文件:
/src/thread/thread.c(h)
/src/device/timer.c(h)
/src/thread/interrupt.c(h)
/src/thread/synch.c(h)
/src/thread/fixed-point.c(h)
/src/tests/thread/对应的test文件
/src/lib/kernel/list.c(h)
(其实这一部分应该放在最后,只简单提下思路)
part I.
简单来说 就是在 计数,block。 数到了 unblock。(thread里添加个attribute 来计数,每次tick全局检查一下)
=========》thread里添加个成员来计数
part II.
(牢记,一个线程block的时候只会等着一把锁,thread_set_priority只发生在当前线程,所以priority发生改变的情况不多)
对于thread所需要做的调整:
1.每个thread要设置一个基础的base_priority和一个当前的priority,以应对set
2.考虑到释放锁的时候需