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

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

?? ide3.c

?? ucos在三星s3c44b0上的ide程序
?? C
?? 第 1 頁 / 共 5 頁
字號:
	 */	for (unit = 0; unit < MAX_DRIVES; ++unit)		pre_reset(&hwif->drives[unit]);#if OK_TO_RESET_CONTROLLER	if (!IDE_CONTROL_REG) {		__restore_flags(flags);		return ide_stopped;	}	/*	 * Note that we also set nIEN while resetting the device,	 * to mask unwanted interrupts from the interface during the reset.	 * However, due to the design of PC hardware, this will cause an	 * immediate interrupt due to the edge transition it produces.	 * This single interrupt gives us a "fast poll" for drives that	 * recover from reset very quickly, saving us the first 50ms wait time.	 */	OUT_BYTE(drive->ctl|6,IDE_CONTROL_REG);	/* set SRST and nIEN */	udelay(10);			/* more than enough time */	if (drive->quirk_list == 2) {		OUT_BYTE(drive->ctl,IDE_CONTROL_REG);	/* clear SRST and nIEN */	} else {		OUT_BYTE(drive->ctl|2,IDE_CONTROL_REG);	/* clear SRST, leave nIEN */	}	udelay(10);			/* more than enough time */	hwgroup->poll_timeout = jiffies + WAIT_WORSTCASE;	ide_set_handler (drive, &reset_pollfunc, HZ/20, NULL);	/*	 * Some weird controller like resetting themselves to a strange	 * state when the disks are reset this way. At least, the Winbond	 * 553 documentation says that	 */	if (hwif->resetproc != NULL)		hwif->resetproc(drive);#endif	/* OK_TO_RESET_CONTROLLER */	__restore_flags (flags);	/* local CPU only */	return ide_started;}/* * ide_do_reset() is the entry point to the drive/interface reset code. */ide_startstop_t ide_do_reset (ide_drive_t *drive){	return do_reset1 (drive, 0);}static inline u32 read_24 (ide_drive_t *drive){	return  (IN_BYTE(IDE_HCYL_REG)<<16) |		(IN_BYTE(IDE_LCYL_REG)<<8) |		 IN_BYTE(IDE_SECTOR_REG);}/* * Clean up after success/failure of an explicit drive cmd */void ide_end_drive_cmd (ide_drive_t *drive, byte stat, byte err){	unsigned long flags;	struct request *rq;	spin_lock_irqsave(&io_request_lock, flags);	rq = HWGROUP(drive)->rq;	spin_unlock_irqrestore(&io_request_lock, flags);	switch(rq->cmd) {		case IDE_DRIVE_CMD:		{			byte *args = (byte *) rq->buffer;			rq->errors = !OK_STAT(stat,READY_STAT,BAD_STAT);			if (args) {				args[0] = stat;				args[1] = err;				args[2] = IN_BYTE(IDE_NSECTOR_REG);			}			break;		}		case IDE_DRIVE_TASK:		{			byte *args = (byte *) rq->buffer;			rq->errors = !OK_STAT(stat,READY_STAT,BAD_STAT);			if (args) {				args[0] = stat;				args[1] = err;				args[2] = IN_BYTE(IDE_NSECTOR_REG);				args[3] = IN_BYTE(IDE_SECTOR_REG);				args[4] = IN_BYTE(IDE_LCYL_REG);				args[5] = IN_BYTE(IDE_HCYL_REG);				args[6] = IN_BYTE(IDE_SELECT_REG);			}			break;		}		case IDE_DRIVE_TASKFILE:		{			ide_task_t *args = (ide_task_t *) rq->special;			rq->errors = !OK_STAT(stat,READY_STAT,BAD_STAT);			if (args) {				if (args->tf_in_flags.b.data) {					unsigned short data			= IN_WORD(IDE_DATA_REG);					args->tfRegister[IDE_DATA_OFFSET]	= (data) & 0xFF;					args->hobRegister[IDE_DATA_OFFSET_HOB]	= (data >> 8) & 0xFF;				}				args->tfRegister[IDE_ERROR_OFFSET]   = err;				args->tfRegister[IDE_NSECTOR_OFFSET] = IN_BYTE(IDE_NSECTOR_REG);				args->tfRegister[IDE_SECTOR_OFFSET]  = IN_BYTE(IDE_SECTOR_REG);				args->tfRegister[IDE_LCYL_OFFSET]    = IN_BYTE(IDE_LCYL_REG);				args->tfRegister[IDE_HCYL_OFFSET]    = IN_BYTE(IDE_HCYL_REG);				args->tfRegister[IDE_SELECT_OFFSET]  = IN_BYTE(IDE_SELECT_REG);				args->tfRegister[IDE_STATUS_OFFSET]  = stat;				if ((drive->id->command_set_2 & 0x0400) &&				    (drive->id->cfs_enable_2 & 0x0400) &&				    (drive->addressing == 1)) {					OUT_BYTE(drive->ctl|0x80, IDE_CONTROL_REG_HOB);					args->hobRegister[IDE_FEATURE_OFFSET_HOB] = IN_BYTE(IDE_FEATURE_REG);					args->hobRegister[IDE_NSECTOR_OFFSET_HOB] = IN_BYTE(IDE_NSECTOR_REG);					args->hobRegister[IDE_SECTOR_OFFSET_HOB]  = IN_BYTE(IDE_SECTOR_REG);					args->hobRegister[IDE_LCYL_OFFSET_HOB]    = IN_BYTE(IDE_LCYL_REG);					args->hobRegister[IDE_HCYL_OFFSET_HOB]    = IN_BYTE(IDE_HCYL_REG);				}			}			break;		}		default:			break;	}	spin_lock_irqsave(&io_request_lock, flags);	blkdev_dequeue_request(rq);	HWGROUP(drive)->rq = NULL;	end_that_request_last(rq);	spin_unlock_irqrestore(&io_request_lock, flags);}/* * Error reporting, in human readable form (luxurious, but a memory hog). */byte ide_dump_status (ide_drive_t *drive, const char *msg, byte stat){	unsigned long flags;	byte err = 0;	__save_flags (flags);	/* local CPU only */	ide__sti();		/* local CPU only */	printk("%s: %s: status=0x%02x", drive->name, msg, stat);#if FANCY_STATUS_DUMPS	printk(" { ");	if (stat & BUSY_STAT)		printk("Busy ");	else {		if (stat & READY_STAT)	printk("DriveReady ");		if (stat & WRERR_STAT)	printk("DeviceFault ");		if (stat & SEEK_STAT)	printk("SeekComplete ");		if (stat & DRQ_STAT)	printk("DataRequest ");		if (stat & ECC_STAT)	printk("CorrectedError ");		if (stat & INDEX_STAT)	printk("Index ");		if (stat & ERR_STAT)	printk("Error ");	}	printk("}");#endif	/* FANCY_STATUS_DUMPS */	printk("\n");	if ((stat & (BUSY_STAT|ERR_STAT)) == ERR_STAT) {		err = GET_ERR();		printk("%s: %s: error=0x%02x", drive->name, msg, err);#if FANCY_STATUS_DUMPS		if (drive->media == ide_disk) {			printk(" { ");			if (err & ABRT_ERR)	printk("DriveStatusError ");			if (err & ICRC_ERR)	printk("%s", (err & ABRT_ERR) ? "BadCRC " : "BadSector ");			if (err & ECC_ERR)	printk("UncorrectableError ");			if (err & ID_ERR)	printk("SectorIdNotFound ");			if (err & TRK0_ERR)	printk("TrackZeroNotFound ");			if (err & MARK_ERR)	printk("AddrMarkNotFound ");			printk("}");			if ((err & (BBD_ERR | ABRT_ERR)) == BBD_ERR || (err & (ECC_ERR|ID_ERR|MARK_ERR))) {				if ((drive->id->command_set_2 & 0x0400) &&				    (drive->id->cfs_enable_2 & 0x0400) &&				    (drive->addressing == 1)) {					__u64 sectors = 0;					u32 low = 0, high = 0;					low = read_24(drive);					OUT_BYTE(drive->ctl|0x80, IDE_CONTROL_REG);					high = read_24(drive);					sectors = ((__u64)high << 24) | low;					printk(", LBAsect=%llu, high=%d, low=%d",					       (unsigned long long) sectors,					       high, low);				} else {					byte cur = IN_BYTE(IDE_SELECT_REG);					if (cur & 0x40) {	/* using LBA? */						printk(", LBAsect=%ld", (unsigned long)						 ((cur&0xf)<<24)						 |(IN_BYTE(IDE_HCYL_REG)<<16)						 |(IN_BYTE(IDE_LCYL_REG)<<8)						 | IN_BYTE(IDE_SECTOR_REG));					} else {						printk(", CHS=%d/%d/%d",						 (IN_BYTE(IDE_HCYL_REG)<<8) +						  IN_BYTE(IDE_LCYL_REG),						  cur & 0xf,						  IN_BYTE(IDE_SECTOR_REG));					}				}				if (HWGROUP(drive) && HWGROUP(drive)->rq)					printk(", sector=%ld", HWGROUP(drive)->rq->sector);			}		}#endif	/* FANCY_STATUS_DUMPS */		printk("\n");	}	__restore_flags (flags);	/* local CPU only */	return err;}/* * try_to_flush_leftover_data() is invoked in response to a drive * unexpectedly having its DRQ_STAT bit set.  As an alternative to * resetting the drive, this routine tries to clear the condition * by read a sector's worth of data from the drive.  Of course, * this may not help if the drive is *waiting* for data from *us*. */static void try_to_flush_leftover_data (ide_drive_t *drive){	int i = (drive->mult_count ? drive->mult_count : 1) * SECTOR_WORDS;	if (drive->media != ide_disk)		return;	while (i > 0) {		u32 buffer[16];		unsigned int wcount = (i > 16) ? 16 : i;		i -= wcount;		ide_input_data (drive, buffer, wcount);	}}/* * ide_error() takes action based on the error returned by the drive. */ide_startstop_t ide_error (ide_drive_t *drive, const char *msg, byte stat){	struct request *rq;	byte err;	err = ide_dump_status(drive, msg, stat);	if (drive == NULL || (rq = HWGROUP(drive)->rq) == NULL)		return ide_stopped;	/* retry only "normal" I/O: */	if (rq->cmd == IDE_DRIVE_CMD || rq->cmd == IDE_DRIVE_TASK) {		rq->errors = 1;		ide_end_drive_cmd(drive, stat, err);		return ide_stopped;	}	if (rq->cmd == IDE_DRIVE_TASKFILE) {		rq->errors = 1;		ide_end_drive_cmd(drive, stat, err);//		ide_end_taskfile(drive, stat, err);		return ide_stopped;	}	if (stat & BUSY_STAT || ((stat & WRERR_STAT) && !drive->nowerr)) { /* other bits are useless when BUSY */		rq->errors |= ERROR_RESET;	} else {		if (drive->media == ide_disk && (stat & ERR_STAT)) {			/* err has different meaning on cdrom and tape */			if (err == ABRT_ERR) {				if (drive->select.b.lba && IN_BYTE(IDE_COMMAND_REG) == WIN_SPECIFY)					return ide_stopped; /* some newer drives don't support WIN_SPECIFY */			} else if ((err & (ABRT_ERR | ICRC_ERR)) == (ABRT_ERR | ICRC_ERR)) {				drive->crc_count++; /* UDMA crc error -- just retry the operation */			} else if (err & (BBD_ERR | ECC_ERR))	/* retries won't help these */				rq->errors = ERROR_MAX;			else if (err & TRK0_ERR)	/* help it find track zero */				rq->errors |= ERROR_RECAL;		}		if ((stat & DRQ_STAT) && rq->cmd != WRITE)			try_to_flush_leftover_data(drive);	}	if (GET_STAT() & (BUSY_STAT|DRQ_STAT))		OUT_BYTE(WIN_IDLEIMMEDIATE,IDE_COMMAND_REG);	/* force an abort */	if (rq->errors >= ERROR_MAX) {		if (drive->driver != NULL)			DRIVER(drive)->end_request(0, HWGROUP(drive));		else	 		ide_end_request(0, HWGROUP(drive));	} else {		if ((rq->errors & ERROR_RESET) == ERROR_RESET) {			++rq->errors;			return ide_do_reset(drive);		}		if ((rq->errors & ERROR_RECAL) == ERROR_RECAL)			drive->special.b.recalibrate = 1;		++rq->errors;	}	return ide_stopped;}/* * Issue a simple drive command * The drive must be selected beforehand. */void ide_cmd (ide_drive_t *drive, byte cmd, byte nsect, ide_handler_t *handler){	ide_set_handler (drive, handler, WAIT_CMD, NULL);	if (IDE_CONTROL_REG)		OUT_BYTE(drive->ctl,IDE_CONTROL_REG);	/* clear nIEN */	SELECT_MASK(HWIF(drive),drive,0);	OUT_BYTE(nsect,IDE_NSECTOR_REG);	OUT_BYTE(cmd,IDE_COMMAND_REG);}/* * drive_cmd_intr() is invoked on completion of a special DRIVE_CMD. */static ide_startstop_t drive_cmd_intr (ide_drive_t *drive){	struct request *rq = HWGROUP(drive)->rq;	byte *args = (byte *) rq->buffer;	byte stat = GET_STAT();	int retries = 10;	ide__sti();	/* local CPU only */	if ((stat & DRQ_STAT) && args && args[3]) {		byte io_32bit = drive->io_32bit;		drive->io_32bit = 0;		ide_input_data(drive, &args[4], args[3] * SECTOR_WORDS);		drive->io_32bit = io_32bit;		while (((stat = GET_STAT()) & BUSY_STAT) && retries--)			udelay(100);	}	if (!OK_STAT(stat, READY_STAT, BAD_STAT))		return ide_error(drive, "drive_cmd", stat); /* calls ide_end_drive_cmd */	ide_end_drive_cmd (drive, stat, GET_ERR());	return ide_stopped;}/* * do_special() is used to issue WIN_SPECIFY, WIN_RESTORE, and WIN_SETMULT * commands to a drive.  It used to do much more, but has been scaled back. */static ide_startstop_t do_special (ide_drive_t *drive){	special_t *s = &drive->special;#ifdef DEBUG	printk("%s: do_special: 0x%02x\n", drive->name, s->all);#endif	if (s->b.set_tune) {		ide_tuneproc_t *tuneproc = HWIF(drive)->tuneproc;		s->b.set_tune = 0;		if (tuneproc != NULL)			tuneproc(drive, drive->tune_req);	} else if (drive->driver != NULL) {		return DRIVER(drive)->special(drive);	} else if (s->all) {		printk("%s: bad special flag: 0x%02x\n", drive->name, s->all);		s->all = 0;	}	return ide_stopped;}/* * This routine busy-waits for the drive status to be not "busy". * It then checks the status for all of the "good" bits and none * of the "bad" bits, and if all is okay it returns 0.  All other * cases return 1 after invoking ide_error() -- caller should just return. * * This routine should get fixed to not hog the cpu during extra long waits.. * That could be done by busy-waiting for the first jiffy or two, and then * setting a timer to wake up at half second intervals thereafter, * until timeout is achieved, before timing out. */int ide_wait_stat (ide_startstop_t *startstop, ide_drive_t *drive, byte good, byte bad, unsigned long timeout) {	byte stat;	int i;	unsigned long flags; 	/* bail early if we've exceeded max_failures */	if (drive->max_failures && (drive->failures > drive->max_failures)) {		*startstop = ide_stopped;		return 1;	}	udelay(1);	/* spec allows drive 400ns to assert "BUSY" */	if ((stat = GET_STAT()) & BUSY_STAT) {		__save_flags(flags);	/* local CPU only */		ide__sti();		/* local CPU only */		timeout += jiffies;		while ((stat = GET_STAT()) & BUSY_STAT) {			if (0 < (signed long)(jiffies - timeout)) {				__restore_flags(flags);	/* local CPU only */				*startstop = ide_error(drive, "status timeout", stat);				return 1;			}		}		__restore_flags(flags);	/* local CPU only */	}	/*	 * Allow status to settle, then read it again.	 * A few rare drives vastly violate the 400ns spec here,	 * so we'll wait up to 10usec for a "good" status	 * rather than expensively fail things immediately.	 * This fix courtesy of Matthew Faupel & Niccolo Rigacci.	 */	for (i = 0; i < 10; i++) {		udelay(1);		if (OK_STAT((stat = GET_STAT()), good, bad))

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
94-欧美-setu| 国产欧美日韩视频一区二区| 91精品国产高清一区二区三区蜜臀 | 亚洲成a人片在线观看中文| 青青草成人在线观看| 99热国产精品| 久久久午夜精品理论片中文字幕| 亚洲在线视频网站| 国产成人aaa| 精品国产一区二区三区不卡 | 波多野结衣精品在线| 911精品国产一区二区在线| 国产精品国产a级| 国产综合久久久久久鬼色 | 亚洲精品成人少妇| 国产老妇另类xxxxx| 777午夜精品免费视频| 蜜臀99久久精品久久久久久软件| av高清久久久| 26uuu欧美| 精品一区二区三区影院在线午夜| 在线观看免费视频综合| 亚洲欧洲av一区二区三区久久| 激情国产一区二区| 欧美一级高清片在线观看| 亚洲免费观看高清完整版在线| 国产成人啪午夜精品网站男同| 日韩欧美国产综合| 免费亚洲电影在线| 这里只有精品免费| 五月婷婷激情综合| 欧美日韩国产免费一区二区| 亚洲一区成人在线| 在线视频国内一区二区| 亚洲欧美色图小说| 色婷婷精品大在线视频 | 国产99精品国产| 国产日韩欧美精品电影三级在线| 国产一区二区久久| 国产日韩欧美亚洲| 成人综合婷婷国产精品久久免费| 欧美国产日韩a欧美在线观看| 国产激情视频一区二区在线观看| 日韩极品在线观看| 51精品视频一区二区三区| 婷婷一区二区三区| 日韩欧美黄色影院| 国产精品18久久久久久久久久久久 | eeuss国产一区二区三区| 中文在线一区二区| 色综合天天视频在线观看| 一区二区三区在线免费| 欧美日韩在线播放三区| 日韩av高清在线观看| 日韩精品一区二| 国产成人综合在线| 亚洲日本成人在线观看| 欧美日韩dvd在线观看| 久久99热这里只有精品| 日本一区二区三区国色天香| 色婷婷综合五月| 日本va欧美va瓶| 国产精品视频yy9299一区| 在线看国产一区二区| 美女视频网站久久| 日韩二区三区四区| 国产日产欧美一区| 欧美日韩综合在线免费观看| 国产伦精品一区二区三区免费 | 一区二区久久久| 欧美一级电影网站| 成人黄色一级视频| 日本系列欧美系列| 国产精品的网站| 欧美一级一区二区| 91在线精品秘密一区二区| 天天av天天翘天天综合网色鬼国产| 欧美zozozo| 欧美日韩一区二区在线观看| 国产不卡高清在线观看视频| 亚洲国产中文字幕| 中文一区一区三区高中清不卡| 欧美日韩国产综合视频在线观看| 国产精品自产自拍| 首页欧美精品中文字幕| 国产精品传媒视频| 久久久久久久久久久久久女国产乱| 色综合天天性综合| 国产成人亚洲综合a∨婷婷图片| 亚洲福利一二三区| 国产精品久久久久影视| 久久―日本道色综合久久| 欧美吻胸吃奶大尺度电影 | 蜜桃视频一区二区| 亚洲激情第一区| 中文字幕欧美日本乱码一线二线| 欧美一区二区人人喊爽| 91精彩视频在线观看| 国产成人午夜电影网| 麻豆精品一区二区| 日韩精品一二三| 一区二区三区欧美日| 亚洲婷婷综合久久一本伊一区| 久久男人中文字幕资源站| 欧美一区二区三区播放老司机| 97久久超碰精品国产| 成人免费视频免费观看| 国产真实乱子伦精品视频| 奇米精品一区二区三区四区| 香蕉乱码成人久久天堂爱免费| 一级做a爱片久久| 亚洲欧美偷拍卡通变态| 日韩理论片中文av| 国产精品久久久99| 国产精品麻豆99久久久久久| 欧美韩国日本综合| 中文字幕乱码一区二区免费| 欧美激情一区二区| 国产精品久久久久久久蜜臀| 欧美激情一区在线| 国产精品久久福利| 亚洲精品国产一区二区三区四区在线| 国产精品每日更新| 亚洲激情欧美激情| 亚洲图片欧美一区| 日本午夜精品视频在线观看| 日韩高清国产一区在线| 九九视频精品免费| 国产成人免费xxxxxxxx| 成人aaaa免费全部观看| 色综合久久中文字幕综合网| 欧美日韩午夜影院| 日韩欧美高清在线| 国产日韩欧美高清在线| 亚洲特黄一级片| 午夜久久久久久电影| 久久精品国产第一区二区三区| 国产在线一区观看| eeuss鲁片一区二区三区在线看| 一本色道亚洲精品aⅴ| 欧美精品在欧美一区二区少妇| 欧美一级片在线| 中文字幕av一区二区三区免费看| 夜夜嗨av一区二区三区中文字幕| 日韩精品亚洲一区二区三区免费| 狠狠色狠狠色合久久伊人| 成人黄色软件下载| 欧美精品 日韩| 欧美国产日产图区| 丝袜亚洲精品中文字幕一区| 国产在线国偷精品免费看| 9i看片成人免费高清| 欧美一区二区三区视频在线| 国产女同互慰高潮91漫画| 一区二区三区国产精品| 激情图区综合网| 91国模大尺度私拍在线视频| 精品久久久久久久久久久久久久久| 国产精品天天摸av网| 三级久久三级久久| 94色蜜桃网一区二区三区| 日韩午夜激情免费电影| 亚洲精品国产一区二区精华液 | 精品国内二区三区| 亚洲人成网站影音先锋播放| 美女视频免费一区| 91黄视频在线| 国产三区在线成人av| 丝瓜av网站精品一区二区| eeuss鲁片一区二区三区在线看| 欧美xfplay| 亚洲国产欧美在线| 菠萝蜜视频在线观看一区| 日韩女优av电影在线观看| 亚洲自拍偷拍综合| 不卡电影免费在线播放一区| 精品不卡在线视频| 日韩精品一二三| 欧美日本视频在线| 亚洲美女少妇撒尿| 不卡视频在线观看| 久久久99精品免费观看不卡| 久久精工是国产品牌吗| 欧美日韩免费观看一区二区三区 | 国产91清纯白嫩初高中在线观看| 在线电影一区二区三区| 一区二区三区在线影院| av一本久道久久综合久久鬼色| 久久人人超碰精品| 久久不见久久见免费视频1| 91精品国产综合久久久久久漫画| 亚洲乱码国产乱码精品精可以看| 风间由美性色一区二区三区| 久久免费偷拍视频| 国产精品一区在线观看你懂的| 久久综合国产精品| 国产一区二区三区视频在线播放| 欧美成人aa大片| 激情都市一区二区| 久久久www免费人成精品|