6 Star 4 Fork 3

ZhouHeyu/simulation

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
LRUWSR.c 5.54 KB
一键复制 编辑 原始数据 按行查看 历史
//
// Created by mao on 18-1-17.
//
#include "LRUWSR.h"
#include <stdlib.h>
#include "global.h"
#include "flash.h"
#include "Interface.h"
//找到LRUWSR算法中剔除干净页并不是遍历全部的节点找到干净页剔除,而是判断LRU的数据页是否为冷脏或干净页进行选择剔除
pNode FindCleanOrColdNode(pNode pHead){
pNode Victim=NULL,ps;
Victim=pHead->Pre;
int count=0,L;
L=GetListLength(pHead);
while( Victim->isCold!=1){
// 确保所有的剔除的尾部的页都是冷页
// 当然是干净页则直接剔除
if(Victim->isD==0){
break;
}
Victim->isCold=1;
// 选择上一个作为新的核实节点
ps=Victim;
Victim=ps->Pre;
pHead->Pre=Victim;
Victim->Next=pHead;
// 将核实过的节点移动到MRU位置
ps->Next=pHead->Next;
ps->Pre=pHead;
pHead->Next->Pre=ps;
pHead->Next=ps;
count++;
// debug
if(count >=L+2 ){
fprintf(stderr,"while count over the limit !");
assert(0);
}
}
// 错误检测
if(Victim!=pHead->Pre){
fprintf(stderr,"error happend in FindClean or Cold Node : Victim is not LRU page!");
assert(0);
}
return Victim;
}
//该函数完成对双链表的创建,窗口大小的设置,最大缓冲区配置
int LRUWSR_init(int size,int blk_num)
{
LRUWSR_Cache_Max_Entry=size;
LRUWSR_Cache_Num_Entry=0;
//创建对应的头结点
LRUWSR_Head=CreateList();
//针对输入的参数blk_num不加操作
Init_Cycle_WF_Value();
return 0;
}
void LRUWSR_end()
{
//释放双链表的空间
FreeList(LRUWSR_Head);
}
//函数返回命中LPN在链表中的位置index,如果没有命中则返回-1
int LRUWSR_Search(int LPN,int operation)
{
int index=-1;
pNode pt=LRUWSR_Head->Next;
int count=0;
//索引从1开始
while(pt!=LRUWSR_Head){
count++;
if(pt->LPN==LPN){
index=count;
break;
}
pt=pt->Next;
}
Show_Cycle_WF_Info(ADCTUpdateCycle,LRUWSR_Cache_Max_Entry,"LRUWSR");
return index;
}
//输入参数包括请求命中的LPN号,操作类型和命中的位置(在双链表中按顺序排列的位置)
int LRUWSR_HitCache(int LPN,int operation ,int index)
{
pNode HitNode=NULL;
HitNode=FindIndexNode(LRUWSR_Head,index);
if(HitNode==NULL){
fprintf(stderr,"error happened in LRUWSR_Hit:\n");
fprintf(stderr,"HitNode is NULL!!\n");
assert(0);
}
// debug
if(HitNode->LPN!=LPN){
fprintf(stderr,"error happened in LRUWSR_Hit:\n");
fprintf(stderr,"HitNode->LPN is %d\t req-LPN is %d\n",HitNode->LPN,LPN);
assert(0);
}
// 统计命中的操作
buffer_hit_cnt++;
if(operation==0){
HitNode->isD=1;
buffer_write_hit++;
cache_write_num++;
}else{
buffer_read_hit++;
cache_read_num++;
}
// 将命中的移动到MRU位置
MoveToMRU(LRUWSR_Head,HitNode);
HitNode->isCold=0; //非冷页
return 0;
}
double LRUWSR_AddCacheEntry(int LPN,int operation)
{
double delay=0.0;
pNode p_new=NULL;
p_new=(struct Node*)malloc(sizeof(struct Node));
if(p_new==NULL){
printf("error happened in LRUWSR_AddCacheEntry:\n");
printf("malloc for New node is error\n");
assert(0);
}
buffer_miss_cnt++;
//根据请求初始化对应节点的参数
if (operation==0){ //写操作
buffer_write_miss++;
cache_write_num++;
p_new->isD=1;
} else{ //读操作
buffer_read_miss++;
cache_read_num++;
p_new->isD=0;
}
p_new->LPN=LPN;
//插入头部
AddNewToMRU(LRUWSR_Head,p_new);
// 增加相应链表的长度
LRUWSR_Cache_Num_Entry++;
p_new->isCold=0; //非冷页 新增!!!!
delay+=callFsim(LPN*4,4,1);
physical_read++;
//错误判断
if(LRUWSR_Cache_Num_Entry!=GetListLength(LRUWSR_Head)){
printf("error happened in LRUWSR_AddCacheEntry:\n");
printf("LRUWSR_Cache_Num_Entry is %d\t list-size is %d\t",LRUWSR_Cache_Num_Entry,GetListLength(LRUWSR_Head));
exit(-1);
}
return delay;
}
double LRUWSR_DelCacheEntry(int ReqLPN,int ReqOperation)
{
double delay=0.0;
int DelLPN=-1;
pNode pVictim = NULL;
// 如果缓冲区没有满,没有必要进行删除操作
if(LRUWSR_Cache_Num_Entry<LRUWSR_Cache_Max_Entry){
return delay;
}
// 首先选择链表中的干净页进行删除.其次选择脏页
pVictim=FindCleanOrColdNode(LRUWSR_Head);
DelLPN=pVictim->LPN;
// 如果选择的是干净页,则直接删除即可,脏页则需要回写操作
if(pVictim->isD!=0){
delay+=callFsim(DelLPN*4,4,0);
physical_write++;
}
DelVictimNodeInList(LRUWSR_Head,pVictim);
LRUWSR_Cache_Num_Entry--;
// test debug
if(LRUWSR_Cache_Num_Entry!=GetListLength(LRUWSR_Head)){
printf("error happened in LRUWSR_DelCacheEntry:\n");
printf("LRUWSR_Cache_Num_Entry is %d\t list-size is %d\t",LRUWSR_Cache_Num_Entry,GetListLength(LRUWSR_Head));
exit(-1);
}
return delay;
}
struct cache_operation LRUWSR_Operation={
init: LRUWSR_init,
SearchCache: LRUWSR_Search,
HitCache: LRUWSR_HitCache,
AddCacheEntry: LRUWSR_AddCacheEntry,
DelCacheEntry: LRUWSR_DelCacheEntry,
end: LRUWSR_end
};
struct cache_operation * LRUWSR_op_setup()
{
return &LRUWSR_Operation;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/ZhouHeyu/simulation.git
git@gitee.com:ZhouHeyu/simulation.git
ZhouHeyu
simulation
simulation
master

搜索帮助