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

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

?? ide-taskfile.c

?? ep9315平臺下硬盤驅動的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
		if (stat & (ERR_STAT|DRQ_STAT)) {			if (!rq->bh) {                                rq->current_nr_sectors += drive->mult_count;				/*				 * NOTE: could rewind beyond beginning :-/				 */			} else {				printk(KERN_ERR "%s: MULTI-WRITE assume all data " \					"transfered is bad status=0x%02x\n",					drive->name, stat);			}			return DRIVER(drive)->error(drive, "task_mulout_intr", stat);		}		if (!rq->bh)			DRIVER(drive)->end_request(drive, 1);		return startstop;	}	/*	 * DON'T be lazy code the above and below togather !!!	 */	if (!OK_STAT(stat,DATA_READY,BAD_R_STAT)) {		if (stat & (ERR_STAT|DRQ_STAT)) {			if (!rq->bh) {				rq->current_nr_sectors += drive->mult_count;				/*				 * NOTE: could rewind beyond beginning :-/				 */			} else {				printk(KERN_ERR "%s: MULTI-WRITE assume all data " \					"transfered is bad status=0x%02x\n",					drive->name, stat);			}			return DRIVER(drive)->error(drive, "task_mulout_intr", stat);		}		/* no data yet, so wait for another interrupt */		if (HWGROUP(drive)->handler == NULL)			ide_set_handler(drive, &task_mulout_intr, WAIT_WORSTCASE, NULL);		return ide_started;	}#ifndef ALTERNATE_STATE_DIAGRAM_MULTI_OUT	if (HWGROUP(drive)->handler != NULL) {		unsigned long lflags;		spin_lock_irqsave(&io_request_lock, lflags);		HWGROUP(drive)->handler = NULL;		del_timer(&HWGROUP(drive)->timer);		spin_unlock_irqrestore(&io_request_lock, lflags);	}#endif /* ALTERNATE_STATE_DIAGRAM_MULTI_OUT */	do {		nsect = rq->current_nr_sectors;		if (nsect > msect)			nsect = msect;		pBuf = task_map_rq(rq, &flags);		DTF("Multiwrite: %p, nsect: %d, msect: %d, " \			"rq->current_nr_sectors: %ld\n",			pBuf, nsect, msect, rq->current_nr_sectors);		msect -= nsect;		taskfile_output_data(drive, pBuf, nsect * SECTOR_WORDS);		task_unmap_rq(rq, pBuf, &flags);		rq->current_nr_sectors -= nsect;		/*		 * FIXME :: We really can not legally get a new page/bh		 * regardless, if this is the end of our segment.		 * BH walking or segment can only be updated after we		 * have a good  hwif->INB(IDE_STATUS_REG); return.		 */		if (!rq->current_nr_sectors) {			if (!DRIVER(drive)->end_request(drive, 1))				if (!rq->bh)					return ide_stopped;		}	} while (msect);	rq->errors = 0;	if (HWGROUP(drive)->handler == NULL)		ide_set_handler(drive, &task_mulout_intr, WAIT_WORSTCASE, NULL);	return ide_started;}EXPORT_SYMBOL(task_mulout_intr);/* Called by internal to feature out type of command being called *///ide_pre_handler_t * ide_pre_handler_parser (task_struct_t *taskfile, hob_struct_t *hobfile)ide_pre_handler_t * ide_pre_handler_parser (struct hd_drive_task_hdr *taskfile, struct hd_drive_hob_hdr *hobfile){	switch(taskfile->command) {				/* IDE_DRIVE_TASK_RAW_WRITE */		case CFA_WRITE_MULTI_WO_ERASE:	//	case WIN_WRITE_LONG:	//	case WIN_WRITE_LONG_ONCE:		case WIN_MULTWRITE:		case WIN_MULTWRITE_EXT:			return &pre_task_mulout_intr;							/* IDE_DRIVE_TASK_OUT */		case WIN_WRITE:	//	case WIN_WRITE_ONCE:		case WIN_WRITE_EXT:		case WIN_WRITE_VERIFY:		case WIN_WRITE_BUFFER:		case CFA_WRITE_SECT_WO_ERASE:		case WIN_DOWNLOAD_MICROCODE:			return &pre_task_out_intr;				/* IDE_DRIVE_TASK_OUT */		case WIN_SMART:			if (taskfile->feature == SMART_WRITE_LOG_SECTOR)				return &pre_task_out_intr;		case WIN_WRITEDMA:	//	case WIN_WRITEDMA_ONCE:		case WIN_WRITEDMA_QUEUED:		case WIN_WRITEDMA_EXT:		case WIN_WRITEDMA_QUEUED_EXT:				/* IDE_DRIVE_TASK_OUT */		default:			break;	}	return(NULL);}EXPORT_SYMBOL(ide_pre_handler_parser);/* Called by internal to feature out type of command being called *///ide_handler_t * ide_handler_parser (task_struct_t *taskfile, hob_struct_t *hobfile)ide_handler_t * ide_handler_parser (struct hd_drive_task_hdr *taskfile, struct hd_drive_hob_hdr *hobfile){	switch(taskfile->command) {		case WIN_IDENTIFY:		case WIN_PIDENTIFY:		case CFA_TRANSLATE_SECTOR:		case WIN_READ_BUFFER:		case WIN_READ:	//	case WIN_READ_ONCE:		case WIN_READ_EXT:			return &task_in_intr;		case WIN_SECURITY_DISABLE:		case WIN_SECURITY_ERASE_UNIT:		case WIN_SECURITY_SET_PASS:		case WIN_SECURITY_UNLOCK:		case WIN_DOWNLOAD_MICROCODE:		case CFA_WRITE_SECT_WO_ERASE:		case WIN_WRITE_BUFFER:		case WIN_WRITE_VERIFY:		case WIN_WRITE:	//	case WIN_WRITE_ONCE:			case WIN_WRITE_EXT:			return &task_out_intr;	//	case WIN_READ_LONG:	//	case WIN_READ_LONG_ONCE:		case WIN_MULTREAD:		case WIN_MULTREAD_EXT:			return &task_mulin_intr;	//	case WIN_WRITE_LONG:	//	case WIN_WRITE_LONG_ONCE:		case CFA_WRITE_MULTI_WO_ERASE:		case WIN_MULTWRITE:		case WIN_MULTWRITE_EXT:			return &task_mulout_intr;		case WIN_SMART:			switch(taskfile->feature) {				case SMART_READ_VALUES:				case SMART_READ_THRESHOLDS:				case SMART_READ_LOG_SECTOR:					return &task_in_intr;				case SMART_WRITE_LOG_SECTOR:					return &task_out_intr;				default:					return &task_no_data_intr;			}		case CFA_REQ_EXT_ERROR_CODE:		case CFA_ERASE_SECTORS:		case WIN_VERIFY:	//	case WIN_VERIFY_ONCE:		case WIN_VERIFY_EXT:		case WIN_SEEK:			return &task_no_data_intr;		case WIN_SPECIFY:			return &set_geometry_intr;		case WIN_RECAL:	//	case WIN_RESTORE:			return &recal_intr;		case WIN_NOP:		case WIN_DIAGNOSE:		case WIN_FLUSH_CACHE:		case WIN_FLUSH_CACHE_EXT:		case WIN_STANDBYNOW1:		case WIN_STANDBYNOW2:		case WIN_SLEEPNOW1:		case WIN_SLEEPNOW2:		case WIN_SETIDLE1:		case WIN_CHECKPOWERMODE1:		case WIN_CHECKPOWERMODE2:		case WIN_GETMEDIASTATUS:		case WIN_MEDIAEJECT:			return &task_no_data_intr;		case WIN_SETMULT:			return &set_multmode_intr;		case WIN_READ_NATIVE_MAX:		case WIN_SET_MAX:		case WIN_READ_NATIVE_MAX_EXT:		case WIN_SET_MAX_EXT:		case WIN_SECURITY_ERASE_PREPARE:		case WIN_SECURITY_FREEZE_LOCK:		case WIN_DOORLOCK:		case WIN_DOORUNLOCK:		case WIN_SETFEATURES:			return &task_no_data_intr;		case DISABLE_SEAGATE:		case EXABYTE_ENABLE_NEST:			return &task_no_data_intr;#ifdef CONFIG_BLK_DEV_IDEDMA		case WIN_READDMA:	//	case WIN_READDMA_ONCE:		case WIN_IDENTIFY_DMA:		case WIN_READDMA_QUEUED:		case WIN_READDMA_EXT:		case WIN_READDMA_QUEUED_EXT:		case WIN_WRITEDMA:	//	case WIN_WRITEDMA_ONCE:		case WIN_WRITEDMA_QUEUED:		case WIN_WRITEDMA_EXT:		case WIN_WRITEDMA_QUEUED_EXT:#endif		case WIN_FORMAT:		case WIN_INIT:		case WIN_DEVICE_RESET:		case WIN_QUEUED_SERVICE:		case WIN_PACKETCMD:		default:			return(NULL);	}	}EXPORT_SYMBOL(ide_handler_parser);ide_post_handler_t * ide_post_handler_parser (struct hd_drive_task_hdr *taskfile, struct hd_drive_hob_hdr *hobfile){	switch(taskfile->command) {		case WIN_SPECIFY:	/* set_geometry_intr */		case WIN_RESTORE:	/* recal_intr */		case WIN_SETMULT:	/* set_multmode_intr */		default:			return(NULL);	}}EXPORT_SYMBOL(ide_post_handler_parser);/* Called by ioctl to feature out type of command being called */int ide_cmd_type_parser (ide_task_t *args){	task_struct_t *taskfile = (task_struct_t *) args->tfRegister;	hob_struct_t *hobfile   = (hob_struct_t *) args->hobRegister;	args->prehandler	= ide_pre_handler_parser(taskfile, hobfile);	args->handler		= ide_handler_parser(taskfile, hobfile);	args->posthandler	= ide_post_handler_parser(taskfile, hobfile);	switch(args->tfRegister[IDE_COMMAND_OFFSET]) {		case WIN_IDENTIFY:		case WIN_PIDENTIFY:			return IDE_DRIVE_TASK_IN;		case CFA_TRANSLATE_SECTOR:		case WIN_READ:	//	case WIN_READ_ONCE:		case WIN_READ_EXT:		case WIN_READ_BUFFER:			return IDE_DRIVE_TASK_IN;		case WIN_WRITE:	//	case WIN_WRITE_ONCE:		case WIN_WRITE_EXT:		case WIN_WRITE_VERIFY:		case WIN_WRITE_BUFFER:		case CFA_WRITE_SECT_WO_ERASE:		case WIN_DOWNLOAD_MICROCODE:			return IDE_DRIVE_TASK_RAW_WRITE;	//	case WIN_READ_LONG:	//	case WIN_READ_LONG_ONCE:		case WIN_MULTREAD:		case WIN_MULTREAD_EXT:			return IDE_DRIVE_TASK_IN;	//	case WIN_WRITE_LONG:	//	case WIN_WRITE_LONG_ONCE:		case CFA_WRITE_MULTI_WO_ERASE:		case WIN_MULTWRITE:		case WIN_MULTWRITE_EXT:			return IDE_DRIVE_TASK_RAW_WRITE;		case WIN_SECURITY_DISABLE:		case WIN_SECURITY_ERASE_UNIT:		case WIN_SECURITY_SET_PASS:		case WIN_SECURITY_UNLOCK:			return IDE_DRIVE_TASK_OUT;		case WIN_SMART:			args->tfRegister[IDE_LCYL_OFFSET] = SMART_LCYL_PASS;			args->tfRegister[IDE_HCYL_OFFSET] = SMART_HCYL_PASS;			switch(args->tfRegister[IDE_FEATURE_OFFSET]) {				case SMART_READ_VALUES:				case SMART_READ_THRESHOLDS:				case SMART_READ_LOG_SECTOR:					return IDE_DRIVE_TASK_IN;				case SMART_WRITE_LOG_SECTOR:					return IDE_DRIVE_TASK_OUT;				default:					return IDE_DRIVE_TASK_NO_DATA;			}#ifdef CONFIG_BLK_DEV_IDEDMA		case WIN_READDMA:	//	case WIN_READDMA_ONCE:		case WIN_IDENTIFY_DMA:		case WIN_READDMA_QUEUED:		case WIN_READDMA_EXT:		case WIN_READDMA_QUEUED_EXT:			return IDE_DRIVE_TASK_IN;		case WIN_WRITEDMA:	//	case WIN_WRITEDMA_ONCE:		case WIN_WRITEDMA_QUEUED:		case WIN_WRITEDMA_EXT:		case WIN_WRITEDMA_QUEUED_EXT:			return IDE_DRIVE_TASK_RAW_WRITE;#endif		case WIN_SETFEATURES:			switch(args->tfRegister[IDE_FEATURE_OFFSET]) {				case SETFEATURES_EN_8BIT:				case SETFEATURES_EN_WCACHE:					return IDE_DRIVE_TASK_NO_DATA;				case SETFEATURES_XFER:					return IDE_DRIVE_TASK_SET_XFER;				case SETFEATURES_DIS_DEFECT:				case SETFEATURES_EN_APM:				case SETFEATURES_DIS_MSN:				case SETFEATURES_DIS_RETRY:				case SETFEATURES_EN_AAM:				case SETFEATURES_RW_LONG:				case SETFEATURES_SET_CACHE:				case SETFEATURES_DIS_RLA:				case SETFEATURES_EN_RI:				case SETFEATURES_EN_SI:				case SETFEATURES_DIS_RPOD:				case SETFEATURES_DIS_WCACHE:				case SETFEATURES_EN_DEFECT:				case SETFEATURES_DIS_APM:				case SETFEATURES_EN_ECC:				case SETFEATURES_EN_MSN:				case SETFEATURES_EN_RETRY:				case SETFEATURES_EN_RLA:				case SETFEATURES_PREFETCH:				case SETFEATURES_4B_RW_LONG:				case SETFEATURES_DIS_AAM:				case SETFEATURES_EN_RPOD:				case SETFEATURES_DIS_RI:				case SETFEATURES_DIS_SI:				default:					return IDE_DRIVE_TASK_NO_DATA;			}		case WIN_NOP:		case CFA_REQ_EXT_ERROR_CODE:		case CFA_ERASE_SECTORS:		case WIN_VERIFY:	//	case WIN_VERIFY_ONCE:		case WIN_VERIFY_EXT:		case WIN_SEEK:		case WIN_SPECIFY:		case WIN_RESTORE:		case WIN_DIAGNOSE:		case WIN_FLUSH_CACHE:		case WIN_FLUSH_CACHE_EXT:		case WIN_STANDBYNOW1:		case WIN_STANDBYNOW2:		case WIN_SLEEPNOW1:		case WIN_SLEEPNOW2:		case WIN_SETIDLE1:		case DISABLE_SEAGATE:		case WIN_CHECKPOWERMODE1:		case WIN_CHECKPOWERMODE2:		case WIN_GETMEDIASTATUS:		case WIN_MEDIAEJECT:		case WIN_SETMULT:		case WIN_READ_NATIVE_MAX:		case WIN_SET_MAX:		case WIN_READ_NATIVE_MAX_EXT:		case WIN_SET_MAX_EXT:		case WIN_SECURITY_ERASE_PREPARE:		case WIN_SECURITY_FREEZE_LOCK:		case EXABYTE_ENABLE_NEST:		case WIN_DOORLOCK:		case WIN_DOORUNLOCK:			return IDE_DRIVE_TASK_NO_DATA;		case WIN_FORMAT:		case WIN_INIT:		case WIN_DEVICE_RESET:		case WIN_QUEUED_SERVICE:		case WIN_PACKETCMD:		default:			return IDE_DRIVE_TASK_INVALID;	}}EXPORT_SYMBOL(ide_cmd_type_parser);/* * This function is intended to be used prior to invoking ide_do_drive_cmd(). */void ide_init_drive_taskfile (struct request *rq){	memset(rq, 0, sizeof(*rq));	rq->cmd = IDE_DRIVE_TASK_NO_DATA;}EXPORT_SYMBOL(ide_init_drive_taskfile);#if 1int ide_diag_taskfile (ide_drive_t *drive, ide_task_t *args, unsigned long data_size, u8 *buf){	struct request rq;	ide_init_drive_taskfile(&rq);	rq.cmd = IDE_DRIVE_TASKFILE;	rq.buffer = buf;	/*	 * (ks) We transfer currently only whole sectors.	 * This is suffient for now.  But, it would be great,	 * if we would find a solution to transfer any size.	 * To support special commands like READ LONG.	 */	if (args->command_type != IDE_DRIVE_TASK_NO_DATA) {		if (data_size == 0)			rq.current_nr_sectors = rq.nr_sectors = (args->hobRegister[IDE_NSECTOR_OFFSET_HOB] << 8) | args->tfRegister[IDE_NSECTOR_OFFSET];		/*	rq.hard_cur_sectors	*/		else			rq.current_nr_sectors = rq.nr_sectors = data_size / SECTOR_SIZE;		/*	rq.hard_cur_sectors	*/	}	if (args->tf_out_flags.all == 0) {		/*		 * clean up kernel settings for driver sanity, regardless.		 * except for discrete diag services.		 */		args->posthandler = ide_post_handler_parser(				(struct hd_drive_task_hdr *) args->tfRegister,				(struct hd_drive_hob_hdr *) args->hobRegister);	}	rq.special = args;	return ide_do_drive_cmd(drive, &rq, ide_wait);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲激情网站免费观看| 精品一区二区国语对白| 亚洲国产人成综合网站| 精品在线一区二区| 91国产福利在线| 国产亚洲va综合人人澡精品| 亚洲精品精品亚洲| 国产福利一区二区三区视频在线 | 精品国产自在久精品国产| 久久久久亚洲蜜桃| 婷婷综合另类小说色区| 91理论电影在线观看| 久久综合九色欧美综合狠狠| 亚洲国产精品一区二区www在线 | 欧美sm美女调教| 一区二区三区在线视频观看58| 国内精品国产成人国产三级粉色| 在线免费观看一区| 国产精品传媒视频| 国产精品一卡二卡| 日韩精品中午字幕| 午夜成人免费电影| 欧美中文字幕一区| 亚洲免费在线观看视频| 成人午夜精品在线| 2020国产精品| 久久成人免费电影| 日韩欧美专区在线| 日本成人中文字幕| 777精品伊人久久久久大香线蕉| 亚洲激情中文1区| 91蜜桃免费观看视频| 国产精品欧美极品| caoporn国产一区二区| 欧美国产国产综合| 成人三级伦理片| 中文字幕欧美国产| 成人免费高清在线| 国产欧美日韩另类视频免费观看| 国产一区二区三区四| www国产精品av| 国产真实精品久久二三区| 精品国产凹凸成av人导航| 精品一区二区三区视频在线观看 | 在线亚洲一区观看| 一区二区高清视频在线观看| 色中色一区二区| 亚洲一区自拍偷拍| 欧美精品一二三| 美腿丝袜一区二区三区| 欧美zozo另类异族| 风间由美性色一区二区三区| 亚洲欧洲性图库| 欧美色电影在线| 亚洲国产va精品久久久不卡综合| 91精品国产综合久久香蕉麻豆| 青青草国产成人99久久| 精品区一区二区| 国产精品一二三在| 亚洲欧美日韩国产成人精品影院| 欧美日韩一区二区在线观看| 男男成人高潮片免费网站| 久久夜色精品一区| 色偷偷88欧美精品久久久| 三级精品在线观看| 久久久精品天堂| 色欧美88888久久久久久影院| 五月婷婷久久丁香| 国产欧美一区二区精品秋霞影院| 97久久超碰国产精品| 午夜精品免费在线观看| 国产欧美日韩三区| 欧美性一区二区| 激情综合色丁香一区二区| 亚洲欧洲精品一区二区三区不卡| 欧美精品一二三四| 国产成a人亚洲| 亚洲成人免费电影| 国产丝袜欧美中文另类| 欧美综合欧美视频| 国产精品一级黄| 五月天国产精品| 国产精品久久久久7777按摩| 51精品视频一区二区三区| 成人蜜臀av电影| 麻豆精品在线视频| 亚洲午夜在线电影| 国产日韩av一区| 欧美大胆一级视频| 91老司机福利 在线| 国产精品888| 日本aⅴ亚洲精品中文乱码| 亚洲欧美日韩国产另类专区| 久久亚洲春色中文字幕久久久| 欧美亚洲综合一区| 99久久综合国产精品| 国产在线视频一区二区三区| 婷婷开心久久网| 国产精品一区专区| 国产精品色婷婷久久58| youjizz国产精品| 久久只精品国产| 亚洲电影一区二区三区| 久久国产精品免费| 欧美videos大乳护士334| 国产综合色视频| 久久久五月婷婷| 99精品视频在线观看| ...av二区三区久久精品| 91丝袜呻吟高潮美腿白嫩在线观看| 中文字幕人成不卡一区| 日韩欧美一级二级三级久久久| 色就色 综合激情| 99精品视频中文字幕| 成人网男人的天堂| 国产成人av一区二区| 精品一区二区免费在线观看| 奇米影视一区二区三区| 日韩成人午夜电影| 午夜视频在线观看一区二区三区| 亚洲福中文字幕伊人影院| 亚洲精品成人精品456| 亚洲乱码国产乱码精品精的特点| 亚洲欧洲日韩综合一区二区| 国产精品国产三级国产专播品爱网 | 成人精品视频一区二区三区 | 欧美一区二区三区在| 欧美日韩国产首页| 69堂成人精品免费视频| 在线成人av影院| 日韩免费观看2025年上映的电影| 91精品啪在线观看国产60岁| 欧美一区二区三区在| 久久美女艺术照精彩视频福利播放 | 成人免费视频一区| 99re热视频精品| 色天天综合色天天久久| 欧美午夜影院一区| 欧美一区永久视频免费观看| 欧美精品一区二区三区在线| 久久久高清一区二区三区| 国产精品乱码一区二三区小蝌蚪| 中文字幕亚洲精品在线观看| 悠悠色在线精品| 日本亚洲一区二区| 国产一区二区成人久久免费影院| 成人天堂资源www在线| 色域天天综合网| 欧美一级专区免费大片| 日本一区二区免费在线| 亚洲黄色免费电影| 久久超碰97中文字幕| 99在线热播精品免费| 欧美日韩国产一二三| 久久这里只精品最新地址| 亚洲色图一区二区| 美脚の诱脚舐め脚责91| 99免费精品视频| 欧美一级一区二区| 国产精品亲子乱子伦xxxx裸| 亚洲国产精品一区二区久久| 激情成人综合网| 色偷偷久久一区二区三区| 欧美精品一区二区不卡| 亚洲精品高清在线观看| 久久99国产精品免费网站| 99国产一区二区三精品乱码| 欧美一区二区在线不卡| 亚洲欧美自拍偷拍色图| 老司机一区二区| 色综合久久66| 欧美国产精品久久| 国产成人在线影院| 欧美精品一二三| 亚洲欧美色图小说| 国产伦精品一区二区三区在线观看| 91搞黄在线观看| 日本一区二区三区dvd视频在线 | 色婷婷激情综合| 国产日韩欧美电影| 久热成人在线视频| 欧美日韩一区久久| 亚洲视频免费在线| 成人一区二区三区中文字幕| 欧美大片一区二区三区| 亚洲午夜成aⅴ人片| 波多野结衣中文一区| 久久久久亚洲蜜桃| 激情亚洲综合在线| 欧美大片一区二区三区| 亚洲成人综合视频| 欧美色综合网站| 一区二区三区日韩欧美精品| 大白屁股一区二区视频| 久久综合九色综合久久久精品综合| 亚洲成人黄色影院| 欧美日韩成人综合| 亚洲一区二区欧美激情| 91麻豆国产自产在线观看| 国产精品久久久久久久久免费樱桃 |