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

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

?? ide-taskfile.c

?? ep9315平臺下硬盤驅動的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
#elseint ide_diag_taskfile (ide_drive_t *drive, ide_task_t *args, unsigned long data_size, u8 *buf){	struct request *rq;	unsigned long flags;	ide_hwgroup_t *hwgroup = HWGROUP(drive);	unsigned int major = HWIF(drive)->major;	struct list_head *queue_head = &drive->queue.queue_head;	DECLARE_COMPLETION(wait);	if (HWIF(drive)->chipset == ide_pdc4030 && buf != NULL)		return -ENOSYS; /* special drive cmds not supported */	memset(rq, 0, sizeof(*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) {			ata_nsector_t nsector;			nsector.b.low = args->hobRegister[IDE_NSECTOR_OFFSET_HOB];			nsector.b.high = args->tfRegister[IDE_NSECTOR_OFFSET];			rq.nr_sectors = nsector.all;		} else {			rq.nr_sectors = data_size / SECTOR_SIZE;		}		rq.current_nr_sectors = rq.nr_sectors;	//	rq.hard_cur_sectors = rq.nr_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;	rq->errors = 0;	rq->rq_status = RQ_ACTIVE;	rq->rq_dev = MKDEV(major,(drive->select.b.unit)<<PARTN_BITS);	rq->waiting = &wait;	spin_lock_irqsave(&io_request_lock, flags);	queue_head = queue_head->prev;	list_add(&rq->queue, queue_head);	ide_do_request(hwgroup, 0);	spin_unlock_irqrestore(&io_request_lock, flags);	wait_for_completion(&wait);	/* wait for it to be serviced */	return rq->errors ? -EIO : 0;	/* return -EIO if errors */}#endifEXPORT_SYMBOL(ide_diag_taskfile);int ide_raw_taskfile (ide_drive_t *drive, ide_task_t *args, u8 *buf){	return ide_diag_taskfile(drive, args, 0, buf);}EXPORT_SYMBOL(ide_raw_taskfile);	#ifdef CONFIG_IDE_TASK_IOCTL_DEBUGchar * ide_ioctl_verbose (unsigned int cmd){	return("unknown");}char * ide_task_cmd_verbose (u8 task){	return("unknown");}#endif /* CONFIG_IDE_TASK_IOCTL_DEBUG */#define MAX_DMA		(256*SECTOR_WORDS)ide_startstop_t flagged_taskfile(ide_drive_t *, ide_task_t *);ide_startstop_t flagged_task_no_data_intr(ide_drive_t *);ide_startstop_t flagged_task_in_intr(ide_drive_t *);ide_startstop_t flagged_task_mulin_intr(ide_drive_t *);ide_startstop_t flagged_pre_task_out_intr(ide_drive_t *, struct request *);ide_startstop_t flagged_task_out_intr(ide_drive_t *);ide_startstop_t flagged_pre_task_mulout_intr(ide_drive_t *, struct request *);ide_startstop_t flagged_task_mulout_intr(ide_drive_t *);int ide_taskfile_ioctl (ide_drive_t *drive, struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg){	ide_task_request_t	*req_task;	ide_task_t		args;	u8 *outbuf		= NULL;	u8 *inbuf		= NULL;	task_ioreg_t *argsptr	= args.tfRegister;	task_ioreg_t *hobsptr	= args.hobRegister;	int err			= 0;	int tasksize		= sizeof(struct ide_task_request_s);	int taskin		= 0;	int taskout		= 0;	u8 io_32bit		= drive->io_32bit;//	printk("IDE Taskfile ...\n");	req_task = kmalloc(tasksize, GFP_KERNEL);	if (req_task == NULL) return -ENOMEM;	memset(req_task, 0, tasksize);	if (copy_from_user(req_task, (void *) arg, tasksize)) {		kfree(req_task);		return -EFAULT;	}	taskout = (int) req_task->out_size;	taskin  = (int) req_task->in_size;	if (taskout) {		int outtotal = tasksize;		outbuf = kmalloc(taskout, GFP_KERNEL);		if (outbuf == NULL) {			err = -ENOMEM;			goto abort;		}		memset(outbuf, 0, taskout);		if (copy_from_user(outbuf, (void *)arg + outtotal, taskout)) {			err = -EFAULT;			goto abort;		}	}	if (taskin) {		int intotal = tasksize + taskout;		inbuf = kmalloc(taskin, GFP_KERNEL);		if (inbuf == NULL) {			err = -ENOMEM;			goto abort;		}		memset(inbuf, 0, taskin);		if (copy_from_user(inbuf, (void *)arg + intotal , taskin)) {			err = -EFAULT;			goto abort;		}	}	memset(&args, 0, sizeof(ide_task_t));	memcpy(argsptr, req_task->io_ports, HDIO_DRIVE_TASK_HDR_SIZE);	memcpy(hobsptr, req_task->hob_ports, HDIO_DRIVE_HOB_HDR_SIZE);	args.tf_in_flags  = req_task->in_flags;	args.tf_out_flags = req_task->out_flags;	args.data_phase   = req_task->data_phase;	args.command_type = req_task->req_cmd;#ifdef CONFIG_IDE_TASK_IOCTL_DEBUG	DTF("%s: ide_ioctl_cmd %s:  ide_task_cmd %s\n",		drive->name,		ide_ioctl_verbose(cmd),		ide_task_cmd_verbose(args.tfRegister[IDE_COMMAND_OFFSET]));#endif /* CONFIG_IDE_TASK_IOCTL_DEBUG */	drive->io_32bit = 0;	switch(req_task->data_phase) {		case TASKFILE_OUT_DMAQ:		case TASKFILE_OUT_DMA:			err = ide_diag_taskfile(drive, &args, taskout, outbuf);			break;		case TASKFILE_IN_DMAQ:		case TASKFILE_IN_DMA:			err = ide_diag_taskfile(drive, &args, taskin, inbuf);			break;		case TASKFILE_IN_OUT:#if 0			args.prehandler = &pre_task_out_intr;			args.handler = &task_out_intr;			args.posthandler = NULL;			err = ide_diag_taskfile(drive, &args, taskout, outbuf);			args.prehandler = NULL;			args.handler = &task_in_intr;			args.posthandler = NULL;			err = ide_diag_taskfile(drive, &args, taskin, inbuf);			break;#else			err = -EFAULT;			goto abort;#endif		case TASKFILE_MULTI_OUT:			if (!drive->mult_count) {				/* (hs): give up if multcount is not set */				printk(KERN_ERR "%s: %s Multimode Write " \					"multcount is not set\n",					drive->name, __FUNCTION__);				err = -EPERM;				goto abort;			}			if (args.tf_out_flags.all != 0) {				args.prehandler = &flagged_pre_task_mulout_intr;				args.handler = &flagged_task_mulout_intr;			} else {				args.prehandler = &pre_task_mulout_intr;				args.handler = &task_mulout_intr;			}			err = ide_diag_taskfile(drive, &args, taskout, outbuf);			break;		case TASKFILE_OUT:			if (args.tf_out_flags.all != 0) {				args.prehandler = &flagged_pre_task_out_intr;				args.handler    = &flagged_task_out_intr;			} else {				args.prehandler = &pre_task_out_intr;				args.handler = &task_out_intr;			}			err = ide_diag_taskfile(drive, &args, taskout, outbuf);			break;		case TASKFILE_MULTI_IN:			if (!drive->mult_count) {				/* (hs): give up if multcount is not set */				printk(KERN_ERR "%s: %s Multimode Read failure " \					"multcount is not set\n",					drive->name, __FUNCTION__);				err = -EPERM;				goto abort;			}			if (args.tf_out_flags.all != 0) {				args.handler = &flagged_task_mulin_intr;			} else {				args.handler = &task_mulin_intr;			}			err = ide_diag_taskfile(drive, &args, taskin, inbuf);			break;		case TASKFILE_IN:			if (args.tf_out_flags.all != 0) {				args.handler = &flagged_task_in_intr;			} else {				args.handler = &task_in_intr;			}			err = ide_diag_taskfile(drive, &args, taskin, inbuf);			break;		case TASKFILE_NO_DATA:			if (args.tf_out_flags.all != 0) {				args.handler = &flagged_task_no_data_intr;			} else {				args.handler = &task_no_data_intr;			}			err = ide_diag_taskfile(drive, &args, 0, NULL);			break;		default:			err = -EFAULT;			goto abort;	}	memcpy(req_task->io_ports, &(args.tfRegister), HDIO_DRIVE_TASK_HDR_SIZE);	memcpy(req_task->hob_ports, &(args.hobRegister), HDIO_DRIVE_HOB_HDR_SIZE);	req_task->in_flags  = args.tf_in_flags;	req_task->out_flags = args.tf_out_flags;	if (copy_to_user((void *)arg, req_task, tasksize)) {		err = -EFAULT;		goto abort;	}	if (taskout) {		int outtotal = tasksize;		if (copy_to_user((void *)arg+outtotal, outbuf, taskout)) {			err = -EFAULT;			goto abort;		}	}	if (taskin) {		int intotal = tasksize + taskout;		if (copy_to_user((void *)arg+intotal, inbuf, taskin)) {			err = -EFAULT;			goto abort;		}	}abort:	kfree(req_task);	if (outbuf != NULL)		kfree(outbuf);	if (inbuf != NULL)		kfree(inbuf);//	printk("IDE Taskfile ioctl ended. rc = %i\n", err);	drive->io_32bit = io_32bit;	return err;}EXPORT_SYMBOL(ide_taskfile_ioctl);int ide_wait_cmd (ide_drive_t *drive, u8 cmd, u8 nsect, u8 feature, u8 sectors, u8 *buf){	struct request rq;	u8 buffer[4];	if (!buf)		buf = buffer;	memset(buf, 0, 4 + SECTOR_WORDS * 4 * sectors);	ide_init_drive_cmd(&rq);	rq.buffer = buf;	*buf++ = cmd;	*buf++ = nsect;	*buf++ = feature;	*buf++ = sectors;	return ide_do_drive_cmd(drive, &rq, ide_wait);}EXPORT_SYMBOL(ide_wait_cmd);/* * FIXME : this needs to map into at taskfile. <andre@linux-ide.org> */int ide_cmd_ioctl (ide_drive_t *drive, struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg){#if 1	int err = -EIO;	u8 args[4], *argbuf = args;	u8 xfer_rate = 0;	int argsize = 4;	ide_task_t tfargs;	if (NULL == (void *) arg) {		struct request rq;		ide_init_drive_cmd(&rq);		return ide_do_drive_cmd(drive, &rq, ide_wait);	}	if (copy_from_user(args, (void *)arg, 4))		return -EFAULT;	memset(&tfargs, 0, sizeof(ide_task_t));	tfargs.tfRegister[IDE_FEATURE_OFFSET] = args[2];	tfargs.tfRegister[IDE_NSECTOR_OFFSET] = args[3];	tfargs.tfRegister[IDE_SECTOR_OFFSET]  = args[1];	tfargs.tfRegister[IDE_LCYL_OFFSET]    = 0x00;	tfargs.tfRegister[IDE_HCYL_OFFSET]    = 0x00;	tfargs.tfRegister[IDE_SELECT_OFFSET]  = 0x00;	tfargs.tfRegister[IDE_COMMAND_OFFSET] = args[0];	if (args[3]) {		argsize = 4 + (SECTOR_WORDS * 4 * args[3]);		argbuf = kmalloc(argsize, GFP_KERNEL);		if (argbuf == NULL)			return -ENOMEM;		memcpy(argbuf, args, 4);	}	if (set_transfer(drive, &tfargs)) {		xfer_rate = args[1];		if (ide_ata66_check(drive, &tfargs))			goto abort;	}	err = ide_wait_cmd(drive, args[0], args[1], args[2], args[3], argbuf);	if (!err && xfer_rate) {		/* active-retuning-calls future */		ide_set_xfer_rate(drive, xfer_rate);		ide_driveid_update(drive);	}abort:	if (copy_to_user((void *)arg, argbuf, argsize))		err = -EFAULT;	if (argsize > 4)		kfree(argbuf);	return err;#else	int err = 0;	u8 args[4], *argbuf = args;	u8 xfer_rate = 0;	int argsize = 0;	ide_task_t tfargs;	if (NULL == (void *) arg) {		struct request rq;		ide_init_drive_cmd(&rq);		return ide_do_drive_cmd(drive, &rq, ide_wait);	}	if (copy_from_user(args, (void *)arg, 4))		return -EFAULT;	memset(&tfargs, 0, sizeof(ide_task_t));	tfargs.tfRegister[IDE_FEATURE_OFFSET] = args[2];	tfargs.tfRegister[IDE_NSECTOR_OFFSET] = args[3];	tfargs.tfRegister[IDE_SECTOR_OFFSET]  = args[1];	tfargs.tfRegister[IDE_LCYL_OFFSET]    = 0x00;	tfargs.tfRegister[IDE_HCYL_OFFSET]    = 0x00;	tfargs.tfRegister[IDE_SELECT_OFFSET]  = 0x00;	tfargs.tfRegister[IDE_COMMAND_OFFSET] = args[0];	if (args[3]) {		argsize = (SECTOR_WORDS * 4 * args[3]);		argbuf = kmalloc(argsize, GFP_KERNEL);		if (argbuf == NULL)			return -ENOMEM;	}	if (set_transfer(drive, &tfargs)) {		xfer_rate = args[1];		if (ide_ata66_check(drive, &tfargs))			goto abort;	}	tfargs.command_type = ide_cmd_type_parser(&tfargs);	err = ide_raw_taskfile(drive, &tfargs, argbuf);	if (!err && xfer_rate) {		/* active-retuning-calls future */		ide_set_xfer_rate(drive, xfer_rate);		ide_driveid_update(drive);	}abort:	args[0] = tfargs.tfRegister[IDE_COMMAND_OFFSET];	args[1] = tfargs.tfRegister[IDE_FEATURE_OFFSET];	args[2] = tfargs.tfRegister[IDE_NSECTOR_OFFSET];	args[3] = 0;	if (copy_to_user((void *)arg, argbuf, 4))		err = -EFAULT;	if (argbuf != NULL) {		if (copy_to_user((void *)arg, argbuf + 4, argsize))			err = -EFAULT;		kfree(argbuf);	}	return err;#endif}EXPORT_SYMBOL(ide_cmd_ioctl);int ide_wait_cmd_task (ide_drive_t *drive, u8 *buf){	struct request rq;	ide_init_drive_cmd(&rq);	rq.cmd = IDE_DRIVE_TASK;	rq.buffer = buf;	return ide_do_drive_cmd(drive, &rq, ide_wait);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久精品国产| 日韩欧美电影一区| 欧美裸体一区二区三区| 久久精品视频在线看| 亚洲在线观看免费| 成人性视频免费网站| 777xxx欧美| 亚洲精品美国一| 国产精品一卡二| 欧美一区二区三区不卡| 亚洲高清三级视频| 91原创在线视频| 国产日本亚洲高清| 狠狠色综合播放一区二区| 欧美日韩久久一区| 一区二区三区欧美视频| 国产69精品久久久久777| 精品国产髙清在线看国产毛片| 一区二区三区不卡视频在线观看| 成人深夜在线观看| 久久久国际精品| 国产伦精品一区二区三区免费迷| 91精品欧美久久久久久动漫| 午夜视频在线观看一区二区三区| 一本大道av一区二区在线播放| 国产精品久久久久久久久免费相片| 国产福利一区在线| 久久影院视频免费| 国产在线精品视频| www久久精品| 国产精品中文字幕日韩精品| 精品国产精品一区二区夜夜嗨| 美国三级日本三级久久99 | 91精品国产91久久久久久一区二区| 亚洲日本在线天堂| 欧美在线观看一二区| 中文字幕在线不卡| 色噜噜狠狠成人网p站| 一区二区三区在线免费观看 | 中文字幕欧美一| 99精品视频一区二区三区| 亚洲视频香蕉人妖| 在线观看区一区二| 亚洲成人精品一区二区| 欧美一区二区免费| 精品一区二区三区免费观看| 国产日产欧美一区| 99久久久久久| 亚洲同性同志一二三专区| 91欧美一区二区| 亚洲第一成人在线| 日韩精品中文字幕在线不卡尤物| 国产美女娇喘av呻吟久久| 国产精品毛片久久久久久| 欧美中文字幕亚洲一区二区va在线 | 91福利国产成人精品照片| 午夜婷婷国产麻豆精品| wwwwww.欧美系列| 95精品视频在线| 亚洲国产精品久久艾草纯爱| 精品国产乱码久久久久久久| 99久久精品一区| 日韩精品一二区| 久久精品一区八戒影视| 色偷偷一区二区三区| 蜜桃精品视频在线| 国产精品成人免费| 欧美少妇一区二区| 国产一区二区三区国产| 亚洲精品欧美激情| 精品久久久久久久久久久久久久久久久 | 欧美在线色视频| 久久99久久久久| 亚洲欧美日韩成人高清在线一区| 7777精品伊人久久久大香线蕉| 国产不卡高清在线观看视频| 一级女性全黄久久生活片免费| 精品美女被调教视频大全网站| 91丨九色丨蝌蚪丨老版| 精品在线视频一区| 亚洲电影一级片| 国产精品美女久久福利网站| 日韩三级电影网址| 91国偷自产一区二区三区观看 | 日本一不卡视频| 亚洲啪啪综合av一区二区三区| 26uuu欧美日本| 欧美日韩mp4| 91丨九色丨尤物| 国产麻豆视频一区二区| 欧美aⅴ一区二区三区视频| 亚洲免费资源在线播放| 国产欧美一区二区精品性| 欧美电视剧免费全集观看| 欧美日韩一区精品| 91麻豆swag| www.爱久久.com| 国产精品一级片在线观看| 老司机精品视频在线| 首页国产丝袜综合| 一级特黄大欧美久久久| 亚洲伦理在线精品| 亚洲欧洲日韩女同| 日本一区二区三区高清不卡| 欧美不卡一区二区三区四区| 91麻豆精品国产91久久久久| 欧美性大战久久久久久久| 91色综合久久久久婷婷| 成人黄动漫网站免费app| 成人综合婷婷国产精品久久免费| 久久超级碰视频| 极品少妇xxxx精品少妇偷拍| 免费看精品久久片| 美女一区二区在线观看| 麻豆国产91在线播放| 紧缚捆绑精品一区二区| 狠狠色综合日日| 国产成人综合视频| 国产一区二区三区精品视频| 麻豆国产精品777777在线| 国产在线播精品第三| 国产一区二区网址| 国产91精品一区二区麻豆网站 | 麻豆成人在线观看| 毛片av一区二区| 国产精品18久久久久久久久久久久| 国精品**一区二区三区在线蜜桃| 国产老妇另类xxxxx| 成人av在线影院| 在线观看欧美黄色| 在线不卡一区二区| 欧美xxxxx裸体时装秀| 欧美国产国产综合| 亚洲精品国产高清久久伦理二区| 一区二区三区小说| 欧美aⅴ一区二区三区视频| 国产精品一级二级三级| 91丨九色丨黑人外教| 欧美精品久久久久久久多人混战| 日韩欧美一级二级三级| 国产亚洲一本大道中文在线| 亚洲色欲色欲www| 污片在线观看一区二区| 激情五月婷婷综合网| 成人av免费观看| 欧美精品粉嫩高潮一区二区| 久久免费国产精品| 亚洲一区在线视频观看| 久久精品国产99| 丁香桃色午夜亚洲一区二区三区 | 成人av网站免费| 欧美日韩国产中文| 国产欧美一区二区精品忘忧草| 一区二区三区四区精品在线视频| 美女视频网站黄色亚洲| 91老司机福利 在线| 日韩欧美国产一二三区| 亚洲色欲色欲www| 免费在线看一区| 九九热在线视频观看这里只有精品| 精品一区二区三区免费播放| 色婷婷综合久久久久中文| 91精品欧美一区二区三区综合在 | 国产成人综合视频| 欧美疯狂做受xxxx富婆| 自拍视频在线观看一区二区| 久久精品理论片| 欧美体内she精视频| 国产区在线观看成人精品| 石原莉奈一区二区三区在线观看| 不卡的电影网站| 久久免费视频色| 男女性色大片免费观看一区二区 | 亚洲精选在线视频| 蜜桃久久久久久久| 欧美视频第二页| 中文字幕在线不卡一区| 国产伦精一区二区三区| 欧美一级在线免费| 亚洲综合色噜噜狠狠| caoporm超碰国产精品| 久久精品一区四区| 精品一区二区三区香蕉蜜桃| 91精品国产一区二区三区香蕉 | 麻豆91精品91久久久的内涵| 日本道色综合久久| 中文字幕在线播放不卡一区| 国产成人精品影院| 国产香蕉久久精品综合网| 开心九九激情九九欧美日韩精美视频电影| 欧美在线999| 夜夜嗨av一区二区三区四季av| 色哟哟国产精品| 一区二区在线观看免费| 色综合久久中文综合久久牛| 综合自拍亚洲综合图不卡区| 成人午夜私人影院| 国产精品乱人伦中文| 成人免费毛片嘿嘿连载视频| 国产欧美日韩久久|