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

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

?? 91x_enet.c

?? 最新版FreeRTOS, 包擴多種開發平臺的移植
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************** 
* Original work (C) COPYRIGHT 2006 STMicroelectronics **************************
* Modifications (C) CopyRight 2006 Richard barry
* File Name          : 91x_enet.c
* Author             : MCD Application Team
* Date First Issued  : May 2006
* Description        : ENET library functions
********************************************************************************
* History:
* May 2006: v1.0
********************************************************************************
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/


/* Includes ------------------------------------------------------------------*/
#include "FreeRTOS.h"
#include "task.h"
#include "91x_lib.h"
#include "string.h"  //include when using memcpy function

/* Include of other module interface headers ---------------------------------*/
/* Local includes ------------------------------------------------------------*/
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
#ifndef NULL
#define NULL    (0)
#endif
/* Function return values */
#define ENET_OK  (1)
#define ENET_NOK (0)

/* PHY interface constants. */
#define STE100P_STATUS_REG				0x01
#define STE100P_CONTROL_REG				0x00
#define STE100P_LINK_ABILITY			0x05
#define STE100P_STATUS_LINKED			0x0004
#define STE100P_AUTO_NEGOTIATE_ABILITY	0x1000
#define STE100P_AUTO_NEGOTIATE_COMPLETE 0x20
#define STE100P_10HALF              	0x0020
#define STE100P_10FULL              	0x0040
#define STE100P_100HALF             	0x0080
#define STE100P_100FULL             	0x0100
#define STE100P_CTRL_FULL           	0x0100


/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
#define ENET_NUM_RX_BUFFERS 8

static ENET_DMADSCRBase  dmaTxDscrBase, dmaRxDscrBase[ ENET_NUM_RX_BUFFERS ];
static volatile u8 RxBuff[ ENET_NUM_RX_BUFFERS ][ENET_BUFFER_SIZE], TxBuff[ENET_BUFFER_SIZE];

/* Private function prototypes -----------------------------------------------*/
extern MEMCOPY_L2S_BY4();

/* Interface functions -------------------------------------------------------*/
/* Private functions ---------------------------------------------------------*/

/*******************************************************************************
* Function Name  : ENET_SetMACConfig(ENET_MACConfig * MAC_Config)
* Description    : MAC Control Register Configuration
* Input          : MAC_Config structure
* Output         : None
* Return         : None
*******************************************************************************/
void ENET_MACControlConfig(ENET_MACConfig *MAC_Config)
{
  /* ReceiveALL bit */
  if (MAC_Config->ReceiveALL==ENABLE) ENET_MAC->MCR |= MAC_MCR_RA;
  else ENET_MAC->MCR &=~MAC_MCR_RA;

  /* MIIPrescaler */
  ENET_MAC->MCR &=~(0x3<<24);
  if ((MAC_Config->MIIPrescaler) == MIIPrescaler_2)
  ENET_MAC->MCR |=0x1<<24;

  /* Loopback mode */
  if (MAC_Config->LoopbackMode==ENABLE)
  {
    ENET_MAC->MCR &=~MAC_MCR_LM;
    ENET_MAC->MCR |=0x1<<21;
    ENET_MAC->MCR &=~MAC_MCR_DRO;  /*enable frame reception during transmission*/
  }

  /* Address filtering mode */
  ENET_MAC->MCR &=~MAC_MCR_AFM;
  ENET_MAC->MCR |= MAC_Config->AddressFilteringMode;

  /* VLAN Filtering Mode */
  ENET_MAC->MCR = (MAC_Config->VLANFilteringMode)<<15;

  /*Wrong Frame Pass */
  if (MAC_Config->PassWrongFrame == ENABLE) ENET_MAC->MCR |=MAC_MCR_PWF;
  else ENET_MAC->MCR &=~MAC_MCR_PWF;

  /* Late Collision Retransmission*/
  if (MAC_Config->LateCollision == ENABLE) ENET_MAC->MCR |=MAC_MCR_ELC;
  else ENET_MAC->MCR &=~MAC_MCR_ELC;

  /* Broadcast Frame Reception */
  if (MAC_Config->BroadcastFrameReception == ENABLE) ENET_MAC->MCR |=MAC_MCR_DBF;
  else ENET_MAC->MCR &=~MAC_MCR_DBF;

  /* PacketRetry */
  if (MAC_Config->PacketRetry == ENABLE) ENET_MAC->MCR &=~MAC_MCR_DPR;
  else ENET_MAC->MCR |=MAC_MCR_DPR;

  /* RxFrameFiltering */
  if (MAC_Config->RxFrameFiltering == ENABLE) ENET_MAC->MCR |=MAC_MCR_RVFF;
  else ENET_MAC->MCR &=~MAC_MCR_RVFF;

  /* AutomaticPadRemoval */
  if (MAC_Config->AutomaticPadRemoval == ENABLE) ENET_MAC->MCR |=MAC_MCR_APR;
  else ENET_MAC->MCR &=~MAC_MCR_APR;

  /* DefferalCheck */
  if (MAC_Config->DeferralCheck == ENABLE) ENET_MAC->MCR |=MAC_MCR_DCE;
  else ENET_MAC->MCR &=~MAC_MCR_DCE;

}



/*******************************************************************************
* Function Name  : ENET_SetOperatingMode
* Description    : Sets the Operating mode
* Input          : ENET_OperatingMode:(see ENET_OperatingMode in 91x_enet.h)
* Output         : None
* Return         : None
*******************************************************************************/
portBASE_TYPE ENET_SetOperatingMode( void )
{
unsigned portLONG ulStatusReg, ulControlReg, ulLinkAbilityReg;

	/* Link status is latched, so read twice to get current value */
	ulStatusReg = ENET_MIIReadReg(0, STE100P_STATUS_REG);
	ulStatusReg = ENET_MIIReadReg(0, STE100P_STATUS_REG);

	if( !( ulStatusReg & STE100P_STATUS_LINKED ) )
	{	
		/* No Link. */
		return pdFAIL;
	}

	ulControlReg = ENET_MIIReadReg(0, STE100P_CONTROL_REG);
	if (ulControlReg & STE100P_AUTO_NEGOTIATE_ABILITY)
	{				
		/* AutoNegotiation is enabled. */
		if (!(ulStatusReg & STE100P_AUTO_NEGOTIATE_COMPLETE))
		{
			/* Auto-negotiation in progress. */
			return pdFAIL;				
		}		

		ulLinkAbilityReg = ENET_MIIReadReg(0, STE100P_LINK_ABILITY);
		if( ( ulLinkAbilityReg & STE100P_100FULL ) || ( ulLinkAbilityReg & STE100P_10FULL ) )
		{
			ENET_MAC->MCR |=MAC_MCR_FDM;   /* full duplex mode */
			ENET_MAC->MCR &=~MAC_MCR_DRO;  /* enable frame reception during transmission */
		}
		else
		{
			ENET_MAC->MCR &=~MAC_MCR_FDM; /* half duplex mode */
			ENET_MAC->MCR |=MAC_MCR_DRO;  /* disable frame reception during transmission */
		}
	}
	else
	{
		if( ulStatusReg & STE100P_CTRL_FULL )
		{
			ENET_MAC->MCR |=MAC_MCR_FDM;   /* full duplex mode */
			ENET_MAC->MCR &=~MAC_MCR_DRO;  /* enable frame reception during transmission */		
		}
		else
		{
			ENET_MAC->MCR &=~MAC_MCR_FDM; /* half duplex mode */
			ENET_MAC->MCR |=MAC_MCR_DRO;  /* disable frame reception during transmission */
		}
	}	
	
	return pdPASS;
}

/*******************************************************************************
* Function Name  : ENET_MIIWriteReg
* Description    : Writes a value on the PHY registers
* Input          : phyDev PHY device address
                 : phyReg PHY register to be written
*                : phyVal PHY register value
* Output         : None
* Return         : None
*******************************************************************************/
void ENET_MIIWriteReg (u8 phyDev, u8 phyReg, u32  phyVal)
{

  volatile u32 addr;
  volatile u32 res;     /* temporary result for address register status */
  volatile u32 timeout;

  /* Prepare the MII register address */
  addr = 0;
  addr |= ((phyDev<<11) & MAC_MII_ADDR_PHY_ADDR); /* set the PHY address */
  addr |= ((phyReg<<6) & MAC_MII_ADDR_MII_REG); /* select the corresponding register */
  addr |= MAC_MII_ADDR_MII_WRITE;  /* in write mode */
  addr |= MAC_MII_ADDR_MII_BUSY;

  /* Check for the Busy flag */
  timeout=0;
  do
  {
    timeout++;
    res = ENET_MAC->MIIA;
  } while ((res & MAC_MII_ADDR_MII_BUSY) && (timeout < (u32 )MII_WRITE_TO));

  /* Give the value to the MII data register */
  ENET_MAC->MIID = (phyVal & 0xFFFF);

  /* write the result value into the MII Address register */
  ENET_MAC->MIIA =addr;

  /* Check for the Busy flag */
  timeout=0;
  do
  {
    timeout++;
    res = ENET_MAC->MIIA;
  } while ((res & MAC_MII_ADDR_MII_BUSY) && (timeout < (u32 )MII_WRITE_TO));

}

/*******************************************************************************
* Function Name  : ENET_MIIReadReg
* Description    : Writes a value on the PHY
* Input          : phyDev PHY device address
*                : phyReg PHY register to be read
* Output         : None
* Return         : The read value (16 bits)
*******************************************************************************/
u32 ENET_MIIReadReg (u8 phyDev, u32 phyReg )
{

  u32 rValue;
  u32 addr;
  u32 res;     /* temporary result for address register status */
  u32 timeout; /* timeout value for read process */

  /* prepare the MII register address */
  addr = 0;
  addr |= ((phyDev<<11) & MAC_MII_ADDR_PHY_ADDR); /* set the PHY address */
  addr |= ((phyReg<<6) & MAC_MII_ADDR_MII_REG); /* select the corresponding register */
  addr &= ~(MAC_MII_ADDR_MII_WRITE);  /* ... in read mode */
  addr |= MAC_MII_ADDR_MII_BUSY;

  /* Check for the Busy flag */
  timeout = 0;

  do
  {
    timeout++;
    res = ENET_MAC->MIIA;
  } while ((res & MAC_MII_ADDR_MII_BUSY) && (timeout < (u32 )MII_READ_TO));

  /* write the result value into the MII Address register */
  ENET_MAC->MIIA = addr;

  /* Check for the Busy flag */
  timeout = 0;

  do
  {
    timeout++;
    res = ENET_MAC->MIIA;
  } while ((res & MAC_MII_ADDR_MII_BUSY) && (timeout < (u32 )MII_READ_TO));

  /* read the result value from data register*/
  rValue = ENET_MAC->MIID;

  return (rValue & 0x0000FFFF);
}

/*******************************************************************************
* Function Name  : ENET_RxDscrInit
* Description    : Initializes the Rx ENET descriptor chain. Single Descriptor
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/

void ENET_RxDscrInit(void)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.欧美精品一二区| 高清不卡一二三区| 91丨porny丨蝌蚪视频| 欧美成人性战久久| 亚洲午夜羞羞片| 高清不卡在线观看| 日韩欧美精品三级| 亚洲国产一区二区视频| av高清不卡在线| 国产日产亚洲精品系列| 麻豆一区二区三| 精品视频一区二区不卡| 亚洲人成亚洲人成在线观看图片 | 亚洲免费成人av| 国产成人日日夜夜| 久久综合精品国产一区二区三区 | 国产精品美女久久久久久久久久久 | 精品综合久久久久久8888| 色综合中文字幕| 亚洲欧洲精品一区二区三区| 国产黑丝在线一区二区三区| 日韩免费视频一区二区| 视频一区国产视频| 精品视频一区二区三区免费| 一区二区三区在线高清| 99在线视频精品| 国产精品美女久久久久久2018| 国产精品996| 久久伊99综合婷婷久久伊| 日日欢夜夜爽一区| 欧美日韩一级片网站| 亚洲一线二线三线视频| 色老头久久综合| 一区二区视频免费在线观看| 91老司机福利 在线| 国产精品电影院| 99视频精品全部免费在线| 中文字幕成人av| 成人av免费在线播放| 国产精品视频一区二区三区不卡| 国产盗摄一区二区三区| 国产欧美精品一区二区色综合朱莉 | 中文字幕亚洲电影| 成人黄色在线网站| 国产精品国产三级国产aⅴ无密码| 国产98色在线|日韩| 欧美激情艳妇裸体舞| 国产成人8x视频一区二区| 国产精品美女久久久久aⅴ国产馆| 成人免费视频国产在线观看| 国产精品区一区二区三| 99热精品一区二区| 一区二区三区久久| 在线视频国内自拍亚洲视频| 亚洲观看高清完整版在线观看| 欧美乱熟臀69xxxxxx| 美女脱光内衣内裤视频久久影院| 欧美一级久久久| 国产精华液一区二区三区| 国产精品国产精品国产专区不蜜| 色综合中文字幕国产| 亚洲国产精品麻豆| 精品久久国产字幕高潮| 国产精品456| 亚洲欧洲www| 欧美日韩一二区| 麻豆精品一区二区av白丝在线| 久久久一区二区三区捆绑**| 成人激情小说乱人伦| 亚洲另类春色校园小说| 欧美日韩一卡二卡三卡| 国产中文字幕精品| 国产精品国产三级国产普通话蜜臀| 欧洲精品在线观看| 麻豆视频观看网址久久| 亚洲国产精品高清| 在线观看日产精品| 久久99精品国产麻豆不卡| 欧美高清在线一区| 欧美日韩国产高清一区二区三区| 国产自产2019最新不卡| 综合网在线视频| 3d动漫精品啪啪| 成人精品视频一区二区三区尤物| 亚洲影视在线观看| 久久久久亚洲综合| 欧美色老头old∨ideo| 韩国av一区二区三区在线观看| 亚洲日穴在线视频| 日韩三级视频在线观看| 成年人国产精品| 日本在线不卡视频| 国产精品久久久久久久久搜平片 | 国产suv精品一区二区883| 一区二区三区久久| 精品国产a毛片| 色94色欧美sute亚洲13| 国内精品久久久久影院薰衣草| 中文字幕一区二区5566日韩| 日韩欧美国产精品| 色婷婷av一区二区三区软件| 国产综合久久久久久鬼色| 亚洲一二三四在线观看| 国产午夜精品一区二区三区嫩草 | 国产视频不卡一区| 欧美男女性生活在线直播观看| 风间由美一区二区三区在线观看 | 国产精品国产三级国产普通话99| 555夜色666亚洲国产免| av在线免费不卡| 免费久久99精品国产| 亚洲黄色在线视频| 久久先锋影音av鲁色资源网| 欧美日韩精品一区二区三区| 成人综合婷婷国产精品久久| 日本不卡的三区四区五区| 亚洲青青青在线视频| 国产日韩欧美激情| 欧美大黄免费观看| 欧美日韩综合色| 91热门视频在线观看| 国产电影一区二区三区| 毛片基地黄久久久久久天堂| 亚洲福利国产精品| 亚洲日本丝袜连裤袜办公室| 久久久久久久综合色一本| 日韩一级免费观看| 欧美日韩精品久久久| 色8久久人人97超碰香蕉987| 菠萝蜜视频在线观看一区| 精品一区二区三区久久| 丝袜美腿亚洲综合| 亚洲一区二区三区自拍| 亚洲欧美日韩国产成人精品影院| 国产精品私房写真福利视频| 久久久亚洲国产美女国产盗摄| 日韩一区二区影院| 91精品欧美一区二区三区综合在| 欧美视频在线观看一区二区| 色婷婷av一区二区三区软件 | 91亚洲精品久久久蜜桃| 粉嫩高潮美女一区二区三区| 精品在线一区二区三区| 石原莉奈在线亚洲三区| 一片黄亚洲嫩模| 亚洲精品午夜久久久| 亚洲色图视频网站| 亚洲欧洲成人av每日更新| 中文字幕一区二区三区不卡在线| 中文字幕成人av| 国产精品久久久久久一区二区三区| 中文字幕免费一区| 国产欧美日本一区二区三区| 国产亚洲精品7777| 国产欧美日韩三级| 国产精品私人自拍| 国产精品福利电影一区二区三区四区| 国产欧美综合在线观看第十页| 精品成人一区二区三区| 精品久久久久一区| 久久综合九色综合97_久久久| 久久久亚洲午夜电影| 国产肉丝袜一区二区| 国产精品视频一区二区三区不卡| 中文av一区特黄| 亚洲视频小说图片| 一区二区三区精品视频| 亚洲成人资源在线| 日韩精品福利网| 麻豆91精品视频| 国产精品自在在线| 成人久久视频在线观看| 色综合色狠狠天天综合色| 欧美制服丝袜第一页| 欧美一区二区三区电影| 欧美成人vr18sexvr| 亚洲国产精品高清| 一区二区在线电影| 日韩不卡一区二区三区| 精品一区二区在线观看| 福利视频网站一区二区三区| 91蜜桃视频在线| 欧美日韩视频一区二区| 日韩视频一区二区| 欧美激情一区在线| 亚洲已满18点击进入久久| 青青草成人在线观看| 国产麻豆精品在线观看| 91麻豆swag| 欧美一区二区三区人| 久久久久久免费| 一区av在线播放| 精东粉嫩av免费一区二区三区| 99久久精品99国产精品| 欧美精品自拍偷拍动漫精品| 精品国产sm最大网站免费看| 中文字幕一区二区三区在线观看| 亚洲午夜精品网| 黑人巨大精品欧美一区| 色婷婷综合中文久久一本|