亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vmm.c

?? 語法分析器 完成從c/c++向C++轉(zhuǎn)變
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
*+
** Module Name:   Vmm.C
** 
** Description:   Virtual Memory Manager
**                  
**                Supports limited virtual memory management.
**
**                Performs cacheing of data and swapping to/from disk file.
**
**
** Written by:  John Tal
**
**
**
** Modification History:
**
** Date          Programmer      Mod#     Modification
** ---------------------------------------------------------------------------
** 17-FEB-1992   J. Tal          V1.0-000 New
**
*-
*/

#ifdef C_ANSI
#include <string.h>
#include <stdlib.h>
#endif

#ifdef C_UNIX
#include <sys/types.h>
#endif

#include <time.h>

#include <stdio.h>

#include <memlib.h>

#include <vmm.h>



VMM_MGR_T  stVmmMgr;
VMM_MGR_P  pstVmmMgr = &stVmmMgr;



/*
**   VmmInit
**
**       Initialize virtual memory manager
*/

#ifdef C_ANSI
SHORT
VmmInit(SHORT sMemoryBytes,PCHAR pcSwapFile)
#else
SHORT
VmmInit(sMemoryBytes,pcSwapFile)
SHORT sMemoryBytes;
PCHAR pcSwapFile;  
#endif 
{
   C_DEF_MODULE("VmmInit")

   static BOOL  fVmmInit;
   VMM_BLOCK_P  pstNewBlock;

   if(fVmmInit)
      C_LEAVE(VMM_ERR_INIT)

   memset(&stVmmMgr,0,sizeof(VMM_MGR_T));

   pstVmmMgr -> pvBlock = (PVOID) calloc(sMemoryBytes,1);
   pstVmmMgr -> lTotalBytes = sMemoryBytes;
   pstVmmMgr -> lSwapBytes = 0;

   if(pstVmmMgr -> pvBlock == NULL)
      C_LEAVE(VMM_ERR_MEM_EXCEEDED)

   strcpy(pstVmmMgr -> szSwapFile,pcSwapFile);


   pstVmmMgr -> fpSwapFile = fopen(pstVmmMgr -> szSwapFile,"w+b");

   if(pstVmmMgr -> fpSwapFile == NULL)
      C_LEAVE(VMM_ERR_INIT)


   /*  create logical block for all of memory */

   C_STATUS = VmmCreateBlock(VMM_MEMORY,sMemoryBytes,VMM_OWNER_NONE,pstVmmMgr -> pvBlock,0L,&pstNewBlock);

   
   if(pstVmmMgr -> fpSwapFile == NULL)
     C_LEAVE(VMM_ERR_SWAP_FILE)

   fVmmInit = C_TRUE;

C_MODULE_EXIT:
 
   C_RETURN
}


/*
**  VmmCompress
**
**  Compress Internal memory.  Called when there is enough space
**  but not in a single continuous block.
*/

#ifdef C_ANSI
SHORT
VmmCompress(VOID)
#else
SHORT
VmmCompress()
#endif 
{
   C_DEF_MODULE("VmmCompress")

   VMM_BLOCK_P  pstNewBlock;
   VMM_BLOCK_P  pstBlock;
   PVOID   pvNewBlock;
   PVOID   pvPtr;
   LLIST_P pstMember;
   LONG    lUseBytes = 0;
   LONG    lRemBytes;
   LLIST_P pstMemberNext;   

   /* get new block of memory */

   pvNewBlock = (PVOID) calloc(1,(SHORT) pstVmmMgr -> lTotalBytes);

   if(pvNewBlock == NULL)
      C_LEAVE(VMM_ERR_MEM_EXCEEDED)

   pvPtr = pvNewBlock;

   /* look at all memory blocks */
 
   pstMember = pstVmmMgr -> pstMemList;

   while(pstMember != NULL)
   {
      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;

      pstMemberNext = pstMember -> psNext;

      /* if active, copy into new master block
                    reset block pointer
                    increment current pointer into new block
                    increment used bytes
      */

      if(pstBlock -> sOwner != VMM_OWNER_NONE)
      {
         if(pstBlock -> sState == VMM_STATE_MEMORY)
         {
            /* retain by copying into new master bloc */

            memcpy(pvPtr,pstBlock -> pvBlock, pstBlock -> sBytes);
            pstBlock -> pvBlock = pvPtr;
            pvPtr = (PVOID) ((long) pvPtr + (long) pstBlock -> sBytes);
            lUseBytes += pstBlock -> sBytes;
         }
      }
      else
      {
         /* free block and remove control list member */

         free(pstBlock);

         MemLstDeleteMember(pstVmmMgr -> pstMemList,
                            pstMember,
                            &(pstVmmMgr -> pstMemList));

      }

      pstMember = pstMemberNext;
   }

   /* free old block and make Vmm point to new */

   free(pstVmmMgr -> pvBlock);
   pstVmmMgr -> pvBlock = pvNewBlock;

   lRemBytes = pstVmmMgr -> lTotalBytes - lUseBytes;
    
   
   C_STATUS = VmmCreateBlock((SHORT) VMM_MEMORY,
                             (SHORT) lRemBytes,
                             (SHORT) VMM_OWNER_NONE,
                             pvPtr,
                             (LONG) 0,
                             &pstNewBlock);

C_MODULE_EXIT:

      ;

   C_RETURN
}
 
 


/*
**  VmmAlloc - Process wants a memory block
*/

#ifdef C_ANSI
SHORT
VmmAlloc(SHORT sOwner,SHORT sTotalBytes,PLONG plHandle)
#else
SHORT
VmmAlloc(sOwner,sTotalBytes,plHandle)
SHORT sOwner;
SHORT sTotalBytes;
PLONG plHandle;
#endif
{
   C_DEF_MODULE("VmmAlloc")

   VMM_BLOCK_P  pstBlock = (VMM_BLOCK_P) NULL;


   if((LONG) sTotalBytes > pstVmmMgr -> lTotalBytes)
      C_LEAVE(VMM_ERR_MEM_EXCEEDED)

   while(pstBlock == NULL)
   {
      VmmAssignBlock(VMM_MEMORY,sTotalBytes,sOwner,&pstBlock);
      if(pstBlock == NULL)
         VmmSizeSwapToDisk(sTotalBytes,sOwner,&pstBlock);
   }

   /* update access time */

   pstBlock -> lTimeLastAccess = VmmCurTime();


   *plHandle = pstBlock -> lDescriptor;

C_MODULE_EXIT:
   
    ;

   C_RETURN
}



/*
**  VmmPrep
**  
**  Setup Memory block before access to ensure is in memory
**  Also call before each access to update access times used
**  in cacheing decisions.
*/

#ifdef C_ANSI
SHORT
VmmPrep(LONG lHandle,PPVOID ppvVirtualPtr)
#else
SHORT
VmmPrep(lHandle,ppvVirtualPtr)
LONG lHandle;
PPVOID ppvVirtualPtr;
#endif
{

   C_DEF_MODULE("VmmPrep")

   LLIST_P  pstMember;
   VMM_BLOCK_P  pstVmmBlock;

   MemLstFindMember(pstVmmMgr -> pstMemList,
                    (PVOID) &lHandle,
                    VmmCompareHandle,
                    &pstMember);

   if(pstMember != NULL)
   {
      pstVmmBlock = (VMM_BLOCK_P) pstMember -> pvData;

      if(pstVmmBlock -> sState == VMM_STATE_DISK)
      {
         pstVmmMgr -> pstReloadBlock = pstVmmBlock;

         VmmLoadFromDisk(pstVmmBlock,pstVmmBlock -> sOwner);

         pstVmmMgr -> pstReloadBlock = (VMM_BLOCK_P) NULL;
      
      }

      /* update access time */

      pstVmmBlock -> lTimeLastAccess = VmmCurTime();

      *ppvVirtualPtr = pstVmmBlock -> pvBlock;

   }

   C_RETURN
}
      

/*
**  VmmFree
**
**  Process is freeing an allocated block
*/

#ifdef C_ANSI
SHORT
VmmFree(LONG lDescriptor)
#else
SHORT
VmmFree(lDescriptor)
LONG lDescriptor;
#endif
{
   C_DEF_MODULE("VmmFree")

   LLIST_P  pstMember;
   VMM_BLOCK_P  pstBlock;

   pstMember = pstVmmMgr -> pstMemList;

   while(pstMember != NULL)
   {
      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;
 
      if(pstBlock -> lDescriptor == lDescriptor)
      {
         pstBlock -> sOwner = VMM_OWNER_NONE;
         
         /* take care of disk block if swapped out */

         if(pstBlock -> pstMate != NULL)
         {
            pstBlock -> pstMate -> sOwner = VMM_OWNER_NONE;
         }

         break;
      }

      pstMember = pstMember -> psNext;
   }


   if(pstMember == NULL)
      C_SET_STATUS(C_NOTOK)

   C_RETURN
}


/*
**  VmmTerm
**
**  Terminate Small Memory Manager
*/

#ifdef C_ANSI
SHORT VmmTerm(VOID)
#else
SHORT VmmTerm()
#endif
{
   C_DEF_MODULE("VmmTerm")

   
   LLIST_P pstMember;
   LLIST_P pstMemberNext;
   VMM_BLOCK_P  pstBlock;

    
   fclose(pstVmmMgr -> fpSwapFile);

  
   /* free main memory block */

   free(pstVmmMgr -> pvBlock);


   /* free all sub-alloc memory blocks */
   
   pstMember = pstVmmMgr -> pstMemList;

   while(pstMember != NULL)
   {
      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;

      pstMemberNext = pstMember -> psNext;

      free(pstBlock);

      pstMember = pstMemberNext;
   }



   /* free all disk swap blocks */

   pstMember = pstVmmMgr -> pstFreeDiskBlocks;

   while(pstMember != NULL)
   {
      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;

      pstMemberNext = pstMember -> psNext;

      free(pstBlock);

      pstMember = pstMemberNext;
   }

   C_RETURN     
}



/*
**   VmmLoadFromDisk
**
**   A block has been swapped to disk, load it back into memory
*/

#ifdef C_ANSI
SHORT
VmmLoadFromDisk(VMM_BLOCK_P pstVmmBlock,SHORT sOwner)
#else
SHORT
VmmLoadFromDisk(pstVmmBlock,sOwner)
VMM_BLOCK_P pstVmmBlock;
SHORT sOwner;
#endif
{
   C_DEF_MODULE("VmmLoadFromDisk")

   VMM_BLOCK_P  pstBlock = NULL;


      
   while(pstBlock == NULL)
   {
      VmmAssignBlock(VMM_MEMORY,pstVmmBlock -> sBytes,sOwner,&pstBlock);
      if(pstBlock == NULL)
         VmmSizeSwapToDisk(pstVmmBlock -> sBytes,sOwner,&pstBlock);
   }

 
   if(pstBlock != pstVmmBlock)
   {
      /* problem here, another block has been created, must merge two 
         together.  All we really need is the pvBlock ptr */

      pstVmmBlock -> pvBlock = pstBlock -> pvBlock;

      /* remove newly created block */
      VmmVanishBlock(VMM_MEMORY,pstBlock);
   }


   fseek(pstVmmMgr -> fpSwapFile,
         pstVmmBlock -> lOffset,
         0);

   fread(pstVmmBlock -> pvBlock,
         1,
         pstVmmBlock -> sBytes,
         pstVmmMgr -> fpSwapFile);

   pstVmmBlock -> sState = VMM_STATE_MEMORY;


   /* free up disk block for other use */

   if(pstVmmBlock -> pstMate != NULL)
   {
      pstVmmBlock -> pstMate -> sOwner = VMM_OWNER_NONE;
      pstVmmBlock -> pstMate = NULL;
   }

   C_RETURN
}


/*
**   VmmVanishBlock
**
**   A new block has been created during processing and is not needed
**   (pvBlock was probably copied before this call)
*/

#ifdef C_ANSI
SHORT
VmmVanishBlock(SHORT sType,VMM_BLOCK_P pstVanishBlock)
#else
SHORT
VmmVanishBlock(sType,pstVanishBlock)
SHORT sType;
VMM_BLOCK_P pstVanishBlock;
#endif
{
  C_DEF_MODULE("VmmVanishBlock")

  LLIST_P  pstMember;
  VMM_BLOCK_P  pstBlock;

  if(sType == VMM_STATE_MEMORY)
     pstMember = pstVmmMgr -> pstMemList;
  else
     pstMember = pstVmmMgr -> pstFreeDiskBlocks;

  while(pstMember != NULL)
  {
     pstBlock = (VMM_BLOCK_P) pstMember -> pvData;  

     if(pstBlock == pstVanishBlock)
     {
        if(sType == VMM_MEMORY)
        {
           C_STATUS = MemLstDeleteMember(pstVmmMgr -> pstMemList,
                                         pstMember,
                                         &(pstVmmMgr -> pstMemList));
        }
        else
        {
           C_STATUS = MemLstDeleteMember(pstVmmMgr -> pstFreeDiskBlocks,
                                         pstMember,
                                         &(pstVmmMgr -> pstFreeDiskBlocks));
        }
        
        break;
     }

     pstMember = pstMember -> psNext;

  }

  
  free(pstVanishBlock);

  C_RETURN
}


/*
**   VmmCheckFreeBlocks
**
**   Check total bytes available across all free fragments
*/

#ifdef C_ANSI
SHORT
VmmCheckFreeBlocks(SHORT * pAvail)
#else
SHORT
VmmCheckFreeBlocks(pAvail)
SHORT * pAvail;
#endif
{
   C_DEF_MODULE("VmmCheckFreeBlocks")

   LLIST_P  pstMember;
   VMM_BLOCK_P  pstBlock;
   SHORT  sFreeBytes = 0;

   pstMember = pstVmmMgr -> pstMemList;

   /* find oldest available block */

   while(pstMember != NULL)
   {
      /*  if unused block, count it */
     
      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;

      if((pstBlock -> sOwner == VMM_OWNER_NONE) &&
         (pstBlock -> sState == VMM_STATE_MEMORY))
      {
         sFreeBytes += pstBlock -> sBytes; 
      }

      pstMember = pstMember -> psNext;

  }

  *pAvail = sFreeBytes;

  return(C_OK);
}


/*
**  VmmFindStaleBlock
*/

#ifdef C_ANSI
SHORT
VmmFindStaleBlock(VMM_BLOCK_P * ppstRetBlock)
#else
SHORT
VmmFindStaleBlock(ppstRetBlock)
VMM_BLOCK_P * ppstRetBlock;
#endif
{
   C_DEF_MODULE("VmmFindStaleBlock")

   LLIST_P  pstMember;
   LLIST_P  pstMemberNext;

   VMM_BLOCK_P  pstBlock;
   VMM_BLOCK_P  pstOldBlock = (VMM_BLOCK_P) NULL;
   LONG     lTimeLastAccess;


   lTimeLastAccess = VmmCurTime();

   *ppstRetBlock = (VMM_BLOCK_P) NULL;

   pstMember = pstVmmMgr -> pstMemList;

   /* find oldest available block */

   while(pstMember != NULL)
   {
      pstMemberNext = pstMember -> psNext;

      pstBlock = (VMM_BLOCK_P) pstMember -> pvData;

      if((pstBlock -> sOwner != VMM_OWNER_NONE) &&
         (pstBlock -> sState != VMM_STATE_DISK))
      {
         if(pstBlock -> lTimeLastAccess <= lTimeLastAccess) 
         { 
            pstOldBlock = pstBlock;
            lTimeLastAccess = pstBlock -> lTimeLastAccess;
         }
      }

      pstMember = pstMemberNext;
   }

   *ppstRetBlock = pstOldBlock;

   return(C_OK);
}



/*
**   VmmAssignBlock
**
**   Find and assign a block for either memory or disk allocation
**   Can return NULL in the return block if none found
*/

#ifdef C_ANSI
SHORT
VmmAssignBlock(SHORT sType,
               SHORT sBlockSize,
               SHORT sOwner,
               VMM_BLOCK_P * ppstRetBlock)
#else
SHORT
VmmAssignBlock(sType,
               sBlockSize,
               sOwner,
               ppstRetBlock)
SHORT sType;
SHORT sBlockSize;
SHORT sOwner;
VMM_BLOCK_P * ppstRetBlock;
#endif
{
    C_DEF_MODULE("VmmAssignBlock")

    LLIST_P  pstMember;
    LLIST_P  pstMemberNext;
    LLIST_P  pstMemberBlock;

    VMM_BLOCK_P  pstBlock;
    BOOL     fFoundBlock = C_FALSE;
    SHORT    sByteDiff;


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品人在线二区三区| 国产视频一区在线观看| 国产在线观看免费一区| 一区二区三区精品视频在线| 日韩欧美一二三四区| 日本精品裸体写真集在线观看| 精品一区二区久久| 亚洲国产精品视频| 国产精品三级av在线播放| 日韩一级片网站| 色哟哟一区二区| 国产精品一区二区在线播放| 午夜精品在线视频一区| 日韩一区在线免费观看| 久久久久久久久久久电影| 欧美精品一级二级三级| 在线亚洲一区二区| 福利一区二区在线| 精品在线观看免费| 亚洲www啪成人一区二区麻豆| 中文字幕在线观看不卡视频| 精品三级在线观看| 欧美一区二区福利在线| 欧美色窝79yyyycom| 成人午夜私人影院| 国产精品一区专区| 韩国精品一区二区| 精品一区二区三区视频| 日韩精品每日更新| 亚洲v中文字幕| 亚洲国产综合人成综合网站| 亚洲免费在线播放| 日韩美女视频一区二区| 国产精品国产三级国产| 中文字幕在线观看一区| 国产精品高潮久久久久无| 国产欧美日韩精品a在线观看| 精品国产一区久久| 精品国产伦一区二区三区观看方式 | 久久网这里都是精品| 欧美精品v日韩精品v韩国精品v| 欧美亚洲一区三区| 欧美日韩小视频| 欧美日韩一区在线| 精品视频1区2区| 欧美精三区欧美精三区| 制服.丝袜.亚洲.另类.中文| 欧美一区二区三区日韩| 日韩午夜在线观看视频| 欧美成人午夜电影| 久久精品人人爽人人爽| 国产精品午夜电影| 亚洲日本免费电影| 亚洲无人区一区| 日本不卡1234视频| 国模套图日韩精品一区二区| 国产黑丝在线一区二区三区| 成人午夜视频福利| 99国产精品99久久久久久| 在线观看视频一区| 欧美日韩一级大片网址| 日韩欧美国产不卡| 国产日韩欧美一区二区三区乱码 | 国产美女在线观看一区| 成人免费视频视频在线观看免费| 91同城在线观看| 欧美性色aⅴ视频一区日韩精品| 欧美三级电影一区| 2023国产精华国产精品| 欧美国产精品久久| 香蕉加勒比综合久久| 国精产品一区一区三区mba桃花| 成人sese在线| 欧美老女人在线| 久久久精品免费观看| 亚洲天堂精品在线观看| 日日夜夜精品视频免费| 国产高清亚洲一区| 欧美色网站导航| 国产亚洲精品福利| 一区二区三区在线免费| 激情深爱一区二区| 91免费视频网址| 精品少妇一区二区三区免费观看| 亚洲欧洲精品一区二区精品久久久| 亚洲风情在线资源站| 国产一区二区三区美女| 欧美色欧美亚洲另类二区| 欧美成人福利视频| 亚洲精品乱码久久久久久久久 | 国产欧美日本一区视频| 亚洲一线二线三线久久久| 国产美女精品人人做人人爽| 欧洲亚洲精品在线| 久久精品视频免费| 亚洲.国产.中文慕字在线| 成人午夜视频免费看| 91精品视频网| 亚洲美女免费视频| 国产成人夜色高潮福利影视| 欧美日韩精品一区二区在线播放| 国产日韩影视精品| 久久精品国产999大香线蕉| 日本精品裸体写真集在线观看| 久久综合九色欧美综合狠狠| 亚洲国产精品一区二区久久| 99在线视频精品| 久久久久高清精品| 美女一区二区视频| 欧美日韩亚洲综合一区二区三区| 欧美激情在线一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 911精品产国品一二三产区| 国产精品乱人伦中文| 国精产品一区一区三区mba桃花 | 国产视频在线观看一区二区三区| 婷婷久久综合九色综合绿巨人| 91一区在线观看| 国产精品日韩成人| 国产精品一区二区在线播放| 日韩视频一区二区在线观看| 亚洲高清视频在线| 一道本成人在线| 最新欧美精品一区二区三区| 成人av在线一区二区三区| 久久在线观看免费| 激情文学综合网| 日韩欧美视频一区| 免费观看日韩av| 日韩你懂的电影在线观看| 男男gaygay亚洲| 91精品午夜视频| 蜜桃精品视频在线| 欧美电影一区二区| 免费成人在线观看视频| 4438x成人网最大色成网站| 婷婷激情综合网| 欧美高清视频在线高清观看mv色露露十八 | 一区二区三区免费| 色老头久久综合| 亚洲精品视频在线观看网站| 91色九色蝌蚪| 一级特黄大欧美久久久| 在线观看日韩电影| 亚洲bt欧美bt精品777| 91精品国产福利| 欧美a级理论片| 亚洲精品一区二区三区影院| 久久av老司机精品网站导航| 久久精品人人做人人爽人人| av中文字幕在线不卡| 最新欧美精品一区二区三区| 欧美亚洲国产一区二区三区| 亚洲成av人片一区二区| 欧美一区午夜视频在线观看| 蜜桃av一区二区三区| 久久免费美女视频| av男人天堂一区| 亚洲高清一区二区三区| 日韩精品中文字幕一区二区三区| 国产一区久久久| 亚洲欧美日韩在线不卡| 6080日韩午夜伦伦午夜伦| 老司机精品视频一区二区三区| 久久久www成人免费无遮挡大片| 成人h动漫精品一区二区| 一区二区久久久| 日韩欧美资源站| 粉嫩av一区二区三区| 夜夜操天天操亚洲| 日韩精品资源二区在线| 波多野结衣视频一区| 午夜av电影一区| 久久久久国产精品人| 91国偷自产一区二区三区观看 | 午夜影视日本亚洲欧洲精品| 欧美大片在线观看| 99re在线视频这里只有精品| 日本亚洲最大的色成网站www| 国产亚洲制服色| 欧美色窝79yyyycom| 国产伦精品一区二区三区视频青涩 | 在线观看视频一区二区欧美日韩| 蜜桃一区二区三区在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 成人丝袜高跟foot| 五月综合激情日本mⅴ| 欧美激情在线看| 日韩一区二区在线观看视频播放| 岛国精品一区二区| 肉色丝袜一区二区| 亚洲欧美色综合| 国产亚洲欧美日韩在线一区| 欧美日韩一级片网站| av在线播放不卡| 国产又粗又猛又爽又黄91精品| 亚洲国产精品欧美一二99| 国产欧美va欧美不卡在线| 欧美肥妇bbw| 91搞黄在线观看|