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

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

?? skgepnmi.c

?? linux下的BOOT程序原碼,有需要的可以來下,保證好用
?? C
?? 第 1 頁 / 共 5 頁
字號:
	case SK_PNMI_EVT_SEN_WAR_LOW:#ifdef DEBUG		if ((unsigned int)Param.Para64 >= (unsigned int)pAC->I2c.MaxSens) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_SEN_WAR_LOW parameter wrong, SensorIndex=%d\n",				(unsigned int)Param.Para64));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate		 * an event for user space applications with the		 * SK_DRIVER_SENDEVENT macro.		 */		QueueSensorTrap(pAC, OID_SKGE_TRAP_SEN_WAR_LOW,			(unsigned int)Param.Para64);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		break;	case SK_PNMI_EVT_SEN_WAR_UPP:#ifdef DEBUG		if ((unsigned int)Param.Para64 >= (unsigned int)pAC->I2c.MaxSens) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR:SkPnmiEvent: SK_PNMI_EVT_SEN_WAR_UPP parameter wrong, SensorIndex=%d\n",				(unsigned int)Param.Para64));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate		 * an event for user space applications with the		 * SK_DRIVER_SENDEVENT macro.		 */		QueueSensorTrap(pAC, OID_SKGE_TRAP_SEN_WAR_UPP,			(unsigned int)Param.Para64);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		break;	case SK_PNMI_EVT_SEN_ERR_LOW:#ifdef DEBUG		if ((unsigned int)Param.Para64 >= (unsigned int)pAC->I2c.MaxSens) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_SEN_ERR_LOW parameter wrong, SensorIndex=%d\n",				(unsigned int)Param.Para64));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate		 * an event for user space applications with the		 * SK_DRIVER_SENDEVENT macro.		 */		QueueSensorTrap(pAC, OID_SKGE_TRAP_SEN_ERR_LOW,			(unsigned int)Param.Para64);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		break;	case SK_PNMI_EVT_SEN_ERR_UPP:#ifdef DEBUG		if ((unsigned int)Param.Para64 >= (unsigned int)pAC->I2c.MaxSens) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_SEN_ERR_UPP parameter wrong, SensorIndex=%d\n",				(unsigned int)Param.Para64));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate		 * an event for user space applications with the		 * SK_DRIVER_SENDEVENT macro.		 */		QueueSensorTrap(pAC, OID_SKGE_TRAP_SEN_ERR_UPP,			(unsigned int)Param.Para64);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		break;	case SK_PNMI_EVT_CHG_EST_TIMER:		/*		 * Calculate port switch average on a per hour basis		 *   Time interval for check       : 28125 ms		 *   Number of values for average  : 8		 *		 * Be careful in changing these values, on change check		 *   - typedef of SK_PNMI_ESTIMATE (Size of EstValue		 *     array one less than value number)		 *   - Timer initilization SkTimerStart() in SkPnmiInit		 *   - Delta value below must be multiplicated with		 *     power of 2		 *		 */		pEst = &pAC->Pnmi.RlmtChangeEstimate;		CounterIndex = pEst->EstValueIndex + 1;		if (CounterIndex == 7) {			CounterIndex = 0;		}		pEst->EstValueIndex = CounterIndex;		NewestValue = pAC->Pnmi.RlmtChangeCts;		OldestValue = pEst->EstValue[CounterIndex];		pEst->EstValue[CounterIndex] = NewestValue;		/*		 * Calculate average. Delta stores the number of		 * port switches per 28125 * 8 = 225000 ms		 */		if (NewestValue >= OldestValue) {			Delta = NewestValue - OldestValue;		}		else {			/* Overflow situation */			Delta = (SK_U64)(0 - OldestValue) + NewestValue;		}		/*		 * Extrapolate delta to port switches per hour.		 *     Estimate = Delta * (3600000 / 225000)		 *              = Delta * 16		 *              = Delta << 4		 */		pAC->Pnmi.RlmtChangeEstimate.Estimate = Delta << 4;		/*		 * Check if threshold is exceeded. If the threshold is		 * permanently exceeded every 28125 ms an event will be		 * generated to remind the user of this condition.		 */		if ((pAC->Pnmi.RlmtChangeThreshold != 0) &&			(pAC->Pnmi.RlmtChangeEstimate.Estimate >=			pAC->Pnmi.RlmtChangeThreshold)) {			QueueSimpleTrap(pAC, OID_SKGE_TRAP_RLMT_CHANGE_THRES);			(void)SK_DRIVER_SENDEVENT(pAC, IoC);		}		SK_MEMSET((char *) &EventParam, 0, sizeof(EventParam));		SkTimerStart(pAC, IoC, &pAC->Pnmi.RlmtChangeEstimate.EstTimer,			28125000, SKGE_PNMI, SK_PNMI_EVT_CHG_EST_TIMER,			EventParam);		break;	case SK_PNMI_EVT_CLEAR_COUNTER:		/*		 *  Param.Para32[0] contains the NetIndex (0 ..1).		 *  Param.Para32[1] is reserved, contains -1.		 */		NetIndex = (SK_U32)Param.Para32[0];#ifdef DEBUG		if (NetIndex >= pAC->Rlmt.NumNets) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_CLEAR_COUNTER parameter wrong, NetIndex=%d\n",				NetIndex));			return (0);		}#endif		/*		 * Set all counters and timestamps to zero		 */		ResetCounter(pAC, IoC, NetIndex); /* the according NetIndex is required												as a Parameter of the Event */		break;	case SK_PNMI_EVT_XMAC_RESET:		/*		 * To grant continuous counter values store the current		 * XMAC statistic values to the entries 1..n of the		 * CounterOffset array. XMAC Errata #2		 */#ifdef DEBUG		if ((unsigned int)Param.Para64 >= SK_MAX_MACS) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_XMAC_RESET parameter wrong, PhysPortIndex=%d\n",				(unsigned int)Param.Para64));			return (0);		}#endif		PhysPortIndex = (unsigned int)Param.Para64;		/*		 * Update XMAC statistic to get fresh values		 */		Ret = MacUpdate(pAC, IoC, 0, pAC->GIni.GIMacsFound - 1);		if (Ret != SK_PNMI_ERR_OK) {			SK_PNMI_CHECKFLAGS("SkPnmiEvent: On return");			return (0);		}		/*		 * Increment semaphore to indicate that an update was		 * already done		 */		pAC->Pnmi.MacUpdatedFlag ++;		for (CounterIndex = 0; CounterIndex < SK_PNMI_MAX_IDX;			CounterIndex ++) {			if (!StatAddr[CounterIndex][MacType].GetOffset) {				continue;			}			pAC->Pnmi.Port[PhysPortIndex].				CounterOffset[CounterIndex] = GetPhysStatVal(				pAC, IoC, PhysPortIndex, CounterIndex);			pAC->Pnmi.Port[PhysPortIndex].				CounterHigh[CounterIndex] = 0;		}		pAC->Pnmi.MacUpdatedFlag --;		break;	case SK_PNMI_EVT_RLMT_PORT_UP:		PhysPortIndex = (unsigned int)Param.Para32[0];#ifdef DEBUG		if (PhysPortIndex >= SK_MAX_MACS) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_RLMT_PORT_UP parameter"		 " wrong, PhysPortIndex=%d\n", PhysPortIndex));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate an event for		 * user space applications with the SK_DRIVER_SENDEVENT macro.		 */		QueueRlmtPortTrap(pAC, OID_SKGE_TRAP_RLMT_PORT_UP, PhysPortIndex);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		/* Bugfix for XMAC errata (#10620)*/		if (pAC->GIni.GIMacType == SK_MAC_XMAC){			/* Add incremental difference to offset (#10620)*/			(void)pAC->GIni.GIFunc.pFnMacStatistic(pAC, IoC, PhysPortIndex,				XM_RXE_SHT_ERR, &Val32);			Value = (((SK_U64)pAC->Pnmi.Port[PhysPortIndex].				 CounterHigh[SK_PNMI_HRX_SHORTS] << 32) | (SK_U64)Val32);			pAC->Pnmi.Port[PhysPortIndex].CounterOffset[SK_PNMI_HRX_SHORTS] +=				Value - pAC->Pnmi.Port[PhysPortIndex].RxShortZeroMark;		}		/* Tell VctStatus() that a link was up meanwhile. */		pAC->Pnmi.VctStatus[PhysPortIndex] |= SK_PNMI_VCT_LINK;		break;    case SK_PNMI_EVT_RLMT_PORT_DOWN:		PhysPortIndex = (unsigned int)Param.Para32[0];#ifdef DEBUG		if (PhysPortIndex >= SK_MAX_MACS) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_RLMT_PORT_DOWN parameter"		 " wrong, PhysPortIndex=%d\n", PhysPortIndex));			return (0);		}#endif		/*		 * Store a trap message in the trap buffer and generate an event for		 * user space applications with the SK_DRIVER_SENDEVENT macro.		 */		QueueRlmtPortTrap(pAC, OID_SKGE_TRAP_RLMT_PORT_DOWN, PhysPortIndex);		(void)SK_DRIVER_SENDEVENT(pAC, IoC);		/* Bugfix #10620 - get zero level for incremental difference */		if ((pAC->GIni.GIMacType == SK_MAC_XMAC)) {			(void)pAC->GIni.GIFunc.pFnMacStatistic(pAC, IoC, PhysPortIndex,				XM_RXE_SHT_ERR, &Val32);			pAC->Pnmi.Port[PhysPortIndex].RxShortZeroMark =				(((SK_U64)pAC->Pnmi.Port[PhysPortIndex].				 CounterHigh[SK_PNMI_HRX_SHORTS] << 32) | (SK_U64)Val32);		}		break;	case SK_PNMI_EVT_RLMT_ACTIVE_DOWN:		PhysPortIndex = (unsigned int)Param.Para32[0];		NetIndex = (SK_U32)Param.Para32[1];#ifdef DEBUG		if (PhysPortIndex >= SK_MAX_MACS) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_RLMT_ACTIVE_DOWN parameter too high, PhysPort=%d\n",				PhysPortIndex));		}		if (NetIndex >= pAC->Rlmt.NumNets) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_RLMT_ACTIVE_DOWN parameter too high, NetIndex=%d\n",				NetIndex));		}#endif		/*		 * For now, ignore event if NetIndex != 0.		 */		if (Param.Para32[1] != 0) {			return (0);		}		/*		 * Nothing to do if port is already inactive		 */		if (!pAC->Pnmi.Port[PhysPortIndex].ActiveFlag) {			return (0);		}		/*		 * Update statistic counters to calculate new offset for the virtual		 * port and increment semaphore to indicate that an update was already		 * done.		 */		if (MacUpdate(pAC, IoC, 0, pAC->GIni.GIMacsFound - 1) !=			SK_PNMI_ERR_OK) {			SK_PNMI_CHECKFLAGS("SkPnmiEvent: On return");			return (0);		}		pAC->Pnmi.MacUpdatedFlag ++;		/*		 * Calculate new counter offset for virtual port to grant continous		 * counting on port switches. The virtual port consists of all currently		 * active ports. The port down event indicates that a port is removed		 * from the virtual port. Therefore add the counter value of the removed		 * port to the CounterOffset for the virtual port to grant the same		 * counter value.		 */		for (CounterIndex = 0; CounterIndex < SK_PNMI_MAX_IDX;			CounterIndex ++) {			if (!StatAddr[CounterIndex][MacType].GetOffset) {				continue;			}			Value = GetPhysStatVal(pAC, IoC, PhysPortIndex, CounterIndex);			pAC->Pnmi.VirtualCounterOffset[CounterIndex] += Value;		}		/*		 * Set port to inactive		 */		pAC->Pnmi.Port[PhysPortIndex].ActiveFlag = SK_FALSE;		pAC->Pnmi.MacUpdatedFlag --;		break;	case SK_PNMI_EVT_RLMT_ACTIVE_UP:		PhysPortIndex = (unsigned int)Param.Para32[0];		NetIndex = (SK_U32)Param.Para32[1];#ifdef DEBUG		if (PhysPortIndex >= SK_MAX_MACS) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNMI: ERR: SkPnmiEvent: SK_PNMI_EVT_RLMT_ACTIVE_UP parameter too high, PhysPort=%d\n",				PhysPortIndex));		}		if (NetIndex >= pAC->Rlmt.NumNets) {			SK_DBG_MSG(pAC, SK_DBGMOD_PNMI, SK_DBGCAT_CTRL,				("PNM

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久久久人人人人传媒 | 成人激情黄色小说| 成人国产精品免费观看视频| 91久久精品一区二区二区| 欧美一区二区成人| 国产精品美日韩| 亚洲成av人综合在线观看| 九九久久精品视频| 91性感美女视频| 欧美一二三四在线| 亚洲丝袜美腿综合| 喷白浆一区二区| caoporen国产精品视频| 日韩一区二区电影网| 国产精品日产欧美久久久久| 亚洲国产精品嫩草影院| 国产乱码精品一区二区三区忘忧草 | 成人国产亚洲欧美成人综合网| 欧美日韩国产一区| 久久久国产综合精品女国产盗摄| 亚洲综合清纯丝袜自拍| 国产精品影视在线观看| 欧美精品123区| 中文字幕日韩一区| 久久精品国产77777蜜臀| 欧洲中文字幕精品| 日本午夜精品视频在线观看| 99久久免费精品高清特色大片| 91精品国产色综合久久不卡蜜臀 | 99在线视频精品| 日韩精品一区二区三区视频播放| 亚洲青青青在线视频| 国产在线国偷精品免费看| 欧美日韩一卡二卡三卡| 亚洲人成在线观看一区二区| 国产高清在线观看免费不卡| 欧美一区中文字幕| 亚洲综合一区二区精品导航| 99综合电影在线视频| 久久久久综合网| 日韩精品电影一区亚洲| 色八戒一区二区三区| 国产精品污污网站在线观看| 久久99久久久欧美国产| 欧美日韩国产一级二级| 亚洲一区在线观看免费观看电影高清 | 欧美福利电影网| 亚洲午夜精品在线| 色网综合在线观看| 国产精品久久久久久久久动漫| 国产主播一区二区三区| 欧美α欧美αv大片| 日韩在线a电影| 欧美三级三级三级| 一区二区三区不卡视频在线观看| www.久久久久久久久| 国产情人综合久久777777| 国产精品一线二线三线精华| 久久综合色8888| 激情五月播播久久久精品| 日韩欧美在线影院| 蜜臀久久99精品久久久久宅男| 欧美日韩免费视频| 亚洲mv在线观看| 欧美日韩一区三区| 亚洲www啪成人一区二区麻豆| 欧美亚日韩国产aⅴ精品中极品| 亚洲激情欧美激情| 日本精品一级二级| 亚洲r级在线视频| 777午夜精品视频在线播放| 日日摸夜夜添夜夜添精品视频| 欧美精品第一页| 琪琪久久久久日韩精品| 欧美一区二区三区四区久久| 日本欧美加勒比视频| 日韩一二三区不卡| 狠狠v欧美v日韩v亚洲ⅴ| 久久久久久亚洲综合| 国产成人午夜电影网| 国产精品色哟哟网站| 99精品视频在线播放观看| 亚洲免费在线观看视频| 日本二三区不卡| 五月综合激情日本mⅴ| 91精品中文字幕一区二区三区| 日本不卡1234视频| 久久精品欧美一区二区三区麻豆| 风间由美一区二区av101| 中文字幕一区二区不卡| 欧美日韩一区成人| 久久99久久精品| 国产精品毛片a∨一区二区三区| jlzzjlzz亚洲女人18| 亚洲午夜免费视频| 精品少妇一区二区三区视频免付费 | 欧美高清dvd| 国产乱码精品一区二区三区五月婷| 国产精品毛片久久久久久久| 色老头久久综合| 久久精品国产久精国产| 中文字幕一区二区三| 欧美丰满少妇xxxbbb| 国产最新精品免费| 亚洲欧美日韩国产另类专区 | 麻豆国产欧美一区二区三区| 国产日韩综合av| 日本电影亚洲天堂一区| 久久国产日韩欧美精品| 中文字幕日韩av资源站| 在线电影欧美成精品| 国产成+人+日韩+欧美+亚洲| 亚洲永久精品大片| 精品区一区二区| 91在线国产观看| 奇米精品一区二区三区在线观看一| 国产欧美日韩不卡免费| 欧美日本一区二区| 国产成人在线网站| 一区二区三区蜜桃| 久久这里只有精品6| 91成人在线精品| 国产成人丝袜美腿| 日韩激情中文字幕| 亚洲欧美综合色| 日韩欧美久久一区| 在线日韩一区二区| 国产美女av一区二区三区| 亚洲国产成人av网| 国产精品免费av| 精品日产卡一卡二卡麻豆| 在线观看国产91| 高清不卡一区二区在线| 日韩国产欧美在线观看| 亚洲你懂的在线视频| 久久久久久久精| 51精品视频一区二区三区| 97久久超碰国产精品| 久久电影网站中文字幕 | 91精品国产综合久久婷婷香蕉| 成人av电影在线播放| 老鸭窝一区二区久久精品| 一区二区三区精品久久久| 国产偷国产偷精品高清尤物| 91精品一区二区三区久久久久久 | 亚洲小说春色综合另类电影| 日本一区二区动态图| 日韩三级在线观看| 欧美日韩一区二区三区视频| 99精品视频在线观看免费| 国产麻豆一精品一av一免费| 日本视频在线一区| 午夜影院在线观看欧美| 亚洲综合在线五月| 国产精品不卡在线观看| 久久久久99精品一区| 亚洲精品在线免费观看视频| 日韩一区二区三区观看| 欧美日韩亚洲国产综合| 色婷婷亚洲综合| 91免费视频观看| 99视频精品全部免费在线| 国产成人av电影在线播放| 激情深爱一区二区| 久久精品久久精品| 奇米精品一区二区三区在线观看一| 亚洲成人免费在线观看| 亚洲国产一二三| 亚洲一二三级电影| 亚洲高清在线视频| 亚洲一二三区视频在线观看| 一区二区三区加勒比av| 一区二区三区中文字幕在线观看| 一区视频在线播放| 国产精品久99| 亚洲欧美综合色| 亚洲美女屁股眼交3| 亚洲日本护士毛茸茸| 亚洲免费毛片网站| 亚洲综合无码一区二区| 亚洲国产日产av| 亚洲1区2区3区视频| 亚瑟在线精品视频| 日韩不卡一区二区| 奇米亚洲午夜久久精品| 精品一二线国产| 国产精品正在播放| 成人sese在线| 91免费视频观看| 欧美日韩免费一区二区三区 | 国产一区在线观看麻豆| 国产精品91一区二区| 国产不卡免费视频| 91网站视频在线观看| 91麻豆免费看| 欧美日韩国产bt| 欧美草草影院在线视频| 久久久午夜电影| 中文字幕一区免费在线观看 | 欧美午夜视频网站|