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

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

?? guialloc.c

?? ucgui在44b0上移植
?? 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 <stddef.h>           /* needed for definition of NULL */
#include <string.h>           /* for memcpy, memset */

#include "GUI_Protected.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一区二区三区免费野_久草精品视频
成年人午夜久久久| 97久久人人超碰| 不卡在线视频中文字幕| 久久综合狠狠综合| 久久精品国产精品亚洲红杏 | 日韩欧美中文字幕公布| 国产精品乱码妇女bbbb| 国产精品亚洲人在线观看| 日韩限制级电影在线观看| 日韩经典一区二区| 日韩午夜在线播放| 黄色成人免费在线| 26uuu色噜噜精品一区| 麻豆成人91精品二区三区| 日韩欧美黄色影院| 国产在线播精品第三| 国产午夜精品福利| 成人91在线观看| 综合色中文字幕| 国产成人99久久亚洲综合精品| 亚洲精品一区二区三区影院| 韩国女主播一区| 国产精品三级在线观看| 97精品超碰一区二区三区| 亚洲天堂福利av| 欧美亚洲国产一区在线观看网站| 国产精品久久久久久久久图文区 | 国产成a人亚洲| 中文字幕第一页久久| 99久久久国产精品| 亚洲一区二区av在线| 日韩欧美一区二区三区在线| 久草在线在线精品观看| 国产拍欧美日韩视频二区| 国产在线精品免费| 国产精品国产三级国产aⅴ中文 | 精品久久久久久综合日本欧美| 日本成人在线不卡视频| 久久久久久久久岛国免费| 97久久精品人人澡人人爽| 亚洲资源中文字幕| 欧美不卡一区二区| 91浏览器在线视频| 日韩在线一二三区| 国产欧美一二三区| 欧美日韩在线观看一区二区 | 精品国产乱码久久久久久蜜臀 | 日韩欧美一区二区免费| 成人午夜私人影院| 午夜精品久久久久久久久久| 久久久久97国产精华液好用吗| 99re亚洲国产精品| 蜜臀av性久久久久蜜臀aⅴ流畅| 中文字幕一区二区三区四区不卡 | 亚洲一二三区在线观看| 日韩一区二区电影网| 色婷婷亚洲综合| 成人自拍视频在线| 国内精品久久久久影院色| 日韩精品成人一区二区三区| 亚洲欧美偷拍另类a∨色屁股| 国产三级欧美三级日产三级99| 欧美一区二区视频免费观看| 欧美三级电影网| 9久草视频在线视频精品| 国产麻豆精品在线| 精品亚洲成a人| 日本不卡中文字幕| 天天综合天天做天天综合| 亚洲国产成人va在线观看天堂| 亚洲欧美日韩在线不卡| 国产精品美女久久福利网站| 欧美激情中文字幕一区二区| 国产日本欧美一区二区| 欧美极品另类videosde| 欧美国产精品中文字幕| 国产午夜一区二区三区| 久久久久久电影| 欧美极品少妇xxxxⅹ高跟鞋 | 久久精品人人爽人人爽| 久久美女艺术照精彩视频福利播放| 欧美精品一区二区三区蜜桃视频| 欧美一区二视频| 日韩精品一区二区三区四区| 日韩免费性生活视频播放| 精品剧情v国产在线观看在线| 日韩欧美成人一区| 精品国产伦一区二区三区观看方式| 日韩欧美国产综合在线一区二区三区 | 99在线视频精品| 99国内精品久久| 色综合天天天天做夜夜夜夜做| 97超碰欧美中文字幕| 在线观看三级视频欧美| 制服视频三区第一页精品| 91精品国产一区二区人妖| 日韩一级免费观看| 国产午夜久久久久| 亚洲欧洲美洲综合色网| 亚洲国产日日夜夜| 久久66热re国产| 成人福利视频网站| 在线免费观看不卡av| 欧美日韩精品二区第二页| 日韩美女视频在线| 国产偷v国产偷v亚洲高清 | 中文字幕一区视频| 亚洲成人一区二区在线观看| 日本美女一区二区三区| 奇米一区二区三区| 国产精品亚洲成人| 欧美亚州韩日在线看免费版国语版| 欧美精品少妇一区二区三区| 欧美不卡在线视频| 亚洲另类中文字| 久久精品国产99久久6| 大美女一区二区三区| 欧美三级日韩在线| 久久免费国产精品| 亚洲风情在线资源站| 精品一区二区国语对白| 成人午夜av在线| 欧美日韩成人综合天天影院| 国产亚洲综合av| 亚洲1区2区3区视频| 丁香婷婷综合激情五月色| 欧美午夜精品电影| 国产亚洲一区二区三区在线观看 | 精品国产91亚洲一区二区三区婷婷| 国产精品乱码人人做人人爱 | 久久综合久色欧美综合狠狠| 亚洲欧美日韩精品久久久久| 久久se这里有精品| 色婷婷国产精品| 久久久影院官网| 日本不卡视频在线| 欧洲视频一区二区| 国产精品久久久久久久浪潮网站| 捆绑调教一区二区三区| 欧美日韩dvd在线观看| 亚洲免费观看高清完整版在线观看| 狠狠色丁香婷综合久久| 欧美精品视频www在线观看| 国产精品久久久久一区二区三区 | 久久免费电影网| 麻豆视频一区二区| 欧美曰成人黄网| 亚洲欧美综合在线精品| 成人一区二区在线观看| www激情久久| 麻豆成人91精品二区三区| 欧美日韩精品福利| 亚洲一级在线观看| 欧洲国产伦久久久久久久| 亚洲欧洲日韩综合一区二区| 国产成人免费xxxxxxxx| 久久久久久久久久美女| 国产综合色产在线精品| 精品久久一区二区| 美腿丝袜亚洲综合| 日韩一级在线观看| 蜜桃视频免费观看一区| 欧美一区二区视频网站| 日韩和欧美一区二区| 8v天堂国产在线一区二区| 丝袜美腿高跟呻吟高潮一区| 精品1区2区3区| 热久久免费视频| 欧美一区二区三区电影| 免费观看一级欧美片| 日韩欧美的一区| 国产综合色产在线精品| 国产日本一区二区| 成人激情黄色小说| 亚洲欧美日韩国产另类专区| 在线看日韩精品电影| 亚洲午夜一区二区| 欧美二区乱c少妇| 另类小说欧美激情| 久久久久久久精| 91美女视频网站| 亚洲国产日日夜夜| 欧美岛国在线观看| 国产精品88av| 国产精品家庭影院| 欧美视频中文字幕| 久久成人av少妇免费| 国产日韩精品一区二区三区| 9i看片成人免费高清| 亚洲一区视频在线观看视频| 制服丝袜亚洲精品中文字幕| 青青草视频一区| 日本一区二区三区视频视频| 99久久久精品| 婷婷国产v国产偷v亚洲高清| 日韩视频在线一区二区| 成人av中文字幕| 亚洲va欧美va天堂v国产综合| 日韩视频一区二区在线观看| 国产成人亚洲精品青草天美|