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

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

?? lan9118.c

?? Lan9118以太網芯片linux驅動程序
?? C
?? 第 1 頁 / 共 4 頁
字號:
DWORD Lan_PopRxStatus(const DWORD dwLanBase)
{
	DWORD result=0UL;
	result=GetRegDW(dwLanBase,RX_FIFO_INF);
	if(result&0x00FF0000UL) {
		/*Rx status is available, read it */
		result=GetRegDW(dwLanBase,RX_STATUS_FIFO_PORT);
	} else {
		result=0UL;
	}
	return result;
}

/*
FUNCTION: Rx_FastForward
This function skips the current packet in RX fifo.
*/
void Rx_FastForward(const DWORD dwLanBase)
{
#ifdef SMC_DEBUG
	char buffer [128];
#endif
	DWORD dwTemp;
	DWORD dwTimeOut=100UL;

	SetRegDW(dwLanBase,RX_DP_CTRL,RX_DP_CTRL_RX_FFWD_);
	dwTemp = GetRegDW(dwLanBase, DUMMY_READ_REG);
	dwTemp = dwTemp;
	LanDelayUS(dwLanBase, 1UL);
	while((dwTimeOut)&&(GetRegDW(dwLanBase,RX_DP_CTRL)& RX_DP_CTRL_RX_FFWD_))
	{
		LanDelayUS(dwLanBase,1UL);
		dwTimeOut--;
	}
	if(dwTimeOut==0UL) {
#ifdef SMC_DEBUG
		sprintf (buffer, "timed out waiting for RX FFWD to finish, RX_DP_CTRL=0x%08lX",
				GetRegDW(dwLanBase, RX_DP_CTRL));
		OS_TEXT_OUT (buffer);
#endif
	}
}

/*
FUNCTION: lan9118Open
	This function allocates and initializes driver private
	structures, lan9118 hardware, platform specific timing.
	It identifies Lan911x variation and attaches interrupt.
*/
static int lan9118Open(NGifnet *netp)
{
	char buffer [128];
	int ictrl;
	DWORD dwIdRev;
	DWORD dwLanBase;
  	NGbuf*  bufPrivate = NULL;
	PLAN9118_DATA pLan9118Data = NULL;

	/*is interface already running?*/
	ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
	if(netp->if_flags & NG_IFF_RUNNING)
	{
		ngOSIntrCtl(ictrl);
		return NG_EALREADY;
	}
	ngOSIntrCtl(ictrl);

	/* allocate a memory buffer to store driver private data */
        ngBufAlloc(bufPrivate);	
	if (bufPrivate == NULL) {
		return NG_EINVAL;
	}

        bufPrivate->buf_datap=(NGubyte*) bufPrivate;
	pLan9118Data = netp->if_devptr1 = bufPrivate;
	pLan9118Data->saved_buf = NULL;

	OS_TEXT_OUT (driver_version);

	NG_ETHIF_DATA(((void *) netp), eif_base) = (void *) LAN9118_REG_BASE;
	NG_ETHIF_DATA(((void *) netp), eif_irq) = LAN9118_IRQN;
	dwLanBase = (DWORD) NG_ETHIF_DATA(((void *) netp), eif_base);

	dwIdRev = LanDetectChipId (dwLanBase);
	if (dwIdRev == 0xffffffffUL)
	{
		OS_TEXT_OUT ("unknown ethernet chip\n");
	}
	else
	{
		sprintf (buffer, "chip id = %04lx\n", dwIdRev);
		OS_TEXT_OUT (buffer);
	}

	PlatformSetBusTiming (dwIdRev);

	if (!Lan_Initialize (netp)) {
		return NG_EINVAL;
	}

	Lan_InitializeInterrupts (dwLanBase, 0UL);

	Lan_EnableSoftwareInterrupt (dwLanBase);

  	/* link configuration: default is auto-negociation */
  	NG_ETHIF_DATA(((void *) netp), eif_flags) = 
		(NGushort) NG_ETHIFF_AUTONEG;
  	SetLinkCfg (netp, (NGubyte) 0); 		    /* auto-negociate */
  	SetLinkAdv (netp, (NGushort) ~0);	    /* advertise all */
	SetLink (netp, (NGubyte) NG_ETHIF_LINK_DOWN);

	if(!Phy_Initialize(netp, PHY_ADDR))
	{
		return NG_EINVAL;
	}

	if (!Lan_MacLoad (netp)) {
		return NG_EINVAL;
	}

	Lan_InitializeTx (dwLanBase);
	Lan_InitializeRx (dwLanBase, 0x00000200UL);

	/*set the NGifnet flags*/
	ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
	netp->if_flags|=NG_IFF_RUNNING|NG_IFF_UP;
	ngOSIntrCtl(ictrl);

	/*install the interupt handler */
	ngOSIsrAttach9118 (LAN9118_IRQN, lan9118Isr, netp);
	return NG_EOK;	
}

/*
FUNCTION: lan9118Start
	This function checks outbound queue for ready to transmit
	packets. Then transmits packets as much as it can.
*/
static void lan9118Start(NGifnet * netp)
{
	LAN9118_DATA *pLan9118Data;
	DWORD dwLanBase;
	int ictrl;
	
	ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
	if(netp->if_flags & NG_IFF_OACTIVE)
	{
		/* interface running */
		ngOSIntrCtl(ictrl);
		return;
	}
	else
	{
		ngOSIntrCtl(ictrl);
		pLan9118Data = (PLAN9118_DATA) netp->if_devptr1;
		dwLanBase = (DWORD) NG_ETHIF_DATA(((void *) netp), eif_base);
		for (;;)
		{
			/* dequeue the packet */
			if (pLan9118Data->saved_buf == NULL) {
				ngBufDequeue(netp, pLan9118Data->saved_buf);
			}
			
			if(pLan9118Data->saved_buf==NULL) {
				ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
				netp->if_flags &= ~NG_IFF_OACTIVE;
				ngOSIntrCtl(ictrl);
				break;
			}
	
			/* if there is enough space in TX fifo */
			if (((DWORD) pLan9118Data->saved_buf->buf_datalen+16UL) <=
				Lan_GetTxDataFreeSpace (dwLanBase)) {
				Lan_SendPacketPIO (
					dwLanBase,
					(NGushort) pLan9118Data->saved_buf->buf_datalen,
					(NGushort) pLan9118Data->saved_buf->buf_datalen,
					pLan9118Data->saved_buf->buf_datap);
				if (Lan_GetTxStatusCount (dwLanBase) >= 30UL) {
					Lan_UpdateTxCounters (netp);
				}

				if (pLan9118Data->saved_buf->buf_flags & (NG_BUFF_BCAST|NG_BUFF_MCAST))
				{
					netp->if_omcasts++;
				}
                        	ngBufOutputFree(pLan9118Data->saved_buf);
				pLan9118Data->saved_buf = NULL;
			}
			else {
				ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
				netp->if_flags |= NG_IFF_OACTIVE;
				ngOSIntrCtl(ictrl);
				SetRegDW (dwLanBase, FIFO_INT, 0x32000000UL);
				break;
			}
		}
	}
	return;	
}
 
/*
FUNCTION: lan9118Close
	This function cleans up driver and shutdowns the lan9118
	ethernet controller.
*/
static int lan9118Close(NGifnet* netp) 
{
	NGbuf * bufp;
	const LAN9118_DATA *pLan9118Data;
	int ictrl;

	/* interface is not running*/
	ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);
	if(!(netp->if_flags & NG_IFF_RUNNING))
	{
		ngOSIntrCtl(ictrl);
		return NG_EALREADY;
	}	
	
	/* clear flags*/
	(netp->if_flags)&=~(NG_IFF_RUNNING|NG_IFF_UP);

	ngOSIntrCtl(ictrl);
	
	pLan9118Data = (PLAN9118_DATA) netp->if_devptr1;

	Lan_UpdateTxCounters (netp);

	/*uninstall the irq*/
	Lan_StopGptTimer ((DWORD) NG_ETHIF_DATA(((void *) netp), eif_base));
	ngOSIsrDetach9118 (LAN9118_IRQN);

	/* Remove pending buffers */
	for (;;)
  	{
    	    ngBufDequeue(netp, bufp);
    	    if (bufp == NULL)
    	    {
    		 break;
    	    }	 
    	    ngBufOutputFree(bufp);
  	}
	if (pLan9118Data->saved_buf)
	{
    	    ngBufOutputFree(pLan9118Data->saved_buf);
	}
	ngBufOutputFree((NGbuf *) ((void *) pLan9118Data));

	return NG_EOK;
}	

/*
FUNCTION: lan9118Isr
	This function handles lan9118 related interrupts.
*/
static void lan9118Isr(void *data) 
{
  NGbuf* bufReceiv;		/*buffer to store the received packet*/
  NGifnet *netp;
  DWORD dwIntCfg;
  DWORD dwIntSts;
  DWORD dwLanBase;

  netp = (NGifnet *) data;
  dwLanBase = (DWORD) NG_ETHIF_DATA(((void *) netp), eif_base);

  dwIntCfg = GetRegDW (dwLanBase, INT_CFG);
  if ((dwIntCfg & 0x00001100UL) != 0x00001100UL) {
    return;
  }
  if (dwIntCfg & 0x00FFEEEEUL) {
    return;
  }
  dwIntSts = Lan_GetInterruptStatus (dwLanBase);

  if(dwIntSts&INT_STS_SW_INT_) {
    Lan_HandleSoftwareInterrupt(dwLanBase);
  }
  if(dwIntSts&INT_STS_RSFL_) {
    DWORD dwRxStatus;
    while((dwRxStatus=Lan_PopRxStatus(dwLanBase))!=0UL)
    {
      const DWORD dwPacketLength=((dwRxStatus&0x3FFF0000UL)>>16);

      if(dwRxStatus&RX_STS_ES) {
        netp->if_ierrors++;
        netp->if_iqdrops++;
        /* flush RX FIFO */
	Rx_FastForward(dwLanBase);
	continue;
      } 
      else {
	/* check for length error & ignore packet */
	if ((dwRxStatus & (RX_STS_LENGTH_ERR_ | RX_STS_FRAME_TYPE_ETH_)) == RX_STS_LENGTH_ERR_) {
          netp->if_ierrors++;
          netp->if_iqdrops++;
          /* flush RX FIFO */
	  Rx_FastForward(dwLanBase);
	  continue;
	}

        /* allocate memory for the received packet*/			
        ngBufAlloc(bufReceiv);	
					
        if(bufReceiv==NULL)
        {
          netp->if_iqdrops++;							
          /* flush RX FIFO */
	  Rx_FastForward(dwLanBase);
	  continue;
        }
        else {
	  if (dwRxStatus & RX_STS_MCAST_PACKET)
	  {
	    netp->if_imcasts++;
	  }

          /* prepare structure */
          bufReceiv->buf_datap=((NGubyte*)bufReceiv)+ngBufDataOffset-ETHER_HDR_LEN;
          bufReceiv->buf_datalen=(int) dwPacketLength - 4 /* CRC */;

          Lan_ReadRxFifo (dwLanBase, 
            ((DWORD *)((DWORD) bufReceiv->buf_datap - 2UL)),
            (dwPacketLength+2UL+3UL)>>2);

          netp->if_ibytes += dwPacketLength;

          /* enqueue the message */
          ngEtherInput(netp, bufReceiv,1);

          /* update stat */
          netp->if_ipackets++;			
        }
      }
    }
    netp->if_iqdrops += GetRegDW(dwLanBase,RX_DROP);

    Lan_ClearInterruptStatus(dwLanBase,INT_STS_RSFL_);
  }
  if(dwIntSts&INT_STS_TDFA_) {
    SetRegDW(dwLanBase,FIFO_INT,0xFF000000UL);
    Lan_ClearInterruptStatus(dwLanBase,INT_STS_TDFA_);
    netp->if_flags &= ~NG_IFF_OACTIVE;
    lan9118Start (netp);
  }
  if(dwIntSts&INT_STS_GPT_INT_) {
    	Lan_ClearInterruptStatus(dwLanBase,INT_STS_GPT_INT_);
	Phy_CheckLink (netp);
  }
}	

/*
FUNCTION: lan9118SetMulti
	This function set the lan9118 hash table to filter out
	unwanted multicast packets.
*/
#ifdef _lint
static void lan9118SetMulti(const NGifnet * const netp)
#else
static void lan9118SetMulti(NGifnet * netp)
#endif
{
	NGubyte ht[8];  		/* hash table */
	NGuint crc;   /* crc of the dest adr*/
	int i;
	int ictrl;	/* save previous interrupt state */
	DWORD dwMacCr;
	DWORD dwLanBase;

	/* disable int */
	ictrl = ngOSIntrCtl(NG_INTRCTL_DISABLE);	

	dwLanBase = (DWORD) NG_ETHIF_DATA(((void *) netp), eif_base);

  	if(netp->if_flags & NG_IFF_PROMISC) 
	{
    		/* get all promiscuous */
		dwMacCr = Lan_GetMacRegDW (dwLanBase, MAC_CR);
		dwMacCr |= MAC_CR_PRMS_;
		dwMacCr &= ~MAC_CR_MCPAS_;
		dwMacCr &= ~MAC_CR_HPFILT_;
		Lan_SetMacRegDW (dwLanBase, MAC_CR, dwMacCr);
		ngOSIntrCtl(ictrl);	/* re-enable inetrrupt */
  		return;
 	}
 	
  	if(netp->if_flags & NG_IFF_ALLMULTI || NG_ETHIF_DATA(((void *) netp), eif_allmultis)) 
	{
    		/* get all multicasts */
		dwMacCr = Lan_GetMacRegDW (dwLanBase, MAC_CR);
		dwMacCr &= ~MAC_CR_PRMS_;
		dwMacCr |= MAC_CR_MCPAS_;
		dwMacCr &= ~MAC_CR_HPFILT_;
		Lan_SetMacRegDW (dwLanBase, MAC_CR, dwMacCr);
		ngOSIntrCtl(ictrl);	/* re-enable inetrrupt */
  		return;
 	}
 	
#if (NG_ETHIF_MULTIADDRS_MAX==0) 
	dwMacCr = Lan_GetMacRegDW (dwLanBase, MAC_CR);
	dwMacCr &= ~MAC_CR_PRMS_;
	dwMacCr &= ~MAC_CR_MCPAS_;
	dwMacCr &= ~MAC_CR_HPFILT_;
	Lan_SetMacRegDW (dwLanBase, HASHH, 0);
	Lan_SetMacRegDW (dwLanBase, HASHL, 0);
	Lan_SetMacRegDW (dwLanBase, MAC_CR, dwMacCr);
	ngOSIntrCtl(ictrl);	/* re-enable inetrrupt */
#else

	dwMacCr = Lan_GetMacRegDW (dwLanBase, MAC_CR);
	dwMacCr &= ~MAC_CR_PRMS_;
	dwMacCr &= ~MAC_CR_MCPAS_;
	dwMacCr |= MAC_CR_HPFILT_;

 	/* clear table */
    	for(i = 0; i < 8; i++) 
    		ht [i] = (NGubyte) 0;

    	/* parse list of groups */
    	for (i = 0; i < NG_ETHIF_MULTIADDRS_MAX; i++) 
    	{
      		if (NG_ETHIF_DATA(((void *) netp), eif_multiaddrs)[i].eifm_refcount) 
      		{
       			crc = ngEtherCRC32( NG_ETHIF_DATA(((void *) netp), eif_multiaddrs)[i].eifm_addr, 6);
       			crc >>= 26;
       			ht[crc>>3] = (NGubyte) (ht[crc>>3] | (1 << (crc & 0x7U)));
      		}
    	}
  
  	/* set filter */   
	Lan_SetMacRegDW (dwLanBase, HASHL, ((DWORD) ht [3] << 24) | ((DWORD) ht [2] << 16) | ((DWORD) ht [1] << 8) | (DWORD) ht [0]);
	Lan_SetMacRegDW (dwLanBase, HASHH, ((DWORD) ht [7] << 24) | ((DWORD) ht [6] << 16) | ((DWORD) ht [5] << 8) | (DWORD) ht [4]);

	Lan_SetMacRegDW (dwLanBase, MAC_CR, dwMacCr);
	ngOSIntrCtl(ictrl);	/* re-enable inetrrupt */
#endif
}		

/* Driver entry point */
#define LAN9118_MACROCAT_(a, b) a ## b
#define LAN9118_MACROCAT(a, b) LAN9118_MACROCAT_(a, b)
#define LAN9118_MACROQUOTE_(a) #a
#define LAN9118_MACROQUOTE(a) LAN9118_MACROQUOTE_(a)

const NGnetdrv LAN9118_MACROCAT(ngNetDrv_, LAN9118_DRVNAME) = {
  LAN9118_MACROQUOTE(LAN9118_DRVNAME),
  NG_IFT_ETHER,		/* adaptator type */
  NG_IFF_BROADCAST|NG_IFF_MULTICAST,	   /* interface at startup*/
//lint -e{834}
  ETHERMTU,		/* maximum transmission unit*/
  100000000UL,		/* link speed (b/s)*/
  ngEtherInit,	/* initialise the NGethifnet*/
  lan9118Open, 					
  lan9118Close,
  ngEtherOutput,
  lan9118Start,
  ngEtherCntl,
  lan9118SetMulti   
};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级淫片007| 欧美三级在线看| 91原创在线视频| 911精品国产一区二区在线| 日本一区二区高清| 午夜精品影院在线观看| 国产精品羞羞答答xxdd| 欧美一级搡bbbb搡bbbb| 亚洲另类色综合网站| 国产乱码精品一品二品| 91精品免费在线| 亚洲永久精品大片| 成熟亚洲日本毛茸茸凸凹| 欧美日韩国产片| 亚洲视频在线一区二区| 国产福利91精品一区| 日韩欧美精品三级| 午夜欧美大尺度福利影院在线看| 9l国产精品久久久久麻豆| 26uuu久久综合| 丝袜亚洲另类欧美综合| 91黄色免费观看| 一区二区三区精品久久久| av一区二区不卡| 国产精品美女久久久久久2018| 国内成+人亚洲+欧美+综合在线 | 亚洲欧美日韩国产另类专区| 国产精品一区二区果冻传媒| 日韩视频免费观看高清完整版 | 极品瑜伽女神91| 日韩视频免费观看高清完整版| 午夜精品福利一区二区三区蜜桃| 日本高清不卡aⅴ免费网站| 精品在线免费观看| 欧美日韩国产天堂| 亚洲h精品动漫在线观看| 欧美三区在线视频| 调教+趴+乳夹+国产+精品| 欧美日韩国产在线播放网站| 亚洲成国产人片在线观看| 欧美中文字幕一区| 香蕉久久一区二区不卡无毒影院 | 日韩精品亚洲一区| 91精品久久久久久久99蜜桃| 亚洲国产aⅴ成人精品无吗| 欧美日韩一区二区三区在线| 亚洲大片在线观看| 91精品国产欧美一区二区成人 | 在线91免费看| 国内偷窥港台综合视频在线播放| 精品国产三级电影在线观看| 成人一区二区三区视频在线观看| 国产欧美日韩激情| proumb性欧美在线观看| 亚洲精品国产a| 91精品国产一区二区三区| 久久精品国产精品亚洲精品| 精品粉嫩aⅴ一区二区三区四区 | 国产精品久久久久久久久晋中| 波多野结衣精品在线| 一级女性全黄久久生活片免费| 欧美私模裸体表演在线观看| 久久精品国产免费| 亚洲同性同志一二三专区| 欧美日韩国产一区二区三区地区| 日本aⅴ精品一区二区三区 | 日韩伦理免费电影| 欧美丰满少妇xxxbbb| 国产精品一卡二卡| 亚洲一区在线电影| 久久免费电影网| 一本一道波多野结衣一区二区| 天天色综合成人网| 国产人久久人人人人爽| 欧美日韩一区二区三区四区五区| 精品一区二区三区在线播放| 亚洲激情图片一区| 久久久久久麻豆| 欧美日韩国产高清一区| 国产成人免费av在线| 污片在线观看一区二区| 国产精品视频一区二区三区不卡| 欧美性色黄大片| 成人性生交大片免费看中文网站| 亚洲va韩国va欧美va精品| 精品一区精品二区高清| 自拍偷拍国产精品| 精品美女在线播放| 欧美日韩在线直播| heyzo一本久久综合| 精品一区二区三区久久久| 亚洲综合小说图片| 中文字幕日韩一区| 久久久亚洲高清| 日韩美女在线视频| 91老司机福利 在线| 国产一区二区久久| 麻豆一区二区三| 日韩成人一级片| 亚洲激情男女视频| 国产精品福利影院| 欧美极品xxx| 欧美成人aa大片| 日韩女优电影在线观看| 欧美久久久久中文字幕| 91免费国产在线| 91麻豆免费看| 99久久久免费精品国产一区二区 | 精品国产91亚洲一区二区三区婷婷| 色狠狠一区二区三区香蕉| 国产传媒久久文化传媒| 久久激情五月婷婷| 精品在线免费观看| 国产一区二区主播在线| 激情综合网激情| 经典三级在线一区| 国产一区二区三区免费看| 精品一区二区免费在线观看| 免费人成精品欧美精品| 奇米综合一区二区三区精品视频| 午夜视频久久久久久| 亚洲第一主播视频| 日韩激情一区二区| 蜜桃av噜噜一区| 国产一区二区三区蝌蚪| 国产高清一区日本| 波多野结衣91| 欧美伊人久久大香线蕉综合69 | 北条麻妃一区二区三区| 91天堂素人约啪| 欧美午夜片在线观看| 亚洲视频网在线直播| 国产欧美一区二区精品秋霞影院| 欧美大尺度电影在线| 日韩亚洲欧美综合| 久久久午夜精品| 亚洲视频中文字幕| 日韩制服丝袜先锋影音| 国内精品写真在线观看| 国产成人综合精品三级| 99久久免费视频.com| 欧美日韩国产综合久久| 欧美岛国在线观看| 日本一区二区免费在线| 亚洲夂夂婷婷色拍ww47| 日本成人在线看| 国产在线看一区| 成人精品国产一区二区4080| 色香蕉成人二区免费| 欧美一级午夜免费电影| 国产精品理伦片| 午夜精品一区在线观看| 国产不卡免费视频| 欧美日韩一区二区三区高清| 欧美成va人片在线观看| 综合久久久久久| 精品在线视频一区| 色偷偷88欧美精品久久久| 日韩精品自拍偷拍| 亚洲精品v日韩精品| 黑人巨大精品欧美黑白配亚洲| 成人av网址在线| 欧美高清视频一二三区| 国产精品嫩草99a| 秋霞电影一区二区| 成人黄色777网| 在线不卡中文字幕播放| 国产精品午夜春色av| 全国精品久久少妇| 一本久久a久久精品亚洲| 久久久久久久久蜜桃| 午夜a成v人精品| 成人免费福利片| 日韩三级精品电影久久久 | 亚洲一区av在线| 成人午夜私人影院| 日韩一级高清毛片| 夜夜揉揉日日人人青青一国产精品| 国产毛片精品视频| 欧美大片在线观看一区二区| 午夜不卡av在线| 欧美性色aⅴ视频一区日韩精品| 成人免费在线视频观看| 国产馆精品极品| 久久欧美一区二区| 久久国产综合精品| 欧美一级在线视频| 免费观看久久久4p| 欧美二区在线观看| 亚洲电影视频在线| 欧美色图天堂网| 一区二区成人在线| 成人av网址在线观看| 国产精品美女久久久久久久久| 国产福利精品一区| 欧美激情一区二区在线| 国产.欧美.日韩| 日本一区二区动态图| 成人av午夜电影| 亚洲精品欧美激情|