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

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

?? cache.c

?? ATMEL單片機可用的文件系統源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/***********************************************************************/
/*                                                                     */
/*   Module:  cache.c                                                  */
/*   Release: 2004.5                                                   */
/*   Version: 2004.2                                                   */
/*   Purpose: Cache interface for the file systems                     */
/*                                                                     */
/*---------------------------------------------------------------------*/
/*                                                                     */
/*               Copyright 2004, Blunk Microsystems                    */
/*                      ALL RIGHTS RESERVED                            */
/*                                                                     */
/*   Licensees have the non-exclusive right to use, modify, or extract */
/*   this computer program for software development at a single site.  */
/*   This program may be resold or disseminated in executable format   */
/*   only. The source code may not be redistributed or resold.         */
/*                                                                     */
/***********************************************************************/
#include "posixfsp.h"
#include "../include/cache.h"

/***********************************************************************/
/* Local Function Definitions                                          */
/***********************************************************************/

/***********************************************************************/
/* remove_from_replacer: Remove specified entry from cache LRU list    */
/*                                                                     */
/*      Inputs: entry = pointer to cache entry                         */
/*              C = cache to which LRU list belongs                    */
/*                                                                     */
/***********************************************************************/
static void remove_from_replacer(CacheEntry *entry, Cache *C)
{
  /*-------------------------------------------------------------------*/
  /* Adjust the double linked list (LRU) by taking the entry out.      */
  /*-------------------------------------------------------------------*/
  if (entry->prev_lru)
    entry->prev_lru->next_lru = entry->next_lru;
  else
    C->lru_head = entry->next_lru;

  if (entry->next_lru)
    entry->next_lru->prev_lru = entry->prev_lru;
  else
    C->lru_tail = entry->prev_lru;

  /*-------------------------------------------------------------------*/
  /* Null out the pointers for the taken out entry.                    */
  /*-------------------------------------------------------------------*/
  entry->prev_lru = entry->next_lru = NULL;
}

/***********************************************************************/
/* put_into_tail: Add an entry to the end of the linked list           */
/*                                                                     */
/*      Inputs: entry = pointer to cache entry to be added             */
/*              C = cache to which the list belongs                    */
/*                                                                     */
/***********************************************************************/
static void put_into_tail(CacheEntry *entry, Cache *C)
{
  /*-------------------------------------------------------------------*/
  /* Set next to NULL since entry will be last entry, and prev to what */
  /* tail of list was before.                                          */
  /*-------------------------------------------------------------------*/
  entry->next_lru = NULL;
  entry->prev_lru = C->lru_tail;

  /*-------------------------------------------------------------------*/
  /* If the list was not empty, set the next of tail to new entry,     */
  /* else, because list was empty, set also head of list to new entry. */
  /*-------------------------------------------------------------------*/
  if (C->lru_tail)
    C->lru_tail->next_lru = entry;
  else
    C->lru_head = entry;

  /*-------------------------------------------------------------------*/
  /* Set tail of list to new entry.                                    */
  /*-------------------------------------------------------------------*/
  C->lru_tail = entry;
}

/***********************************************************************/
/*        hash: Hash based on the sector number                        */
/*                                                                     */
/*      Inputs: sector_number = value on which hash is done            */
/*              size = size of the table                               */
/*                                                                     */
/*     Returns: Index into the hash table where value gets hashed      */
/*                                                                     */
/***********************************************************************/
static int hash(int sector_number, int size)
{
  return (19823 * sector_number + 321043) % size;
}

/***********************************************************************/
/* Global Function Definitions                                         */
/***********************************************************************/

/***********************************************************************/
/*   InitCache: Initialize and allocate memory for the specified cache */
/*                                                                     */
/*      Inputs: C = cache to be initialized                            */
/*              pool_size = number of sectors in the cache             */
/*              writef = write sector function                         */
/*              readf = read sector function                           */
/*              sect_sz = sector size for file system                  */
/*              temp_sects = number of temporary sectors               */
/*              alignment = memory alignment                           */
/*                                                                     */
/*     Returns: Beginning of pool on success, 0 on failure             */
/*                                                                     */
/***********************************************************************/
ui32 InitCache(Cache *C, int pool_size, MedWFunc writef, MedRFunc readf,
               int sect_sz, int temp_sects, int alignment)
{
  ui32 *sectors;

  /*-------------------------------------------------------------------*/
  /* Set the write and read functions for the cache.                   */
  /*-------------------------------------------------------------------*/
  C->write = writef;
  C->read = readf;

  /*-------------------------------------------------------------------*/
  /* Set the number of sectors in cache.                               */
  /*-------------------------------------------------------------------*/
  C->pool_size = pool_size;

  /*-------------------------------------------------------------------*/
  /* Allocate memory for the pool and hash table.                      */
  /*-------------------------------------------------------------------*/
  C->pool = calloc((size_t)C->pool_size * sizeof(CacheEntry), (size_t)1);
  if (C->pool == NULL)
    return 0;
  C->hash_tbl = calloc((size_t)C->pool_size * sizeof(CacheEntry *),
                       (size_t)1);
  if (C->hash_tbl == NULL)
  {
    free(C->pool);
    return 0;
  }

  /*-------------------------------------------------------------------*/
  /* Allocate memory for all the sectors. This is where data goes.     */
  /* Also, allocate extra sectors for use by file sys. internals.      */
  /* Pointers to extra sectors will be set in file system init routine.*/
  /*-------------------------------------------------------------------*/
  sectors = calloc((size_t)(sect_sz * (C->pool_size + temp_sects) /
                            alignment), (size_t)alignment);
  if (sectors == NULL)
  {
    free(C->pool);
    free(C->hash_tbl);
    return 0;
  }

  /*-------------------------------------------------------------------*/
  /* Initialize the pool for the cache.                                */
  /*-------------------------------------------------------------------*/
  C->pool[0].sector = (ui8 *)sectors;
  ReinitCache(C, sect_sz);

  return (ui32)sectors;
}

/***********************************************************************/
/* ReinitCache: Re-initialize the cache                                */
/*                                                                     */
/*      Inputs: C = cache to be reinitialized                          */
/*              sect_sz = sector size for file system                  */
/*                                                                     */
/***********************************************************************/
void ReinitCache(Cache *C, int sect_sz)
{
  int i;
  ui8 *mem = C->pool[0].sector;

  /*-------------------------------------------------------------------*/
  /* Loop to initialize each entry in the cache.                       */
  /*-------------------------------------------------------------------*/
  for (i = 0; i < C->pool_size; ++i)
  {
    /*-----------------------------------------------------------------*/
    /* Assign a sector chunk of the preallocated memory.               */
    /*-----------------------------------------------------------------*/
    C->pool[i].sector = mem;
    mem += sect_sz;

    /*-----------------------------------------------------------------*/
    /* Set the entry in the pool to have an invalid sector number, -1, */
    /* not dirty, 0 pin count, no hash location and file_ptr.          */
    /*-----------------------------------------------------------------*/
    C->pool[i].sect_num = -1;
    C->pool[i].dirty = CLEAN;
    C->pool[i].pin_cnt = 0;
    C->pool[i].hash_loc = NULL;
    C->pool[i].file_ptr = NULL;

    /*-----------------------------------------------------------------*/
    /* If the first entry in pool, set its prev_lru to NULL.           */
    /*-----------------------------------------------------------------*/
    if (!i)
    {
      C->pool[i].prev_lru = NULL;
      if (C->pool_size == 1)
        C->pool[i].next_lru = NULL;
      else
        C->pool[i].next_lru = &C->pool[i + 1];
    }

    /*-----------------------------------------------------------------*/
    /* Else if last entry in pool, set its next_lru to NULL.           */
    /*-----------------------------------------------------------------*/
    else if (i == (C->pool_size - 1))
    {
      C->pool[i].prev_lru = &C->pool[i - 1];
      C->pool[i].next_lru = NULL;
    }

    /*-----------------------------------------------------------------*/
    /* Else set prev_lru to previous and next_lru to next entry.       */
    /*-----------------------------------------------------------------*/
    else
    {
      C->pool[i].prev_lru = &C->pool[i - 1];
      C->pool[i].next_lru = &C->pool[i + 1];
    }

    /*-----------------------------------------------------------------*/
    /* Initialize also the hash table entry.                           */
    /*-----------------------------------------------------------------*/
    C->pool[i].next_hash = C->pool[i].prev_hash = NULL;
    C->pool[i].hash_loc = NULL;
    C->hash_tbl[i] = NULL;
  }

  /*-------------------------------------------------------------------*/
  /* Set the dirty flags.                                              */
  /*-------------------------------------------------------------------*/
  C->dirty_old = C->dirty_new = FALSE;

  /*-------------------------------------------------------------------*/
  /* Initialize the current sector being worked on.                    */
  /*-------------------------------------------------------------------*/
  C->sector_number = -1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久三级国产网站| 国产高清成人在线| 亚洲免费在线播放| 亚洲欧洲精品天堂一级| 国产日韩综合av| 久久久九九九九| 欧美国产欧美亚州国产日韩mv天天看完整 | 久久综合九色综合欧美98| 欧美一区二区三区视频免费| 欧美高清激情brazzers| 欧美三级日韩在线| 欧美性做爰猛烈叫床潮| 欧美日韩aaaaa| 日韩免费电影一区| 久久久久久久电影| 国产精品久久久久四虎| 亚洲日本va在线观看| 一区二区三区高清在线| 一区二区三区在线看| 午夜精品久久久久久久99水蜜桃 | 精品福利在线导航| 欧美激情艳妇裸体舞| 自拍偷拍国产精品| 五月婷婷综合网| 久久99精品久久久久久国产越南 | 国内久久精品视频| 成人激情文学综合网| 欧美色涩在线第一页| 日韩欧美美女一区二区三区| 国产精品色在线| 亚洲午夜一二三区视频| 国产在线精品国自产拍免费| 91视频一区二区三区| 51精品视频一区二区三区| 久久久久久久久久久久电影| 一区二区三区四区视频精品免费 | 国产精品久久99| 午夜天堂影视香蕉久久| 国产传媒一区在线| 欧美日韩国产高清一区二区三区| 精品国产sm最大网站免费看| 亚洲欧洲精品天堂一级| 免费黄网站欧美| 99在线精品一区二区三区| 日韩美女一区二区三区| 亚洲天堂成人在线观看| 黄色精品一二区| 欧美亚洲自拍偷拍| 亚洲国产精品99久久久久久久久| 亚洲sss视频在线视频| 国产91富婆露脸刺激对白| 欧美精品乱码久久久久久 | 亚洲一区二区三区视频在线| 国产福利一区二区三区视频| 欧美二区在线观看| 一区二区三区视频在线看| 狠狠v欧美v日韩v亚洲ⅴ| 欧美日韩高清在线| 自拍偷拍亚洲欧美日韩| 国产成人免费视频网站高清观看视频| 欧美美女一区二区| 亚洲欧美日韩精品久久久久| 精品一区二区三区日韩| 欧美日韩一区二区在线观看视频 | 亚洲最新视频在线播放| 波多野结衣中文字幕一区| 中文字幕第一页久久| 韩国女主播一区二区三区| 亚洲精品一区二区三区在线观看| 爽爽淫人综合网网站| 欧美丰满美乳xxx高潮www| 亚洲国产精品一区二区久久| 欧洲一区在线电影| 亚洲国产sm捆绑调教视频 | 中文字幕在线观看不卡视频| 精一区二区三区| 欧美日韩综合不卡| 在线免费观看不卡av| 亚洲一级二级三级| 99久久国产综合精品色伊| 精品久久久久99| 国产精品传媒入口麻豆| 久久精品男人的天堂| 国产欧美精品一区二区色综合 | 国产原创一区二区| 在线播放中文字幕一区| 亚洲视频免费看| 成人免费黄色在线| 在线成人免费视频| 欧美国产日韩一二三区| 亚洲精品成人精品456| 国产高清亚洲一区| 久久综合色天天久久综合图片| 亚洲国产精品精华液网站| 成人综合激情网| 精品1区2区在线观看| 国产精品区一区二区三| 国产麻豆精品95视频| 91精品免费观看| 日本欧美一区二区在线观看| 欧美精品aⅴ在线视频| 香港成人在线视频| 欧美日韩一区二区三区四区五区| 亚洲精品视频在线| 91福利资源站| 免费看精品久久片| 欧美一区二区三区视频在线| 亚洲国产日日夜夜| 欧美精品 国产精品| 午夜视频久久久久久| 91精品国产91热久久久做人人| 成人欧美一区二区三区| 国产一区二区三区四| 国产欧美一二三区| 色综合天天综合| 亚洲福利视频导航| 日韩欧美色综合| 高清shemale亚洲人妖| 亚洲欧美一区二区三区极速播放| 9i在线看片成人免费| 亚洲狠狠丁香婷婷综合久久久| 91福利在线观看| 日本美女一区二区三区视频| 精品国产免费一区二区三区四区 | 国产精品三级av| 色天使色偷偷av一区二区| 午夜欧美电影在线观看| 精品国产91乱码一区二区三区 | 26uuu精品一区二区| 国产福利一区二区三区视频在线 | 韩国视频一区二区| 欧美国产日产图区| 91丨porny丨蝌蚪视频| 亚洲精品在线网站| 色国产综合视频| 精品一二三四在线| 最新久久zyz资源站| 91麻豆精品国产91| www.亚洲精品| 另类中文字幕网| 亚洲免费观看视频| 日韩欧美国产一区在线观看| 91蜜桃在线观看| 国产尤物一区二区| 亚洲高清在线精品| 亚洲国产高清不卡| 欧美一区二视频| 亚洲高清视频中文字幕| 91麻豆精品国产91久久久久 | 7777精品伊人久久久大香线蕉完整版 | 久久人人爽爽爽人久久久| 色婷婷国产精品综合在线观看| 国产一区二区三区在线看麻豆| 亚洲另类在线一区| 欧美放荡的少妇| 久久成人麻豆午夜电影| 亚洲欧美视频在线观看| 精品久久久久久久久久久久久久久 | 国产真实乱偷精品视频免| 亚洲一区二区三区爽爽爽爽爽| 精品电影一区二区三区| 美国欧美日韩国产在线播放| 日韩精品中午字幕| 欧美日韩久久一区二区| 91性感美女视频| 国产sm精品调教视频网站| 精品综合免费视频观看| 日韩av中文字幕一区二区三区| 亚洲美女视频在线| 中文字幕一区二区三区四区不卡| 欧美一二三区精品| 成人性生交大片免费看视频在线| 麻豆传媒一区二区三区| 日韩va亚洲va欧美va久久| 婷婷久久综合九色综合伊人色| 一区二区不卡在线播放| 亚洲精品日日夜夜| 色综合欧美在线视频区| 蜜芽一区二区三区| 毛片av一区二区三区| 激情六月婷婷久久| 国产综合久久久久久鬼色| 国产一区二三区| 成人午夜av在线| 成人h版在线观看| 99精品视频在线播放观看| 91视视频在线观看入口直接观看www| 成人免费电影视频| 91啪亚洲精品| 成人18精品视频| 亚洲高清视频中文字幕| 亚洲成人在线免费| 午夜视频在线观看一区二区三区| 午夜欧美在线一二页| 青椒成人免费视频| 国产精品69久久久久水密桃| 国产很黄免费观看久久| 成人国产视频在线观看| 91黄色在线观看| 欧美视频你懂的|