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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? guialloc.c

?? 在純DOS下運行的TurboC3_ucos2_ucgui bug改進版本
?? C
字號:
/*
*********************************************************************************************************
*                                                uC/GUI
*                        Universal graphic software for embedded applications
*
*                       (c) Copyright 2002, Micrium Inc., Weston, FL
*                       (c) Copyright 2002, SEGGER Microcontroller Systeme GmbH
*
*              礐/GUI is protected by international copyright laws. Knowledge of the
*              source code may not be used to write a similar product. This file may
*              only be used in accordance with a license and should not be redistributed
*              in any way. We appreciate your understanding and fairness.
*
----------------------------------------------------------------------
File        : GUIAlloc.C
Purpose     : emWin dynamic memory management
----------------------------------------------------------------------
Version-Date---Author-Explanation
----------------------------------------------------------------------
1.00    000107 RS     First version
----------------------------------------------------------------------
Known problems:
None.
----------------------------------------------------------------------
Open issues:
None.
----------------------------------------------------------------------
Todo:
Nothing.

*/

#include "headers.h"
#include <stddef.h>           // needed for definition of NULL 
#include <string.h>           // for memcpy, memset 

#include "GProtect.H"
#include "GUIDebug.h"

#if GUI_ALLOC_SIZE==0
  #error GUI_ALLOC_SIZE needs to be > 0 when using this module
#endif
/*
  *****************************************************************
  *
  *              Config defaults
  *
  *****************************************************************
*/

// Permit automatic defragmentation when necessary 
#ifndef GUI_ALLOC_AUTDEFRAG
  #define GUI_ALLOC_AUTDEFRAG 1
#endif

#ifndef GUI_BLOCK_ALIGN
  #define GUI_BLOCK_ALIGN 2    // 2 means 4 bytes, 1 means 2 bytes 
                              // 1 can be used on 16-bit CPUs and
                              //   CPUs which do not require aligned
                              //   32-bit values (such as x86)  
#endif

#ifndef GUI_MAXBLOCKS
  #define GUI_MAXBLOCKS (2+GUI_ALLOC_SIZE/32)
#endif


/*
  *****************************************************************
  *
  *              Internal types and declarations
  *
  *****************************************************************
*/
#if GUI_ALLOC_SIZE <32767
  #define tALLOCINT I16
#else
  #define tALLOCINT I32
#endif

#if GUI_MAXBLOCKS >= 256
  #define HANDLE U16
#else
  #define HANDLE U8
#endif




typedef struct {
  tALLOCINT Off;       // Offset of memory area 
  tALLOCINT Size;      // usable size of allocated block 
  HANDLE Next;      // next handle in linked list 
  HANDLE Prev;
} tBlock;

/****************************************************************
*
*              Static data
*
*****************************************************************
*/

GUI_HEAP GUI_Heap;       // Public for debugging only 
static tBlock aBlock[GUI_MAXBLOCKS];

struct {
  int       NumUsedBlocks, NumFreeBlocks, NumFreeBlocksMin;        // For statistical purposes only 
  tALLOCINT NumUsedBytes,  NumFreeBytes,  NumFreeBytesMin;
} GUI_ALLOC;

static char   IsInitialized =0;

/*
  ********************************************************************
  *
  *                 Macros for internal use
  *
  ********************************************************************
*/

#define Min(v0,v1) ((v0>v1) ? v1 : v0)
#define Max(v0,v1) ((v0>v1) ? v0 : v1)
#define ASSIGN_IF_LESS(v0,v1) if (v1<v0) v0=v1
#define HMEM2PTR(hMem) (void*)&GUI_Heap.abHeap[aBlock[hMem].Off]


/*
  ********************************************************************
  *
  *                    Internal routines
  *
  ********************************************************************
*/


/*
  *************************************************
  *
  *                 Size2LegalSize
  *
  *************************************************

  returns: Legal allocation size
*/

static int Size2LegalSize(int size) {
  return (size + ((1<<GUI_BLOCK_ALIGN)-1)) & ~((1<<GUI_BLOCK_ALIGN)-1);
}
  
/*
  *************************************************
  *
  *                 FindFreeHandle
  *
  *************************************************

  returns: Free handle
*/

static GUI_HMEM FindFreeHandle(void) {
  int i;
  for (i=1; i< GUI_MAXBLOCKS; i++) {
    if (aBlock[i].Size ==0)
	  return i;
  }
  //GUI_DEBUG_ERROROUT1("Insufficient memory handles configured (GUI_MAXBLOCKS == %d (See GUIConf.h))", GUI_MAXBLOCKS);
  return GUI_HMEM_NULL;
}


/*
  *************************************************
  *
  *               Find hole in heap area
  *
  *************************************************

  returns: Offset to the memory hole (if available)
           -1 if not available
*/


static GUI_HMEM FindHole(int Size) {
  int i, iNext;
  for (i=0; (iNext = aBlock[i].Next) != 0; i = iNext) {
    int NumFreeBytes = aBlock[iNext].Off- (aBlock[i].Off+aBlock[i].Size);
    if (NumFreeBytes>=Size)
      return i;
  }
// Check last block 
  if (GUI_ALLOC_SIZE - (aBlock[i].Off+aBlock[i].Size) >= Size)
    return i;
  return -1;
}

/*
  *************************************************
  *
  *             Create hole in heap area
  *
  *************************************************

  returns: Offset to the memory hole (if available)
           -1 if not available
*/


static GUI_HMEM CreateHole(int Size) {
  int i, iNext;
  int r = -1;
  for (i=0; (iNext =aBlock[i].Next) !=0; i= iNext) {
    int NumFreeBytes = aBlock[iNext].Off- (aBlock[i].Off+aBlock[i].Size);
    if (NumFreeBytes < Size) {
      int NumBytesBeforeBlock = aBlock[iNext].Off - (aBlock[i].Off+aBlock[i].Size);
      if (NumBytesBeforeBlock) {
        U8* pData = &GUI_Heap.abHeap[aBlock[iNext].Off];
        memmove(pData-NumBytesBeforeBlock, pData, aBlock[iNext].Size);
        aBlock[iNext].Off -=NumBytesBeforeBlock;
      }
    }
  }
// Check last block 
  if (GUI_ALLOC_SIZE - (aBlock[i].Off+aBlock[i].Size) >= Size)
    r = i;
  return r;
}


static void CheckInit(void) {
  if (!IsInitialized)
    GUI_ALLOC_Init();
}


/*
  ********************************************************************
  *
  *                  Exported routines
  *
  ********************************************************************
*/


void GUI_ALLOC_Init(void) {
  //GUI_DEBUG_LOG("\nGUI_ALLOC_Init...");
  GUI_ALLOC.NumFreeBlocksMin = GUI_ALLOC.NumFreeBlocks = GUI_MAXBLOCKS-1;
  GUI_ALLOC.NumFreeBytesMin  = GUI_ALLOC.NumFreeBytes  = GUI_ALLOC_SIZE;
  GUI_ALLOC.NumUsedBlocks = 0;
  GUI_ALLOC.NumUsedBytes = 0;
  aBlock[0].Size = (1<<GUI_BLOCK_ALIGN);  // occupy minimum for a block 
  aBlock[0].Off  = 0;
  aBlock[0].Next = 0;
  IsInitialized =1;
}


static GUI_HMEM _Alloc(int size) {
  GUI_HMEM hMemNew, hMemIns;
  CheckInit();
  size = Size2LegalSize(size);
  // Check if memory is available at all ...
  if (size > GUI_ALLOC.NumFreeBytes) {
    //GUI_DEBUG_WARN1("GUI_ALLOC_Alloc: Insufficient memory configured (Trying to alloc % bytes)", size);
    return 0;
  }
  // Locate free handle 
  if ((hMemNew = FindFreeHandle()) == 0)
    return 0;
  // Locate or Create hole of sufficient size 
  hMemIns = FindHole(size);
  #if GUI_ALLOC_AUTDEFRAG
    if (hMemIns == -1) {
      hMemIns = CreateHole(size);
    }
  #endif
// Occupy hole 
  if (hMemIns==-1) {
    //GUI_DEBUG_ERROROUT1("GUI_ALLOC_Alloc: Could not allocate %d bytes",size);
    return 0;
	}
  {
    int Off = aBlock[hMemIns].Off+aBlock[hMemIns].Size;
    int Next = aBlock[hMemIns].Next;
    aBlock[hMemNew].Size  = size;
    aBlock[hMemNew].Off   = Off;
    if ((aBlock[hMemNew].Next  = Next) >0) {
      aBlock[Next].Prev = hMemNew;  
    }
    aBlock[hMemNew].Prev  = hMemIns;
    aBlock[hMemIns].Next  = hMemNew;
  }
// Keep track of number of blocks and av. memory 
  GUI_ALLOC.NumUsedBlocks++;
  GUI_ALLOC.NumFreeBlocks--;
  if (GUI_ALLOC.NumFreeBlocksMin > GUI_ALLOC.NumFreeBlocks) {
    GUI_ALLOC.NumFreeBlocksMin = GUI_ALLOC.NumFreeBlocks;
  }
  GUI_ALLOC.NumUsedBytes += size;
  GUI_ALLOC.NumFreeBytes -= size;
  if (GUI_ALLOC.NumFreeBytesMin > GUI_ALLOC.NumFreeBytes) {
    GUI_ALLOC.NumFreeBytesMin = GUI_ALLOC.NumFreeBytes;
  }
// In order to be on the safe side, zeroinit ! 
  memset(HMEM2PTR(hMemNew), 0, size);
  return hMemNew;
}



GUI_HMEM GUI_ALLOC_Alloc(int size) {
  GUI_HMEM hMem;
 // First make sure that init has been called
  GUI_LOCK();
  //GUI_DEBUG_LOG2("\nGUI_ALLOC_Alloc... requesting %d, %d avail", size, GUI_ALLOC.NumFreeBytes);
  hMem = _Alloc(size);
  //GUI_DEBUG_LOG1("\nGUI_ALLOC_Alloc : Handle", hMem);
  GUI_UNLOCK();
  return hMem;
}

void GUI_ALLOC_Free(GUI_HMEM hMem) {
  int Size;
  if (hMem == GUI_HMEM_NULL)  // Note: This is not an error, it is permitted
    return;
  GUI_LOCK();
  //GUI_DEBUG_LOG1("\nGUI_ALLOC_Free(%d)", hMem);
  // Do some error checking ...
  #if GUI_DEBUG_LEVEL>0
    // Block not allocated ?
    if (aBlock[hMem].Size==0) {
      //GUI_DEBUG_ERROROUT("GUI_ALLOC_Free(): Invalid hMem");
      return;
    }
  #endif
  Size = aBlock[hMem].Size;
  #ifdef WIN32
    memset(&GUI_Heap.abHeap[aBlock[hMem].Off], 0xcc, Size);
  #endif
  GUI_ALLOC.NumFreeBytes += Size;
  GUI_ALLOC.NumUsedBytes -= Size;
  aBlock[hMem].Size = 0;
  {
    int Next = aBlock[hMem].Next;
    int Prev = aBlock[hMem].Prev;
    aBlock[Prev].Next = Next;
    if (Next)
      aBlock[Next].Prev = Prev;
  }
  GUI_ALLOC.NumFreeBlocks++;
  GUI_ALLOC.NumUsedBlocks--;
  GUI_UNLOCK();
}

void*       GUI_ALLOC_h2p   (GUI_HMEM  hMem) {
  #if GUI_DEBUG_LEVEL>0
    if (!hMem) {
      //GUI_DEBUG_ERROROUT("\n"__FILE__ " GUI_ALLOC_h2p: illegal argument (0 handle)");
      return 0;
    }
  #endif
  return HMEM2PTR(hMem);
}


void GUI_ALLOC_FreePtr(GUI_HMEM *ph) {
  GUI_LOCK();
  GUI_ALLOC_Free(*ph);
  *ph =0;
  GUI_UNLOCK();
}

/*
  ********************************************************************
  *
  *                  Exported info routines
  *
  ********************************************************************
*/
/*
int GUI_GetUsedMem(void) {
  int NumUsedBytes=0;
  int i;
  GUI_LOCK();
  CheckInit();
  for (i=1; i; i = aBlock[i].Next) {
    NumUsedBytes += aBlock[i].Size;
  }
  GUI_UNLOCK();
  return NumUsedBytes;
}


int GUI_ALLOC_GetNumFreeBytes(void) {
  CheckInit();
  return GUI_ALLOC.NumFreeBytes;  
}
*/

/*
  *************************************************
  *
  *       GetMaxSize
  *
  *************************************************

  Returns the biggest available blocksize
  (without relocation)

*/
/*
int GUI_ALLOC_GetMaxSize(void) {
  int r=0;
  int NumFreeBytes;
  int i, iNext;
  GUI_LOCK();
  CheckInit();
  for (i=0; (iNext =aBlock[i].Next) !=0; i= iNext) {
    NumFreeBytes = aBlock[iNext].Off- (aBlock[i].Off+aBlock[i].Size);
    if (NumFreeBytes > r) {
      r = NumFreeBytes;
    }
  }
// Check last block 
  NumFreeBytes = (GUI_ALLOC_SIZE - (aBlock[i].Off+aBlock[i].Size));
  if (NumFreeBytes > r) {
    r = NumFreeBytes;
  }
  GUI_UNLOCK();
  return r;
}
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
老鸭窝一区二区久久精品| 国产激情视频一区二区在线观看| 香蕉久久夜色精品国产使用方法| 日本午夜精品视频在线观看| 久久69国产一区二区蜜臀| 成人高清免费观看| 欧美精品第1页| 国产色91在线| 亚洲精品va在线观看| 老司机精品视频在线| aaa欧美日韩| 91精品国产色综合久久久蜜香臀| 国产嫩草影院久久久久| 亚洲国产精品久久艾草纯爱| 国产毛片一区二区| 欧美日韩亚洲不卡| 欧美高清一级片在线观看| 五月激情综合婷婷| www.色精品| 日韩三级在线免费观看| 亚洲欧美日韩人成在线播放| 久久精品国产亚洲一区二区三区| 91蜜桃免费观看视频| 欧美精品一区二区三区视频| 亚洲一区二区五区| 成人免费视频视频| 欧美一级爆毛片| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲靠逼com| 久久99深爱久久99精品| 91亚洲精华国产精华精华液| 日韩免费电影一区| 亚洲第一激情av| 99久久伊人网影院| 久久久久久久久久久电影| 亚洲观看高清完整版在线观看| 国产91精品一区二区麻豆亚洲| 欧美日韩国产成人在线免费| 成人免费在线观看入口| 国产成人啪午夜精品网站男同| 在线日韩国产精品| 国产精品毛片无遮挡高清| 日本伊人色综合网| 国产亚洲综合在线| 午夜久久电影网| 亚洲va韩国va欧美va| 国产一区二区三区美女| 欧美xxxx在线观看| 99久久国产综合精品女不卡 | 欧美极品aⅴ影院| 国产精品久久久久久久久搜平片 | 日韩欧美在线网站| 亚洲成人自拍偷拍| 欧美三级中文字| 亚洲欧洲精品一区二区三区| 国产精品69久久久久水密桃| 精品奇米国产一区二区三区| 青青草视频一区| 在线视频欧美区| 一区二区久久久久久| 一本久久综合亚洲鲁鲁五月天 | 久久久久久久久97黄色工厂| 欧美日韩久久久| 中文字幕国产一区| 国产精品91一区二区| 久久品道一品道久久精品| 国产真实乱偷精品视频免| 欧美va亚洲va香蕉在线| 精品制服美女丁香| 精品99久久久久久| 久久成人免费日本黄色| 日韩欧美电影一区| 老司机精品视频线观看86 | 蜜桃视频一区二区| 日韩亚洲欧美在线| 麻豆91免费观看| 日韩你懂的在线观看| 激情欧美一区二区三区在线观看| 精品理论电影在线| 国产精品中文字幕欧美| 国产蜜臀av在线一区二区三区| 国产成人午夜精品影院观看视频 | 99re视频这里只有精品| 亚洲女厕所小便bbb| 欧洲人成人精品| 五月天一区二区| 欧美一二三四区在线| 精品中文字幕一区二区小辣椒| 久久影视一区二区| 成人app网站| 一区二区三区欧美亚洲| 欧美精品粉嫩高潮一区二区| 蜜桃av噜噜一区二区三区小说| 精品国产乱码久久| 成人小视频免费观看| 亚洲精品伦理在线| 欧美一区二区福利视频| 国产精品123区| 亚洲精品国产无天堂网2021 | 日韩国产精品91| 欧美本精品男人aⅴ天堂| 国产成人av影院| 亚洲精品国产精华液| 7777精品伊人久久久大香线蕉完整版 | 国产一区二区三区国产| 中文成人av在线| 色狠狠桃花综合| 青青草国产精品97视觉盛宴| 久久夜色精品国产欧美乱极品| av中文字幕不卡| 亚洲不卡一区二区三区| 精品国产伦一区二区三区免费| 国产成人av电影在线观看| 亚洲免费毛片网站| 日韩一级在线观看| www.色精品| 天天操天天色综合| 久久精品视频免费| 在线观看日韩一区| 国产麻豆视频精品| 一区二区三区四区在线播放 | 国产成a人亚洲精| 午夜精品aaa| 国产丝袜欧美中文另类| 欧美日韩五月天| 福利视频网站一区二区三区| 亚洲成av人片在线观看无码| 国产亚洲成aⅴ人片在线观看 | 日韩一区精品视频| 欧美国产精品中文字幕| 欧美日韩第一区日日骚| 国产v综合v亚洲欧| 青青草精品视频| 亚洲女人小视频在线观看| 精品国内二区三区| 欧美在线色视频| 国产白丝精品91爽爽久久| 日韩av在线发布| 亚洲美女免费视频| 国产亚洲综合在线| 日韩一级免费观看| 欧美性大战久久| 99久免费精品视频在线观看| 激情深爱一区二区| 丝瓜av网站精品一区二区| 亚洲欧洲国产日韩| 国产偷国产偷精品高清尤物| 欧美一激情一区二区三区| 色哟哟日韩精品| 成人手机电影网| 久久国产尿小便嘘嘘尿| 亚洲国产成人av网| 亚洲欧洲www| 中文字幕不卡的av| 欧美一级在线免费| 欧美丝袜丝交足nylons| 99久久精品情趣| 国产999精品久久久久久绿帽| 蜜臀精品一区二区三区在线观看| 夜夜嗨av一区二区三区中文字幕| 国产精品毛片久久久久久久| 久久久久久久国产精品影院| 欧美一区二区在线视频| 欧美日韩另类国产亚洲欧美一级| 91香蕉视频污| 99天天综合性| 成人av先锋影音| 成人免费高清在线| 在线视频观看一区| 97久久精品人人做人人爽50路| 国产91综合一区在线观看| 国产乱子伦一区二区三区国色天香 | 成人av资源在线| 国产91精品一区二区麻豆亚洲| 国产在线播放一区| 国产在线日韩欧美| 国产一区欧美日韩| 精品一区二区久久| 久久国产综合精品| 精品一区二区三区免费播放| 男女激情视频一区| 久久狠狠亚洲综合| 韩国av一区二区三区| 国产精品一二三区在线| 国产精品亚洲一区二区三区在线| 久久9热精品视频| 国产美女精品一区二区三区| 国产一区二区成人久久免费影院 | 国产精品丝袜久久久久久app| 国产日韩欧美电影| 国产精品乱人伦中文| 综合av第一页| 亚洲国产综合视频在线观看| 午夜精品久久久久久久久久| 日韩va亚洲va欧美va久久| 美女视频黄 久久| 国产毛片精品国产一区二区三区| 成人性生交大片免费看在线播放| 不卡一区二区中文字幕| 一本在线高清不卡dvd|