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

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

?? ide-cd.c

?? ep9315平臺下硬盤驅動的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
{	struct request *rq = HWGROUP(drive)->rq;	struct packet_command *pc = (struct packet_command *) rq->buffer;	unsigned long wait = 0;	/*	 * Some commands are *slow* and normally take a long time to	 * complete. Usually we can use the ATAPI "disconnect" to bypass	 * this, but not all commands/drives support that. Let	 * ide_timer_expiry keep polling us for these.	 */	switch (pc->c[0]) {		case GPCMD_BLANK:		case GPCMD_FORMAT_UNIT:		case GPCMD_RESERVE_RZONE_TRACK:			wait = WAIT_CMD;			break;		default:			wait = 0;			break;	}	return wait;}/* Set up the device registers for transferring a packet command on DEV,   expecting to later transfer XFERLEN bytes.  HANDLER is the routine   which actually transfers the command to the drive.  If this is a   drq_interrupt device, this routine will arrange for HANDLER to be   called when the interrupt from the drive arrives.  Otherwise, HANDLER   will be called immediately after the drive is prepared for the transfer. */static ide_startstop_t cdrom_start_packet_command(ide_drive_t *drive,						  int xferlen,						  ide_handler_t *handler){	ide_startstop_t startstop;	struct cdrom_info *info = drive->driver_data;	/* Wait for the controller to be idle. */	if (ide_wait_stat(&startstop, drive, 0, BUSY_STAT, WAIT_READY))		return startstop;	if (info->dma) {		if (info->cmd == READ) {			info->dma = !HWIF(drive)->ide_dma_read(drive);		} else if (info->cmd == WRITE) {			info->dma = !HWIF(drive)->ide_dma_write(drive);		} else {			printk("ide-cd: DMA set, but not allowed\n");		}	}	/* Set up the controller registers. */	/* FIXME: for Virtual DMA we must check harder */	HWIF(drive)->OUTB(info->dma, IDE_FEATURE_REG);	HWIF(drive)->OUTB(0, IDE_IREASON_REG);	HWIF(drive)->OUTB(0, IDE_SECTOR_REG);	HWIF(drive)->OUTB(xferlen & 0xff, IDE_BCOUNTL_REG);	HWIF(drive)->OUTB(xferlen >> 8  , IDE_BCOUNTH_REG);	if (IDE_CONTROL_REG)		HWIF(drive)->OUTB(drive->ctl, IDE_CONTROL_REG); 	if (CDROM_CONFIG_FLAGS (drive)->drq_interrupt) {		/* packet command */		ide_execute_command(drive, WIN_PACKETCMD, handler, WAIT_CMD, cdrom_timer_expiry);		return ide_started;	} else {		/* packet command */		HWIF(drive)->OUTB(WIN_PACKETCMD, IDE_COMMAND_REG);		return (*handler) (drive);	}}/* Send a packet command to DRIVE described by CMD_BUF and CMD_LEN.   The device registers must have already been prepared   by cdrom_start_packet_command.   HANDLER is the interrupt handler to call when the command completes   or there's data ready. *//* * changed 5 parameters to 3 for dvd-ram * struct packet_command *pc; now packet_command_t *pc; */static ide_startstop_t cdrom_transfer_packet_command (ide_drive_t *drive,					  struct packet_command *pc,					  ide_handler_t *handler){	unsigned char *cmd_buf	= pc->c;	int cmd_len		= sizeof(pc->c);	unsigned int timeout	= pc->timeout;	struct cdrom_info *info = drive->driver_data;	ide_startstop_t startstop;	if (CDROM_CONFIG_FLAGS(drive)->drq_interrupt) {		/* Here we should have been called after receiving an interrupt		   from the device.  DRQ should how be set. */		int stat_dum;		/* Check for errors. */		if (cdrom_decode_status(&startstop, drive, DRQ_STAT, &stat_dum))			return startstop;	} else {		/* Otherwise, we must wait for DRQ to get set. */		if (ide_wait_stat(&startstop, drive, DRQ_STAT,				BUSY_STAT, WAIT_READY))			return startstop;	}	/* Arm the interrupt handler. */	ide_set_handler(drive, handler, timeout, cdrom_timer_expiry);	/* Send the command to the device. */	HWIF(drive)->atapi_output_bytes(drive, cmd_buf, cmd_len);	/* Start the DMA if need be */	if (info->dma)		(void) HWIF(drive)->ide_dma_begin(drive);	return ide_started;}/**************************************************************************** * Block read functions. *//* * Buffer up to SECTORS_TO_TRANSFER sectors from the drive in our sector * buffer.  Once the first sector is added, any subsequent sectors are * assumed to be continuous (until the buffer is cleared).  For the first * sector added, SECTOR is its sector number.  (SECTOR is then ignored until * the buffer is cleared.) */static void cdrom_buffer_sectors (ide_drive_t *drive, unsigned long sector,                                  int sectors_to_transfer){	struct cdrom_info *info = drive->driver_data;	/* Number of sectors to read into the buffer. */	int sectors_to_buffer = MIN (sectors_to_transfer,				     (SECTOR_BUFFER_SIZE >> SECTOR_BITS) -				       info->nsectors_buffered);	char *dest;	/* If we couldn't get a buffer, don't try to buffer anything... */	if (info->buffer == NULL)		sectors_to_buffer = 0;	/* If this is the first sector in the buffer, remember its number. */	if (info->nsectors_buffered == 0)		info->sector_buffered = sector;	/* Read the data into the buffer. */	dest = info->buffer + info->nsectors_buffered * SECTOR_SIZE;	while (sectors_to_buffer > 0) {		HWIF(drive)->atapi_input_bytes(drive, dest, SECTOR_SIZE);		--sectors_to_buffer;		--sectors_to_transfer;		++info->nsectors_buffered;		dest += SECTOR_SIZE;	}	/* Throw away any remaining data. */	while (sectors_to_transfer > 0) {		char dum[SECTOR_SIZE];		HWIF(drive)->atapi_input_bytes(drive, dum, sizeof (dum));		--sectors_to_transfer;	}}/* * Check the contents of the interrupt reason register from the cdrom * and attempt to recover if there are problems.  Returns  0 if everything's * ok; nonzero if the request has been terminated. */static inlineint cdrom_read_check_ireason (ide_drive_t *drive, int len, int ireason){	ireason &= 3;	if (ireason == 2) return 0;	if (ireason == 0) {		/* Whoops... The drive is expecting to receive data from us! */		printk ("%s: cdrom_read_intr: "			"Drive wants to transfer data the wrong way!\n",			drive->name);		/* Throw some data at the drive so it doesn't hang		   and quit this request. */		while (len > 0) {			int dum = 0;			HWIF(drive)->atapi_output_bytes(drive, &dum, sizeof (dum));			len -= sizeof (dum);		}	} else  if (ireason == 1) {		/* Some drives (ASUS) seem to tell us that status		 * info is available. just get it and ignore.		 */		(void) HWIF(drive)->INB(IDE_STATUS_REG);		return 0;	} else {		/* Drive wants a command packet, or invalid ireason... */		printk ("%s: cdrom_read_intr: bad interrupt reason %d\n",			drive->name, ireason);	}	cdrom_end_request(drive, 0);	return -1;}/* * Interrupt routine.  Called when a read request has completed. */static ide_startstop_t cdrom_read_intr (ide_drive_t *drive){	int stat;	int ireason, len, sectors_to_transfer, nskip;	struct cdrom_info *info = drive->driver_data;	u8 lowcyl = 0, highcyl = 0;	int i, dma = info->dma, dma_error = 0;	ide_startstop_t startstop;	struct request *rq = HWGROUP(drive)->rq;	/* Check for errors. */	if (dma) {		info->dma = 0;#ifdef CONFIG_ARCH_EP93XX		dma_error = HWIF(drive)->ide_dma_end(drive);#else		if ((dma_error = HWIF(drive)->ide_dma_end(drive)))			HWIF(drive)->ide_dma_off(drive);#endif	}	if (cdrom_decode_status (&startstop, drive, 0, &stat))		return startstop; 	if (dma) {		if (!dma_error) {			for (i = rq->nr_sectors; i > 0;) {				i -= rq->current_nr_sectors;				ide_cdrom_end_request(drive, 1);			}			return ide_stopped;		} else#ifdef CONFIG_ARCH_EP93XX			return ide_stopped;#else			return DRIVER(drive)->error(drive, "dma error", stat);#endif	}	/* Read the interrupt reason and the transfer length. */	ireason = HWIF(drive)->INB(IDE_IREASON_REG);	lowcyl  = HWIF(drive)->INB(IDE_BCOUNTL_REG);	highcyl = HWIF(drive)->INB(IDE_BCOUNTH_REG);	len = lowcyl + (256 * highcyl);	/* If DRQ is clear, the command has completed. */	if ((stat & DRQ_STAT) == 0) {		/* If we're not done filling the current buffer, complain.		   Otherwise, complete the command normally. */		if (rq->current_nr_sectors > 0) {			printk ("%s: cdrom_read_intr: data underrun (%ld blocks)\n",				drive->name, rq->current_nr_sectors);			cdrom_end_request(drive, 0);		} else			cdrom_end_request(drive, 1);		return ide_stopped;	}	/* Check that the drive is expecting to do the same thing we are. */	if (cdrom_read_check_ireason (drive, len, ireason))		return ide_stopped;	/* Assume that the drive will always provide data in multiples	   of at least SECTOR_SIZE, as it gets hairy to keep track	   of the transfers otherwise. */	if ((len % SECTOR_SIZE) != 0) {		printk ("%s: cdrom_read_intr: Bad transfer size %d\n",			drive->name, len);		if (CDROM_CONFIG_FLAGS(drive)->limit_nframes)			printk ("  This drive is not supported by this version of the driver\n");		else {			printk ("  Trying to limit transfer sizes\n");			CDROM_CONFIG_FLAGS(drive)->limit_nframes = 1;		}		cdrom_end_request(drive, 0);		return ide_stopped;	}	/* The number of sectors we need to read from the drive. */	sectors_to_transfer = len / SECTOR_SIZE;	/* First, figure out if we need to bit-bucket	   any of the leading sectors. */	nskip = MIN ((int)(rq->current_nr_sectors - (rq->bh->b_size >> SECTOR_BITS)),		     sectors_to_transfer);	while (nskip > 0) {		/* We need to throw away a sector. */		char dum[SECTOR_SIZE];		HWIF(drive)->atapi_input_bytes(drive, dum, sizeof (dum));		--rq->current_nr_sectors;		--nskip;		--sectors_to_transfer;	}	/* Now loop while we still have data to read from the drive. */	while (sectors_to_transfer > 0) {		int this_transfer;		/* If we've filled the present buffer but there's another		   chained buffer after it, move on. */		if (rq->current_nr_sectors == 0 && rq->nr_sectors)			cdrom_end_request(drive, 1);		/* If the buffers are full, cache the rest of the data in our		   internal buffer. */		if (rq->current_nr_sectors == 0) {			cdrom_buffer_sectors(drive, rq->sector, sectors_to_transfer);			sectors_to_transfer = 0;		} else {			/* Transfer data to the buffers.			   Figure out how many sectors we can transfer			   to the current buffer. */			this_transfer = MIN (sectors_to_transfer,					     rq->current_nr_sectors);			/* Read this_transfer sectors			   into the current buffer. */			while (this_transfer > 0) {				HWIF(drive)->atapi_input_bytes(drive, rq->buffer, SECTOR_SIZE);				rq->buffer += SECTOR_SIZE;				--rq->nr_sectors;				--rq->current_nr_sectors;				++rq->sector;				--this_transfer;				--sectors_to_transfer;			}		}	}	/* Done moving data!  Wait for another interrupt. */	ide_set_handler(drive, &cdrom_read_intr, WAIT_CMD, NULL);	return ide_started;}/* * Try to satisfy some of the current read request from our cached data. * Returns nonzero if the request has been completed, zero otherwise. */static int cdrom_read_from_buffer (ide_drive_t *drive){	struct cdrom_info *info = drive->driver_data;	struct request *rq = HWGROUP(drive)->rq;	/* Can't do anything if there's no buffer. */	if (info->buffer == NULL) return 0;	/* Loop while this request needs data and the next block is present	   in our cache. */	while (rq->nr_sectors > 0 &&	       rq->sector >= info->sector_buffered &&	       rq->sector < info->sector_buffered + info->nsectors_buffered) {		if (rq->current_nr_sectors == 0)			cdrom_end_request(drive, 1);		memcpy (rq->buffer,			info->buffer +			(rq->sector - info->sector_buffered) * SECTOR_SIZE,			SECTOR_SIZE);		rq->buffer += SECTOR_SIZE;		--rq->current_nr_sectors;		--rq->nr_sectors;		++rq->sector;	}	/* If we've satisfied the current request,	   terminate it successfully. */	if (rq->nr_sectors == 0) {		cdrom_end_request(drive, 1);		return -1;	}	/* Move on to the next buffer if needed. */	if (rq->current_nr_sectors == 0)		cdrom_end_request(drive, 1);	/* If this condition does not hold, then the kluge i use to	   represent the number of sectors to skip at the start of a transfer	   will fail.  I think that this will never happen, but let's be	   paranoid and check. */	if (rq->current_nr_sectors < (rq->bh->b_size >> SECTOR_BITS) &&	    (rq->sector % SECTORS_PER_FRAME) != 0) {		printk("%s: cdrom_read_from_buffer: buffer botch (%ld)\n",			drive->name, rq->sector);		cdrom_end_request(drive, 0);		return -1;	}	return 0;}/* * Routine to send a read packet command to the drive. * This is usually called directly from cdrom_start_read. * However, for drq_interrupt devices, it is called from an interrupt * when the drive is ready to accept the command. */static ide_startstop_t cdrom_start_read_continuation (ide_drive_t *drive)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲夂夂婷婷色拍ww47| 亚洲精品成人在线| 亚洲欧美在线aaa| 三级欧美韩日大片在线看| 精东粉嫩av免费一区二区三区 | 日韩一区二区免费视频| 国产精品天干天干在观线| 日韩专区一卡二卡| 99久久99久久综合| 日韩午夜在线播放| 天天色天天操综合| 91麻豆免费看片| 国产欧美一区二区三区鸳鸯浴| 亚洲夂夂婷婷色拍ww47| www.久久精品| 久久久91精品国产一区二区三区| 亚洲三级电影网站| 国产精品一二三区| 亚洲精品一区二区精华| 天堂久久久久va久久久久| 99视频在线观看一区三区| 国产亚洲欧美一区在线观看| 天天综合天天综合色| 欧美午夜视频网站| 亚洲美女区一区| 丁香啪啪综合成人亚洲小说| 欧美zozozo| 另类的小说在线视频另类成人小视频在线| 在线亚洲一区观看| 亚洲精品国产一区二区三区四区在线| 久久99热这里只有精品| 日韩欧美色电影| 日韩福利电影在线| 91精品视频网| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲一区二区偷拍精品| 99视频有精品| 亚洲九九爱视频| 色中色一区二区| 亚洲精品国产a| 色狠狠av一区二区三区| 亚洲精品成人在线| 欧美美女bb生活片| 水野朝阳av一区二区三区| 欧美日本乱大交xxxxx| 天天综合天天综合色| 欧美一级黄色片| 韩国女主播成人在线| 国产亚洲欧美色| 99久久精品国产一区| 一区二区视频在线| 一本色道a无线码一区v| 亚洲免费观看高清| 欧美三级电影在线观看| 五月激情综合婷婷| 日韩限制级电影在线观看| 国产精品一级片| 1024成人网色www| 欧美日韩一本到| 久热成人在线视频| 国产精品三级av| 欧美中文字幕一二三区视频| 日韩高清一区在线| 国产日韩欧美精品一区| 91女人视频在线观看| 亚洲成人免费观看| 久久综合久色欧美综合狠狠| 成人不卡免费av| 午夜在线电影亚洲一区| 2023国产一二三区日本精品2022| 东方欧美亚洲色图在线| 亚洲国产精品一区二区www| 欧美大片在线观看| 色综合天天综合网天天看片| 石原莉奈一区二区三区在线观看| 久久美女艺术照精彩视频福利播放| 99re这里只有精品视频首页| 午夜精品久久久久| 国产精品私人影院| 制服丝袜亚洲网站| 成人免费观看av| 日韩不卡一二三区| 自拍偷拍国产亚洲| 精品国产一二三区| 欧美亚洲自拍偷拍| 懂色av一区二区三区免费观看| 午夜精品免费在线| 亚洲免费伊人电影| 精品日韩一区二区三区免费视频| 99久久精品国产毛片| 国产在线视视频有精品| 亚洲图片欧美色图| 国产精品欧美一区二区三区| 日韩一区二区三区免费观看| 色婷婷久久久亚洲一区二区三区| 韩日欧美一区二区三区| 日韩精品免费专区| 亚洲美女屁股眼交3| 久久久久久久久岛国免费| 69久久夜色精品国产69蝌蚪网 | 国产一区在线精品| 天堂在线亚洲视频| 一卡二卡三卡日韩欧美| 欧美国产一区二区| 久久精品日产第一区二区三区高清版| 欧美久久久久久久久| 色猫猫国产区一区二在线视频| 国产精品一区二区无线| 亚洲国产成人一区二区三区| 在线综合视频播放| 欧美精选一区二区| 91丝袜美腿高跟国产极品老师 | 99久久99久久精品免费观看| 国产一区二区三区| 免费观看日韩av| 美腿丝袜一区二区三区| 午夜精品在线视频一区| 亚洲大片精品永久免费| 亚洲电影一级黄| 亚洲曰韩产成在线| 亚洲一区二区在线观看视频| 一级做a爱片久久| 亚洲综合清纯丝袜自拍| 一区二区三区色| 午夜精品一区二区三区免费视频| 亚洲国产成人av网| 天天影视涩香欲综合网| 日本vs亚洲vs韩国一区三区二区 | 亚洲欧美自拍偷拍| 亚洲人成伊人成综合网小说| 亚洲欧美偷拍卡通变态| 一区二区理论电影在线观看| 亚洲综合色婷婷| 五月天视频一区| 免费视频一区二区| 国产揄拍国内精品对白| 成人av电影观看| 91国模大尺度私拍在线视频| 欧美自拍丝袜亚洲| 日韩视频123| 中文字幕第一区综合| 综合色天天鬼久久鬼色| 亚洲高清一区二区三区| 水野朝阳av一区二区三区| 韩国毛片一区二区三区| 成人亚洲精品久久久久软件| 欧美片网站yy| 日韩美女视频在线| 国产精品嫩草影院av蜜臀| 亚洲精品老司机| 精品一区二区三区影院在线午夜| 国产一区二区三区不卡在线观看 | 欧美一卡二卡在线| 久久综合久久综合久久综合| 亚洲色图.com| 日韩激情一二三区| 国产不卡在线一区| 欧美在线短视频| 国产香蕉久久精品综合网| 一区二区三区在线观看视频 | 亚洲一区二区三区小说| 狠狠色丁香久久婷婷综合_中| 91蜜桃网址入口| 日韩女同互慰一区二区| 一区精品在线播放| 久久国产精品99久久久久久老狼| 成人毛片在线观看| 日韩一区二区三区视频| 亚洲天堂2014| 国产综合色在线视频区| 欧美视频日韩视频| 日本一区二区视频在线| 青青草国产成人99久久| 91高清视频免费看| 国产区在线观看成人精品| 日韩黄色在线观看| 国产色91在线| 久久电影国产免费久久电影| 成人avav影音| 中文字幕乱码日本亚洲一区二区| 天天做天天摸天天爽国产一区| 99国产精品久久久久久久久久 | 综合欧美一区二区三区| 国产一区二区不卡在线 | 久久青草欧美一区二区三区| 婷婷久久综合九色综合绿巨人| 色悠悠亚洲一区二区| 国产女同性恋一区二区| 精品一区二区三区蜜桃| 日韩欧美二区三区| 午夜欧美电影在线观看| 日本福利一区二区| 亚洲欧美另类久久久精品2019| 岛国精品在线观看| 亚洲国产高清不卡| 成人午夜碰碰视频| 中文av一区二区| www.久久久久久久久| 国产精品乱码久久久久久| 国产一区二区三区不卡在线观看|