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

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

?? mem.c

?? STR71X源代碼包括例程與各功能的源代碼
?? C
字號(hào):
/** @file
 *
 * Dynamic memory manager
 *
 */

/* 
 * Copyright (c) 2001-2004 Swedish Institute of Computer Science.
 * All rights reserved. 
 * 
 * Redistribution and use in source and binary forms, with or without modification, 
 * are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions and the following disclaimer in the documentation
 *    and/or other materials provided with the distribution.
 * 3. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission. 
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 
 * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 
 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 
 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 
 * OF SUCH DAMAGE.
 *
 * This file is part of the lwIP TCP/IP stack.
 * 
 * Author: Adam Dunkels <adam@sics.se>
 *
 */

#include <string.h>

#include "lwip/arch.h"
#include "lwip/opt.h"
#include "lwip/def.h"
#include "lwip/mem.h"

#include "lwip/sys.h"

#include "lwip/stats.h"

struct mem {
  mem_size_t next, prev;
#if MEM_ALIGNMENT == 1
  u8_t used;
#elif MEM_ALIGNMENT == 2
  u16_t used;
#elif MEM_ALIGNMENT == 4
  u32_t used;
#elif MEM_ALIGNMENT == 8
  u64_t used;
#else
#error "unhandled MEM_ALIGNMENT size"
#endif /* MEM_ALIGNMENT */
}; 

static struct mem *ram_end;
static u8_t ram[MEM_SIZE + sizeof(struct mem) + MEM_ALIGNMENT];

#define MIN_SIZE 12
#if 0 /* this one does not align correctly for some, resulting in crashes */
#define SIZEOF_STRUCT_MEM (unsigned int)MEM_ALIGN_SIZE(sizeof(struct mem))
#else
#define SIZEOF_STRUCT_MEM (sizeof(struct mem) + \
                          (((sizeof(struct mem) % MEM_ALIGNMENT) == 0)? 0 : \
                          (4 - (sizeof(struct mem) % MEM_ALIGNMENT))))
#endif

static struct mem *lfree;   /* pointer to the lowest free block */

static sys_sem_t mem_sem;

static void
plug_holes(struct mem *mem)
{
  struct mem *nmem;
  struct mem *pmem;

  LWIP_ASSERT("plug_holes: mem >= ram", (u8_t *)mem >= ram);
  LWIP_ASSERT("plug_holes: mem < ram_end", (u8_t *)mem < (u8_t *)ram_end);
  LWIP_ASSERT("plug_holes: mem->used == 0", mem->used == 0);
  
  /* plug hole forward */
  LWIP_ASSERT("plug_holes: mem->next <= MEM_SIZE", mem->next <= MEM_SIZE);
  
  nmem = (struct mem *)&ram[mem->next];
  if (mem != nmem && nmem->used == 0 && (u8_t *)nmem != (u8_t *)ram_end) {
    if (lfree == nmem) {
      lfree = mem;
    }
    mem->next = nmem->next;
    ((struct mem *)&ram[nmem->next])->prev = (u8_t *)mem - ram;
  }

  /* plug hole backward */
  pmem = (struct mem *)&ram[mem->prev];
  if (pmem != mem && pmem->used == 0) {
    if (lfree == mem) {
      lfree = pmem;
    }
    pmem->next = mem->next;
    ((struct mem *)&ram[mem->next])->prev = (u8_t *)pmem - ram;
  }

}
void
mem_init(void)
{
  struct mem *mem;

  memset(ram, 0, MEM_SIZE);
  mem = (struct mem *)ram;
  mem->next = MEM_SIZE;
  mem->prev = 0;
  mem->used = 0;
  ram_end = (struct mem *)&ram[MEM_SIZE];
  ram_end->used = 1;
  ram_end->next = MEM_SIZE;
  ram_end->prev = MEM_SIZE;

  mem_sem = sys_sem_new(1);

  lfree = (struct mem *)ram;

#if MEM_STATS
  lwip_stats.mem.avail = MEM_SIZE;
#endif /* MEM_STATS */
}
void
mem_free(void *rmem)
{
  struct mem *mem;

  if (rmem == NULL) {
    LWIP_DEBUGF(MEM_DEBUG | DBG_TRACE | 2, ("mem_free(p == NULL) was called.\n"));
    return;
  }
  
  sys_sem_wait(mem_sem);

  LWIP_ASSERT("mem_free: legal memory", (u8_t *)rmem >= (u8_t *)ram &&
    (u8_t *)rmem < (u8_t *)ram_end);
  
  if ((u8_t *)rmem < (u8_t *)ram || (u8_t *)rmem >= (u8_t *)ram_end) {
    LWIP_DEBUGF(MEM_DEBUG | 3, ("mem_free: illegal memory\n"));
#if MEM_STATS
    ++lwip_stats.mem.err;
#endif /* MEM_STATS */
    sys_sem_signal(mem_sem);
    return;
  }
  mem = (struct mem *)((u8_t *)rmem - SIZEOF_STRUCT_MEM);

  LWIP_ASSERT("mem_free: mem->used", mem->used);
  
  mem->used = 0;

  if (mem < lfree) {
    lfree = mem;
  }
  
#if MEM_STATS
  lwip_stats.mem.used -= mem->next - ((u8_t *)mem - ram);
  
#endif /* MEM_STATS */
  plug_holes(mem);
  sys_sem_signal(mem_sem);
}
void *
mem_reallocm(void *rmem, mem_size_t newsize)
{
  void *nmem;
  nmem = mem_malloc(newsize);
  if (nmem == NULL) {
    return mem_realloc(rmem, newsize);
  }
  memcpy(nmem, rmem, newsize);
  mem_free(rmem);
  return nmem;
}

void *
mem_realloc(void *rmem, mem_size_t newsize)
{
  mem_size_t size;
  mem_size_t ptr, ptr2;
  struct mem *mem, *mem2;

  /* Expand the size of the allocated memory region so that we can
     adjust for alignment. */
  if ((newsize % MEM_ALIGNMENT) != 0) {
   newsize += MEM_ALIGNMENT - ((newsize + SIZEOF_STRUCT_MEM) % MEM_ALIGNMENT);
  }
  
  if (newsize > MEM_SIZE) {
    return NULL;
  }
  
  sys_sem_wait(mem_sem);
  
  LWIP_ASSERT("mem_realloc: legal memory", (u8_t *)rmem >= (u8_t *)ram &&
   (u8_t *)rmem < (u8_t *)ram_end);
  
  if ((u8_t *)rmem < (u8_t *)ram || (u8_t *)rmem >= (u8_t *)ram_end) {
    LWIP_DEBUGF(MEM_DEBUG | 3, ("mem_realloc: illegal memory\n"));
    return rmem;
  }
  mem = (struct mem *)((u8_t *)rmem - SIZEOF_STRUCT_MEM);

  ptr = (u8_t *)mem - ram;

  size = mem->next - ptr - SIZEOF_STRUCT_MEM;
#if MEM_STATS
  lwip_stats.mem.used -= (size - newsize);
#endif /* MEM_STATS */
  
  if (newsize + SIZEOF_STRUCT_MEM + MIN_SIZE < size) {
    ptr2 = ptr + SIZEOF_STRUCT_MEM + newsize;
    mem2 = (struct mem *)&ram[ptr2];
    mem2->used = 0;
    mem2->next = mem->next;
    mem2->prev = ptr;
    mem->next = ptr2;
    if (mem2->next != MEM_SIZE) {
      ((struct mem *)&ram[mem2->next])->prev = ptr2;
    }

    plug_holes(mem2);
  }
  sys_sem_signal(mem_sem);  
  return rmem;
}
void *
mem_malloc(mem_size_t size)
{
  mem_size_t ptr, ptr2;
  struct mem *mem, *mem2;

  if (size == 0) {
    return NULL;
  }

  /* Expand the size of the allocated memory region so that we can
     adjust for alignment. */
  if ((size % MEM_ALIGNMENT) != 0) {
    size += MEM_ALIGNMENT - ((size + SIZEOF_STRUCT_MEM) % MEM_ALIGNMENT);
  }
  
  if (size > MEM_SIZE) {
    return NULL;
  }
  
  sys_sem_wait(mem_sem);

  for (ptr = (u8_t *)lfree - ram; ptr < MEM_SIZE; ptr = ((struct mem *)&ram[ptr])->next) {
    mem = (struct mem *)&ram[ptr];
    if (!mem->used &&
       mem->next - (ptr + SIZEOF_STRUCT_MEM) >= size + SIZEOF_STRUCT_MEM) {
      ptr2 = ptr + SIZEOF_STRUCT_MEM + size;
      mem2 = (struct mem *)&ram[ptr2];

      mem2->prev = ptr;      
      mem2->next = mem->next;
      mem->next = ptr2;      
      if (mem2->next != MEM_SIZE) {
        ((struct mem *)&ram[mem2->next])->prev = ptr2;
      }
      
      mem2->used = 0;      
      mem->used = 1;
#if MEM_STATS
      lwip_stats.mem.used += (size + SIZEOF_STRUCT_MEM);
      /*      if (lwip_stats.mem.max < lwip_stats.mem.used) {
        lwip_stats.mem.max = lwip_stats.mem.used;
  } */
      if (lwip_stats.mem.max < ptr2) {
        lwip_stats.mem.max = ptr2;
      }      
#endif /* MEM_STATS */

      if (mem == lfree) {
  /* Find next free block after mem */
        while (lfree->used && lfree != ram_end) {
    lfree = (struct mem *)&ram[lfree->next];
        }
        LWIP_ASSERT("mem_malloc: !lfree->used", !lfree->used);
      }
      sys_sem_signal(mem_sem);
      LWIP_ASSERT("mem_malloc: allocated memory not above ram_end.",
       (mem_ptr_t)mem + SIZEOF_STRUCT_MEM + size <= (mem_ptr_t)ram_end);
      LWIP_ASSERT("mem_malloc: allocated memory properly aligned.",
       (unsigned long)((u8_t *)mem + SIZEOF_STRUCT_MEM) % MEM_ALIGNMENT == 0);
      return (u8_t *)mem + SIZEOF_STRUCT_MEM;
    }    
  }
  LWIP_DEBUGF(MEM_DEBUG | 2, ("mem_malloc: could not allocate %d bytes\n", (int)size));
#if MEM_STATS
  ++lwip_stats.mem.err;
#endif /* MEM_STATS */  
  sys_sem_signal(mem_sem);
  return NULL;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人激情av网| av一二三不卡影片| 欧美成人伊人久久综合网| 亚洲小少妇裸体bbw| 91香蕉视频在线| 中文字幕在线观看不卡| 丁香激情综合国产| 国产精品入口麻豆九色| 国产高清在线观看免费不卡| 久久久无码精品亚洲日韩按摩| 激情综合色丁香一区二区| 欧美成人精品3d动漫h| 蜜桃av噜噜一区| 精品国产123| 久久精品久久综合| 26uuu另类欧美| 国产盗摄一区二区| 国产精品久久久久一区二区三区共| 成人一区二区三区| 亚洲视频1区2区| 色婷婷精品大在线视频| 一区二区三区久久久| 精品视频全国免费看| 天天影视涩香欲综合网| 51精品视频一区二区三区| 日本美女视频一区二区| 久久综合九色综合久久久精品综合| 韩国av一区二区三区在线观看| 久久久99久久| 97国产精品videossex| 亚洲激情网站免费观看| 欧美视频在线观看一区| 日韩av不卡一区二区| 欧美成人午夜电影| 国产高清成人在线| 亚洲靠逼com| 欧美精品在线一区二区三区| 久久er99精品| 国产精品网站导航| 91久久精品网| 奇米精品一区二区三区在线观看| 欧美精品一区二区三| www.亚洲在线| 亚洲国产精品尤物yw在线观看| 日韩美女天天操| 国产不卡在线视频| 99热在这里有精品免费| 久久久久综合网| 国产成人免费av在线| 亚洲精品中文字幕乱码三区| 欧美二区三区的天堂| 精品成人一区二区| 国产欧美日韩在线视频| 轻轻草成人在线| www国产精品av| 91首页免费视频| 亚洲夂夂婷婷色拍ww47| 欧美一区二区国产| 韩国一区二区视频| 国产精品乱码人人做人人爱 | 中日韩av电影| 成人av在线影院| 午夜视频一区在线观看| 69久久夜色精品国产69蝌蚪网| 国产一区二区三区在线观看免费 | 中文久久乱码一区二区| 在线亚洲一区观看| 欧美aⅴ一区二区三区视频| 国产亚洲精品aa| 91久久精品一区二区三区| 奇米影视7777精品一区二区| 国产视频在线观看一区二区三区| 日本欧美久久久久免费播放网| 蜜臂av日日欢夜夜爽一区| 欧美精品一区二区在线播放 | 亚洲一卡二卡三卡四卡无卡久久| 91麻豆精品国产91久久久更新时间| 国产成人鲁色资源国产91色综 | 欧美电影免费观看高清完整版| 国产精品1区2区3区| 一区二区在线免费| 精品少妇一区二区| 99热精品一区二区| 麻豆视频观看网址久久| 中文字幕中文在线不卡住| 色综合久久九月婷婷色综合| 免费人成在线不卡| 国产精品不卡在线| 日韩一区二区影院| 色综合天天综合色综合av| 麻豆91在线看| 一区二区三区四区不卡在线| 久久久噜噜噜久久人人看| 欧美日韩国产三级| 国产资源精品在线观看| 亚洲综合久久久久| 国产亚洲人成网站| 91精品婷婷国产综合久久| 9久草视频在线视频精品| 精品一区二区免费视频| 一区二区日韩av| 日本一区二区综合亚洲| 欧美一区二区网站| 久久99精品一区二区三区| 成人看片黄a免费看在线| 五月婷婷久久综合| 中文字幕在线不卡视频| 精品国产伦一区二区三区免费| 欧美专区日韩专区| 国产乱码精品一区二区三区忘忧草| 亚洲一区二区欧美日韩| 国产亚洲女人久久久久毛片| 制服视频三区第一页精品| 91老司机福利 在线| 国产黑丝在线一区二区三区| 免费成人小视频| 亚洲成人激情av| 成人免费在线观看入口| 欧美国产综合色视频| 欧美日韩大陆在线| 高清beeg欧美| 国内欧美视频一区二区| 毛片不卡一区二区| 亚洲黄色录像片| 中文字幕中文乱码欧美一区二区| 久久免费视频一区| 日韩精品资源二区在线| 色婷婷精品大在线视频| 9i在线看片成人免费| 成人激情动漫在线观看| 丰满放荡岳乱妇91ww| 国产一区二区三区最好精华液| 美女视频黄a大片欧美| 五月婷婷欧美视频| 亚洲欧美视频在线观看视频| 国产欧美日韩在线| 精品日韩在线观看| 欧美日韩成人综合| 欧美日韩在线亚洲一区蜜芽| 不卡的电影网站| 国产九色精品成人porny | 中文字幕av资源一区| 久久久久久久久久久久电影 | 欧美疯狂做受xxxx富婆| 欧美视频一区二| 欧美在线不卡一区| 欧美网站大全在线观看| 在线影院国内精品| 日本高清视频一区二区| 91黄色免费版| 欧洲另类一二三四区| 99精品久久只有精品| 成人一区二区三区| 99久久99精品久久久久久| 91亚洲精品久久久蜜桃| 色视频成人在线观看免| 91精品91久久久中77777| 欧美亚洲一区二区在线| 在线观看免费一区| 欧美日韩精品欧美日韩精品| 欧美色爱综合网| 日韩视频免费直播| 精品国产一区二区三区久久影院| 精品国产一二三区| 久久天天做天天爱综合色| 精品嫩草影院久久| 精品理论电影在线观看| 国产午夜精品一区二区三区四区| 国产精品久久久久久久久免费丝袜 | 国产精品正在播放| 不卡电影一区二区三区| 成人h动漫精品一区二区| 99久久er热在这里只有精品15| 91麻豆免费观看| 欧美人牲a欧美精品| 精品国产99国产精品| 国产片一区二区三区| 亚洲欧美激情小说另类| 日韩国产一区二| 国产精品资源站在线| 国产99久久精品| 99国产欧美另类久久久精品| 欧美主播一区二区三区| 欧美一区二区高清| 日本一区二区免费在线| 亚洲欧美另类久久久精品| 免费成人你懂的| 国产91在线看| 欧美影院一区二区| 欧美成人精品1314www| 国产精品视频你懂的| 一区二区三区欧美久久| 老司机精品视频在线| 大桥未久av一区二区三区中文| 欧美在线视频你懂得| 精品久久人人做人人爱| 国产精品高潮呻吟久久| 免费观看一级特黄欧美大片| 国产一区在线看| 91小视频在线|