最近闲来无事看了下linux内核调度算法部分代码写几个算法出来玩玩,过几天有空会把其他几个算法发上来
/*模拟实现LINUX进程调度的静态优先级算法和时间片轮转算法,当时间片用
完时采用降优先级处理,让低优先级进程先运行,当一轮调度用完时重新分配时间片。。*/
#include
#include
#include
#define RUN 1
#define SLEEP 0
#define READY 2
#define SIG_WAKE 25
struct OSPCB
{
int PcbName ; /*进程名字*/
int ReqCount; /*进程执行计数*/
int RunTime; /*进程执行时间数*/
int Prority; /*进程优先级*/
int PcbStatus; /*进程状态*/
int PcbTime; /*进程时间片*/
struct OSPCB* prev;
struct OSPCB *next;
};
struct RunQueue /*模拟CPU调度运行队列*/
{
struct OSPCB *PointerHead; /*指向运行进程链表头*/
int PcbNumber; /*CPU每次调度计数器*/
};
struct SleepQueue /*模拟CPU调度睡眠队列*/
{
struct OSPCB *PointerHead;/*指向睡眠进程链表头*/
int PcbNumber; /*CPU每次调度计数器*/
};
//void InitPcb(struct OSPCB *pcb);
int Schedule(struct RunQueue *queue);
int *WakeUpPcb(struct SleepQueue *queue);
static void *SignallCallFunction(void);
int main(void)
{
int i,ret;
struct OSPCB *Newpcb,*p;
struct ProcessQueue *NewQueue;
int a[4][4] = {{1,1,0,1},{2,2,0,2},{3,3,0,3},{4,4,0,4}};
NewQueue = (struct ProcessQueue *)malloc(sizeof(struct ProcessQueue));
NewQueue->PointerHead = NULL;
NewQueue->PcbNumber = 0;
for(i = 0; i < 4;i++) /*进程初始化*/
{
Newpcb = (struct OSPCB *)malloc(sizeof(struct OSPCB));
Newpcb->PcbName = a[i][0];
Newpcb->ReqCount = a[i][1];
Newpcb->RunTime = a[i][2];
Newpcb->Prority = a[i][3];
Newpcb->PcbStatus = READY;
Newpcb->PcbTime = 3;
InitPcb(Newpcb);
if(NewQueue->PointerHead == NULL)
{
NewQueue->PointerHead = Newpcb;
}else{
p->next = Newpcb;
Newpcb->prev = p;
}
p = Newpcb;
NewQueue->PcbNumber++;
}
#if 0
for(p = NewQueue->PointerHead; p != NULL; p = p->next)
{
printf("process name = %d\n",p->PcbName);
}
#endif
Schedule(NewQueue);/*进入进程调度*/
return 0;
}
void InitPcb(struct OSPCB *pcb)
{
pcb->prev = NULL;
pcb->next = NULL;
}
struct OSPCB *WakeUpPcb(struct SleepQueue *queue);
{
struct OSPCB *pcb,PreRunPcb;
PreRunPcb = queue->PointerHead;
for(pcb = queue->PointerHead; pcb !=NULL; pcb = pcb->next)
{
if (pcb->Prority > PreRunPcb->Prority)
{
PreRunPcb = pcb;
}
}
return PreRunPcb;
}
int Schedule(struct RunQueue *queue,struct SleepQueue *queue_t ) /*进程调度*/
{
struct OSPCB *pcb,*pcb_t,*CurrRun;
int value,SechNumber = 8;
#if 1 //模拟进程队了惴ㄐ
// printf("%s\n",__FUNCTION__);
for(pcb = queue->PointerHead;pcb !=NULL;pcb = pcb->next)
{
if(pcb->PcbTime == 0)
{
// pcb->Prority +=4;
if(CurrRun == queue->PointerHead)
{
queue->PointerHead = CurrRun->next;
}else if (CurrRun->next != NULL){
CurrRun->prev->next = CurrRun->next;
CurrRun->next->prev = CurrRun->prev;
}else{
CurrRun->prev->next = NULL;
}
if( queue_t->PointerHead == NULL)
{
queue_t->PointerHead = pcb;
}
for(pcb_t = queue_t->PointerHead; pcb_t->next != NULL; pcb_t = pcb_t->next)
{
}
pcb_t ->next = pcb;
pcb->PcbStatus = SLEEP;
}
pcb->PcbTime = 3;
}
while(queue->PointerHead != NULL)
{
for(pcb = queue->PointerHead;pcb !=NULL;pcb = pcb->next)
{
if(pcb == queue->PointerHead)
{
CurrRun = pcb;
}else{
if(CurrRun->Prority < pcb->Prority)
CurrRun = pcb;
}
CurrRun->PcbStatus = RUN;
}
SechNumber--;
CurrRun->ReqCount--;
CurrRun->PcbTime--;
printf("present process = %d CurrRun->ReqCount = %d\n",CurrRun->PcbName,CurrRun->ReqCount);
pthread_create();
if(CurrRun->PcbTime == 0)
{
CurrRun->Prority -=4;
}
if(CurrRun->ReqCount == 0)
{
if(CurrRun == queue->PointerHead)
{
queue->PointerHead = CurrRun->next;
}else if (CurrRun->next != NULL){
CurrRun->prev->next = CurrRun->next;
CurrRun->next->prev = CurrRun->prev;
}else{
CurrRun->prev->next = NULL;
}
// printf("Run process name = %d Reqcount = %d Sechedule count = %d\n",CurrRun->PcbName,CurrRun->ReqCount,SechNumber);
}
if(SechNumber == 0)
{
Schedule(queue);
}
}
#endif
return 0;
}
阅读(2007) | 评论(1) | 转发(0) |