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

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

?? memalloc.c

?? ZIGBEE2006協議棧
?? C
字號:
/*
 *2006/08/16 WXL 2.0
 *
 */

/*
V0.2 added PC-based binding         21/July/2006
V0.1 Initial Release                10/July/2006
*/



#include "compiler.h"               //compiler specific
#include <string.h>                 // has memset function
#include "lrwpan_config.h"
#include "hal.h"        //for global interrupt enable/disable
#include "halStack.h"
#include "console.h"
#include "debug.h"
#include "memalloc.h"




//LRWPAN_HEAPSIZE must be < 64K, can allocate blocks up to this size
// format of block is
// free bit/15 bit size block_UINT8s | free bit/15 bit size block_UINT8s | etc..
// heap merging done on FREE, free adjacent blocks are merged.



//static UINT8 mem_heap[LRWPAN_HEAPSIZE];
#include "halHeapSpace.h"

typedef UINT16 MEMHDR;

#define MEMHDR_FREE_MASK 0x80
#define MEMHDR_SIZE_MASK 0x7FFF

#define MEMHDR_GET_FREE(x) (*(x+1)&MEMHDR_FREE_MASK)
#define MEMHDR_CLR_FREE(x)  *(x+1) = *(x+1)&(~MEMHDR_FREE_MASK)
#define MEMHDR_SET_FREE(x)  *(x+1) = *(x+1)|MEMHDR_FREE_MASK


UINT16 memhdr_get_size (UINT8 *ptr) {
	UINT16 x;

	x = (UINT8) *ptr;
	x += ((UINT16) *(ptr+1)<< 8);
	x = x & 0x7FFF;
	return(x);
}

void memhdr_set_size (UINT8 *ptr, UINT16 size) {

	*ptr = (UINT8) size;
	ptr++;
	*ptr = *ptr & 0x80;  //clear size field
	*(ptr) += (size >> 8);  //add in size.
}


#if 0
typedef struct _MEMHDR {
    UINT16 val;

    unsigned int free:1;
	unsigned int size:15;	
}MEMHDR;
#endif


#define MINSIZE 16+sizeof(MEMHDR)


void MemInit (void) {
	memset(mem_heap,0,LRWPAN_HEAPSIZE);
	MEMHDR_SET_FREE(((UINT8 *)&mem_heap[0]));
    memhdr_set_size(((UINT8 *)&mem_heap[0]),(LRWPAN_HEAPSIZE - sizeof(MEMHDR)));
}

UINT8 * MemAlloc (UINT16 size) {

	UINT8 *free_blk, *next_blk;
	UINT16 offset;
	UINT16 remainder;
        BOOL  gie_status;



    if (!size) return(NULL);      //illegal size
	if (size < MINSIZE) size = MINSIZE;

        SAVE_AND_DISABLE_GLOBAL_INTERRUPT(gie_status);
	free_blk = mem_heap;
	offset = 0;
	while (1) {
		if (MEMHDR_GET_FREE(((UINT8 *)free_blk)) &&
			(memhdr_get_size((UINT8 *)free_blk) >= size)) break; //found block
		//advance to next block
		offset = offset + memhdr_get_size((UINT8 *)free_blk) + sizeof(MEMHDR);
                if (offset >= LRWPAN_HEAPSIZE) {
                  DEBUG_CHAR( DBG_ERR,DBG_CHAR_MEMFULL  );
                  RESTORE_GLOBAL_INTERRUPT(gie_status);
                  return(NULL); // no free blocks
                }
		free_blk = mem_heap + offset;
	}
	remainder =  memhdr_get_size((UINT8 *)free_blk) - size;
	if (remainder < MINSIZE) {
		//found block, mark as not-free
		MEMHDR_CLR_FREE((UINT8 *)free_blk);
        RESTORE_GLOBAL_INTERRUPT(gie_status);
		return(free_blk + sizeof(MEMHDR));
	}
	//remainder is large enough to support a new block
	//adjust allocated block to requested size
	memhdr_set_size(((UINT8 *)free_blk),size);
	//format next blk
	next_blk = free_blk+size+sizeof(MEMHDR);
	MEMHDR_SET_FREE((UINT8 *) next_blk);
	memhdr_set_size(((UINT8 *) next_blk), (remainder - sizeof(MEMHDR)));

	MEMHDR_CLR_FREE((UINT8 *)free_blk); //mark allocated block as non-free
    RESTORE_GLOBAL_INTERRUPT(gie_status);
	return(free_blk + sizeof(MEMHDR));      //return new block
}

void MemFree(UINT8 *ptr) {
	UINT8 *hdr;
	UINT16 offset, tmp;
        BOOL  gie_status;


    if (ptr == NULL) return;
    SAVE_AND_DISABLE_GLOBAL_INTERRUPT(gie_status);
	hdr = ptr - sizeof(MEMHDR);
	//free this block
	MEMHDR_SET_FREE((UINT8 *)hdr);
	//now merge
	offset = 0;
	hdr = mem_heap;
	//loop until blocks that can be merged are merged
	while (1) {
		if (MEMHDR_GET_FREE((UINT8 *)hdr)) {
			//found a free block, see if we can merge with next block
			tmp = offset +  memhdr_get_size((UINT8 *)hdr) + sizeof(MEMHDR);
			if (tmp >= LRWPAN_HEAPSIZE) break; //at end of heap, exit loop
			ptr = mem_heap + tmp; //point at next block
			if (MEMHDR_GET_FREE((UINT8 *)ptr)) {
				//next block is free, do merge by adding size of next block
	            memhdr_set_size(((UINT8 *)hdr),(memhdr_get_size((UINT8 *)hdr)+ memhdr_get_size((UINT8 *)ptr)
					                            + sizeof(MEMHDR)));
				// after merge, do not change offset, try to merge again
				//next time through loop
				continue; //back to top of loop
			}			
		}
		// next block
		offset = offset + memhdr_get_size((UINT8 *)hdr) + sizeof(MEMHDR);
		if (offset >= LRWPAN_HEAPSIZE) break;  //at end of heap, exit loop
		hdr = mem_heap + offset;
	}
	 RESTORE_GLOBAL_INTERRUPT(gie_status);
}

#ifdef LRWPAN_COMPILER_NO_RECURSION

//this supports the HI-TECH compiler, which does not support recursion

UINT16 ISR_memhdr_get_size (UINT8 *ptr) {
	UINT16 x;

	x = (UINT8) *ptr;
	x += ((UINT16) *(ptr+1)<< 8);
	x = x & 0x7FFF;
	return(x);
}

void ISR_memhdr_set_size (UINT8 *ptr, UINT16 size) {

	*ptr = (UINT8) size;
	ptr++;
	*ptr = *ptr & 0x80;  //clear size field
	*(ptr) += (size >> 8);  //add in size.
}



UINT8 * ISRMemAlloc (UINT16 size) {

	UINT8 *free_blk, *next_blk;
	UINT16 offset;
	UINT16 remainder;
        BOOL  gie_status;



        if (!size) return(NULL);      //illegal size
	if (size < MINSIZE) size = MINSIZE;

        SAVE_AND_DISABLE_GLOBAL_INTERRUPT(gie_status);
	free_blk = mem_heap;
	offset = 0;
	while (1) {
		if (MEMHDR_GET_FREE(((UINT8 *)free_blk)) &&
			(ISR_memhdr_get_size((UINT8 *)free_blk) >= size)) break; //found block
		//advance to next block
		offset = offset + ISR_memhdr_get_size((UINT8 *)free_blk) + sizeof(MEMHDR);
                if (offset >= LRWPAN_HEAPSIZE) {
                  DEBUG_CHAR( DBG_ERR,DBG_CHAR_MEMFULL  );
                  RESTORE_GLOBAL_INTERRUPT(gie_status);
                  return(NULL); // no free blocks
                }
		free_blk = mem_heap + offset;
	}
	remainder =  ISR_memhdr_get_size((UINT8 *)free_blk) - size;
	if (remainder < MINSIZE) {
		//found block, mark as not-free
		MEMHDR_CLR_FREE((UINT8 *)free_blk);
        RESTORE_GLOBAL_INTERRUPT(gie_status);
		return(free_blk + sizeof(MEMHDR));
	}
	//remainder is large enough to support a new block
	//adjust allocated block to requested size
	ISR_memhdr_set_size(((UINT8 *)free_blk),size);
	//format next blk
	next_blk = free_blk+size+sizeof(MEMHDR);
	MEMHDR_SET_FREE((UINT8 *) next_blk);
	ISR_memhdr_set_size(((UINT8 *) next_blk), (remainder - sizeof(MEMHDR)));

	MEMHDR_CLR_FREE((UINT8 *)free_blk); //mark allocated block as non-free
    RESTORE_GLOBAL_INTERRUPT(gie_status);
	return(free_blk + sizeof(MEMHDR));      //return new block
}

void ISRMemFree(UINT8 *ptr) {
	UINT8 *hdr;
	UINT16 offset, tmp;
        BOOL  gie_status;


        SAVE_AND_DISABLE_GLOBAL_INTERRUPT(gie_status);
	hdr = ptr - sizeof(MEMHDR);
	//free this block
	MEMHDR_SET_FREE((UINT8 *)hdr);
	//now merge
	offset = 0;
	hdr = mem_heap;
	//loop until blocks that can be merged are merged
	while (1) {
		if (MEMHDR_GET_FREE((UINT8 *)hdr)) {
			//found a free block, see if we can merge with next block
			tmp = offset +  ISR_memhdr_get_size((UINT8 *)hdr) + sizeof(MEMHDR);
			if (tmp >= LRWPAN_HEAPSIZE) break; //at end of heap, exit loop
			ptr = mem_heap + tmp; //point at next block
			if (MEMHDR_GET_FREE((UINT8 *)ptr)) {
				//next block is free, do merge by adding size of next block
	            ISR_memhdr_set_size(((UINT8 *)hdr),(ISR_memhdr_get_size((UINT8 *)hdr)+ ISR_memhdr_get_size((UINT8 *)ptr)
					                            + sizeof(MEMHDR)));
				// after merge, do not change offset, try to merge again
				//next time through loop
				continue; //back to top of loop
			}			
		}
		// next block
		offset = offset + ISR_memhdr_get_size((UINT8 *)hdr) + sizeof(MEMHDR);
		if (offset >= LRWPAN_HEAPSIZE) break;  //at end of heap, exit loop
		hdr = mem_heap + offset;
	}
	 RESTORE_GLOBAL_INTERRUPT(gie_status);
}




#endif





#ifdef LRWPAN_DEBUG
//Dump Memory to see what it looks like
void MemDump(void) {
	UINT8 *hdr;
	UINT16 offset,j;

	offset = 0;
	j = 1;
	while (offset < LRWPAN_HEAPSIZE) {
		hdr = mem_heap+offset;
                conPrintROMString("Blk: ");
                conPrintUINT16(j);
                conPrintROMString("; offset: ");
                conPrintUINT16(offset);
                conPrintROMString(", Free:");
				if (MEMHDR_GET_FREE((UINT8 *)hdr)) {
                 conPrintROMString("Y ");
				}
				else {conPrintROMString("N ");
				}
                conPrintROMString(", Size: ");
                conPrintUINT16(memhdr_get_size((UINT8 *)hdr));
                conPrintROMString("\n");
		offset = offset + memhdr_get_size((UINT8 *)hdr)+ sizeof(MEMHDR);
		j++;

	}
}

#endif





?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品热视频| 成人午夜伦理影院| 欧美一区二区在线视频| 日韩av在线播放中文字幕| 91精品久久久久久久久99蜜臂| 日韩电影在线观看网站| 精品国产亚洲在线| 国产精品影音先锋| 一区二区三区自拍| 精品视频一区二区不卡| 九一久久久久久| 国产农村妇女精品| 91久久线看在观草草青青| 天天操天天干天天综合网| 精品久久久久99| 99精品热视频| 蜜臀av国产精品久久久久| 日本一区二区成人在线| 91国产免费观看| 韩国三级电影一区二区| 最新不卡av在线| 日韩一卡二卡三卡四卡| 风间由美一区二区av101| 亚洲精品亚洲人成人网在线播放| 91精品午夜视频| 成人国产视频在线观看| 午夜在线电影亚洲一区| 国产日韩精品一区二区三区在线| 在线观看网站黄不卡| 韩国精品久久久| 亚洲自拍偷拍麻豆| 国产欧美精品区一区二区三区| 91精品福利在线| 国产成人小视频| 日韩在线卡一卡二| 亚洲欧美偷拍另类a∨色屁股| 欧美一级黄色录像| 99re热视频精品| 国产九色sp调教91| 日本三级韩国三级欧美三级| 国产精品人成在线观看免费 | 成人激情开心网| 日韩1区2区3区| 亚洲欧美日韩国产手机在线 | 国产一区二区三区四区五区美女| 亚洲欧美经典视频| 国产日韩欧美精品电影三级在线| 777午夜精品免费视频| 91污片在线观看| 国产精品 欧美精品| 美腿丝袜亚洲综合| 亚洲国产精品综合小说图片区| 国产精品久久久久7777按摩| 精品播放一区二区| 日韩欧美国产1| 3d动漫精品啪啪| 欧美日韩国产高清一区二区| 日本高清不卡aⅴ免费网站| 成人深夜福利app| 国产一区二区精品久久99| 日本不卡1234视频| 日韩和欧美的一区| 午夜精品一区二区三区三上悠亚| 亚洲人成伊人成综合网小说| 国产精品视频九色porn| 欧美激情一区在线| 国产女人18毛片水真多成人如厕 | 风间由美中文字幕在线看视频国产欧美| 日韩电影免费在线观看网站| 亚洲成人久久影院| 亚洲国产一区二区在线播放| 亚洲高清不卡在线观看| 亚洲高清视频中文字幕| 亚洲妇熟xx妇色黄| 午夜精品一区二区三区三上悠亚| 亚洲一区在线看| 午夜欧美在线一二页| 亚洲国产aⅴ天堂久久| 日日夜夜免费精品视频| 天堂资源在线中文精品| 日日摸夜夜添夜夜添精品视频 | 一区二区三区在线免费视频| 中文字幕日韩一区| 亚洲九九爱视频| 亚洲与欧洲av电影| 日韩成人av影视| 极品少妇xxxx精品少妇| 国产精品亚洲人在线观看| 丰满少妇在线播放bd日韩电影| 成人在线视频首页| 色哟哟一区二区在线观看| 欧美日韩一区不卡| 精品国产免费人成电影在线观看四季| 2欧美一区二区三区在线观看视频| 久久久久久麻豆| 亚洲欧美电影院| 天天色综合成人网| 国产乱子伦视频一区二区三区| 成人福利视频在线| 欧美三级午夜理伦三级中视频| 91精品国产综合久久精品app | 欧美日韩美少妇| 精品精品国产高清a毛片牛牛| 国产欧美精品日韩区二区麻豆天美| 中文字幕中文乱码欧美一区二区| 亚洲精品欧美激情| 久久精品免费观看| 99精品欧美一区二区三区综合在线| 欧美综合天天夜夜久久| 欧美精品一区二区三区在线播放| 中文字幕一区二区三| 五月天中文字幕一区二区| 国产精品 日产精品 欧美精品| 一本大道综合伊人精品热热| 日韩欧美在线综合网| 1000精品久久久久久久久| 麻豆国产欧美一区二区三区| 99九九99九九九视频精品| 91精品国产一区二区| 亚洲色图清纯唯美| 黄色成人免费在线| 欧美唯美清纯偷拍| 欧美国产精品一区| 久久狠狠亚洲综合| 欧美午夜精品免费| 中文字幕国产精品一区二区| 日韩成人精品在线| 91国产福利在线| 国产精品久久久久永久免费观看| 日日摸夜夜添夜夜添国产精品| av亚洲精华国产精华精| 日韩精品一区二区三区在线观看| 亚洲精品免费在线播放| 国产精品1024| 精品国产一区二区三区久久久蜜月| 一区二区视频在线| 成人一道本在线| 精品99久久久久久| 秋霞国产午夜精品免费视频| 在线免费观看视频一区| 亚洲欧美综合色| 国产ts人妖一区二区| 精品国产一区二区三区久久久蜜月 | 日韩在线一区二区| 欧美色图天堂网| 亚洲免费伊人电影| www.欧美日韩国产在线| 国产欧美一区二区三区网站| 久久精品国产在热久久| 欧美一区二区在线看| 亚洲国产色一区| 欧美午夜精品久久久| 一区二区在线电影| 日本福利一区二区| 亚洲激情图片一区| 欧美综合一区二区三区| 一区二区在线观看视频| 91视频观看免费| 日韩毛片精品高清免费| av亚洲精华国产精华精华| 国产精品超碰97尤物18| av亚洲产国偷v产偷v自拍| 国产精品午夜久久| 99亚偷拍自图区亚洲| 专区另类欧美日韩| 日本韩国欧美一区二区三区| 樱桃国产成人精品视频| 在线观看免费视频综合| 亚洲1区2区3区视频| 亚洲欧美偷拍三级| 福利一区二区在线观看| 国产欧美日韩另类一区| 国产成人精品影视| 国产精品入口麻豆九色| 91原创在线视频| 一区二区三区影院| 在线不卡中文字幕| 久久99精品久久久| 国产欧美一区二区三区网站| 成人免费黄色在线| 亚洲精品你懂的| 91.麻豆视频| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲综合色区另类av| 欧美日韩中文国产| 久久精品72免费观看| 国产性色一区二区| 日本道免费精品一区二区三区| 午夜久久久久久久久| 久久综合狠狠综合| 91日韩在线专区| 日本欧美一区二区| 中文字幕 久热精品 视频在线| 不卡的av在线播放| 午夜久久久久久久久| 日韩欧美国产成人一区二区| 国产传媒欧美日韩成人| 洋洋成人永久网站入口| 欧美刺激脚交jootjob| 99久久精品久久久久久清纯|