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

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

?? cmd_ide.c

?? ARM的bootloader代碼.rar
?? C
?? 第 1 頁 / 共 3 頁
字號:
							    WE_DONT_HAVE_BD_BI_BUSFREQ);	    pio_config_clk[i].t_hold   = PCMCIA_MK_CLKS(pio_config_ns[i].t_hold,							    WE_DONT_HAVE_BD_BI_BUSFREQ);	    PRINTF ("PIO Mode %d: setup=%2d ns/%d clk"		    "  len=%3d ns/%d clk"		    "  hold=%2d ns/%d clk\n",		    i,		    pio_config_ns[i].t_setup,  pio_config_clk[i].t_setup,		    pio_config_ns[i].t_length, pio_config_clk[i].t_length,		    pio_config_ns[i].t_hold,   pio_config_clk[i].t_hold);	}	/* Reset the IDE just to be sure.	 * Light LED's to show	 */	ide_led ((LED_IDE1 | LED_IDE2), 1);		/* LED's on	*/	ide_reset (); /* ATAPI Drives seems to need a proper IDE Reset */#ifdef CONFIG_IDE_PCMCIA	/* PCMCIA / IDE initialization for common mem space */	pcmp->pcmc_pgcrb = 0;#endif	/* start in PIO mode 0 - most relaxed timings */	pio_mode = 0;	set_pcmcia_timing (pio_mode);	/*	 * Wait for IDE to get ready.	 * According to spec, this can take up to 31 seconds!	 */	for (bus=0; bus<CFG_IDE_MAXBUS; ++bus) {		int dev = bus * (CFG_IDE_MAXDEVICE / CFG_IDE_MAXBUS);		printf ("Bus %d: ", bus);		ide_bus_ok[bus] = 0;		/* Select device		 */#if defined(CONFIG_WATCHDOG)		watchdog_reset ();#endif	/* CONFIG_WATCHDOG */		udelay (100000);		/* 100 ms */		outb (dev, ATA_DEV_HD, ATA_LBA | ATA_DEVICE(dev));#if defined(CONFIG_WATCHDOG)		watchdog_reset ();#endif	/* CONFIG_WATCHDOG */		udelay (100000);		/* 100 ms */		i = 0;		do {#if defined(CONFIG_WATCHDOG)			watchdog_reset ();#endif	/* CONFIG_WATCHDOG */			udelay (10000);		/* 10 ms */			c = inb (dev, ATA_STATUS);			i++;			if (i > (ATA_RESET_TIME * 100)) {				puts ("** Timeout **\n");				ide_led ((LED_IDE1 | LED_IDE2), 0); /* LED's off */				return;			}			if ((i >= 100) && ((i%100)==0)) {				putc ('.');			}		} while (c & ATA_STAT_BUSY);		if (c & (ATA_STAT_BUSY | ATA_STAT_FAULT)) {			printf ("Status 0x%02x ", c);#ifndef CONFIG_ATAPI /* ATAPI Devices do not set DRDY */		} else  if ((c & ATA_STAT_READY) == 0) {			puts ("not available  ");			PRINTF ("Status = 0x%02X ", c);#endif		} else {			puts ("OK ");			ide_bus_ok[bus] = 1;		}#if defined(CONFIG_WATCHDOG)		watchdog_reset ();#endif	/* CONFIG_WATCHDOG */	}	putc ('\n');	ide_led ((LED_IDE1 | LED_IDE2), 0);	/* LED's off	*/	curr_device = -1;	for (i=0; i<CFG_IDE_MAXDEVICE; ++i) {#ifdef CONFIG_IDE_LED		int led = (IDE_BUS(i) == 0) ? LED_IDE1 : LED_IDE2;#endif		ide_dev_desc[i].if_type=IF_TYPE_IDE;		ide_dev_desc[i].dev=i;		ide_dev_desc[i].part_type=PART_TYPE_UNKNOWN;		ide_dev_desc[i].blksz=0;		ide_dev_desc[i].lba=0;		ide_dev_desc[i].block_read=ide_read;		if (!ide_bus_ok[IDE_BUS(i)])			continue;		ide_led (led, 1);		/* LED on	*/		ide_ident(&ide_dev_desc[i]);		ide_led (led, 0);		/* LED off	*/		dev_print(&ide_dev_desc[i]);/*		ide_print (i); *//*		if((ide_device[i].size > 0) && (ide_dev_desc[i].if_type==IF_TYPE_IDE)) */		if((ide_dev_desc[i].lba > 0) && (ide_dev_desc[i].blksz > 0)) {			init_part (&ide_dev_desc[i]);			/* initialize partition type */			if(curr_device < 0)				curr_device = i;		}	}#if defined(CONFIG_WATCHDOG)	watchdog_reset ();#endif	/* CONFIG_WATCHDOG */}/* ------------------------------------------------------------------------- */block_dev_desc_t * ide_get_dev(int dev){	return((block_dev_desc_t *)&ide_dev_desc[dev]);}#ifdef CONFIG_IDE_PCMCIAstatic voidset_pcmcia_timing (int pmode){	volatile immap_t *immr = (immap_t *)CFG_IMMR;	volatile pcmconf8xx_t *pcmp = &(immr->im_pcmcia);	ulong timings;	timings = PCMCIA_SHT(pio_config_clk[pmode].t_hold)		| PCMCIA_SST(pio_config_clk[pmode].t_setup)		| PCMCIA_SL (pio_config_clk[pmode].t_length)		;	/* IDE 0	 */	pcmp->pcmc_pbr0 = CFG_PCMCIA_PBR0;	pcmp->pcmc_por0 = CFG_PCMCIA_POR0#if (CFG_PCMCIA_POR0 != 0)			| timings#endif			;	PRINTF ("PBR0: %08x  POR0: %08x\n", pcmp->pcmc_pbr0, pcmp->pcmc_por0);	pcmp->pcmc_pbr1 = CFG_PCMCIA_PBR1;	pcmp->pcmc_por1 = CFG_PCMCIA_POR1#if (CFG_PCMCIA_POR1 != 0)			| timings#endif			;	PRINTF ("PBR1: %08x  POR1: %08x\n", pcmp->pcmc_pbr1, pcmp->pcmc_por1);	pcmp->pcmc_pbr2 = CFG_PCMCIA_PBR2;	pcmp->pcmc_por2 = CFG_PCMCIA_POR2#if (CFG_PCMCIA_POR2 != 0)			| timings#endif			;	PRINTF ("PBR2: %08x  POR2: %08x\n", pcmp->pcmc_pbr2, pcmp->pcmc_por2);	pcmp->pcmc_pbr3 = CFG_PCMCIA_PBR3;	pcmp->pcmc_por3 = CFG_PCMCIA_POR3#if (CFG_PCMCIA_POR3 != 0)			| timings#endif			;	PRINTF ("PBR3: %08x  POR3: %08x\n", pcmp->pcmc_pbr3, pcmp->pcmc_por3);	/* IDE 1	 */	pcmp->pcmc_pbr4 = CFG_PCMCIA_PBR4;	pcmp->pcmc_por4 = CFG_PCMCIA_POR4#if (CFG_PCMCIA_POR4 != 0)			| timings#endif			;	PRINTF ("PBR4: %08x  POR4: %08x\n", pcmp->pcmc_pbr4, pcmp->pcmc_por4);	pcmp->pcmc_pbr5 = CFG_PCMCIA_PBR5;	pcmp->pcmc_por5 = CFG_PCMCIA_POR5#if (CFG_PCMCIA_POR5 != 0)			| timings#endif			;	PRINTF ("PBR5: %08x  POR5: %08x\n", pcmp->pcmc_pbr5, pcmp->pcmc_por5);	pcmp->pcmc_pbr6 = CFG_PCMCIA_PBR6;	pcmp->pcmc_por6 = CFG_PCMCIA_POR6#if (CFG_PCMCIA_POR6 != 0)			| timings#endif			;	PRINTF ("PBR6: %08x  POR6: %08x\n", pcmp->pcmc_pbr6, pcmp->pcmc_por6);	pcmp->pcmc_pbr7 = CFG_PCMCIA_PBR7;	pcmp->pcmc_por7 = CFG_PCMCIA_POR7#if (CFG_PCMCIA_POR7 != 0)			| timings#endif			;	PRINTF ("PBR7: %08x  POR7: %08x\n", pcmp->pcmc_pbr7, pcmp->pcmc_por7);}#endif	/* CONFIG_IDE_PCMCIA *//* ------------------------------------------------------------------------- */static void __inline__outb(int dev, int port, unsigned char val){	/* Ensure I/O operations complete */	//__asm__ volatile("eieio");#if 0	printf ("OUTB on dev %d, 0x%08lx + 0x%08lx <== 0x%02x\n", dev, ATA_CURR_BASE(dev), port, val);#endif	*((uchar *)(ATA_CURR_BASE(dev)+port)) = val;}static unsigned char __inline__inb(int dev, int port){	uchar val;	/* Ensure I/O operations complete */	//__asm__ volatile("eieio");#if 0	printf ("INB: 0x%08lx", ATA_CURR_BASE(dev)+port);#endif	val = *((uchar *)(ATA_CURR_BASE(dev)+port));//	printf ("==> 0x%02x\n", val);	return (val);}__inline__ unsigned ld_le16(const volatile unsigned short *addr){	//unsigned val;	unsigned short *val;	char buf[2], tmp;	val = (unsigned short *)&buf;//	printf("access on %p\n", addr);	*val = *addr;	tmp = buf[0];	buf[0] = buf[1];	buf[1] = tmp;	return *val;}static voidinput_swap_data(int dev, ulong *sect_buf, int words){	volatile ushort	*pbuf = (ushort *)(ATA_CURR_BASE(dev)+ATA_DATA_REG);	ushort	*dbuf = (ushort *)sect_buf;//	printf("input_swap_data on %p\n", sect_buf);	while (words--) {		*dbuf++ = ld_le16(pbuf);		*dbuf++ = ld_le16(pbuf);	}}static voidoutput_data(int dev, ulong *sect_buf, int words){	ushort	*dbuf;	volatile ushort	*pbuf;//	printf("output_data on %p\n", sect_buf);	pbuf = (ushort *)(ATA_CURR_BASE(dev)+ATA_DATA_REG);	dbuf = (ushort *)sect_buf;	while (words--) {		//__asm__ volatile ("eieio");		*pbuf = *dbuf++;		//__asm__ volatile ("eieio");		*pbuf = *dbuf++;	}}static voidinput_data(int dev, ulong *sect_buf, int words){	ushort	*dbuf;	volatile ushort	*pbuf;//	printf("input_data on %p\n", sect_buf);	pbuf = (ushort *)(ATA_CURR_BASE(dev)+ATA_DATA_REG);	dbuf = (ushort *)sect_buf;	while (words--) {		//__asm__ volatile ("eieio");		*dbuf++ = *pbuf;		//__asm__ volatile ("eieio");		*dbuf++ = *pbuf;	}}/* ------------------------------------------------------------------------- */static void ide_ident (block_dev_desc_t *dev_desc){	ulong iobuf[ATA_SECTORWORDS];	unsigned char c;	hd_driveid_t *iop = (hd_driveid_t *)iobuf;#if 0	int mode, cycle_time;#endif	int device;	device=dev_desc->dev;	printf ("  Device %d: ", device);	ide_led (DEVICE_LED(device), 1);	/* LED on	*/	/* Select device	 */	outb (device, ATA_DEV_HD, ATA_LBA | ATA_DEVICE(device));	dev_desc->if_type=IF_TYPE_IDE;#ifdef CONFIG_ATAPI	/* check signature */	if((inb(device,ATA_SECT_CNT)==0x01) &&		 (inb(device,ATA_SECT_NUM)==0x01) &&		 (inb(device,ATA_CYL_LOW)==0x14) &&		 (inb(device,ATA_CYL_HIGH)==0xEB)) {		/* ATAPI Signature found */		dev_desc->if_type=IF_TYPE_ATAPI;		/* Start Ident Command	 	 */		outb (device, ATA_COMMAND, ATAPI_CMD_IDENT);		/* Wait for completion ATAPI devices need more time to become ready		 */		c = ide_wait (device, ATAPI_TIME_OUT);	}	else#endif	{		/* Start Ident Command		 */		outb (device, ATA_COMMAND, ATA_CMD_IDENT);		/* Wait for completion		 */		c = ide_wait (device, IDE_TIME_OUT);	}	ide_led (DEVICE_LED(device), 0);	/* LED off	*/	if (((c & ATA_STAT_READY) == 0) ||	    ((c & (ATA_STAT_FAULT|ATA_STAT_ERR)) != 0) ) {		dev_desc->type=DEV_TYPE_UNKNOWN;		return;	}	input_swap_data (device, iobuf, ATA_SECTORWORDS);	ident_cpy (dev_desc->revision, iop->fw_rev, sizeof(dev_desc->revision));	ident_cpy (dev_desc->vendor, iop->model, sizeof(dev_desc->vendor));	ident_cpy (dev_desc->product, iop->serial_no, sizeof(dev_desc->product));	if((iop->config & 0x0080)==0x0080)		dev_desc->removable = 1;	else		dev_desc->removable = 0;#if 0	/*	 * Drive PIO mode autoselection	 */	mode = iop->tPIO;	printf ("tPIO = 0x%02x = %d\n",mode, mode);	if (mode > 2) {		/* 2 is maximum allowed tPIO value */		mode = 2;		PRINTF ("Override tPIO -> 2\n");	}	if (iop->field_valid & 2) {	/* drive implements ATA2? */		PRINTF ("Drive implements ATA2\n");		if (iop->capability & 8) {	/* drive supports use_iordy? */			cycle_time = iop->eide_pio_iordy;		} else {			cycle_time = iop->eide_pio;		}		PRINTF ("cycle time = %d\n", cycle_time);		mode = 4;		if (cycle_time > 120) mode = 3;	/* 120 ns for PIO mode 4 */		if (cycle_time > 180) mode = 2;	/* 180 ns for PIO mode 3 */		if (cycle_time > 240) mode = 1;	/* 240 ns for PIO mode 4 */		if (cycle_time > 383) mode = 0;	/* 383 ns for PIO mode 4 */	}	printf ("PIO mode to use: PIO %d\n", mode);#endif#ifdef CONFIG_ATAPI	if(dev_desc->if_type==IF_TYPE_ATAPI) {		atapi_inquiry(dev_desc);		return;	}		 #endif	/* swap shorts */	//dev_desc->lba = (iop->lba_capacity << 16) | (iop->lba_capacity >> 16);	dev_desc->lba = iop->lba_capacity;	/* assuming HD */	dev_desc->type=DEV_TYPE_HARDDISK;	dev_desc->blksz=ATA_BLOCKSIZE;	dev_desc->lun=0; /* just to fill something in... */	}/* ------------------------------------------------------------------------- */ulong ide_read (int device, ulong blknr, ulong blkcnt, ulong *buffer){	ulong n = 0;	unsigned char c;	PRINTF("ide_read dev %d start %lX, blocks %lX buffer at %lX\n",device,blknr,blkcnt,(ulong)buffer);	ide_led (DEVICE_LED(device), 1);	/* LED on	*/	/* Select device	 */	outb (device, ATA_DEV_HD, ATA_LBA | ATA_DEVICE(device));	while (blkcnt-- > 0) {		c = ide_wait (device, IDE_TIME_OUT);		if (c & ATA_STAT_BUSY) {			printf ("IDE read: device %d not ready\n", device);			goto RD_OUT;		}		outb (device, ATA_SECT_CNT, 1);		outb (device, ATA_LBA_LOW,  (blknr >>  0) & 0xFF);		outb (device, ATA_LBA_MID,  (blknr >>  8) & 0xFF);		outb (device, ATA_LBA_HIGH, (blknr >> 16) & 0xFF);		outb (device, ATA_DEV_HD,   ATA_LBA		|					    ATA_DEVICE(device)	|					    ((blknr >> 24) & 0xF) );		outb (device, ATA_COMMAND,  ATA_CMD_READ);		udelay (50);		c = ide_wait (device, IDE_TIME_OUT);	/* can't take over 500 ms */		if ((c&(ATA_STAT_DRQ|ATA_STAT_BUSY|ATA_STAT_ERR)) != ATA_STAT_DRQ) {			printf ("Error (no IRQ) dev %d blk %ld: status 0x%02x\n",				device, blknr, c);			goto RD_OUT;		}		input_data (device, buffer, ATA_SECTORWORDS);		(void) inb (device, ATA_STATUS);	/* clear IRQ */		++n;		++blknr;		buffer += ATA_SECTORWORDS;	}RD_OUT:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩专区在线| 国产精品 欧美精品| 亚洲色图在线视频| 国产精品美女久久福利网站| 久久新电视剧免费观看| 精品久久久久久无| 久久免费看少妇高潮| 精品久久久久久最新网址| 精品国产乱码久久久久久图片| 欧美mv和日韩mv的网站| 欧美精品一区二区精品网| 久久精品亚洲精品国产欧美| 久久精品视频一区二区| 中文无字幕一区二区三区| 中文字幕亚洲一区二区va在线| 日韩理论电影院| 一级做a爱片久久| |精品福利一区二区三区| 自拍偷在线精品自拍偷无码专区| 亚洲精品成人少妇| 日日噜噜夜夜狠狠视频欧美人| 奇米888四色在线精品| 激情深爱一区二区| 99精品视频在线观看免费| 欧美色中文字幕| 久久亚区不卡日本| 亚洲欧洲日韩一区二区三区| 亚洲国产精品久久久久秋霞影院| 蜜臀久久久久久久| 成人一区二区三区在线观看| 91欧美一区二区| 在线免费亚洲电影| 亚洲一区二区视频在线观看| 午夜精品一区二区三区电影天堂 | 欧美三级视频在线| 日韩欧美国产电影| 中文字幕日本不卡| 日本欧美在线观看| 成人18视频在线播放| 在线不卡的av| 亚洲丝袜精品丝袜在线| 天堂在线亚洲视频| av在线一区二区| 欧美一区二区三区色| 亚洲欧洲av在线| 久久99精品一区二区三区| 色婷婷久久综合| 久久久777精品电影网影网| 欧美日韩精品一区视频| 久久国产精品第一页| 9i在线看片成人免费| 欧美一区二区福利视频| 亚洲精品中文字幕在线观看| 国产一区二区成人久久免费影院| 日本韩国欧美在线| 国产精品日韩精品欧美在线| 天天综合日日夜夜精品| 91片在线免费观看| 国产清纯在线一区二区www| 天天色天天操综合| 欧美主播一区二区三区美女| 国产精品久久夜| 国产麻豆视频一区| 日韩精品自拍偷拍| 蜜臀国产一区二区三区在线播放| 欧美三区在线观看| 亚洲激情一二三区| 色悠悠久久综合| 亚洲色欲色欲www在线观看| 成人美女视频在线看| 国产精品热久久久久夜色精品三区| 久久成人免费电影| 欧美www视频| 国产一区二区主播在线| 欧美成人a∨高清免费观看| 日本系列欧美系列| 欧美一区永久视频免费观看| 五月激情综合色| 91精品国产乱码| 乱一区二区av| 久久先锋影音av| 福利电影一区二区| 国产精品久久久久毛片软件| 国产mv日韩mv欧美| 亚洲欧美在线高清| 色8久久精品久久久久久蜜| 一区二区在线观看av| 精品视频1区2区3区| 亚洲www啪成人一区二区麻豆| 欧美日韩久久久久久| 视频一区在线视频| 91精品国产91久久综合桃花 | 欧美美女一区二区| 日韩1区2区日韩1区2区| 欧美sm美女调教| 国产盗摄视频一区二区三区| 国产精品免费aⅴ片在线观看| www.视频一区| 亚洲v日本v欧美v久久精品| 日韩一区二区视频在线观看| 亚洲第一电影网| 久久av资源网| 日本一区二区在线不卡| 97se亚洲国产综合自在线不卡 | 91麻豆精品国产综合久久久久久| 日韩国产成人精品| 2023国产精华国产精品| 成人午夜精品在线| 亚洲va国产天堂va久久en| 日韩免费视频线观看| 成人毛片老司机大片| 天天av天天翘天天综合网色鬼国产| 在线观看区一区二| 韩国成人精品a∨在线观看| 一色屋精品亚洲香蕉网站| 欧美精品九九99久久| 成人h动漫精品一区二区| 亚洲h动漫在线| 中文字幕免费一区| 91精品视频网| 99re成人在线| 国产丶欧美丶日本不卡视频| 亚洲高清在线视频| 中文字幕av资源一区| 日韩三级视频在线观看| 91久久精品一区二区二区| 国产精品1区2区3区| 日本免费新一区视频 | 色哟哟一区二区在线观看| 激情综合网av| 日韩在线播放一区二区| 亚洲人吸女人奶水| 久久久.com| 精品久久人人做人人爱| 91精品国产综合久久香蕉麻豆 | 亚洲韩国一区二区三区| 国产精品久久久久久久久免费桃花 | 久久精子c满五个校花| 欧美久久久一区| 色综合天天综合网国产成人综合天| 国产精品一区二区在线观看网站| 亚洲成人动漫一区| 亚洲一区二区视频在线| 亚洲精品免费播放| 亚洲三级免费观看| 自拍偷拍亚洲激情| 国产精品毛片无遮挡高清| 国产三级精品三级在线专区| 精品黑人一区二区三区久久| 日韩一区二区免费在线观看| 6080国产精品一区二区| 4hu四虎永久在线影院成人| 欧美精品123区| 91精品蜜臀在线一区尤物| 欧美一区二区三区视频免费播放| 91精品国产一区二区三区蜜臀| 91精品婷婷国产综合久久竹菊| 欧美日韩在线三级| 日韩欧美成人一区| 欧美xxx久久| 国产欧美精品一区二区色综合朱莉| www久久久久| 亚洲国产成人自拍| 亚洲视频一区二区免费在线观看 | 欧美在线小视频| 欧美在线视频日韩| 日韩一区二区三区视频| 日韩精品一区二区三区在线观看| 久久综合色综合88| 欧美国产成人在线| 一区二区三区中文在线观看| 亚洲妇女屁股眼交7| 日韩国产精品久久久久久亚洲| 美女在线一区二区| 国产.欧美.日韩| 在线精品视频小说1| 欧美一级免费观看| 国产女人18毛片水真多成人如厕| 自拍偷拍国产精品| 免费av网站大全久久| 成人免费视频网站在线观看| 91精品1区2区| 精品国产91洋老外米糕| 综合久久久久久久| 青青草97国产精品免费观看无弹窗版| 国产又黄又大久久| 欧美中文字幕一区| 久久九九久久九九| 午夜电影久久久| 丰满岳乱妇一区二区三区| 欧美综合在线视频| 国产欧美日韩在线观看| 五月天激情综合| av电影在线观看完整版一区二区| 欧美精品在欧美一区二区少妇| 久久久国产精品不卡| 五月天婷婷综合| 91丨九色丨蝌蚪丨老版| 日韩久久久精品| 五月婷婷激情综合|