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

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

?? mpc8xx.c

?? ep9315平臺下硬盤驅動的源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
#define PCMCIA_SL(t) ((t==32) ? 0 : ((t & 0x1F)<<7)) /* Strobe Length	*/#endif/* Calculate PIO timings */static voidm8xx_ide_tuneproc(ide_drive_t *drive, u8 pio){	ide_pio_data_t d;#if defined(CONFIG_IDE_8xx_PCCARD) || defined(CONFIG_IDE_8xx_DIRECT)	volatile pcmconf8xx_t	*pcmp;	ulong timing, mask, reg;#endif	pio = ide_get_best_pio_mode(drive, pio, 4, &d);#if 1	printk("%s[%d] %s: best PIO mode: %d\n",		__FILE__,__LINE__,__FUNCTION__, pio);#endif#if defined(CONFIG_IDE_8xx_PCCARD) || defined(CONFIG_IDE_8xx_DIRECT)	pcmp = (pcmconf8xx_t *)(&(((immap_t *)IMAP_ADDR)->im_pcmcia));	mask = ~(PCMCIA_SHT(0xFF) | PCMCIA_SST(0xFF) | PCMCIA_SL(0xFF));	timing  = PCMCIA_SHT(hold_time[pio]  )		| PCMCIA_SST(ide_pio_clocks[pio].setup_time )		| PCMCIA_SL (ide_pio_clocks[pio].active_time)		;#if 1	printk ("Setting timing bits 0x%08lx in PCMCIA controller\n", timing);#endif	if ((reg = pcmp->pcmc_por0 & mask) != 0)		pcmp->pcmc_por0 = reg | timing;	if ((reg = pcmp->pcmc_por1 & mask) != 0)		pcmp->pcmc_por1 = reg | timing;	if ((reg = pcmp->pcmc_por2 & mask) != 0)		pcmp->pcmc_por2 = reg | timing;	if ((reg = pcmp->pcmc_por3 & mask) != 0)		pcmp->pcmc_por3 = reg | timing;	if ((reg = pcmp->pcmc_por4 & mask) != 0)		pcmp->pcmc_por4 = reg | timing;	if ((reg = pcmp->pcmc_por5 & mask) != 0)		pcmp->pcmc_por5 = reg | timing;	if ((reg = pcmp->pcmc_por6 & mask) != 0)		pcmp->pcmc_por6 = reg | timing;	if ((reg = pcmp->pcmc_por7 & mask) != 0)		pcmp->pcmc_por7 = reg | timing;#elif defined(CONFIG_IDE_EXT_DIRECT)	printk("%s[%d] %s: not implemented yet!\n",		__FILE__,__LINE__,__FUNCTION__);#endif /* defined(CONFIG_IDE_8xx_PCCARD) || defined(CONFIG_IDE_8xx_PCMCIA */}static voidide_interrupt_ack (void *dev){#ifdef CONFIG_IDE_8xx_PCCARD	u_int pscr, pipr;#if (PCMCIA_SOCKETS_NO == 2)	u_int _slot_;#endif	/* get interrupt sources */	pscr = ((volatile immap_t *)IMAP_ADDR)->im_pcmcia.pcmc_pscr;	pipr = ((volatile immap_t *)IMAP_ADDR)->im_pcmcia.pcmc_pipr;	/*	 * report only if both card detect signals are the same	 * not too nice done,	 * we depend on that CD2 is the bit to the left of CD1...	 */	if(_slot_==-1){	  printk("PCMCIA slot has not been defined! Using A as default\n");	  _slot_=0;	}	if(((pipr & M8XX_PCMCIA_CD2(_slot_)) >> 1) ^	   (pipr & M8XX_PCMCIA_CD1(_slot_))         ) {	  printk ("card detect interrupt\n");	}	/* clear the interrupt sources */	((immap_t *)IMAP_ADDR)->im_pcmcia.pcmc_pscr = pscr;#else /* ! CONFIG_IDE_8xx_PCCARD */	/*	 * Only CONFIG_IDE_8xx_PCCARD is using the interrupt of the	 * MPC8xx's PCMCIA controller, so there is nothing to be done here	 * for CONFIG_IDE_8xx_DIRECT and CONFIG_IDE_EXT_DIRECT.	 * The interrupt is handled somewhere else.	-- Steven	 */#endif /* CONFIG_IDE_8xx_PCCARD */}/* * CIS Tupel codes */#define CISTPL_NULL		0x00#define CISTPL_DEVICE		0x01#define CISTPL_LONGLINK_CB	0x02#define CISTPL_INDIRECT		0x03#define CISTPL_CONFIG_CB	0x04#define CISTPL_CFTABLE_ENTRY_CB 0x05#define CISTPL_LONGLINK_MFC	0x06#define CISTPL_BAR		0x07#define CISTPL_PWR_MGMNT	0x08#define CISTPL_EXTDEVICE	0x09#define CISTPL_CHECKSUM		0x10#define CISTPL_LONGLINK_A	0x11#define CISTPL_LONGLINK_C	0x12#define CISTPL_LINKTARGET	0x13#define CISTPL_NO_LINK		0x14#define CISTPL_VERS_1		0x15#define CISTPL_ALTSTR		0x16#define CISTPL_DEVICE_A		0x17#define CISTPL_JEDEC_C		0x18#define CISTPL_JEDEC_A		0x19#define CISTPL_CONFIG		0x1a#define CISTPL_CFTABLE_ENTRY	0x1b#define CISTPL_DEVICE_OC	0x1c#define CISTPL_DEVICE_OA	0x1d#define CISTPL_DEVICE_GEO	0x1e#define CISTPL_DEVICE_GEO_A	0x1f#define CISTPL_MANFID		0x20#define CISTPL_FUNCID		0x21#define CISTPL_FUNCE		0x22#define CISTPL_SWIL		0x23#define CISTPL_END		0xff/* * CIS Function ID codes */#define CISTPL_FUNCID_MULTI	0x00#define CISTPL_FUNCID_MEMORY	0x01#define CISTPL_FUNCID_SERIAL	0x02#define CISTPL_FUNCID_PARALLEL	0x03#define CISTPL_FUNCID_FIXED	0x04#define CISTPL_FUNCID_VIDEO	0x05#define CISTPL_FUNCID_NETWORK	0x06#define CISTPL_FUNCID_AIMS	0x07#define CISTPL_FUNCID_SCSI	0x08/* * Fixed Disk FUNCE codes */#define CISTPL_IDE_INTERFACE	0x01#define CISTPL_FUNCE_IDE_IFACE	0x01#define CISTPL_FUNCE_IDE_MASTER	0x02#define CISTPL_FUNCE_IDE_SLAVE	0x03/* First feature byte */#define CISTPL_IDE_SILICON	0x04#define CISTPL_IDE_UNIQUE	0x08#define CISTPL_IDE_DUAL		0x10/* Second feature byte */#define CISTPL_IDE_HAS_SLEEP	0x01#define CISTPL_IDE_HAS_STANDBY	0x02#define CISTPL_IDE_HAS_IDLE	0x04#define CISTPL_IDE_LOW_POWER	0x08#define CISTPL_IDE_REG_INHIBIT	0x10#define CISTPL_IDE_HAS_INDEX	0x20#define CISTPL_IDE_IOIS16	0x40/* -------------------------------------------------------------------- */#define	MAX_TUPEL_SZ	512#define MAX_FEATURES	4static int check_ide_device (unsigned long base){	volatile u8 *ident = NULL;	volatile u8 *feature_p[MAX_FEATURES];	volatile u8 *p, *start;	int n_features = 0;	u8 func_id = ~0;	u8 code, len;	unsigned short config_base = 0;	int found = 0;	int i;#ifdef DEBUG	printk ("PCMCIA MEM: %08lX\n", base);#endif	start = p = (volatile u8 *) base;	while ((p - start) < MAX_TUPEL_SZ) {		code = *p; p += 2;		if (code == 0xFF) { /* End of chain */			break;		}		len = *p; p += 2;#ifdef	DEBUG_PCMCIA		{ volatile u8 *q = p;			printk ("\nTuple code %02x  length %d\n\tData:",				code, len);			for (i = 0; i < len; ++i) {				printk (" %02x", *q);				q+= 2;			}		}#endif	/* DEBUG_PCMCIA */		switch (code) {		case CISTPL_VERS_1:			ident = p + 4;			break;		case CISTPL_FUNCID:			func_id = *p;			break;		case CISTPL_FUNCE:			if (n_features < MAX_FEATURES)				feature_p[n_features++] = p;			break;		case CISTPL_CONFIG:			config_base = (*(p+6) << 8) + (*(p+4));		default:			break;		}		p += 2 * len;	}	found = identify (ident);	if (func_id != ((u8)~0)) {		print_funcid (func_id);		if (func_id == CISTPL_FUNCID_FIXED)			found = 1;		else			return (1);	/* no disk drive */	}	for (i=0; i<n_features; ++i) {		print_fixed (feature_p[i]);	}	if (!found) {		printk ("unknown card type\n");		return (1);	}	/* set level mode irq and I/O mapped device in config reg*/	*((u8 *)(base + config_base)) = 0x41;	return (0);}/* ------------------------------------------------------------------------- */static void print_funcid (int func){	switch (func) {	case CISTPL_FUNCID_MULTI:		printk (" Multi-Function");		break;	case CISTPL_FUNCID_MEMORY:		printk (" Memory");		break;	case CISTPL_FUNCID_SERIAL:		printk (" Serial Port");		break;	case CISTPL_FUNCID_PARALLEL:		printk (" Parallel Port");		break;	case CISTPL_FUNCID_FIXED:		printk (" Fixed Disk");		break;	case CISTPL_FUNCID_VIDEO:		printk (" Video Adapter");		break;	case CISTPL_FUNCID_NETWORK:		printk (" Network Adapter");		break;	case CISTPL_FUNCID_AIMS:		printk (" AIMS Card");		break;	case CISTPL_FUNCID_SCSI:		printk (" SCSI Adapter");		break;	default:		printk (" Unknown");		break;	}	printk (" Card\n");}/* ------------------------------------------------------------------------- */static void print_fixed (volatile u8 *p){	if (p == NULL)		return;	switch (*p) {	case CISTPL_FUNCE_IDE_IFACE:	    {   u8 iface = *(p+2);		printk ((iface == CISTPL_IDE_INTERFACE) ? " IDE" : " unknown");		printk (" interface ");		break;	    }	case CISTPL_FUNCE_IDE_MASTER:	case CISTPL_FUNCE_IDE_SLAVE:	    {   u8 f1 = *(p+2);		u8 f2 = *(p+4);		printk ((f1 & CISTPL_IDE_SILICON) ? " [silicon]" : " [rotating]");		if (f1 & CISTPL_IDE_UNIQUE)			printk (" [unique]");		printk ((f1 & CISTPL_IDE_DUAL) ? " [dual]" : " [single]");		if (f2 & CISTPL_IDE_HAS_SLEEP)			printk (" [sleep]");		if (f2 & CISTPL_IDE_HAS_STANDBY)			printk (" [standby]");		if (f2 & CISTPL_IDE_HAS_IDLE)			printk (" [idle]");		if (f2 & CISTPL_IDE_LOW_POWER)			printk (" [low power]");		if (f2 & CISTPL_IDE_REG_INHIBIT)			printk (" [reg inhibit]");		if (f2 & CISTPL_IDE_HAS_INDEX)			printk (" [index]");		if (f2 & CISTPL_IDE_IOIS16)			printk (" [IOis16]");		break;	    }	}	printk ("\n");}/* ------------------------------------------------------------------------- */#define MAX_IDENT_CHARS		64#define	MAX_IDENT_FIELDS	4static u8 *known_cards[] = {	"ARGOSY PnPIDE D5",	NULL};static int identify  (volatile u8 *p){	u8 id_str[MAX_IDENT_CHARS];	u8 data;	u8 *t;	u8 **card;	int i, done;	if (p == NULL)		return (0);	/* Don't know */	t = id_str;	done =0;	for (i=0; i<=4 && !done; ++i, p+=2) {		while ((data = *p) != '\0') {			if (data == 0xFF) {				done = 1;				break;			}			*t++ = data;			if (t == &id_str[MAX_IDENT_CHARS-1]) {				done = 1;				break;			}			p += 2;		}		if (!done)			*t++ = ' ';	}	*t = '\0';	while (--t > id_str) {		if (*t == ' ')			*t = '\0';		else			break;	}	printk ("Card ID: %s\n", id_str);	for (card=known_cards; *card; ++card) {		if (strcmp(*card, id_str) == 0) {	/* found! */			return (1);		}	}	return (0);	/* don't know */}void m8xx_ide_init(void){	ppc_ide_md.default_irq          = m8xx_ide_default_irq;	ppc_ide_md.default_io_base      = m8xx_ide_default_io_base;	ppc_ide_md.ide_init_hwif        = m8xx_ide_init_hwif_ports;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品视频在线看| 精品国产三级a在线观看| 中文字幕一区在线观看| eeuss鲁片一区二区三区在线观看| 日本一区二区三区dvd视频在线| 成人永久aaa| 一区二区三区影院| 欧美久久免费观看| 激情六月婷婷久久| 国产欧美一区二区三区在线老狼| 成人精品视频一区二区三区| 一区二区在线电影| 日韩亚洲欧美成人一区| 国产精品羞羞答答xxdd| 日韩码欧中文字| 欧美一区二区三区四区久久| 国产一区二区三区在线看麻豆| 国产精品视频在线看| 欧美日韩国产影片| 国产一区二区三区黄视频| 亚洲欧美综合在线精品| 欧美日产国产精品| 国产成人av影院| 亚洲一区在线视频观看| 欧美精品一区二区蜜臀亚洲| 丰满放荡岳乱妇91ww| 亚洲一区二区在线视频| 精品久久久久久综合日本欧美| 91丝袜美腿高跟国产极品老师| 亚洲aⅴ怡春院| 国产精品久久久久永久免费观看| 欧美色手机在线观看| 国产精品亚洲а∨天堂免在线| 亚洲韩国一区二区三区| 日本一区二区成人在线| 在线成人免费视频| 成av人片一区二区| 国产美女久久久久| 午夜伊人狠狠久久| 日韩毛片视频在线看| 日韩精品一区二区三区蜜臀| 色综合久久久久久久| 精品一区二区在线看| 亚洲一区在线观看免费| 国产免费成人在线视频| 日韩欧美国产高清| 欧美日韩免费观看一区三区| 91网站黄www| 国产99久久精品| 国产真实乱子伦精品视频| 视频一区中文字幕| 亚洲制服丝袜在线| 亚洲天堂精品视频| 亚洲国产精品99久久久久久久久 | 精品国产一区a| 欧美日韩精品福利| 色94色欧美sute亚洲线路二| 成人av午夜电影| 处破女av一区二区| 国产精品99精品久久免费| 另类中文字幕网| 日产精品久久久久久久性色| 亚洲图片欧美综合| 亚洲男女一区二区三区| 亚洲视频在线观看一区| 中文字幕一区二区三中文字幕| 久久蜜桃av一区精品变态类天堂| 日韩欧美亚洲国产精品字幕久久久| 欧美日韩国产一级片| 欧美吻胸吃奶大尺度电影| 欧美影视一区在线| 欧美丝袜丝nylons| 8x福利精品第一导航| 91精品免费在线| 欧美一二三四在线| 日韩视频中午一区| 久久久久久黄色| 欧美极品aⅴ影院| 亚洲欧洲日韩在线| 一区二区三区在线免费播放| 一级日本不卡的影视| 亚洲成人av在线电影| 日韩精品午夜视频| 激情欧美一区二区三区在线观看| 国产在线不卡一区| 成人av网站在线| 在线一区二区三区四区五区| 欧美色倩网站大全免费| 91精品国产一区二区三区| 精品国产免费一区二区三区四区 | 国产精品丝袜久久久久久app| 国产性色一区二区| 一区在线播放视频| 一区二区三区丝袜| 日韩av中文在线观看| 久久草av在线| 成人黄色国产精品网站大全在线免费观看| www.综合网.com| 欧美亚洲国产怡红院影院| 欧美一区二区三区四区视频| 久久午夜羞羞影院免费观看| 国产精品伦理一区二区| 亚洲123区在线观看| 国模套图日韩精品一区二区| 91在线视频免费观看| 欧美日韩免费不卡视频一区二区三区| 日韩精品一区二区三区中文不卡| 国产片一区二区| 亚洲成年人网站在线观看| 精品夜夜嗨av一区二区三区| 91在线观看污| 欧美一区二区福利视频| 中文字幕va一区二区三区| 亚洲成人一二三| 成人网在线播放| 欧美一区二区三区免费观看视频| 久久久国产精品午夜一区ai换脸| 亚洲美女视频在线| 国产一区二区看久久| 色婷婷久久99综合精品jk白丝| 日韩无一区二区| 夜夜揉揉日日人人青青一国产精品| 麻豆成人久久精品二区三区红 | 美腿丝袜亚洲色图| 成人福利视频在线| 欧美成人一级视频| 亚洲一区二区三区四区在线 | 91亚洲永久精品| 欧美不卡一二三| 一级精品视频在线观看宜春院| 理论片日本一区| 欧美色图在线观看| 中文字幕色av一区二区三区| 精品综合久久久久久8888| 欧美视频完全免费看| 国产精品国模大尺度视频| 免费高清在线视频一区·| 欧美亚洲一区二区在线| 国产精品成人午夜| 国产成人免费av在线| 91精品国产一区二区三区蜜臀| 亚洲欧美日韩一区二区 | 日韩不卡一区二区| 色av成人天堂桃色av| 国产精品久久久久久久久免费相片| 男女男精品网站| 欧美一区二区三区日韩| 午夜精品久久久久影视| 欧美在线视频日韩| 亚洲精品视频观看| 99精品久久免费看蜜臀剧情介绍| 2024国产精品| 美女网站视频久久| 日韩欧美在线网站| 免费观看在线综合色| 日韩一区二区免费在线电影| 天天亚洲美女在线视频| 欧美区视频在线观看| 亚洲一区二区成人在线观看| 91福利视频网站| 亚洲午夜视频在线| 欧美日韩和欧美的一区二区| 亚洲成人精品一区二区| 欧美日韩一区在线| 天天影视网天天综合色在线播放| 欧美午夜精品一区二区蜜桃| 性做久久久久久免费观看| 欧美老肥妇做.爰bbww| 免费观看日韩电影| 久久女同精品一区二区| 国产成人精品免费视频网站| 欧美国产欧美亚州国产日韩mv天天看完整| 国产激情一区二区三区| 中文字幕在线观看不卡| 日本电影欧美片| 午夜精品久久久久影视| 精品剧情v国产在线观看在线| 国产在线播放一区三区四| 中文无字幕一区二区三区| 99久久久免费精品国产一区二区| 亚洲人成亚洲人成在线观看图片 | 精品在线视频一区| 国产人久久人人人人爽| 色综合色综合色综合色综合色综合 | 国产精品久久久久一区| 在线欧美小视频| 玖玖九九国产精品| 久久精品一区四区| 99久久久久免费精品国产| 亚洲国产成人tv| 久久久亚洲高清| 色婷婷综合久久久中文字幕| 三级欧美在线一区| 久久久久久免费网| 在线视频中文字幕一区二区| 日本vs亚洲vs韩国一区三区 | 欧美日韩精品三区| 狠狠色丁香婷婷综合久久片| 中文字幕一区二区三区不卡在线| 欧美在线观看视频在线|