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

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

?? memalloc.c

?? zigbee 2004協(xié)議棧
?? C
字號(hào):
/*
 *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





?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品麻豆日日躁夜夜躁| 国产美女一区二区三区| 99在线精品视频| 国产欧美日韩另类一区| 久久www免费人成看片高清| 成人av资源网站| 成人免费在线观看入口| 91蜜桃婷婷狠狠久久综合9色| 91精品国产入口| 亚洲一区中文日韩| 欧美日韩国产首页在线观看| 亚洲国产另类av| 91精品国产一区二区| 日本三级亚洲精品| 精品国产污网站| 国产69精品久久久久777| 欧美一区二区三区成人| 日韩va欧美va亚洲va久久| 91精品国产入口| 国产一区福利在线| 亚洲国产电影在线观看| 99久久国产综合精品女不卡| 亚洲人xxxx| 在线播放中文一区| 美女脱光内衣内裤视频久久网站 | 精品国产免费人成在线观看| 美日韩黄色大片| 久久久久久一二三区| 国产很黄免费观看久久| 亚洲少妇中出一区| 欧美日韩在线免费视频| 老司机精品视频在线| 久久精品一区二区| 91免费版pro下载短视频| 亚洲国产精品人人做人人爽| 日韩午夜激情免费电影| 粗大黑人巨茎大战欧美成人| 一区二区不卡在线视频 午夜欧美不卡在| 欧美日韩免费电影| 国内国产精品久久| 亚洲激情图片qvod| 日韩精品一区二区三区中文不卡| 精品制服美女丁香| 国产蜜臀97一区二区三区 | 免费高清不卡av| 中文字幕精品三区| 欧美一区中文字幕| 国产综合色视频| 亚洲电影第三页| 欧美国产日产图区| 欧美精品乱码久久久久久按摩| 国产成人精品在线看| 亚洲成人先锋电影| 国产精品久久看| 6080yy午夜一二三区久久| 成人av资源在线观看| 毛片不卡一区二区| 亚洲精品国产一区二区精华液| www日韩大片| 欧美xxx久久| 日韩一区二区在线观看| 欧美日韩精品一区视频| 欧美中文字幕亚洲一区二区va在线| 成人免费的视频| 成人午夜av在线| 高清视频一区二区| 国产伦精品一区二区三区在线观看| 日本vs亚洲vs韩国一区三区二区| 亚洲国产精品久久久男人的天堂| 中文字幕中文在线不卡住| 国产日韩欧美精品综合| 久久综合国产精品| 久久婷婷综合激情| 日本一区二区成人在线| 中文字幕中文字幕一区| 中文字幕在线不卡一区| 国产精品成人网| 亚洲精品视频一区| 亚洲国产成人精品视频| 综合av第一页| 亚洲一二三四在线| 日韩国产精品久久久| 男女男精品视频| 久久99热这里只有精品| 国产精品一区在线观看乱码 | 亚洲高清免费视频| 日韩激情一二三区| 精品在线播放免费| 丁香另类激情小说| 色噜噜久久综合| 91精品国产综合久久婷婷香蕉| 91精品国产高清一区二区三区蜜臀 | 亚洲天堂福利av| 亚洲免费观看高清完整版在线观看熊 | 国产精品久久久久桃色tv| 亚洲人123区| 天天亚洲美女在线视频| 免费在线观看不卡| 久久精品国产99国产| 岛国精品一区二区| 欧美亚洲丝袜传媒另类| 日韩精品一区二区在线| 国产精品久久久久久久久图文区 | 2020国产精品久久精品美国| 国产女人aaa级久久久级| 亚洲美女屁股眼交| 蜜臀a∨国产成人精品| 国产成人福利片| 91久久一区二区| 欧美一级专区免费大片| 中文字幕精品一区二区精品绿巨人| 尤物在线观看一区| 精品一区二区三区在线播放视频| 大尺度一区二区| 欧美视频一区二区三区| 久久久夜色精品亚洲| 亚洲一区二区三区四区在线观看| 精品亚洲porn| 91久久国产综合久久| 精品国产一区二区三区四区四| 最新高清无码专区| 美女视频一区二区三区| 一本久久a久久免费精品不卡| 日韩精品中文字幕一区二区三区| 亚洲欧洲日韩av| 另类中文字幕网| 欧美在线免费视屏| 国产精品午夜在线| 美女视频免费一区| 91精彩视频在线| 国产女人18水真多18精品一级做| 视频一区中文字幕国产| 99精品视频在线免费观看| 久久综合中文字幕| 日韩国产欧美在线观看| 91欧美一区二区| 国产婷婷色一区二区三区四区| 亚洲成精国产精品女| 91亚洲精品久久久蜜桃| 精品乱人伦小说| 午夜成人免费视频| 色香蕉久久蜜桃| 国产精品夫妻自拍| 国产精品 日产精品 欧美精品| 欧美一卡在线观看| 午夜av电影一区| 色一区在线观看| 亚洲特黄一级片| 国产91色综合久久免费分享| 日韩欧美区一区二| 午夜精品久久久久久久久久久| 色婷婷精品久久二区二区蜜臂av| 久久久av毛片精品| 黄页网站大全一区二区| 91麻豆精品国产综合久久久久久| 亚洲永久免费视频| 在线免费亚洲电影| 亚洲精品久久久蜜桃| av电影在线观看一区| 亚洲欧洲精品一区二区精品久久久 | 不卡高清视频专区| 国产亚洲精品中文字幕| 国产在线观看免费一区| 精品免费视频.| 国产一区二三区| 久久久久久久久久久久久女国产乱 | 日韩一区在线播放| 成人美女视频在线观看18| 国产日韩精品一区二区三区| 国产精品一区二区黑丝| 国产三级精品三级| 成人黄色电影在线| 亚洲欧美在线观看| 在线一区二区视频| 图片区小说区区亚洲影院| 欧美另类久久久品| 久久国产综合精品| 久久久不卡网国产精品一区| 粉嫩av亚洲一区二区图片| 国产精品传媒视频| 欧美日韩亚州综合| 九色|91porny| 国产欧美久久久精品影院| 欧美日韩国产在线播放网站| 亚洲一区二区中文在线| 91精品免费在线| 国产ts人妖一区二区| 亚洲欧洲日本在线| 欧美肥妇free| 国产盗摄一区二区| ...xxx性欧美| 欧美日韩情趣电影| 国内外精品视频| 亚洲丝袜自拍清纯另类| 欧美高清dvd| 国产成a人亚洲| 亚洲第四色夜色| 26uuu精品一区二区| 97久久超碰精品国产| 日韩国产欧美在线播放|