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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? skvpd.c

?? giga網(wǎng)卡完整的驅(qū)動(dòng)代碼,系統(tǒng)是linux,可以了解整個(gè)網(wǎng)卡驅(qū)動(dòng)在linux系統(tǒng)的結(jié)構(gòu),并且包含了giga模式的特有接口的實(shí)現(xiàn).
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
	int		Rtv;	for (i = 0; i < Len; i++, buf++) {		if ((i%sizeof(SK_U32)) == 0) {			/* New Address needs to be written to VPD_ADDR reg */			AdrReg = (SK_U16) Addr;			Addr += sizeof(SK_U32);			AdrReg &= ~VPD_WRITE;	/* READ operation */			VPD_OUT16(pAC, IoC, PCI_VPD_ADR_REG, AdrReg);			/* Wait for termination */			Rtv = VpdWait(pAC, IoC, VPD_READ);			if (Rtv != 0) {				return(i);			}		}		VPD_IN8(pAC, IoC, PCI_VPD_DAT_REG + (i%sizeof(SK_U32)),			(SK_U8 *)buf);	}	return(Len);}/* *	Read ore writes 'len' bytes of VPD data, starting at 'addr' from *	or to the I2C EEPROM. * * Returns number of bytes read / written. */static int VpdTransferBlock(SK_AC	*pAC,	/* Adapters context */SK_IOC	IoC,	/* IO Context */char	*buf,	/* data buffer */int		addr,	/* VPD start address */int		len,	/* number of bytes to read / to write */int		dir)	/* transfer direction may be VPD_READ or VPD_WRITE */{	int		Rtv;	/* Return value */	int		vpd_rom_size;	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,		("VPD %s block, addr = 0x%x, len = %d\n",		dir ? "write" : "read", addr, len));	if (len == 0)		return(0);	vpd_rom_size = pAC->vpd.rom_size;		if (addr > vpd_rom_size - 4) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Address error: 0x%x, exp. < 0x%x\n",			addr, vpd_rom_size - 4));		return(0);	}		if (addr + len > vpd_rom_size) {		len = vpd_rom_size - addr;		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR,			("Warning: len was cut to %d\n", len));	}	if (dir == VPD_READ) {		Rtv = VpdReadStream(pAC, IoC, buf, addr, len);	}	else {		Rtv = VpdWriteStream(pAC, IoC, buf, addr, len);	}	return(Rtv);}#ifdef SKDIAG/* *	Read 'len' bytes of VPD data, starting at 'addr'. * * Returns number of bytes read. */int VpdReadBlock(SK_AC	*pAC,	/* pAC pointer */SK_IOC	IoC,	/* IO Context */char	*buf,	/* buffer were the data should be stored */int		addr,	/* start reading at the VPD address */int		len)	/* number of bytes to read */{	return(VpdTransferBlock(pAC, IoC, buf, addr, len, VPD_READ));}/* *	Write 'len' bytes of *but to the VPD EEPROM, starting at 'addr'. * * Returns number of bytes writes. */int VpdWriteBlock(SK_AC	*pAC,	/* pAC pointer */SK_IOC	IoC,	/* IO Context */char	*buf,	/* buffer, holds the data to write */int		addr,	/* start writing at the VPD address */int		len)	/* number of bytes to write */{	return(VpdTransferBlock(pAC, IoC, buf, addr, len, VPD_WRITE));}#endif	/* SKDIAG *//* * (re)initialize the VPD buffer * * Reads the VPD data from the EEPROM into the VPD buffer. * Get the remaining read only and read / write space. * * return	0:	success *		1:	fatal VPD error */static int VpdInit(SK_AC	*pAC,	/* Adapters context */SK_IOC	IoC)	/* IO Context */{	SK_VPD_PARA *r, rp;	/* RW or RV */	int		i;	unsigned char	x;	int		vpd_size;	SK_U16	dev_id;	SK_U32	our_reg2;	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_INIT, ("VpdInit .. "));		VPD_IN16(pAC, IoC, PCI_DEVICE_ID, &dev_id);		VPD_IN32(pAC, IoC, PCI_OUR_REG_2, &our_reg2);		pAC->vpd.rom_size = 256 << ((our_reg2 & PCI_VPD_ROM_SZ) >> 14);		/*	 * this function might get used before the hardware is initialized	 * therefore we cannot always trust in GIChipId	 */	if (((pAC->vpd.v.vpd_status & VPD_VALID) == 0 &&		dev_id != VPD_DEV_ID_GENESIS) ||		((pAC->vpd.v.vpd_status & VPD_VALID) != 0 &&		!pAC->GIni.GIGenesis)) {		/* for Yukon the VPD size is always 256 */		vpd_size = VPD_SIZE_YUKON;	}	else {		/* Genesis uses the maximum ROM size up to 512 for VPD */		if (pAC->vpd.rom_size > VPD_SIZE_GENESIS) {			vpd_size = VPD_SIZE_GENESIS;		}		else {			vpd_size = pAC->vpd.rom_size;		}	}	/* read the VPD data into the VPD buffer */	if (VpdTransferBlock(pAC, IoC, pAC->vpd.vpd_buf, 0, vpd_size, VPD_READ)		!= vpd_size) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR,			("Block Read Error\n"));		return(1);	}		pAC->vpd.vpd_size = vpd_size;	/* find the end tag of the RO area */	if (!(r = vpd_find_para(pAC, VPD_RV, &rp))) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Encoding Error: RV Tag not found\n"));		return(1);	}		if (r->p_val + r->p_len > pAC->vpd.vpd_buf + vpd_size/2) {		SK_DBG_MSG(pAC,SK_DBGMOD_VPD,SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Encoding Error: Invalid VPD struct size\n"));		return(1);	}	pAC->vpd.v.vpd_free_ro = r->p_len - 1;	/* test the checksum */	for (i = 0, x = 0; (unsigned)i <= (unsigned)vpd_size/2 - r->p_len; i++) {		x += pAC->vpd.vpd_buf[i];	}		if (x != 0) {		/* checksum error */		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("VPD Checksum Error\n"));		return(1);	}	/* find and check the end tag of the RW area */	if (!(r = vpd_find_para(pAC, VPD_RW, &rp))) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Encoding Error: RV Tag not found\n"));		return(1);	}		if (r->p_val < pAC->vpd.vpd_buf + vpd_size/2) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Encoding Error: Invalid VPD struct size\n"));		return(1);	}	pAC->vpd.v.vpd_free_rw = r->p_len;	/* everything seems to be ok */	if (pAC->GIni.GIChipId != 0) {		pAC->vpd.v.vpd_status |= VPD_VALID;	}	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_INIT,		("done. Free RO = %d, Free RW = %d\n",		pAC->vpd.v.vpd_free_ro, pAC->vpd.v.vpd_free_rw));	return(0);}/* *	find the Keyword 'key' in the VPD buffer and fills the *	parameter struct 'p' with it's values * * returns	*p	success *		0:	parameter was not found or VPD encoding error */static SK_VPD_PARA *vpd_find_para(SK_AC		*pAC,	/* common data base */const char	*key,	/* keyword to find (e.g. "MN") */SK_VPD_PARA *p)		/* parameter description struct */{	char *v	;	/* points to VPD buffer */	int max;	/* Maximum Number of Iterations */	v = pAC->vpd.vpd_buf;	max = 128;	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,		("VPD find para %s .. ",key));	/* check mandatory resource type ID string (Product Name) */	if (*v != (char)RES_ID) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Error: 0x%x missing\n", RES_ID));		return(0);	}	if (strcmp(key, VPD_NAME) == 0) {		p->p_len = VPD_GET_RES_LEN(v);		p->p_val = VPD_GET_VAL(v);		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,			("found, len = %d\n", p->p_len));		return(p);	}	v += 3 + VPD_GET_RES_LEN(v) + 3;	for (;; ) {		if (SK_MEMCMP(key,v,2) == 0) {			p->p_len = VPD_GET_VPD_LEN(v);			p->p_val = VPD_GET_VAL(v);			SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,				("found, len = %d\n",p->p_len));			return(p);		}		/* exit when reaching the "RW" Tag or the maximum of itera. */		max--;		if (SK_MEMCMP(VPD_RW,v,2) == 0 || max == 0) {			break;		}		if (SK_MEMCMP(VPD_RV,v,2) == 0) {			v += 3 + VPD_GET_VPD_LEN(v) + 3;	/* skip VPD-W */		}		else {			v += 3 + VPD_GET_VPD_LEN(v);		}		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,			("scanning '%c%c' len = %d\n",v[0],v[1],v[2]));	}#ifdef DEBUG	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL, ("not found\n"));	if (max == 0) {		SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Key/Len Encoding error\n"));	}#endif /* DEBUG */	return(0);}/* *	Move 'n' bytes. Begin with the last byte if 'n' is > 0, *	Start with the last byte if n is < 0. * * returns nothing */static void vpd_move_para(char	*start,		/* start of memory block */char	*end,		/* end of memory block to move */int		n)			/* number of bytes the memory block has to be moved */{	char *p;	int i;		/* number of byte copied */	if (n == 0)		return;	i = (int) (end - start + 1);	if (n < 0) {		p = start + n;		while (i != 0) {			*p++ = *start++;			i--;		}	}	else {		p = end + n;		while (i != 0) {			*p-- = *end--;			i--;		}	}}/* *	setup the VPD keyword 'key' at 'ip'. * * returns nothing */static void vpd_insert_key(const char	*key,	/* keyword to insert */const char	*buf,	/* buffer with the keyword value */int		len,		/* length of the value string */char	*ip)		/* inseration point */{	SK_VPD_KEY *p;	p = (SK_VPD_KEY *) ip;	p->p_key[0] = key[0];	p->p_key[1] = key[1];	p->p_len = (unsigned char) len;	SK_MEMCPY(&p->p_val,buf,len);}/* *	Setup the VPD end tag "RV" / "RW". *	Also correct the remaining space variables vpd_free_ro / vpd_free_rw. * * returns	0:	success *		1:	encoding error */static int vpd_mod_endtag(SK_AC	*pAC,		/* common data base */char	*etp)		/* end pointer input position */{	SK_VPD_KEY *p;	unsigned char	x;	int	i;	int	vpd_size;	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,		("VPD modify endtag at 0x%x = '%c%c'\n",etp,etp[0],etp[1]));	vpd_size = pAC->vpd.vpd_size;	p = (SK_VPD_KEY *) etp;	if (p->p_key[0] != 'R' || (p->p_key[1] != 'V' && p->p_key[1] != 'W')) {		/* something wrong here, encoding error */		SK_DBG_MSG(pAC,SK_DBGMOD_VPD,SK_DBGCAT_ERR | SK_DBGCAT_FATAL,			("Encoding Error: invalid end tag\n"));		return(1);	}	if (etp > pAC->vpd.vpd_buf + vpd_size/2) {		/* create "RW" tag */		p->p_len = (unsigned char)(pAC->vpd.vpd_buf+vpd_size-etp-3-1);		pAC->vpd.v.vpd_free_rw = (int) p->p_len;		i = pAC->vpd.v.vpd_free_rw;		etp += 3;	}	else {		/* create "RV" tag */		p->p_len = (unsigned char)(pAC->vpd.vpd_buf+vpd_size/2-etp-3);		pAC->vpd.v.vpd_free_ro = (int) p->p_len - 1;		/* setup checksum */		for (i = 0, x = 0; i < vpd_size/2 - p->p_len; i++) {			x += pAC->vpd.vpd_buf[i];		}		p->p_val = (char) 0 - x;		i = pAC->vpd.v.vpd_free_ro;		etp += 4;	}	while (i) {		*etp++ = 0x00;		i--;	}	return(0);}/* *	Insert a VPD keyword into the VPD buffer. * *	The keyword 'key' is inserted at the position 'ip' in the *	VPD buffer. *	The keywords behind the input position will *	be moved. The VPD end tag "RV" or "RW" is generated again. * * returns	0:	success *		2:	value string was cut *		4:	VPD full, keyword was not written *		6:	fatal VPD error * */int	VpdSetupPara(SK_AC	*pAC,		/* common data base */const char	*key,	/* keyword to insert */const char	*buf,	/* buffer with the keyword value */int		len,		/* length of the keyword value */int		type,		/* VPD_RO_KEY or VPD_RW_KEY */int		op)			/* operation to do: ADD_KEY or OWR_KEY */{	SK_VPD_PARA vp;	char	*etp;		/* end tag position */	int	free;		/* remaining space in selected area */	char	*ip;		/* input position inside the VPD buffer */	int	rtv;		/* return code */	int	head;		/* additional haeder bytes to move */	int	found;		/* additinoal bytes if the keyword was found */	int vpd_size;	SK_DBG_MSG(pAC, SK_DBGMOD_VPD, SK_DBGCAT_CTRL,		("VPD setup para key = %s, val = %s\n",key,buf));		vpd_size = pAC->vpd.vpd_size;	rtv = 0;	ip = 0;	if (type == VPD_RW_KEY) {		/* end tag is "RW" */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产麻豆视频精品| 91年精品国产| 亚洲精品欧美在线| 337p粉嫩大胆噜噜噜噜噜91av| av毛片久久久久**hd| 麻豆精品在线观看| 日韩电影免费一区| 亚洲一区二区三区影院| 亚洲欧美在线高清| 国产午夜精品在线观看| 久久九九99视频| 成人欧美一区二区三区视频网页 | 麻豆成人91精品二区三区| 国产盗摄精品一区二区三区在线| 老司机精品视频导航| 免费观看在线综合| 国产一区二区三区免费播放 | 亚洲丝袜精品丝袜在线| 亚洲丝袜制服诱惑| 另类小说图片综合网| 99这里都是精品| 91麻豆精品国产无毒不卡在线观看| 欧美日韩精品免费| 欧美一区中文字幕| 欧美一区二区免费观在线| 国产日韩欧美精品一区| 国产精品久久久久7777按摩| 亚洲日本护士毛茸茸| 日韩成人一区二区三区在线观看| 成人福利电影精品一区二区在线观看| 国v精品久久久网| 成人免费毛片片v| 一本一道综合狠狠老| 欧美日韩中文精品| 欧美zozozo| 国产午夜精品久久| 五月婷婷综合在线| 国产在线国偷精品免费看| 在线免费精品视频| 欧美浪妇xxxx高跟鞋交| 精品欧美久久久| 一区二区欧美精品| 久久99久久久欧美国产| 欧美在线你懂的| 国产精品私人自拍| 亚洲国产aⅴ成人精品无吗| 奇米一区二区三区av| 色菇凉天天综合网| 日韩精品一区二区三区视频播放| 国产欧美精品一区| 久久激情综合网| 欧美日韩一区二区三区高清| 亚洲私人黄色宅男| 成人91在线观看| 欧美高清一级片在线观看| 亚洲丶国产丶欧美一区二区三区| 激情图片小说一区| 色综合视频在线观看| 中文字幕成人在线观看| 国产一区二区精品久久91| 日韩视频123| 亚洲欧洲99久久| 大胆亚洲人体视频| 久久久亚洲欧洲日产国码αv| 亚洲综合在线视频| 91网址在线看| 成人欧美一区二区三区| 成人深夜福利app| 国产人成亚洲第一网站在线播放 | 欧美va亚洲va国产综合| 日韩精品视频网站| 99re热视频这里只精品| 91精品国产91热久久久做人人| 亚洲国产成人91porn| 欧美在线视频日韩| 午夜久久电影网| 欧美人动与zoxxxx乱| 性久久久久久久| 欧美肥妇bbw| 日韩成人精品视频| 日韩一区二区免费视频| 免费观看成人av| 2欧美一区二区三区在线观看视频| 毛片基地黄久久久久久天堂| 欧美成人国产一区二区| 国内精品不卡在线| 国产亚洲欧洲997久久综合| 国产福利一区二区三区视频在线| 国产亚洲欧美日韩俺去了| 国产成人在线看| 中文字幕一区二区三区四区不卡| av一二三不卡影片| 亚洲乱码国产乱码精品精可以看| 欧美中文字幕一区| 日韩精品成人一区二区三区| 日韩你懂的电影在线观看| 韩国av一区二区三区在线观看| 久久久久久免费网| 成人aaaa免费全部观看| 亚洲一区二区美女| 日韩欧美国产不卡| 国产成人在线视频网址| 亚洲丝袜另类动漫二区| 欧美男女性生活在线直播观看| 日日摸夜夜添夜夜添精品视频| 欧美成人性福生活免费看| 国产精品亚洲一区二区三区妖精| 欧美成人国产一区二区| 高清不卡在线观看| 亚洲国产va精品久久久不卡综合| 日韩欧美一二区| www.99精品| 天使萌一区二区三区免费观看| 久久综合久久综合久久| 91啪亚洲精品| 美腿丝袜亚洲色图| 国产精品日产欧美久久久久| 欧洲一区在线电影| 精品在线播放午夜| 精品国产a毛片| 国产在线一区二区综合免费视频| 中文字幕一区视频| 67194成人在线观看| 国产传媒久久文化传媒| 亚洲综合视频在线| 欧美r级在线观看| 一本久道久久综合中文字幕| 日本aⅴ亚洲精品中文乱码| 日本一二三不卡| 欧美日韩的一区二区| 国产99久久精品| 亚洲国产成人av网| 国产精品美女久久久久久久 | 美女看a上一区| 亚洲图片另类小说| 精品国产免费一区二区三区香蕉| 91社区在线播放| 精彩视频一区二区三区| 亚洲综合自拍偷拍| 中文字幕国产精品一区二区| 91麻豆精品国产自产在线观看一区| 成人一二三区视频| 麻豆一区二区三区| 亚洲国产精品影院| 国产精品国产三级国产aⅴ入口| 欧美一区三区二区| 在线亚洲一区二区| 国产成人精品免费在线| 免费三级欧美电影| 一区二区三区鲁丝不卡| 欧美韩日一区二区三区四区| 日韩欧美在线一区二区三区| 色老汉一区二区三区| 丁香激情综合国产| 激情综合色综合久久| 日韩影院在线观看| 亚洲永久精品大片| 亚洲色图欧洲色图婷婷| 久久久精品免费网站| 欧美一区二区免费视频| 欧美日韩一区国产| 色综合天天做天天爱| 亚洲一区二区三区四区五区中文| 国产欧美一区二区精品仙草咪| 日韩美女一区二区三区| 欧美日韩精品一区二区三区 | 天天影视网天天综合色在线播放| 日韩理论片中文av| 久久九九久精品国产免费直播| 欧美成人在线直播| 日韩一级片网站| 884aa四虎影成人精品一区| 欧美专区亚洲专区| 日本电影亚洲天堂一区| 99久久99久久精品免费看蜜桃| 国产69精品久久99不卡| 国产电影精品久久禁18| 国产成人午夜精品5599| 狠狠v欧美v日韩v亚洲ⅴ| 久久se这里有精品| 蜜桃一区二区三区四区| 男人的天堂久久精品| 日日嗨av一区二区三区四区| 婷婷六月综合亚洲| 五月天中文字幕一区二区| 午夜久久久久久电影| 天天爽夜夜爽夜夜爽精品视频| 亚洲国产成人91porn| 亚洲成人777| 午夜欧美大尺度福利影院在线看| 亚洲一区二区三区中文字幕在线| 亚洲成人午夜电影| 日韩精品乱码免费| 久久er99热精品一区二区| 精品一区二区三区在线视频| 国产一区二区三区在线看麻豆| 国产麻豆精品视频| 成人国产亚洲欧美成人综合网| 9i看片成人免费高清| 欧美视频精品在线|