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

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

?? meeprom.c

?? Atheros AP Test with Agilent N4010A source code
?? C
?? 第 1 頁 / 共 5 頁
字號:
			lowerPower = pPowerInfo[lowerIndex].twicePwr48;
			upperPower = pPowerInfo[upperIndex].twicePwr48;
			break;

		case 13:
		case 14:
			lowerPower = pPowerInfo[lowerIndex].twicePwr54;
			upperPower = pPowerInfo[upperIndex].twicePwr54;
			break;
		}

		twicePower = (A_UINT16)(getInterpolatedValue(channel, lowerChannel, upperChannel, lowerPower,
						upperPower, 0));  


		if(twicePower > twiceMaxEdgePower) {
			twicePower = twiceMaxEdgePower;
		}

		if(pLibDev->libCfgParams.applyCtlLimit) {
			if((pLibDev->mode == MODE_11B) || (pLibDev->mode == MODE_11G) ) {
				ctlPower = getCtlPower(devNum, pLibDev->libCfgParams.ctlToApply, channel, MODE_11B, pLibDev->turbo);
			}

			if(ctlPower < twicePower) {
				pRatesPower[i] = (A_INT16)ctlPower;
//				printf("Applying ctl power (x2) of %d to pRatesPower[%d]\n", ctlPower, i);
			} else {
				pRatesPower[i] = twicePower;
			}
		}
		else {
			pRatesPower[i] = twicePower;
		}
	}
	
	return;
}


/**************************************************************************
* forcePCDACTable - Write the linear power - pcdac table to device registers
*
*
* RETURNS: 
*/
MANLIB_API void forcePCDACTable 
(
 A_UINT32		devNum,
 A_UINT16		*pPcdacs
)
{
	A_UINT16	regOffset;
	A_UINT16	i;
	A_UINT32	temp32;
  LIB_DEV_INFO *pLibDev = gLibInfo.pLibDevArray[devNum];
	
	regOffset = 0x9800 + (608 << 2) ;
	for(i = 0; i < 32; i++) {
		temp32 = 0xffff & ((pPcdacs[2*i + 1] << 8) | 0xff);
		temp32 = (temp32 << 16) | (0xffff & ((pPcdacs[2*i] << 8) | 0xff));
		if (pLibDev->devMap.remoteLib) {
			pciValues[i].offset = regOffset;
			pciValues[i].baseValue = temp32;
		}
		else {
		    REGW(devNum, regOffset, temp32);
		}
		//printf("Snoop: regOffset = %x, regValue = %x\n", regOffset, temp32);
		regOffset += 4;
	}
	if (pLibDev->devMap.remoteLib) {
			sendPciWrites(devNum, pciValues, 32);
	}

}


/**************************************************************************
* forcePDADCTable - Write the pdadc table and gain boundaries to device 
*                   registers 672-703
*
* RETURNS:  Nothing
*/
MANLIB_API void forcePDADCTable 
(
 A_UINT32		devNum,
 A_UINT16		*pPdadcs,
 A_UINT16		*pGainBoundaries
)
{
	A_UINT16	regOffset;
	A_UINT16	i;
	A_UINT32	temp32;
	
	regOffset = 0x9800 + (672 << 2) ;
	for(i = 0; i < 32; i++) {
		temp32 = ((pPdadcs[4*i + 0] & 0xFF) << 0)  | 
			     ((pPdadcs[4*i + 1] & 0xFF) << 8)  |
				 ((pPdadcs[4*i + 2] & 0xFF) << 16) |
				 ((pPdadcs[4*i + 3] & 0xFF) << 24) ;		
		REGW(devNum, regOffset, temp32);
		//printf("Snoop: regOffset = %x, regValue = %x\n", regOffset, temp32);
		regOffset += 4;
	}

	//cant use field names incase we are loading ear, these don't exist in non griffin
	//config files.
	temp32 = ((pGainBoundaries[0] & 0x3f) << 4)  |
			 ((pGainBoundaries[1] & 0x3f) << 10) |
			 ((pGainBoundaries[2] & 0x3f) << 16) |
			 ((pGainBoundaries[3] & 0x3f) << 22) ;
	REGW(devNum, 0xa26c, (REGR(devNum, 0xa26c) & 0xf)| temp32);

	//writeField(devNum, "bb_pd_gain_boundary_1", pGainBoundaries[0]);
	//writeField(devNum, "bb_pd_gain_boundary_2", pGainBoundaries[1]);
	//writeField(devNum, "bb_pd_gain_boundary_3", pGainBoundaries[2]);
	//writeField(devNum, "bb_pd_gain_boundary_4", pGainBoundaries[3]);
}



/**************************************************************************
* fbin2freq - Get channel value from binary representation held in eeprom
*
*
* RETURNS: the frequency in MHz
*/
A_UINT16 fbin2freq(A_UINT32 devNum, A_UINT16 fbin)
{
	A_UINT16 returnValue; 
    LIB_DEV_INFO	*pLibDev = gLibInfo.pLibDevArray[devNum];

	if((pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion <= 2)) {
		returnValue = (fbin>62) ? (A_UINT16)(5100 + 10*62 + 5*(fbin-62)) : (A_UINT16)(5100 + 10*fbin);
	}
	else {
		returnValue = (A_UINT16)(4800 + 5*fbin);
	}
	return returnValue;
} 

A_UINT16 fbin2freq_2p4(A_UINT32 devNum, A_UINT16 fbin)
{
	A_UINT16 returnValue; 
    LIB_DEV_INFO	*pLibDev = gLibInfo.pLibDevArray[devNum];

	if((pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion <= 2)) {
		returnValue = (A_UINT16)(2400 + fbin);
	}
	else {
		returnValue = (A_UINT16)(2300 + fbin);
	}
	return returnValue;
}


/**************************************************************************
* allocateEepStructs - Allocate structs to hold eeprom contents
*
* Fills in pointers of the LIB_DEV_INFO struct
*
* RETURNS: TRUE if successfully allocated, false otherwise
*/
A_BOOL allocateEepStructs
(
 A_UINT32			devNum
)
{
    LIB_DEV_INFO *pLibDev = gLibInfo.pLibDevArray[devNum];
	A_UINT32	 i;

	//check to see if we already allocated thes stucts, if so, don't do again
	//if one ptrs is not null then so will the rest.
	if(pLibDev->pCalibrationInfo) {
		return(TRUE);
	}

	//allocate the struct to hold the pcdac/power info
	pLibDev->pCalibrationInfo = (MDK_PCDACS_ALL_MODES *)malloc(sizeof(MDK_PCDACS_ALL_MODES));
	if(NULL == pLibDev->pCalibrationInfo) {
		mError(devNum, ENOMEM, "Device Number %d:Device Number %d:Unable to allocate eeprom structure for pcdac/power info\n", devNum);
		return FALSE;
	}
	
	memset(pLibDev->pCalibrationInfo, 0, sizeof(MDK_PCDACS_ALL_MODES));

	pLibDev->pCalibrationInfo->numChannels_11a = NUM_11A_EEPROM_CHANNELS;
	pLibDev->pCalibrationInfo->numChannels_2_4 = NUM_2_4_EEPROM_CHANNELS;

	for(i = 0; i < NUM_11A_EEPROM_CHANNELS; i ++) {		
		pLibDev->pCalibrationInfo->DataPerChannel_11a[i].numPcdacValues = NUM_PCDAC_VALUES;	
	}

	//allocate the struct to hold the header info
	pLibDev->p16kEepHeader = (MDK_EEP_HEADER_INFO *)malloc(sizeof(MDK_EEP_HEADER_INFO));
	if(NULL ==pLibDev->p16kEepHeader) {
		mError(devNum, ENOMEM, "Device Number %d:Device Number %d:Unable to allocate eeprom structure for header info\n", devNum);
		freeEepStructs(devNum);
		return FALSE;
	}
	memset(pLibDev->p16kEepHeader, 0, sizeof(MDK_EEP_HEADER_INFO));

	//allocate the structure to hold target power info
	pLibDev->p16KTrgtPowerInfo = (MDK_TRGT_POWER_ALL_MODES *)malloc(sizeof(MDK_TRGT_POWER_ALL_MODES));
	if(NULL == pLibDev->p16KTrgtPowerInfo) {
		mError(devNum, ENOMEM, "Device Number %d:Device Number %d:Unable to allocate eeprom structure for target power info\n", devNum);
		freeEepStructs(devNum);
		return FALSE;
	}
	memset(pLibDev->p16KTrgtPowerInfo, 0, sizeof(MDK_TRGT_POWER_ALL_MODES));
	pLibDev->p16kEepHeader->scaledOfdmCckDelta = TENX_OFDM_CCK_DELTA_INIT;
	pLibDev->p16kEepHeader->scaledCh14FilterCckDelta = TENX_CH14_FILTER_CCK_DELTA_INIT;	
	pLibDev->p16kEepHeader->ofdmCckGainDeltaX2 = OFDM_CCK_GAIN_DELTA_INIT;

	//allocate structure for RD edges
	pLibDev->p16KRdEdgesPower = (MDK_RD_EDGES_POWER *)malloc(sizeof(MDK_RD_EDGES_POWER) * NUM_16K_EDGES * MAX_NUM_CTL);
	if(NULL == pLibDev->p16KRdEdgesPower) {
		mError(devNum, ENOMEM, "Device Number %d:Device Number %d:Unable to allocate eeprom structure for RD edges info\n", devNum);
		freeEepStructs(devNum);
		return FALSE;
	}
	memset(pLibDev->p16KRdEdgesPower, 0, sizeof(MDK_RD_EDGES_POWER) * NUM_16K_EDGES * MAX_NUM_CTL);
	
	return TRUE;
}


/**************************************************************************
* freeEepStructs - Free EEPROM structs from LIB_DEV_INFO
*
* Generic free function, has to check for allocation before free since
* not all structs may be allocated.
*
* RETURNS:
*/
void freeEepStructs
(
 A_UINT32			devNum
)
{
    LIB_DEV_INFO *pLibDev = gLibInfo.pLibDevArray[devNum];
	A_UINT16 i;

	if(pLibDev->pCalibrationInfo != NULL) {
		free(pLibDev->pCalibrationInfo);
		pLibDev->pCalibrationInfo = NULL;
	}

	if(pLibDev->p16kEepHeader != NULL) {
		free(pLibDev->p16kEepHeader);
		pLibDev->p16kEepHeader = NULL;
	}

	if(pLibDev->p16KTrgtPowerInfo != NULL) {
		free(pLibDev->p16KTrgtPowerInfo);
		pLibDev->p16KTrgtPowerInfo = NULL;
	}
	
	if (pLibDev->p16KRdEdgesPower != NULL) {
		free(pLibDev->p16KRdEdgesPower);
		pLibDev->p16KRdEdgesPower = NULL;
	}

	if(pLibDev->pGen3CalData != NULL) {
		free(pLibDev->pGen3CalData);
		pLibDev->pGen3CalData = NULL;
	}
	if(pLibDev->pGen5CalData != NULL) {
		free(pLibDev->pGen5CalData);
		pLibDev->pGen5CalData = NULL;
	}
	for(i = 0; i < 3; i++) {
		if(pLibDev->pGen3RawData[i] != NULL) {
			free(pLibDev->pGen3RawData[i]);
			pLibDev->pGen3RawData[i] = NULL;
		}
		if(pLibDev->pGen5RawData[i] != NULL) {
			free(pLibDev->pGen5RawData[i]);
			pLibDev->pGen5RawData[i] = NULL;
		}
	}
	return;
}


/**************************************************************************
* readEepromIntoDataset - Read eeprom contents into structs held by LIB_DEV_INFO 
*
* 
*
* RETURNS: TRUE of OK, FALSE otherwise
*/
A_BOOL readEepromIntoDataset
(
 A_UINT32			devNum
)
{
    LIB_DEV_INFO *pLibDev = gLibInfo.pLibDevArray[devNum];
	A_UINT32			tempValue;
	A_UINT16			i, j, jj;
	A_UINT16			offset = 0;
	MDK_RD_EDGES_POWER		*pRdEdgePwrInfo = pLibDev->p16KRdEdgesPower;
	MDK_TRGT_POWER_INFO	    *pPowerInfo = NULL;
	A_UINT16			numChannels = 0;
	A_UINT16			mode;
	A_UINT16			*pNumTrgtChannels = NULL;
	A_UINT16			sizeCtl;
	EEPROM_DATA_STRUCT_GEN3 *pTempGen3CalData[3];
	EEPROM_DATA_STRUCT_GEN5  *pTempGen5CalData[3];

	// for dual 11a support, start reading eeprom_block1 from location 0x400
	if ((pLibDev->devMap.devIndex == 1) && (pLibDev->libCfgParams.eepStartLocation > 0)) {
		pLibDev->eepromStartLoc = pLibDev->libCfgParams.eepStartLocation;
	}

	//verify the checksum
	if (!eepromVerifyChecksum(devNum)) {
		mError(devNum, EIO, "Device Number %d: eeprom checksum failed\n", devNum);
		return FALSE;
	}

	//get the version information
	tempValue = eepromRead(devNum, (HDR_VERSION + pLibDev->eepromStartLoc));
	pLibDev->p16kEepHeader->majorVersion = (A_UINT16)((tempValue >> 12) & 0x0f);
	pLibDev->p16kEepHeader->minorVersion = (A_UINT16)(tempValue & 0x0fff);

	
	if((pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion <= 2)) {
		pOffsets = &eep3_2;
		pLibDev->p16kEepHeader->numCtl = NUM_CTL_EEP3_2;
	}
	else if(((pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion >= 3)) ||
			(pLibDev->p16kEepHeader->majorVersion >= 4))
	{
		pOffsets = &eep3_3;	
		pLibDev->p16kEepHeader->numCtl = NUM_CTL_EEP3_3;
	}
	else {
		mError(devNum, EIO, "Device Number %d:Device Number %d:eeprom version not supported\n", devNum);
		return (FALSE);
	}

	if (!(( pLibDev->p16kEepHeader->majorVersion > 3) || 
		( pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion >= 2)))
	{
		for (jj=0; jj<NUM_INTERCEPTS; jj++)
		{
			intercepts[jj] = intercepts_pre3p2[jj] ;
		}
	}
	
	//the channel list for 2.4 is fixed, fill this in here
	for(i = 0; i < NUM_2_4_EEPROM_CHANNELS; i++) {
		pLibDev->pCalibrationInfo->Channels_11b[i] = channels_11b[i];
		if((pLibDev->p16kEepHeader->majorVersion == 3) && (pLibDev->p16kEepHeader->minorVersion <= 2)) {
			pLibDev->pCalibrationInfo->Channels_11g[i] = channels_11b[i];
		}
		else {
			pLibDev->pCalibrationInfo->Channels_11g[i] = channels_11g[i];
		}
		pLibDev->pCalibrationInfo->DataPerChannel_11b[i].numPcdacValues = NUM_PCDAC_VALUES;	
		pLibDev->pCalibrationInfo->DataPerChannel_11g[i].numPcdacValues = NUM_PCDAC_VALUES;	
	}

	//read the header information here
	readHeaderInfo(devNum, pLibDev->p16kEepHeader);

	if((pLibDev->p16kEepHeader->majorVersion == 3) ||
		((pLibDev->p16kEepHeader->majorVersion >= 4) && (pLibDev->p16kEepHeader->eepMap == 0)))
	{
		// not really need to correct for  pLibDev->eepromStartLoc as dual 11a mode is 
		// only supported for eep_map = 1. done anyway.
		if(!readCalData_gen2(devNum, pLibDev->pCalibrationInfo)) {
			return (FALSE);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美精品在线观看| 久久电影国产免费久久电影| www.色精品| 亚洲视频一区二区免费在线观看| 丁香婷婷综合色啪| 国产精品电影一区二区| 99re热视频精品| 亚洲精品国产a| 欧美日韩电影在线播放| 麻豆国产精品一区二区三区| 精品99一区二区三区| 成人免费福利片| 亚洲欧美另类久久久精品| 91久久久免费一区二区| 日韩成人av影视| 国产亚洲成aⅴ人片在线观看| 波多野结衣精品在线| 亚洲国产精品视频| 日韩免费福利电影在线观看| 成人午夜av在线| 亚洲综合在线观看视频| 日韩一区二区免费视频| 国产成人小视频| 亚洲国产成人高清精品| 日韩精品自拍偷拍| 波多野结衣中文字幕一区| 亚洲福利视频导航| 国产视频一区在线观看 | 日韩欧美国产一二三区| 国产高清久久久久| 亚洲综合男人的天堂| 精品播放一区二区| 91福利视频网站| 国产一区二区主播在线| 夜色激情一区二区| 国产欧美日韩不卡免费| 欧美日韩亚洲综合一区| 国产盗摄视频一区二区三区| 天堂一区二区在线免费观看| 国产精品欧美经典| 精品精品国产高清a毛片牛牛| 色吧成人激情小说| 大尺度一区二区| 日韩 欧美一区二区三区| 中文字幕中文乱码欧美一区二区| 欧美一区二区三区喷汁尤物| 97精品久久久午夜一区二区三区| 美女视频一区在线观看| 亚洲午夜久久久久久久久电影网| 久久免费精品国产久精品久久久久| 欧美三级乱人伦电影| 91亚洲精品一区二区乱码| 国产一区福利在线| 蜜桃久久久久久久| 五月婷婷久久丁香| 亚洲精品久久嫩草网站秘色| 国产午夜精品美女毛片视频| 日韩视频永久免费| 欧美精品在线一区二区| 日本韩国欧美国产| a级高清视频欧美日韩| 国产激情一区二区三区| 黄色日韩网站视频| 精品一区二区三区日韩| 日本女人一区二区三区| 亚洲狠狠爱一区二区三区| 亚洲日穴在线视频| 中文字幕在线免费不卡| 国产精品色在线观看| 国产性天天综合网| 久久久五月婷婷| 精品成人一区二区三区| 日韩精品影音先锋| 日韩欧美一卡二卡| 欧美一区二区视频在线观看| 51精品秘密在线观看| 欧美日韩一区二区三区在线看| 91国内精品野花午夜精品| 91在线视频播放| 91黄色免费版| 欧美三级资源在线| 666欧美在线视频| 91精品蜜臀在线一区尤物| 91麻豆精品91久久久久久清纯| 欧美乱妇20p| 日韩一级黄色片| 亚洲精品在线免费观看视频| 久久综合久久99| 国产人伦精品一区二区| 亚洲国产精华液网站w| 中文字幕一区二区三区色视频| 中文字幕日韩一区| 一区二区三区日韩在线观看| 亚洲国产视频在线| 琪琪一区二区三区| 加勒比av一区二区| 成人网男人的天堂| 99re6这里只有精品视频在线观看| 在线一区二区三区四区五区| 777欧美精品| 国产亚洲精品中文字幕| 亚洲欧美二区三区| 首页综合国产亚洲丝袜| 久久99国产精品尤物| 丁香婷婷综合激情五月色| 日本国产一区二区| 日韩欧美一级二级三级| 中文字幕中文字幕一区| 日韩影视精彩在线| 国产毛片一区二区| 欧美系列亚洲系列| 2021久久国产精品不只是精品| 国产精品白丝在线| 麻豆91精品91久久久的内涵| 不卡视频一二三四| 7777精品伊人久久久大香线蕉的| 久久精品夜色噜噜亚洲a∨| 亚洲另类一区二区| 久久99精品久久久| 色哦色哦哦色天天综合| 精品国产一区二区三区久久影院 | 九色综合狠狠综合久久| 成人avav影音| 日韩午夜电影av| 亚洲男人天堂av网| 国产成人在线视频网址| 欧美男男青年gay1069videost | 色爱区综合激月婷婷| 精品国产一区二区国模嫣然| 一区二区三区高清在线| 国产激情精品久久久第一区二区| 欧美三电影在线| 国产精品国产三级国产三级人妇 | 久久这里只有精品6| 亚洲综合丁香婷婷六月香| 韩国成人福利片在线播放| 欧洲一区在线电影| 中文字幕日韩精品一区| 国产一区二区不卡在线| 欧美一区二区私人影院日本| 亚洲综合视频在线观看| www.欧美精品一二区| 久久综合久久综合九色| 日韩电影在线看| 91激情五月电影| 亚洲视频精选在线| 成人午夜短视频| 久久久www成人免费毛片麻豆| 日韩电影在线观看网站| 欧美日韩一区在线观看| 最新欧美精品一区二区三区| 国产成人高清视频| 精品欧美一区二区三区精品久久| 午夜激情久久久| 欧洲日韩一区二区三区| 国产精品传媒入口麻豆| 国产成人午夜精品影院观看视频| 欧美一二三四在线| 偷拍日韩校园综合在线| 欧美老女人在线| 亚洲成人在线网站| 精品视频一区二区不卡| 亚洲一区二区欧美| 在线观看亚洲a| 精品一区二区三区久久| 91.麻豆视频| 青青草国产成人99久久| 91精品国产乱| 秋霞成人午夜伦在线观看| 宅男噜噜噜66一区二区66| 丝瓜av网站精品一区二区| 欧美男同性恋视频网站| 日本人妖一区二区| 精品免费国产二区三区| 理论片日本一区| 精品国产一区二区三区av性色| 国产一本一道久久香蕉| 久久久777精品电影网影网| 国产精品资源在线看| 中文字幕免费不卡| 99精品久久只有精品| 亚洲一区二区中文在线| 欧美日韩亚洲综合在线| 六月丁香综合在线视频| 2017欧美狠狠色| 成人午夜激情影院| 一区二区欧美在线观看| 制服丝袜亚洲网站| 激情欧美日韩一区二区| 欧美激情一区二区三区四区 | 亚洲激情图片一区| 欧美三级欧美一级| 久久 天天综合| 中文字幕二三区不卡| 色婷婷精品久久二区二区蜜臀av| 亚洲图片欧美综合| 精品久久国产97色综合| 波多野结衣中文字幕一区二区三区| 夜夜揉揉日日人人青青一国产精品| 56国语精品自产拍在线观看|