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

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

?? store_io_aufs.c

?? 代理服務(wù)器 squid-2.6.STABLE16
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* * $Id: store_io_aufs.c,v 1.34 2006/11/05 21:14:31 hno Exp $ * * DEBUG: section 79    Squid-side AUFS I/O functions. * * SQUID Web Proxy Cache          http://www.squid-cache.org/ * ---------------------------------------------------------- * *  Squid is the result of efforts by numerous individuals from *  the Internet community; see the CONTRIBUTORS file for full *  details.   Many organizations have provided support for Squid's *  development; see the SPONSORS file for full details.  Squid is *  Copyrighted (C) 2001 by the Regents of the University of *  California; see the COPYRIGHT file for full details.  Squid *  incorporates software developed and/or copyrighted by other *  sources; see the CREDITS file for full details. * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. *   *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. *   *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA. * */#include "squid.h"#include "async_io.h"#include "store_asyncufs.h"#if ASYNC_READstatic AIOCB storeAufsReadDone;#elsestatic DRCB storeAufsReadDone;#endif#if ASYNC_WRITEstatic AIOCB storeAufsWriteDone;#elsestatic DWCB storeAufsWriteDone;#endifstatic void storeAufsIOCallback(storeIOState * sio, int errflag);static AIOCB storeAufsOpenDone;static int storeAufsNeedCompletetion(storeIOState *);static int storeAufsKickWriteQueue(storeIOState * sio);static CBDUNL storeAufsIOFreeEntry;CBDATA_TYPE(storeIOState);/* === PUBLIC =========================================================== *//* open for reading */storeIOState *storeAufsOpen(SwapDir * SD, StoreEntry * e, STFNCB * file_callback,    STIOCB * callback, void *callback_data){    sfileno f = e->swap_filen;    char *path = storeAufsDirFullPath(SD, f, NULL);    storeIOState *sio;#if !ASYNC_OPEN    int fd;#endif    debug(79, 3) ("storeAufsOpen: fileno %08X\n", f);    /*     * we should detect some 'too many files open' condition and return     * NULL here.     */#ifdef MAGIC2    if (aioQueueSize() > MAGIC2)	return NULL;#endif#if !ASYNC_OPEN    fd = file_open(path, O_RDONLY | O_BINARY | O_NOATIME);    if (fd < 0) {	debug(79, 3) ("storeAufsOpen: got failure (%d)\n", errno);	return NULL;    }#endif    CBDATA_INIT_TYPE_FREECB(storeIOState, storeAufsIOFreeEntry);    sio = cbdataAlloc(storeIOState);    sio->fsstate = memPoolAlloc(squidaio_state_pool);    ((squidaiostate_t *) (sio->fsstate))->fd = -1;    ((squidaiostate_t *) (sio->fsstate))->flags.opening = 1;    sio->swap_filen = f;    sio->swap_dirn = SD->index;    sio->mode = O_RDONLY | O_BINARY;    sio->callback = callback;    sio->callback_data = callback_data;    sio->e = e;    cbdataLock(callback_data);    Opening_FD++;    statCounter.syscalls.disk.opens++;#if ASYNC_OPEN    aioOpen(path, O_RDONLY | O_BINARY | O_NOATIME, 0644, storeAufsOpenDone, sio);#else    storeAufsOpenDone(fd, sio, fd, 0);#endif    return sio;}/* open for creating */storeIOState *storeAufsCreate(SwapDir * SD, StoreEntry * e, STFNCB * file_callback, STIOCB * callback, void *callback_data){    char *path;    storeIOState *sio;    sfileno filn;    sdirno dirn;#if !ASYNC_CREATE    int fd;#endif    /* Allocate a number */    dirn = SD->index;    filn = storeAufsDirMapBitAllocate(SD);    path = storeAufsDirFullPath(SD, filn, NULL);    debug(79, 3) ("storeAufsCreate: fileno %08X\n", filn);    /*     * we should detect some 'too many files open' condition and return     * NULL here.     */#ifdef MAGIC2    if (aioQueueSize() > MAGIC2)	return NULL;#endif#if !ASYNC_CREATE    fd = file_open(path, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY);    if (fd < 0) {	debug(79, 3) ("storeAufsCreate: got failure (%d)\n", errno);	return NULL;    }#endif    CBDATA_INIT_TYPE_FREECB(storeIOState, storeAufsIOFreeEntry);    sio = cbdataAlloc(storeIOState);    sio->fsstate = memPoolAlloc(squidaio_state_pool);    ((squidaiostate_t *) (sio->fsstate))->fd = -1;    ((squidaiostate_t *) (sio->fsstate))->flags.opening = 1;    sio->swap_filen = filn;    sio->swap_dirn = dirn;    sio->mode = O_WRONLY | O_BINARY;    sio->callback = callback;    sio->callback_data = callback_data;    sio->e = (StoreEntry *) e;    cbdataLock(callback_data);    Opening_FD++;    statCounter.syscalls.disk.opens++;#if ASYNC_CREATE    aioOpen(path, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0644, storeAufsOpenDone, sio);#else    storeAufsOpenDone(fd, sio, fd, 0);#endif    /* now insert into the replacement policy */    storeAufsDirReplAdd(SD, e);    return sio;}/* Close */voidstoreAufsClose(SwapDir * SD, storeIOState * sio){    squidaiostate_t *aiostate = (squidaiostate_t *) sio->fsstate;    debug(79, 3) ("storeAufsClose: dirno %d, fileno %08X, FD %d\n",	sio->swap_dirn, sio->swap_filen, aiostate->fd);    if (storeAufsNeedCompletetion(sio)) {	aiostate->flags.close_request = 1;	return;    }    storeAufsIOCallback(sio, DISK_OK);}/* Read */voidstoreAufsRead(SwapDir * SD, storeIOState * sio, char *buf, size_t size, squid_off_t offset, STRCB * callback, void *callback_data){    squidaiostate_t *aiostate = (squidaiostate_t *) sio->fsstate;    assert(sio->read.callback == NULL);    assert(sio->read.callback_data == NULL);    assert(!aiostate->flags.reading);    if (aiostate->fd < 0) {	struct _queued_read *q;	debug(79, 3) ("storeAufsRead: queueing read because FD < 0\n");	assert(aiostate->flags.opening);	assert(aiostate->pending_reads == NULL);	q = memPoolAlloc(aufs_qread_pool);	q->buf = buf;	q->size = size;	q->offset = (off_t) offset;	q->callback = callback;	q->callback_data = callback_data;	cbdataLock(q->callback_data);	linklistPush(&(aiostate->pending_reads), q);	return;    }    sio->read.callback = callback;    sio->read.callback_data = callback_data;    aiostate->read_buf = buf;    cbdataLock(callback_data);    debug(79, 3) ("storeAufsRead: dirno %d, fileno %08X, FD %d\n",	sio->swap_dirn, sio->swap_filen, aiostate->fd);    sio->offset = offset;    aiostate->flags.reading = 1;#if ASYNC_READ    aioRead(aiostate->fd, (off_t) offset, size, storeAufsReadDone, sio);    statCounter.syscalls.disk.reads++;#else    file_read(aiostate->fd, buf, size, (off_t) offset, storeAufsReadDone, sio);    /* file_read() increments syscalls.disk.reads */#endif}/* Write */voidstoreAufsWrite(SwapDir * SD, storeIOState * sio, char *buf, size_t size, squid_off_t offset, FREE * free_func){    squidaiostate_t *aiostate = (squidaiostate_t *) sio->fsstate;    debug(79, 3) ("storeAufsWrite: dirno %d, fileno %08X, FD %d\n",	sio->swap_dirn, sio->swap_filen, aiostate->fd);    if (aiostate->fd < 0) {	/* disk file not opened yet */	struct _queued_write *q;	assert(aiostate->flags.opening);	q = memPoolAlloc(aufs_qwrite_pool);	q->buf = buf;	q->size = size;	q->offset = (off_t) offset;	q->free_func = free_func;	linklistPush(&(aiostate->pending_writes), q);	return;    }#if ASYNC_WRITE    if (aiostate->flags.writing) {	struct _queued_write *q;	debug(79, 3) ("storeAufsWrite: queuing write\n");	q = memPoolAlloc(aufs_qwrite_pool);	q->buf = buf;	q->size = size;	q->offset = (off_t) offset;	q->free_func = free_func;	linklistPush(&(aiostate->pending_writes), q);	return;    }    aiostate->flags.writing = 1;    aioWrite(aiostate->fd, (off_t) offset, buf, size, storeAufsWriteDone, sio,	free_func);    statCounter.syscalls.disk.writes++;#else    file_write(aiostate->fd, (off_t) offset, buf, size, storeAufsWriteDone, sio,	free_func);    /* file_write() increments syscalls.disk.writes */#endif}/* Unlink */voidstoreAufsUnlink(SwapDir * SD, StoreEntry * e){    debug(79, 3) ("storeAufsUnlink: dirno %d, fileno %08X\n", SD->index, e->swap_filen);    storeAufsDirReplRemove(e);    storeAufsDirMapBitReset(SD, e->swap_filen);    storeAufsDirUnlinkFile(SD, e->swap_filen);    statCounter.syscalls.disk.unlinks++;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re免费视频精品全部| 国产精品乱人伦中文| 国产精品久久二区二区| 成人一二三区视频| 国产精品嫩草影院av蜜臀| 欧美日本韩国一区| 极品尤物av久久免费看| 日韩一卡二卡三卡| 懂色中文一区二区在线播放| 国产精品女主播在线观看| 欧美疯狂做受xxxx富婆| 韩国三级中文字幕hd久久精品| 国产欧美精品一区二区色综合| 99国产精品久久久久久久久久| 久久se精品一区精品二区| 国产精品美日韩| 精品美女一区二区| 成人免费毛片a| 国产一区二区调教| 亚洲精品视频在线| 日韩一级片在线观看| 欧美性欧美巨大黑白大战| 看国产成人h片视频| 亚洲一区二区在线播放相泽| 亚洲精品一区二区精华| 色综合天天视频在线观看 | 视频一区欧美日韩| 国产色产综合色产在线视频| 色8久久人人97超碰香蕉987| 久久99精品久久只有精品| 日韩电影免费在线| 中文字幕一区二区在线播放| 欧美精品日日鲁夜夜添| 欧美自拍偷拍一区| 国产成+人+日韩+欧美+亚洲| 国产在线不卡一卡二卡三卡四卡| 美女一区二区在线观看| 亚洲精品国产视频| 亚洲精品中文字幕乱码三区 | 免费高清不卡av| 自拍偷自拍亚洲精品播放| 制服丝袜亚洲网站| 成人av电影在线| 日韩国产欧美一区二区三区| 日韩国产一二三区| 日本视频一区二区| 久久成人久久鬼色| 国内外成人在线视频| 国产一区二区福利| 懂色av中文一区二区三区| 波多野结衣视频一区| 韩国毛片一区二区三区| 国产精品1区2区3区在线观看| 奇米精品一区二区三区在线观看 | 最新国产の精品合集bt伙计| 亚洲色图视频网站| 婷婷综合久久一区二区三区| 亚洲视频香蕉人妖| 一二三区精品福利视频| 中文无字幕一区二区三区| 欧美久久久久久蜜桃| 日韩一区二区三区在线| 久久先锋影音av| 日韩亚洲欧美在线观看| 久久久精品免费网站| 日韩三级在线观看| 久久久不卡网国产精品一区| 国产精品久久久久永久免费观看 | 日韩在线播放一区二区| 久久99久久久久| 成人激情免费网站| 欧美日韩一区国产| 欧美综合久久久| 日韩精品一区二区三区在线观看 | 欧美熟乱第一页| 欧美一级片在线| 欧美一区二区福利在线| 国产欧美一区视频| 亚洲午夜激情网站| 亚洲福利电影网| 国产在线日韩欧美| 色综合天天综合网天天狠天天| 不卡电影免费在线播放一区| 欧美区视频在线观看| 国产日本欧洲亚洲| 五月天亚洲精品| 成人午夜激情片| 日韩女同互慰一区二区| 亚洲色图.com| 国产毛片一区二区| 欧美日本在线看| 自拍偷拍欧美精品| 国产精品91xxx| 欧美一区三区二区| 亚洲男人的天堂在线aⅴ视频| 亚洲一卡二卡三卡四卡五卡| 国产精品自在欧美一区| 欧美日韩视频在线第一区| 欧美极品少妇xxxxⅹ高跟鞋| 日韩av不卡在线观看| 色综合一区二区| 亚洲国产高清aⅴ视频| 麻豆久久一区二区| 欧美三级一区二区| 日韩码欧中文字| 国产精品一级片在线观看| 69av一区二区三区| 亚洲午夜在线电影| 91视频精品在这里| 欧美高清激情brazzers| 亚洲男女一区二区三区| 成人性色生活片| 久久免费看少妇高潮| 蜜桃av一区二区三区电影| 欧美午夜视频网站| 亚洲啪啪综合av一区二区三区| 国产成人精品免费视频网站| 欧美在线免费视屏| 一区在线中文字幕| 成人永久免费视频| 中文字幕不卡一区| 成人综合婷婷国产精品久久| 国产亚洲欧洲997久久综合| 日韩 欧美一区二区三区| 欧美区在线观看| 性久久久久久久| 不卡一区二区中文字幕| 国产喂奶挤奶一区二区三区| 国产精品一区二区三区乱码| 精品99999| 国产成人免费在线| 亚洲国产精品99久久久久久久久 | 亚洲一区二区三区自拍| 91网页版在线| 中文字幕亚洲精品在线观看 | 精品国产一区二区国模嫣然| 久久精品国产99| 精品久久久久久久久久久久包黑料| 爽好久久久欧美精品| 欧美一级在线观看| 精品亚洲国产成人av制服丝袜| 日韩欧美激情四射| 久久国产综合精品| 精品国产1区二区| 国产精品一区二区三区网站| 日本一区二区电影| 色综合久久久久久久久久久| 亚洲一区二区三区四区五区中文 | 亚洲大片免费看| 欧美一级午夜免费电影| 国内精品伊人久久久久av影院 | 久久精品人人做人人爽97| 国产精品99久久久久久久女警| 亚洲国产成人一区二区三区| 99精品欧美一区二区三区小说| 亚洲人成精品久久久久| 欧美日本一道本在线视频| 久久精品久久99精品久久| 国产日韩精品一区二区三区| 91麻豆国产福利在线观看| 亚洲小少妇裸体bbw| 日韩精品一区二区三区蜜臀| 国产精品一二三| 一区二区三区免费| 日韩一级在线观看| 99久久精品国产一区二区三区| 午夜精品福利久久久| 久久夜色精品一区| 色www精品视频在线观看| 日韩高清一级片| 国产精品久久久久久久久果冻传媒| 一本大道av一区二区在线播放| 免费观看日韩电影| 1区2区3区精品视频| 欧美一级在线免费| 91欧美一区二区| 免费人成在线不卡| 国产精品国产三级国产a| 欧美日韩国产首页| 丁香婷婷深情五月亚洲| 亚洲成人av一区| 日本一区二区综合亚洲| 4438成人网| 成人av在线影院| 精品一区二区精品| 亚洲精品一二三区| 国产女人18毛片水真多成人如厕| 欧美在线999| 成人妖精视频yjsp地址| 蜜臀久久久久久久| 一区二区三区电影在线播| 久久久久久电影| 欧美一区二区在线不卡| 色香蕉成人二区免费| 精品一区二区三区视频在线观看| 一区二区在线看| 国产精品入口麻豆原神| 欧美大片在线观看一区| 91福利在线免费观看| 国产91丝袜在线播放|