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

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

?? mmc_queue.c

?? mmc 記憶棒驅(qū)動 for linux ,可以看一看
?? C
字號:
/* *  linux/drivers/mmc/mmc_queue.c * *  Copyright (C) 2003 Russell King, All Rights Reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * */#include <linux/module.h>#include <linux/blkdev.h>#include <linux/mmc/card.h>#include <linux/mmc/host.h>#include "mmc_queue.h"#define MMC_QUEUE_EXIT		(1 << 0)#define MMC_QUEUE_SUSPENDED	(1 << 1)/* * Prepare a MMC request.  Essentially, this means passing the * preparation off to the media driver.  The media driver will * create a mmc_io_request in req->special. */static int mmc_prep_request(struct request_queue *q, struct request *req){	struct mmc_queue *mq = q->queuedata;	int ret = BLKPREP_KILL;	if (req->flags & REQ_SPECIAL) {		/*		 * Special commands already have the command		 * blocks already setup in req->special.		 */		BUG_ON(!req->special);		ret = BLKPREP_OK;	} else if (req->flags & (REQ_CMD | REQ_BLOCK_PC)) {		/*		 * Block I/O requests need translating according		 * to the protocol.		 */		ret = mq->prep_fn(mq, req);	} else {		/*		 * Everything else is invalid.		 */		blk_dump_rq_flags(req, "MMC bad request");	}	if (ret == BLKPREP_OK)		req->flags |= REQ_DONTPREP;	return ret;}static int mmc_queue_thread(void *d){	struct mmc_queue *mq = d;	struct request_queue *q = mq->queue;	DECLARE_WAITQUEUE(wait, current);	/*	 * Set iothread to ensure that we aren't put to sleep by	 * the process freezing.  We handle suspension ourselves.	 */	current->flags |= PF_MEMALLOC|PF_NOFREEZE;	daemonize("mmcqd");	complete(&mq->thread_complete);	down(&mq->thread_sem);	add_wait_queue(&mq->thread_wq, &wait);	do {		struct request *req = NULL;		spin_lock_irq(q->queue_lock);		set_current_state(TASK_INTERRUPTIBLE);		if (!blk_queue_plugged(q))			mq->req = req = elv_next_request(q);		spin_unlock_irq(q->queue_lock);		if (!req) {			if (mq->flags & MMC_QUEUE_EXIT)				break;			up(&mq->thread_sem);			schedule();			down(&mq->thread_sem);			continue;		}		set_current_state(TASK_RUNNING);		mq->issue_fn(mq, req);	} while (1);	remove_wait_queue(&mq->thread_wq, &wait);	up(&mq->thread_sem);	complete_and_exit(&mq->thread_complete, 0);	return 0;}/* * Generic MMC request handler.  This is called for any queue on a * particular host.  When the host is not busy, we look for a request * on any queue on this host, and attempt to issue it.  This may * not be the queue we were asked to process. */static void mmc_request(request_queue_t *q){	struct mmc_queue *mq = q->queuedata;	if (!mq->req)		wake_up(&mq->thread_wq);}/** * mmc_init_queue - initialise a queue structure. * @mq: mmc queue * @card: mmc card to attach this queue * @lock: queue lock * * Initialise a MMC card request queue. */int mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card, spinlock_t *lock){	struct mmc_host *host = card->host;	u64 limit = BLK_BOUNCE_HIGH;	int ret;	if (host->dev->dma_mask && *host->dev->dma_mask)		limit = *host->dev->dma_mask;	mq->card = card;	mq->queue = blk_init_queue(mmc_request, lock);	if (!mq->queue)		return -ENOMEM;	blk_queue_prep_rq(mq->queue, mmc_prep_request);	blk_queue_bounce_limit(mq->queue, limit);	blk_queue_max_sectors(mq->queue, host->max_sectors);	blk_queue_max_phys_segments(mq->queue, host->max_phys_segs);	blk_queue_max_hw_segments(mq->queue, host->max_hw_segs);	blk_queue_max_segment_size(mq->queue, host->max_seg_size);	mq->queue->queuedata = mq;	mq->req = NULL;	mq->sg = kmalloc(sizeof(struct scatterlist) * host->max_phys_segs,			 GFP_KERNEL);	if (!mq->sg) {		ret = -ENOMEM;		goto cleanup;	}	init_completion(&mq->thread_complete);	init_waitqueue_head(&mq->thread_wq);	init_MUTEX(&mq->thread_sem);	ret = kernel_thread(mmc_queue_thread, mq, CLONE_KERNEL);	if (ret >= 0) {		wait_for_completion(&mq->thread_complete);		init_completion(&mq->thread_complete);		ret = 0;		goto out;	} cleanup:	kfree(mq->sg);	mq->sg = NULL;	blk_cleanup_queue(mq->queue); out:	return ret;}EXPORT_SYMBOL(mmc_init_queue);void mmc_cleanup_queue(struct mmc_queue *mq){	mq->flags |= MMC_QUEUE_EXIT;	wake_up(&mq->thread_wq);	wait_for_completion(&mq->thread_complete);	kfree(mq->sg);	mq->sg = NULL;	blk_cleanup_queue(mq->queue);	mq->card = NULL;}EXPORT_SYMBOL(mmc_cleanup_queue);/** * mmc_queue_suspend - suspend a MMC request queue * @mq: MMC queue to suspend * * Stop the block request queue, and wait for our thread to * complete any outstanding requests.  This ensures that we * won't suspend while a request is being processed. */void mmc_queue_suspend(struct mmc_queue *mq){	request_queue_t *q = mq->queue;	unsigned long flags;	if (!(mq->flags & MMC_QUEUE_SUSPENDED)) {		mq->flags |= MMC_QUEUE_SUSPENDED;		spin_lock_irqsave(q->queue_lock, flags);		blk_stop_queue(q);		spin_unlock_irqrestore(q->queue_lock, flags);		down(&mq->thread_sem);	}}EXPORT_SYMBOL(mmc_queue_suspend);/** * mmc_queue_resume - resume a previously suspended MMC request queue * @mq: MMC queue to resume */void mmc_queue_resume(struct mmc_queue *mq){	request_queue_t *q = mq->queue;	unsigned long flags;	if (mq->flags & MMC_QUEUE_SUSPENDED) {		mq->flags &= ~MMC_QUEUE_SUSPENDED;		up(&mq->thread_sem);		spin_lock_irqsave(q->queue_lock, flags);		blk_start_queue(q);		spin_unlock_irqrestore(q->queue_lock, flags);	}}EXPORT_SYMBOL(mmc_queue_resume);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人深夜在线观看| 成人av动漫网站| 久久久久久99精品| av高清久久久| 丝袜国产日韩另类美女| ww亚洲ww在线观看国产| 91蝌蚪porny| 日本成人超碰在线观看| 国产亚洲欧美在线| 欧洲精品在线观看| 午夜私人影院久久久久| 久久久久国产免费免费| 91久久线看在观草草青青| 日韩经典一区二区| 欧美国产亚洲另类动漫| 欧美嫩在线观看| 国产精品性做久久久久久| 伊人夜夜躁av伊人久久| 日韩欧美专区在线| 日本高清免费不卡视频| 水野朝阳av一区二区三区| 中文字幕免费观看一区| 在线播放中文一区| 国产suv精品一区二区883| 日日夜夜精品视频天天综合网| 国产精品伦一区二区三级视频| 欧美一区二区三区小说| 日本乱人伦一区| 久久精品国产在热久久| 亚洲一二三区不卡| 精品久久久久久久久久久久久久久 | 亚洲成a人片在线观看中文| 精品久久久久久无| 欧美日本精品一区二区三区| 成人网男人的天堂| 国内成人自拍视频| 天天免费综合色| 亚洲激情中文1区| 日本一区二区三区在线不卡 | 成人精品视频.| 奇米888四色在线精品| 国产午夜精品在线观看| 欧美一区二区三区在线观看| 91精品1区2区| 成人av网站大全| 中文字幕巨乱亚洲| 日韩欧美中文字幕精品| 欧美va天堂va视频va在线| 欧美mv日韩mv国产网站app| 欧美xxx久久| 久久影院电视剧免费观看| 久久久久久久综合日本| 国产夜色精品一区二区av| 国产精品女主播av| 综合精品久久久| 亚洲成人精品在线观看| 日韩高清不卡一区二区| 国产在线国偷精品免费看| 国产一区999| 99这里都是精品| 91啦中文在线观看| 在线播放中文字幕一区| 欧美videos中文字幕| 国产视频一区在线播放| 中文字幕在线不卡国产视频| 夜色激情一区二区| 首页国产欧美日韩丝袜| 久久91精品久久久久久秒播| 国产成人精品亚洲777人妖| www.综合网.com| 欧美亚洲综合另类| 日韩精品中文字幕一区| 亚洲国产精品成人久久综合一区| 自拍偷拍欧美激情| 日韩一区欧美二区| 盗摄精品av一区二区三区| 色综合久久综合中文综合网| 91精品婷婷国产综合久久| 久久综合色8888| 一区二区成人在线视频| 美女高潮久久久| 97久久精品人人爽人人爽蜜臀| 欧美疯狂性受xxxxx喷水图片| 久久亚洲一区二区三区四区| 亚洲另类色综合网站| 奇米影视在线99精品| 国产成人精品一区二| 欧美亚洲高清一区二区三区不卡| xnxx国产精品| 一区二区三区日韩精品视频| 韩国欧美国产1区| 91女神在线视频| 精品国产一区二区在线观看| 亚洲人成小说网站色在线 | 亚洲一区二区三区四区五区黄| 卡一卡二国产精品| 色先锋久久av资源部| 久久综合资源网| 亚洲一区二区精品久久av| 国产成人免费高清| 日韩欧美中文一区二区| 亚洲另类色综合网站| 国产精品一区二区91| 555夜色666亚洲国产免| 中文字幕一区视频| 国内精品在线播放| 欧美高清视频www夜色资源网| 国产精品久久一卡二卡| 久久国产精品色婷婷| 欧美人牲a欧美精品| 亚洲欧美激情小说另类| 国产成人欧美日韩在线电影| 日韩免费视频线观看| 亚洲午夜久久久久中文字幕久| 成人精品国产福利| 欧美不卡一区二区| 日本怡春院一区二区| 欧美日韩dvd在线观看| 亚洲人午夜精品天堂一二香蕉| 国产经典欧美精品| 日韩精品一区二区三区swag | 成人av网站免费观看| 久久久国产精华| 黄网站免费久久| 91精品国产综合久久精品app| 亚洲另类色综合网站| 97久久精品人人爽人人爽蜜臀| 亚洲国产高清不卡| 国产成人午夜99999| 久久久久久久电影| 国产东北露脸精品视频| 久久久久综合网| 激情五月婷婷综合| 精品美女在线播放| 狠狠狠色丁香婷婷综合激情| 精品国产区一区| 久久av资源站| 精品va天堂亚洲国产| 日本不卡的三区四区五区| 91精品国产综合久久久久| 日韩在线一区二区| 日韩三级中文字幕| 日本不卡视频在线观看| 欧美一级一区二区| 免费av成人在线| 欧美一区二区久久久| 日av在线不卡| 日韩一级黄色大片| 国内不卡的二区三区中文字幕 | 国产精品欧美一级免费| av在线一区二区三区| 亚洲另类在线视频| 在线观看视频欧美| 日韩中文字幕91| 精品成人佐山爱一区二区| 国产寡妇亲子伦一区二区| 国产精品国产精品国产专区不蜜 | 岛国精品在线观看| 欧美性色aⅴ视频一区日韩精品| 国产亚洲欧洲一区高清在线观看| 韩国v欧美v亚洲v日本v| 国产亚洲欧美在线| 91在线免费看| 国产揄拍国内精品对白| 日韩精品一区二区三区视频在线观看 | 国产一区二区久久| 日韩欧美一级二级| 日产国产高清一区二区三区| 欧美精品久久久久久久多人混战 | av在线免费不卡| 国产精品午夜在线| jvid福利写真一区二区三区| 中文一区二区在线观看| 国产成人av一区| 久久久久久久网| 国产精一区二区三区| 久久久午夜电影| 国产91在线|亚洲| 国产精品久久久久一区| jiyouzz国产精品久久| 亚洲免费看黄网站| 欧美日韩精品二区第二页| 日韩精品欧美精品| 日韩美女一区二区三区| 国产一区福利在线| 国产欧美一区二区三区在线老狼 | 中文字幕一区二区三中文字幕| www.日韩大片| 亚洲黄一区二区三区| 欧美日韩美女一区二区| 捆绑变态av一区二区三区| 久久蜜桃一区二区| 色综合中文字幕国产 | 国产无一区二区| 91丨国产丨九色丨pron| 午夜电影网一区| 国产亚洲精品aa午夜观看| 色悠久久久久综合欧美99| 丝袜a∨在线一区二区三区不卡| 久久亚洲精华国产精华液|