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

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

?? cache.c

?? be文件系統(tǒng)實(shí)現(xiàn)的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
            for(idx=0; idx < iocnt; idx++)                printf("iov[%2d] = 0x%8x :: %d\n", idx, iov[idx].iov_base,                       iov[idx].iov_len);            printf("error %s writing blocks %ld:%d (%d != %d)\n",                   strerror(errno), start_bnum, iocnt, ret, iocnt*bsize);            ret = EINVAL;            break;        }        ret = 0;        for(k=i; k < j; k++) {            if (ents[k]->func) {                ents[k]->func(ents[k]->logged_bnum, 1, ents[k]->arg);                ents[k]->func = NULL;            }            if (ents[k]->clone) {                free(ents[k]->clone);                ents[k]->clone = NULL;            } else {                ents[k]->flags &= ~CE_DIRTY;            }        }                    i = j - 1;  /* i gets incremented by the outer for loop */    }    /*       here we have to go back through and flush any blocks that are       still dirty.  with an arched brow you astutely ask, "but how       could this happen given the above loop?"  Ahhh young grasshopper       I say, the path through the cache is long and twisty and fraught       with peril.  The reason it can happen is that a block can be both       cloned and dirty.  The above loop would only flush the cloned half       of the data, not the main dirty block.  So we have to go back       through and see if there are any blocks that are still dirty.  If       there are we go back to the top of the function and do the whole       thing over.  Kind of grody but it is necessary to insure the       correctness of the log for the Be file system.    */       if (do_again == 0) {        for(i=0; i < n_ents; i++) {            if ((ents[i]->flags & CE_DIRTY) == 0 || ents[i]->lock)                continue;            do_again = 1;            break;        }        if (do_again)            goto restart;    }        release_iovec_array(iov);    return ret;}static voiddelete_cache_list(cache_ent_list *cel){    void      *junk;    cache_ent *ce, *next;        for(ce=cel->lru; ce; ce=next) {        next = ce->next;        if (ce->lock != 0) {            if (ce->func)                printf("*** shutdown_block_cache: block %ld, lock == %d "                       "(arg 0x%lx)!\n", ce->block_num, ce->lock,                       (ulong)ce->arg);            else                printf("*** shutdown_block_cache: block %ld, lock == %d!\n",                       ce->block_num, ce->lock);        }        if (ce->flags & CE_BUSY) {            printf("* shutdown block cache: bnum %ld is busy? ce 0x%lx\n",                   ce->block_num, (ulong)ce);        }        if ((ce->flags & CE_DIRTY) || ce->clone) {            flush_cache_ent(ce);        }        if (ce->clone)            free(ce->clone);        ce->clone = NULL;                if (ce->data)            free(ce->data);        ce->data = NULL;                if ((junk = hash_delete(&bc.ht, ce->dev, ce->block_num)) != ce) {            printf("*** free_device_cache: bad hash table entry %ld "                   "0x%lx != 0x%lx\n", ce->block_num, (ulong)junk, (ulong)ce);        }        memset(ce, 0xfd, sizeof(*ce));        free(ce);        bc.cur_blocks--;    }}voidshutdown_block_cache(void){    /* print_hash_stats(&bc.ht); */    if (bc.lock.s > 0)        LOCK(bc.lock);#ifndef USER    unregister_kernel_daemon(cache_flusher, NULL);#endif    delete_cache_list(&bc.normal);    delete_cache_list(&bc.locked);    bc.normal.lru = bc.normal.mru = NULL;    bc.locked.lru = bc.locked.mru = NULL;    shutdown_hash_table(&bc.ht);    if (bc.lock.s > 0)        free_lock(&bc.lock);    bc.lock.s = -1;    if (iovec_lock.s >= 0)        free_lock(&iovec_lock);}intinit_cache_for_device(int fd, fs_off_t max_blocks){    int ret = 0;        if (fd >= MAX_DEVICES)        return -1;    LOCK(bc.lock);    if (max_device_blocks[fd] != 0) {        printf("device %d is already initialized!\n", fd);        ret = -1;    } else {        max_device_blocks[fd] = max_blocks;    }    UNLOCK(bc.lock);    return ret;}/*   this routine assumes that bc.lock has been acquired*/   static cache_ent *block_lookup(int dev, fs_off_t bnum){    int        count = 0;    cache_ent *ce;    while (1) {        ce = hash_lookup(&bc.ht, dev, bnum);        if (ce == NULL)            return NULL;        if ((ce->flags & CE_BUSY) == 0) /* it's ok, break out and return it */            break;        /* else, it's busy and we need to retry our lookup */        UNLOCK(bc.lock);        snooze(5000);        if (count++ == 5000) {  /* then a lot of time has elapsed */            printf("block %ld isn't coming un-busy (ce @ 0x%lx)\n",                   ce->block_num, (ulong)ce);        }        LOCK(bc.lock);    }    if (ce->flags & CE_BUSY)        panic("block lookup: returning a busy block @ 0x%lx?!?\n",(ulong)ce);    return ce;}intset_blocks_info(int dev, fs_off_t *blocks, int nblocks,               void (*func)(fs_off_t bnum, size_t nblocks, void *arg), void *arg){    int        i, j, cur;    cache_ent *ce;    cache_ent *ents[NUM_FLUSH_BLOCKS];    LOCK(bc.lock);        for(i=0, cur=0; i < nblocks; i++) {        /* printf("sbi:   %ld (arg 0x%x)\n", blocks[i], arg); */        ce = block_lookup(dev, blocks[i]);        if (ce == NULL) {            panic("*** set_block_info can't find bnum %ld!\n", blocks[i]);            UNLOCK(bc.lock);            return ENOENT;   /* hopefully this doesn't happen... */        }        if (blocks[i] != ce->block_num || dev != ce->dev) {            UNLOCK(bc.lock);            panic("** error1: looked up dev %d block %ld but found dev %d "                    "bnum %ld\n", dev, blocks[i], ce->dev, ce->block_num);            return EBADF;        }        if (ce->lock == 0) {            panic("* set_block_info on bnum %ld (%d) but it's not locked!\n",                    blocks[i], nblocks);        }        if ((ce->flags & CE_DIRTY) == 0) {            panic("*** set_block_info on non-dirty block bnum %ld (%d)!\n",                    blocks[i], nblocks);        }        ce->flags |= CE_BUSY;     /* mark all blocks as busy till we're done */        /* if there is cloned data, it needs to be flushed now */        if (ce->clone && ce->func) {            ents[cur++] = ce;            if (cur >= NUM_FLUSH_BLOCKS) {                UNLOCK(bc.lock);                qsort(ents, cur, sizeof(cache_ent **), cache_ent_cmp);                flush_ents(ents, cur);                LOCK(bc.lock);                for(j=0; j < cur; j++)                    ents[j]->flags &= ~CE_BUSY;                cur = 0;            }        }    }        if (cur != 0) {        UNLOCK(bc.lock);        qsort(ents, cur, sizeof(cache_ent **), cache_ent_cmp);        flush_ents(ents, cur);        LOCK(bc.lock);        for(j=0; j < cur; j++)            ents[j]->flags &= ~CE_BUSY;        cur = 0;    }    /* now go through and set the info that we were asked to */    for(i=0; i < nblocks; i++) {        /* we can call hash_lookup() here because we know it's around */        ce = hash_lookup(&bc.ht, dev, blocks[i]);        if (ce == NULL) {            panic("*** set_block_info can't find bnum %ld!\n", blocks[i]);            UNLOCK(bc.lock);            return ENOENT;   /* hopefully this doesn't happen... */        }        ce->flags &= ~(CE_DIRTY | CE_BUSY);        if (ce->func != NULL) {            panic("*** set_block_info non-null callback on bnum %ld\n",                    ce->block_num);        }                if (ce->clone != NULL) {            panic("*** ce->clone == 0x%lx, not NULL in set_block_info\n",                    (ulong)ce->clone);        }                ce->clone = (void *)malloc(ce->bsize);        if (ce->clone == NULL)            panic("*** can't clone bnum %ld (bsize %d)\n",                    ce->block_num, ce->bsize);        memcpy(ce->clone, ce->data, ce->bsize);        ce->func   = func;        ce->arg    = arg;                ce->logged_bnum = blocks[i];        ce->lock--;        if (ce->lock < 0) {            printf("sbi: whoa nellie! ce @ 0x%lx (%ld) has lock == %d\n",                   (ulong)ce, ce->block_num, ce->lock);        }                if (ce->lock == 0) {            delete_from_list(&bc.locked, ce);            add_to_head(&bc.normal, ce);        }    }    UNLOCK(bc.lock);    return 0;}/* this function is only for use by flush_device() */static voiddo_flush(cache_ent **ents, int max){    int i;        for(i=0; i < max; i++) {        ents[i]->flags |= CE_BUSY;    }                    UNLOCK(bc.lock);                    qsort(ents, max, sizeof(cache_ent **), cache_ent_cmp);    flush_ents(ents, max);    LOCK(bc.lock);    for(i=0; i < max; i++) {        ents[i]->flags &= ~CE_BUSY;    }}intflush_device(int dev, int warn_locked){    int cur;    cache_ent *ce;    cache_ent *ents[NUM_FLUSH_BLOCKS];        LOCK(bc.lock);    cur = 0;    ce = bc.normal.lru;    while (ce) {        if (ce->dev != dev || (ce->flags & CE_BUSY)) {            ce = ce->next;            continue;        }                if ((ce->flags & CE_DIRTY) || ce->clone) {            ents[cur++] = ce;            if (cur >= NUM_FLUSH_BLOCKS) {                do_flush(ents, cur);                ce = bc.normal.lru;                cur = 0;                continue;            }        }        ce = ce->next;    }    if (cur != 0)        do_flush(ents, cur);    cur = 0;    ce = bc.locked.lru;    while (ce) {        if (ce->dev != dev || (ce->flags & CE_BUSY)) {            ce = ce->next;            continue;        }                if (ce->clone) {            ents[cur++] = ce;            if (cur >= NUM_FLUSH_BLOCKS) {                do_flush(ents, cur);                ce = bc.locked.lru;                cur = 0;                continue;            }        }        ce = ce->next;    }    if (cur != 0)        do_flush(ents, cur);    UNLOCK(bc.lock);    return 0;}static voidreal_remove_cached_blocks(int dev, int allow_writes, cache_ent_list *cel){    void      *junk;    cache_ent *ce, *next = NULL;        for(ce=cel->lru; ce; ce=next) {        next = ce->next;        if (ce->dev != dev) {            continue;        }        if (ce->lock != 0 || (ce->flags & CE_BUSY)) {            printf("*** remove_cached_dev: block %ld has lock = %d, flags "                   "0x%x! ce @ 0x%lx\n", ce->block_num, ce->lock, ce->flags,                   (ulong)ce);        }                if (allow_writes == ALLOW_WRITES &&            ((ce->flags & CE_DIRTY) || ce->clone)) {            ce->flags |= CE_BUSY;            flush_cache_ent(ce);            ce->flags &= ~CE_BUSY;        }        /* unlink this guy */        if (cel->lru == ce)            cel->lru = ce->next;        if (cel->mru == ce)            cel->mru = ce->prev;                            if (ce->prev)            ce->prev->next = ce->next;        if (ce->next)            ce->next->prev = ce->prev;        if (ce->clone)            free(ce->clone);        ce->clone = NULL;                if (ce->data)            free(ce->data);        ce->data = NULL;                if ((junk = hash_delete(&bc.ht, ce->dev, ce->block_num)) != ce) {            panic("*** remove_cached_device: bad hash table entry %ld "                   "0x%lx != 0x%lx\n", ce->block_num, (ulong)junk, (ulong)ce);        }        free(ce);        bc.cur_blocks--;    }}intremove_cached_device_blocks(int dev, int allow_writes){    LOCK(bc.lock);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国偷自产国产一区| 在线不卡一区二区| 免费人成黄页网站在线一区二区| 国产精品欧美一级免费| 日韩精品中午字幕| 欧美一二三区在线观看| 日韩视频免费观看高清完整版在线观看 | 色综合天天综合网天天狠天天| 久久久一区二区| 国产成人鲁色资源国产91色综 | 国产午夜亚洲精品不卡| 成人精品视频一区二区三区| 国产精品久99| 欧美视频你懂的| 日韩av中文在线观看| 精品成人免费观看| 波多野结衣91| 亚洲国产精品欧美一二99| 日韩区在线观看| 高清日韩电视剧大全免费| 亚洲精品福利视频网站| 日韩午夜在线影院| 成人黄色小视频在线观看| 亚洲六月丁香色婷婷综合久久| 欧美日韩精品福利| 国产黄人亚洲片| 亚洲高清视频在线| 久久免费美女视频| 欧美在线免费播放| 国内久久婷婷综合| 一卡二卡三卡日韩欧美| 精品国产三级电影在线观看| 99国产精品久久久久久久久久| 丝袜a∨在线一区二区三区不卡| 久久久久久黄色| 欧美日韩国产高清一区二区| 国产精品综合视频| 亚洲国产一二三| 国产欧美日韩精品在线| 制服.丝袜.亚洲.另类.中文| 成人免费高清视频| 热久久一区二区| 亚洲另类中文字| 欧美国产综合一区二区| 日韩一区二区免费在线电影| 91网站在线观看视频| 激情深爱一区二区| 首页国产欧美日韩丝袜| 亚洲日本va在线观看| 久久嫩草精品久久久久| 欧美福利电影网| 色狠狠色噜噜噜综合网| 成人少妇影院yyyy| 国内精品伊人久久久久影院对白| 亚洲第一精品在线| 亚洲激情在线播放| 中文字幕一区二区三区在线不卡 | 亚洲国产精品一区二区久久 | 亚洲视频电影在线| 国产亚洲欧美激情| 精品日韩欧美在线| 91精品国产色综合久久不卡电影| 色菇凉天天综合网| 波多野结衣在线一区| 高清av一区二区| 国产精品一二一区| 国产精品亚洲一区二区三区在线 | 久久精工是国产品牌吗| 日韩高清欧美激情| 午夜精品一区在线观看| 亚洲国产一区二区三区| 亚洲综合在线观看视频| 亚洲欧美aⅴ...| 亚洲免费看黄网站| 中文字幕在线不卡一区 | 日韩一级免费观看| 884aa四虎影成人精品一区| 欧美午夜视频网站| 欧美日韩另类一区| 欧美剧情电影在线观看完整版免费励志电影 | www激情久久| 久久综合给合久久狠狠狠97色69| 日韩欧美国产一区二区在线播放| 日韩免费看网站| 欧美va亚洲va在线观看蝴蝶网| 日韩一卡二卡三卡国产欧美| 91精品国产欧美一区二区| 日韩欧美三级在线| 欧美精品一区二区三区在线| 久久免费午夜影院| 国产精品素人一区二区| 亚洲欧美日韩一区| 亚洲网友自拍偷拍| 日本成人在线不卡视频| 激情都市一区二区| 成人18视频在线播放| 一本高清dvd不卡在线观看| 欧美三级乱人伦电影| 欧美一区二区三区视频免费| 久久一日本道色综合| 亚洲欧美一区二区视频| 亚洲成av人片| 国产一区二区三区免费观看| 99久久综合狠狠综合久久| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩国产小视频| 欧美精品一区二区三区蜜臀| 国产欧美精品国产国产专区| 亚洲综合免费观看高清完整版在线| 日韩国产欧美一区二区三区| 国产91对白在线观看九色| 欧美亚洲综合久久| 精品国精品国产| 亚洲欧美一区二区三区国产精品 | 久久国产尿小便嘘嘘尿| proumb性欧美在线观看| 欧美日韩精品综合在线| 国产亚洲成av人在线观看导航| 亚洲精品日日夜夜| 精品在线播放午夜| 日本道免费精品一区二区三区| 91精品国产乱| 成人免费视频在线观看| 蜜桃视频一区二区三区| 99精品视频一区| 欧美电影免费观看高清完整版在线观看| 久久精品男人的天堂| 五月婷婷久久综合| 99精品在线观看视频| 欧美成人在线直播| 一级精品视频在线观看宜春院 | a在线欧美一区| 91麻豆精品国产91久久久久久 | 国产91色综合久久免费分享| 欧美精品v国产精品v日韩精品| 欧美高清在线精品一区| 蜜芽一区二区三区| 色94色欧美sute亚洲线路二| 国产欧美视频一区二区| 日韩国产欧美三级| 欧美色图免费看| 中文字幕在线一区免费| 国产一区二区精品久久91| 欧美精品乱码久久久久久| 亚洲欧美一区二区三区极速播放| 国产精品自拍一区| 精品久久99ma| 奇米精品一区二区三区在线观看 | 日韩激情一区二区| 91九色02白丝porn| 中文字幕亚洲不卡| 成人免费视频一区| 久久精品日韩一区二区三区| 久久国产尿小便嘘嘘| 日韩一区二区三区观看| 日韩成人免费在线| 欧美日本免费一区二区三区| 亚洲图片有声小说| 在线观看av一区二区| 亚洲美女精品一区| 99精品一区二区三区| 最新欧美精品一区二区三区| 福利一区二区在线观看| 日本一区二区综合亚洲| 国产成人激情av| 久久久777精品电影网影网 | 欧美一级二级三级蜜桃| 午夜一区二区三区在线观看| 欧美亚洲免费在线一区| 亚洲综合色婷婷| 欧美日韩国产另类不卡| 午夜精品久久久| 日韩视频123| 国产一区二区导航在线播放| 国产日产欧美一区二区视频| 国产成人精品一区二区三区网站观看 | 国产一区视频在线看| 久久免费视频一区| 成人av电影免费观看| 亚洲欧美自拍偷拍色图| 91高清视频在线| 午夜久久久久久| 精品成人私密视频| 成人aa视频在线观看| 亚洲日本va午夜在线电影| 欧美专区亚洲专区| 日韩极品在线观看| 国产午夜亚洲精品午夜鲁丝片| 成人av资源站| 亚洲国产aⅴ天堂久久| 日韩欧美国产成人一区二区| 国产精品1024久久| 综合色中文字幕| 欧美美女一区二区在线观看| 久久精品99国产精品| 国产精品成人一区二区艾草| 欧美网站一区二区| 激情亚洲综合在线| 亚洲免费观看高清完整版在线观看熊 | av资源网一区|