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

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

?? memory_check_vx.c

?? VxWorks Memory Pool VxWorks Memory Pool
?? C
字號(hào):
/**
 * VxWorks Memory Pool Check                                   V1.00, 14.6.2002
 * -------------------------                           (c) Rene H. Straub, 2002
 * 
 * see notes in header file.
 **/

//--- includes ----------------------------------------------------------------

#include <stdio.h>
#include <string.h>
#include <memory_check_vx.h>



//--- defines ------------------------------------------------------------------

#define MAX_FREE_NODES    (2500)      // Max. number of free memory nodes
#define MAX_ALLOC_BLOCKS  (25000)     // Max. number of allocated blocks per 
                                      // free node.


#ifdef SHOW_LEVEL_ERROLY
# define P_INFO(x)
# define P_MEDIUM(x)  
# define P_ERROR(x)   printf x
#endif

#ifdef SHOW_LEVEL_ERRFRR 
# define P_INFO(x)
# define P_MEDIUM(x)  printf x
# define P_ERROR(x)   printf x
#endif 

#ifdef SHOW_LEVEL_ERRALL
# define P_INFO(x)    printf x
# define P_MEDIUM(x)  printf x
# define P_ERROR(x)   printf x
#endif



//--- local variables ----------------------------------------------------------

static PARTITION*   part        = 0;                  // The partition to check
static void*        memLow      = (void*)0x00000000;  // Lowest valid address 
static void*        memHigh     = (void*)0xffffffff;  // Highest valid address 

static int          errors;                           // Nbr. of errors encountered
static unsigned     totalAlloc;                       // Statistical information
static unsigned     totalFree;
static unsigned     totalAllocNodes;
static unsigned     totalFreeNodes;
static unsigned     largestAlloc;
static unsigned     largestFree;




//--- local functions ----------------------------------------------------------

static void checkPtr(void* ptr, const char* pMsg)
{
  if ((ptr < memLow) || (ptr > memHigh))
  {
    errors++;

    if (pMsg != 0x00000000)
      P_ERROR(("Pointer %8p not in memory region (%8p..%8p)\n", ptr, memLow, memHigh));
    else
      P_ERROR(("%s: Pointer %8p not in memory region (%8p..%8p)\n", pMsg, ptr, memLow, memHigh));
  }
}

//-----------------------------------------------------------------------------

static void existsFreeNode(FREE_BLOCK* pFreeBlock)
{
  // Try to find the specified free block in the list of free nodes.

  DL_NODE*      ndCurrent;
  DL_NODE*      ndRef;
  unsigned      nNodes    = 0;

  checkPtr(part, "Memory Partition");

  ndRef         = &pFreeBlock->node;
  ndCurrent     = DLL_FIRST(&part->freeList);
  checkPtr(ndCurrent, "First node");

  while (ndCurrent != 0x00000000)
  {
    checkPtr(ndCurrent, "existsFreeNode() Free node");

    if (ndCurrent == ndRef)
      return;

    ndCurrent   = DLL_NEXT(ndCurrent);

    if (++nNodes == MAX_FREE_NODES)
    {
      errors++;
      P_ERROR(("Detected more than %d memory nodes.\n", nNodes));
      break;
    }
  };

  P_ERROR(("Free block %p not found in free node list.\n", pFreeBlock));
}

//-----------------------------------------------------------------------------

static void checkMemoryList(FREE_BLOCK* pFreeBlock)
{
  // Check integrity of allocated memory in "managed" by the specified
  // free node.

  BLOCK_HDR*  pMemBlock;
  BLOCK_HDR*  pLastBlock;
  unsigned    nBlock;

  nBlock      = 0;

  pLastBlock  = &pFreeBlock->hdr;
  pMemBlock   = NEXT_HDR(pLastBlock);

  checkPtr(pMemBlock, "Block");

  while (pMemBlock != 0x00000000)
  {
    unsigned    nMemBlockSize;
    int         bMemBlockFree;
 
    checkPtr(pMemBlock, "Block");

    nMemBlockSize = pMemBlock->nWords * 2;
    bMemBlockFree = pMemBlock->free;

    P_INFO((" Block %3d:  Address: %8p  Size: %8d  Next: %p\n", 
      nBlock, pMemBlock, nMemBlockSize, (char*)(pMemBlock) + nMemBlockSize
      ));

    // This nodes previous pointer must point to the last node we processed.
    if (pMemBlock->pPrevHdr != pLastBlock)
    {
      errors++;
      P_ERROR(("mem list broken  current: %p, curr->prev: %p, last: %p\n", 
        pMemBlock, pMemBlock->pPrevHdr, pLastBlock));
      break;
    }

    // The end of the memory list is terminated with a dummy block,
    // just big enough to hold a BLOCK_HDR but no user data. 
    if (nMemBlockSize == sizeof(BLOCK_HDR))
    {
      break;
    }

    // If we encounter a memory block marked as free, then our search ends
    // here. The blocks from here on, will be checked when this free node 
    // is processed.
    if (bMemBlockFree)
    {
      existsFreeNode( (FREE_BLOCK*)pMemBlock ); 
      
      break;
    }

    // Statistics
    totalAllocNodes++;
    totalAlloc  += nMemBlockSize;
    if (nMemBlockSize > largestAlloc)
      largestAlloc = nMemBlockSize;


    // Goto next block
    pLastBlock  = pMemBlock;
    pMemBlock   = NEXT_HDR(pMemBlock);
    
    if (++nBlock == MAX_ALLOC_BLOCKS)
    {
      P_ERROR(("Detected more than %d memory blocks. Aborting.\n", nBlock));
      break;
    }
  }

  P_INFO(("\n"));
}

//-----------------------------------------------------------------------------

static void checkNodeList(DL_NODE* ndFirst, DL_NODE* ndLast)
{
  DL_NODE*      ndPrev    = 0x00000000;
  DL_NODE*      ndCurrent = ndFirst;
  unsigned      nNodes    = 0;

  while (ndCurrent != 0x00000000)
  {
    FREE_BLOCK*     pFreeBlock;
    unsigned        nBlockSize;
    int             bBlockUsed;

    checkPtr(ndCurrent, "Node");

    // Display information
    pFreeBlock  = (FREE_BLOCK*) NODE_TO_HDR(ndCurrent);   // Pointer to free block header
    nBlockSize  = pFreeBlock->hdr.nWords * 2;             // Size in bytes
    if (pFreeBlock->hdr.free)
      bBlockUsed = false;
    else
      bBlockUsed = true;

    P_INFO(("Node %3d: Address: %8p  Size: %8d\n", nNodes, pFreeBlock, nBlockSize));

    // Validate node
    if (pFreeBlock->node.previous != ndPrev)
    {
      errors++;
      P_MEDIUM((" Node %p: Previous pointer %p invalid (should be %p)\n", 
        pFreeBlock, pFreeBlock->node.previous, ndPrev));
    }

    if (bBlockUsed)
    {
      errors++;
      P_ERROR((" Node %p: Marked as used.\n", pFreeBlock));
    }

    // Statistics
    totalFreeNodes++;
    totalFree += nBlockSize;
    if (nBlockSize > largestFree)
      largestFree = nBlockSize;


    /*
     * Go through all memory blocks that are linked from here.
     */
    checkMemoryList(pFreeBlock);


    // Goto next node in free list.
    ndPrev      = ndCurrent;
    ndCurrent   = DLL_NEXT(&pFreeBlock->node);

    if (++nNodes == MAX_FREE_NODES)
    {
      errors++;
      P_ERROR(("Detected more than %d memory nodes.\n", nNodes));
      break;
    }
  };

  // Check list header last pointer versus last free node element found.
  if (ndPrev != ndLast)
  {
    errors++;
    P_ERROR(("List header last pointer %p does not point to last node %p\n", ndLast, ndPrev));
  }
}



//--- global functions ---------------------------------------------------------

void memCheckSetup(PART_ID partition, void* lowAddr, void* highAddr)
{
  if (partition == 0)
  {
    // Use VxWorks default memory partition
    part = memSysPartId;
  }
  else
  {
    // Use callers memory partition
    part = partition; 
  }

  // Remember this memory partitions address range, so we can check pointers.
  memLow    = lowAddr;
  memHigh   = highAddr;
}

//-----------------------------------------------------------------------------

void memCheck(const char* pszFile, unsigned line)
{
  DL_NODE*      ndFirst;
  DL_NODE*      ndLast;

  if (part == 0) 
  {
    P_ERROR(("Memory check not initialized. Call memCheckSetup() first\n."));
  }

  checkPtr(part, "Memory Partition");

  // Take mem list semaphore. This will block everyone trying to allocate/free
  // memory...
  semTake(&part->sem, WAIT_FOREVER);      

  // Init variables to scan free memory list.
  errors            = 0;
  totalAlloc        = 0;
  totalFree         = 0;
  totalAllocNodes   = 0;
  totalFreeNodes    = 0;
  largestAlloc      = 0;
  largestFree       = 0;
  
  ndFirst     = DLL_FIRST(&part->freeList);
  ndLast      = DLL_LAST (&part->freeList);
  checkPtr(ndFirst, "First node");
  checkPtr(ndLast, "Last node");

  /*
   * Scan through list of free memory
   */
  checkNodeList(ndFirst, ndLast);


  // Show collected statistics
  P_MEDIUM(("\n             Alloc      Free     Total\n"
            "-------- --------- --------- -----------\n"));
  P_MEDIUM((" Blocks   %8d  %8d  %8d\n", totalAllocNodes, totalFreeNodes, totalAllocNodes+totalFreeNodes));
  P_MEDIUM((" Bytes    %8d  %8d  %8d\n", totalAlloc, totalFree, totalAlloc+totalFree));
  P_MEDIUM((" Largest  %8d  %8d\n\n", largestAlloc, largestFree));


  // Release semaphore
  (void)semGive(&part->sem);


  // If errors occurred display message and halt system. 
  if (errors != 0)
  {
    P_ERROR(("Memory check %s (%d) failed with %d error(s). Halting task.\n", 
      pszFile, line, errors));

    taskSuspend(0);
  }
}

//-----------------------------------------------------------------------------

void memCheckTest(void)
{
  char*   p1;
  char*   p2;
  
  // Setup test. Don't know valid address range so use max. possible range.
  memCheckSetup(0, (void*)0x00000000, (void*)0xffffffff);
  
  // Alloc some memory we can use for test
  p1 = (char*)malloc(16);
  printf("Allocated 16 bytes at %p\n", p1);
  p2 = (char*)malloc(16);
  printf("Allocated 16 bytes at %p\n", p2);

  // No error until now
  MEM_CHECK();

  // Write beyond the memory allocated for <p2>
  // On a PPC memory is aligned on 8 byte boundaries. Thus we now overwrite
  // the memory node of <p1>.
  memset(p2+16, 0x33, 4);
  printf("Writing 4 bytes beyond allocated memory at %p\n", p2);

  // This test must fail
  MEM_CHECK();

}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久一日本道色综合| 亚洲三级免费电影| 欧美激情综合五月色丁香| 国产精品福利一区二区| 午夜国产精品一区| 国产伦精品一区二区三区免费| av福利精品导航| 宅男在线国产精品| 国产精品成人在线观看| 视频一区视频二区在线观看| 捆绑调教美女网站视频一区| 99精品视频在线观看| 精品视频在线视频| 国产亚洲短视频| 亚洲国产你懂的| 国产jizzjizz一区二区| 欧美日韩国产区一| 国产精品卡一卡二| 麻豆精品新av中文字幕| aaa国产一区| 欧美一区二区三区免费| 成人免费在线视频| 国产在线精品免费| 欧美日韩三级一区二区| 粉嫩在线一区二区三区视频| 欧美三级蜜桃2在线观看| 国产精品视频yy9299一区| 午夜av区久久| 91丝袜美女网| 国产亚洲成年网址在线观看| 日韩成人精品在线| 成人av在线播放网站| 欧美在线观看一区| 亚洲欧洲日韩av| 国产一区二区三区精品视频| 欧美日韩免费视频| 亚洲人午夜精品天堂一二香蕉| 激情综合网激情| 欧美一区国产二区| 亚洲综合一区二区精品导航| 成人av免费观看| 26uuu欧美日本| 偷拍一区二区三区四区| 99精品视频在线观看| 国产欧美视频一区二区| 国内精品国产成人| 欧美成人福利视频| 日韩精品久久理论片| 色素色在线综合| 亚洲天堂2016| 99久久免费视频.com| 中文字幕精品—区二区四季| 精品一区二区在线看| 日韩欧美色综合| 婷婷久久综合九色国产成人| 欧美日韩中文精品| 亚洲午夜免费电影| 色一情一伦一子一伦一区| 国产精品短视频| 99久久综合狠狠综合久久| 国产农村妇女精品| 国产自产视频一区二区三区| 久久国产综合精品| 7777精品伊人久久久大香线蕉的| 亚洲综合色区另类av| 色欧美乱欧美15图片| 国产精品卡一卡二卡三| 成人动漫一区二区在线| 国产欧美日韩卡一| 成人av在线一区二区| 国产精品每日更新| av一区二区不卡| 日韩理论片一区二区| 国产精品2024| 国产丝袜欧美中文另类| 成人美女视频在线看| 亚洲日本在线看| 在线观看精品一区| 三级久久三级久久| 日韩欧美国产一区二区三区| 国产综合色在线视频区| 国产色91在线| 成人成人成人在线视频| 亚洲精品国产品国语在线app| 99久久亚洲一区二区三区青草| 亚洲日本电影在线| 欧美日韩中字一区| 麻豆一区二区三| 国产亚洲欧洲997久久综合| 粉嫩av亚洲一区二区图片| 国产精品成人午夜| 欧美三级日韩三级国产三级| 美国一区二区三区在线播放| 久久综合九色综合久久久精品综合| 国产91丝袜在线观看| 亚洲视频香蕉人妖| 欧美精品久久天天躁| 国产一区在线观看麻豆| 国产精品家庭影院| 欧美色图12p| 黄色小说综合网站| 亚洲男人天堂一区| 69p69国产精品| 国产一区二区按摩在线观看| 国产精品久久久久久久久快鸭| 欧美最新大片在线看 | 成人动漫一区二区在线| 91在线一区二区三区| 亚洲成人免费视| 久久久噜噜噜久久中文字幕色伊伊| 成人永久aaa| 一区二区三区欧美日| 91麻豆精品国产91久久久使用方法| 国内偷窥港台综合视频在线播放| 中文字幕综合网| 4438x成人网最大色成网站| 毛片基地黄久久久久久天堂| 日本一区二区三区免费乱视频| 日本韩国欧美一区二区三区| 麻豆国产精品视频| 最好看的中文字幕久久| 欧美成人一区二区三区片免费| 不卡的av在线播放| 日韩中文欧美在线| 国产精品久久久久久久午夜片 | 天堂蜜桃91精品| 国产三级一区二区| 在线成人高清不卡| 懂色av中文一区二区三区| 亚洲大片精品永久免费| 国产日韩精品一区二区三区| 欧美高清精品3d| 成人午夜短视频| 视频一区二区国产| 中文字幕五月欧美| 日韩手机在线导航| 91久久国产综合久久| 国内精品久久久久影院色| 亚洲三级久久久| 欧美激情在线免费观看| 欧美一级夜夜爽| 一本久久精品一区二区| 国产成人h网站| 另类小说视频一区二区| 亚洲一级二级在线| 国产精品每日更新| 久久久久99精品国产片| 在线播放91灌醉迷j高跟美女| 91看片淫黄大片一级| 国产成人在线网站| 看片的网站亚洲| 日韩av电影免费观看高清完整版 | 色狠狠综合天天综合综合| 国产成人精品一区二区三区四区| 日韩在线一二三区| 亚洲一区av在线| 亚洲欧洲成人精品av97| 欧美国产一区视频在线观看| wwwwxxxxx欧美| 欧美成人精精品一区二区频| 91精品国产一区二区三区蜜臀| 欧美亚洲国产一卡| 91九色最新地址| 在线观看视频91| 在线观看视频欧美| 91传媒视频在线播放| 一本久道久久综合中文字幕 | 亚洲丝袜美腿综合| 中文字幕一区二区三区色视频 | 色八戒一区二区三区| 97精品久久久久中文字幕| 欧美激情一二三区| 久久亚洲影视婷婷| 久久伊99综合婷婷久久伊| 久久综合色婷婷| 久久精品视频一区二区| 久久色中文字幕| 久久久久久久久久久黄色| 久久先锋影音av鲁色资源网| 久久欧美一区二区| 久久久99久久精品欧美| 久久久无码精品亚洲日韩按摩| 欧美成人国产一区二区| 久久看人人爽人人| 久久久不卡影院| 国产欧美综合在线| 国产精品黄色在线观看| 亚洲精品日韩一| 亚洲午夜在线观看视频在线| 五月天激情综合| 美女网站在线免费欧美精品| 激情深爱一区二区| 国产成人综合在线| www.av亚洲| 欧美在线免费视屏| 在线电影欧美成精品| 久久综合久久综合久久| 欧美韩国日本综合| 有码一区二区三区| 三级亚洲高清视频|