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

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

?? store_io_diskd.c

?? 代理服務(wù)器 squid-2.6.STABLE16
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
	/* Damn, we need to issue a sync unlink here :( */	debug(79, 2) ("storeDiskUnlink: Out of queue space, sync unlink\n");	storeDiskdDirUnlinkFile(SD, e->swap_filen);	return;    }    /* We can attempt a diskd unlink */    buf = storeDiskdShmGet(SD, &shm_offset);    xstrncpy(buf, storeDiskdDirFullPath(SD, e->swap_filen, NULL), SHMBUF_BLKSZ);    x = storeDiskdSend(_MQD_UNLINK,	SD,	e->swap_filen,	NULL,	0,	0,	shm_offset);    if (x < 0) {	debug(79, 1) ("storeDiskdSend UNLINK: %s\n", xstrerror());	unlink(buf);		/* XXX EWW! */	storeDiskdShmPut(SD, shm_offset);    }    diskd_stats.unlink.ops++;}voidstoreDiskdRecycle(SwapDir * SD, StoreEntry * e){    debug(79, 3) ("storeDiskdUnlink: fileno %08X\n", e->swap_filen);    /* Detach from the underlying physical object */    if (e->swap_filen > -1) {	storeDiskdDirReplRemove(e);	storeDiskdDirMapBitReset(SD, e->swap_filen);	e->swap_filen = -1;	e->swap_dirn = -1;    }}/*  === STATIC =========================================================== */static voidstoreDiskdOpenDone(diomsg * M){    storeIOState *sio = M->callback_data;    statCounter.syscalls.disk.opens++;    debug(79, 3) ("storeDiskdOpenDone: dirno %d, fileno %08x status %d\n",	sio->swap_dirn, sio->swap_filen, M->status);    if (M->status < 0) {	FILE_MODE(sio->mode) == O_RDONLY ? diskd_stats.open.fail++ : diskd_stats.create.fail++;	storeDiskdIOCallback(sio, DISK_ERROR);    } else {	FILE_MODE(sio->mode) == O_RDONLY ? diskd_stats.open.success++ : diskd_stats.create.success++;    }}static voidstoreDiskdCloseDone(diomsg * M){    storeIOState *sio = M->callback_data;    statCounter.syscalls.disk.closes++;    debug(79, 3) ("storeDiskdCloseDone: dirno %d, fileno %08x status %d\n",	sio->swap_dirn, sio->swap_filen, M->status);    if (M->status < 0) {	diskd_stats.close.fail++;	storeDiskdIOCallback(sio, DISK_ERROR);	return;    }    diskd_stats.close.success++;    storeDiskdIOCallback(sio, DISK_OK);}static voidstoreDiskdReadDone(diomsg * M){    storeIOState *sio = M->callback_data;    STRCB *callback = sio->read.callback;    SwapDir *sd = INDEXSD(sio->swap_dirn);    diskdstate_t *diskdstate = sio->fsstate;    diskdinfo_t *diskdinfo = sd->fsdata;    void *their_data = sio->read.callback_data;    char *their_buf = diskdstate->read_buf;    char *sbuf;    size_t len;    int valid;    statCounter.syscalls.disk.reads++;    diskdstate->flags.reading = 0;    valid = cbdataValid(sio->read.callback_data);    cbdataUnlock(sio->read.callback_data);    debug(79, 3) ("storeDiskdReadDone: dirno %d, fileno %08x status %d\n",	sio->swap_dirn, sio->swap_filen, M->status);    if (M->status < 0) {	diskd_stats.read.fail++;	storeDiskdIOCallback(sio, DISK_ERROR);	return;    }    diskd_stats.read.success++;    sbuf = diskdinfo->shm.buf + M->shm_offset;    len = M->status;    sio->offset += len;    assert(callback);    assert(their_data);    sio->read.callback = NULL;    sio->read.callback_data = NULL;    if (valid) {	assert(!diskdstate->flags.close_request);	/*	 * Only copy the data if the callback is still valid,	 * if it isn't valid then the request should have been	 * aborted.	 *   -- adrian	 */	xmemcpy(their_buf, sbuf, len);	/* yucky copy */	callback(their_data, their_buf, len);    }}static voidstoreDiskdWriteDone(diomsg * M){    storeIOState *sio = M->callback_data;    diskdstate_t *diskdstate = sio->fsstate;    statCounter.syscalls.disk.writes++;    diskdstate->flags.writing = 0;    debug(79, 3) ("storeDiskdWriteDone: dirno %d, fileno %08x status %d\n",	sio->swap_dirn, sio->swap_filen, M->status);    if (M->status < 0) {	diskd_stats.write.fail++;	storeDiskdIOCallback(sio, DISK_ERROR);	return;    }    diskd_stats.write.success++;    sio->offset += M->status;}static voidstoreDiskdUnlinkDone(diomsg * M){    debug(79, 3) ("storeDiskdUnlinkDone: fileno %08x status %d\n",	M->id, M->status);    statCounter.syscalls.disk.unlinks++;    if (M->status < 0)	diskd_stats.unlink.fail++;    else	diskd_stats.unlink.success++;}voidstoreDiskdHandle(diomsg * M){    int valid = M->callback_data ? cbdataValid(M->callback_data) : 1;    if (M->callback_data)	cbdataUnlock(M->callback_data);    if (!valid) {	debug(79, 3) ("storeDiskdHandle: Invalid callback_data %p\n",	    M->callback_data);	/*	 * The read operation has its own callback.  If we don't	 * call storeDiskdReadDone(), then we must make sure the	 * callback_data gets unlocked!	 */	if (_MQD_READ == M->mtype) {	    storeIOState *sio = M->callback_data;	    cbdataUnlock(sio->read.callback_data);	}	return;    }    /* set errno passed from diskd.  makes debugging more meaningful */    if (M->status < 0)	errno = -M->status;    switch (M->mtype) {    case _MQD_OPEN:	storeDiskdOpenDone(M);	break;    case _MQD_CLOSE:	storeDiskdCloseDone(M);	break;    case _MQD_READ:	storeDiskdReadDone(M);	break;    case _MQD_WRITE:	storeDiskdWriteDone(M);	break;    case _MQD_UNLINK:	storeDiskdUnlinkDone(M);	break;    default:	assert(0);	break;    }}static voidstoreDiskdIOCallback(storeIOState * sio, int errflag){    void *p = sio->callback_data;    debug(79, 3) ("storeDiskdIOCallback: errflag=%d\n", errflag);    if (cbdataValid(p))	sio->callback(p, errflag, sio);    cbdataUnlock(p);    cbdataFree(sio);}static intstoreDiskdSend(int mtype, SwapDir * sd, int id, storeIOState * sio, int size, off_t offset, int shm_offset){    int x;    diomsg M;    static int send_errors = 0;    static int last_seq_no = 0;    static int seq_no = 0;    diskdinfo_t *diskdinfo = sd->fsdata;    struct timeval delay =    {0, 1};    M.mtype = mtype;    M.callback_data = sio;    M.size = size;    M.offset = offset;    M.status = -1;    M.shm_offset = (int) shm_offset;    M.id = id;    M.seq_no = ++seq_no;    if (M.callback_data)	cbdataLock(M.callback_data);    if (M.seq_no < last_seq_no)	debug(79, 1) ("WARNING: sequencing out of order\n");    /*     * We have to drain the queue here if necessary.  If we don't,     * then we can have a lot of messages in the queue (probably     * up to 2*magic1) and we can run out of shared memory buffers.     */    /*     * NOTE that it is important that we call storeDirCallback AFTER     * locking the callback data M.callback_data because we need     * to make sure the cbdata lock count doesn't go to zero (and     * get freed) before we have a chance to send the current message     * M!     */    /*     * Note that we call storeDirCallback (for all SDs), rather     * than storeDiskdDirCallback for just this SD, so that while     * we're "blocking" on this SD we can also handle callbacks     * from other SDs that might be ready.     */    while (diskdinfo->away > diskdinfo->magic2) {	select(0, NULL, NULL, NULL, &delay);	storeDirCallback();	if (delay.tv_usec < 1000000)	    delay.tv_usec <<= 1;    }    x = msgsnd(diskdinfo->smsgid, &M, msg_snd_rcv_sz, IPC_NOWAIT);    last_seq_no = M.seq_no;    if (0 == x) {	diskd_stats.sent_count++;	diskdinfo->away++;    } else {	debug(79, 1) ("storeDiskdSend: msgsnd: %s\n", xstrerror());	if (M.callback_data)	    cbdataUnlock(M.callback_data);	assert(++send_errors < 100);    }    return x;}/* * We can't pass memFree() as a free function here, because we need to free * the fsstate variable .. */static voidstoreDiskdIOFreeEntry(void *sio){    memPoolFree(diskd_state_pool, ((storeIOState *) sio)->fsstate);}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一二三区精品福利视频| 五月天激情综合| 欧美日韩一区 二区 三区 久久精品| 爽好久久久欧美精品| 久久精品水蜜桃av综合天堂| 91国偷自产一区二区开放时间| 国内精品免费**视频| 亚洲一区影音先锋| 欧美国产日韩a欧美在线观看| 欧美久久一二三四区| 99久久久无码国产精品| 久久国产剧场电影| 无吗不卡中文字幕| 亚洲视频精选在线| 国产欧美日韩综合精品一区二区| 7777精品伊人久久久大香线蕉完整版 | 在线观看免费亚洲| 国产福利一区二区三区视频| 美腿丝袜一区二区三区| 亚洲va国产天堂va久久en| 亚洲六月丁香色婷婷综合久久| 日本一区二区三区电影| 26uuu久久综合| 欧美一级高清片在线观看| 欧美日韩黄色影视| 在线欧美小视频| 91麻豆国产福利在线观看| 成人精品亚洲人成在线| 成人午夜视频在线观看| 国产在线视频不卡二| 久久精品国产99久久6| 七七婷婷婷婷精品国产| 天天综合网 天天综合色| 亚洲chinese男男1069| 亚洲午夜一区二区三区| 亚洲高清不卡在线观看| 亚洲国产精品麻豆| 亚洲va在线va天堂| 日韩二区在线观看| 日韩电影在线观看电影| 青青青爽久久午夜综合久久午夜| 日本色综合中文字幕| 青草国产精品久久久久久| 美腿丝袜亚洲综合| 麻豆久久久久久久| 国产福利91精品一区二区三区| 国产黄色精品网站| 不卡的av在线| 色悠悠久久综合| 欧美日韩不卡在线| 日韩精品中文字幕一区二区三区 | 国产99精品在线观看| 大白屁股一区二区视频| 93久久精品日日躁夜夜躁欧美| 97久久久精品综合88久久| 91极品视觉盛宴| 91精品啪在线观看国产60岁| 日韩视频免费观看高清完整版在线观看 | 国产日韩欧美亚洲| 中文字幕在线不卡一区二区三区| 亚洲人成网站在线| 丝袜美腿亚洲一区二区图片| 久久精品国产精品亚洲红杏| 高清不卡一区二区在线| 色婷婷精品久久二区二区蜜臂av | 国产精品18久久久久| www.激情成人| 在线观看日韩高清av| 日韩欧美一级精品久久| 中文字幕乱码一区二区免费| 亚洲另类在线视频| 蜜乳av一区二区三区| 高清beeg欧美| 5566中文字幕一区二区电影| 久久奇米777| 亚洲男人都懂的| 奇米综合一区二区三区精品视频| 成人教育av在线| 69久久夜色精品国产69蝌蚪网| 国产丝袜美腿一区二区三区| 一区二区三区欧美激情| 久久99精品国产91久久来源| 91香蕉视频黄| 欧美白人最猛性xxxxx69交| 一区视频在线播放| 全国精品久久少妇| 91麻豆6部合集magnet| 日韩午夜电影av| 亚洲欧美日韩国产另类专区| 久久se精品一区二区| 日本电影欧美片| 久久欧美一区二区| 亚洲午夜激情网页| 国产成人aaa| 91精品国产综合久久精品麻豆| 欧美国产激情一区二区三区蜜月| 天天综合色天天综合色h| 99久久久免费精品国产一区二区| 日韩免费观看高清完整版| 亚洲欧美色综合| 国产精品一二三四区| 51精品国自产在线| 亚洲人精品一区| 国产精品自产自拍| 91精品国产色综合久久不卡电影 | 一区二区高清视频在线观看| 国产精品一级在线| 日韩精品一区二区三区在线观看 | 26uuu亚洲综合色| 日韩有码一区二区三区| 色综合久久六月婷婷中文字幕| 久久久久久亚洲综合影院红桃| 日本女优在线视频一区二区| 欧美综合在线视频| 亚洲欧美日韩一区二区三区在线观看| 久久99国产精品久久99果冻传媒| 欧美日韩亚洲丝袜制服| 亚洲一区二区影院| 色天使色偷偷av一区二区| 国产精品电影院| 成人久久18免费网站麻豆| 久久精品日韩一区二区三区| 精品一区二区三区免费| 欧美一区二区三区婷婷月色| 日韩高清欧美激情| 91精品在线观看入口| 舔着乳尖日韩一区| 这里只有精品99re| 视频一区视频二区在线观看| 欧美日韩亚洲国产综合| 亚洲午夜视频在线| 欧美最猛性xxxxx直播| 夜夜操天天操亚洲| 在线视频中文字幕一区二区| 一区二区三区成人| 欧美在线观看18| 亚洲国产综合色| 欧美少妇bbb| 亚洲成av人片在线观看无码| 欧美日韩国产高清一区二区三区 | 六月婷婷色综合| 精品日产卡一卡二卡麻豆| 久久99精品久久久久久国产越南 | 成人午夜免费视频| 国产精品无圣光一区二区| 成人网在线播放| 亚洲男人电影天堂| 欧美日韩精品一区二区三区蜜桃| 午夜精品福利一区二区蜜股av | 亚洲国产精品久久艾草纯爱| 欧洲一区二区三区在线| 亚洲成国产人片在线观看| 91精品国产一区二区| 激情久久久久久久久久久久久久久久| 26uuu色噜噜精品一区二区| 成人午夜私人影院| 亚洲无人区一区| 欧美成人午夜电影| 成人妖精视频yjsp地址| 亚洲美女免费视频| 欧美精品第1页| 国产乱理伦片在线观看夜一区| 国产精品久久久久久久久免费丝袜| 91麻豆精品一区二区三区| 亚洲不卡在线观看| 欧美大肚乱孕交hd孕妇| 9久草视频在线视频精品| 亚洲一区二区三区在线| 精品久久久久久最新网址| 成年人网站91| 天天爽夜夜爽夜夜爽精品视频 | 一片黄亚洲嫩模| 欧美一区二区精美| aaa亚洲精品| 蜜臀99久久精品久久久久久软件| 国产精品久久久久久久久免费桃花 | 日韩欧美中文字幕公布| 国产超碰在线一区| 婷婷开心激情综合| 欧美国产禁国产网站cc| 欧美蜜桃一区二区三区| 国产成人aaa| 五月天一区二区三区| 国产三级久久久| 欧美日韩精品久久久| 国产成人综合自拍| 日韩专区中文字幕一区二区| 中文字幕久久午夜不卡| 欧美狂野另类xxxxoooo| 成人av影院在线| 美女在线观看视频一区二区| 亚洲人123区| 久久人人爽人人爽| 91精品国产乱| 色综合中文字幕国产| 国产精一品亚洲二区在线视频| 婷婷久久综合九色综合绿巨人| 亚洲色图都市小说| 久久久久久亚洲综合影院红桃| 911精品产国品一二三产区|