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

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

?? hardware_8041_int.c

?? 基于zlg SmartARM2300平臺的源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
#define HARDWARE_GLOBALS
#include "config.h"
#include "../include/cfg_net.h"
#include 	"LPC23XX_ADD_R.h"

union  REC_BUFF_UNION	REC_BUFF[MAX_REC_BUFF];
/* EMAC MODULE ID	*/
#define PHILIPS_EMAC_MODULE_ID	((0x3902 << 16) | 0x2000)

uint32      tempreg1,tempreg;
uint16 PHYREG[80];
uint16 PHYID;
uint16 EINTSTA;
uint8  LINKSTATUS;
volatile uint32 RXOverrunCount = 0;
volatile uint32 RXErrorCount = 0;

volatile uint32 TXUnderrunCount = 0;
volatile uint32 TXErrorCount = 0;
volatile uint32 RxFinishedCount = 0;
volatile uint32 TxFinishedCount = 0;
volatile uint32 TxDoneCount = 0;
volatile uint32 RxDoneCount = 0;

volatile uint32 CurrentRxPtr = EMAC_RX_BUFFER_ADDR;
volatile uint32 ReceiveLength = 0;
volatile uint32 PacketReceived = FALSE;

uint16 EthernetPHYRead(uint8 paddr,uint8 raddr)
{
	uint16 temp16;
	
	rMCMD = 1;					//enable read 
	rMADR = ((paddr&0X1F) <<8 ) + (raddr&0X1F);
	while(rMIND & 0X01);
	rMCMD = 0;
	temp16 = rMRDD;
	return temp16;	
}
/******************************************************************************
** Function name:		EMAC_TxEnable/EMAC_TxDisable
**
** Descriptions:		EMAC TX API modules
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void EMAC_TxEnable( void )
{
    MAC_COMMAND |= 0x02;
    return;
}

void EMAC_TxDisable( void )
{
    MAC_COMMAND &= ~0x02;
    return;
}

/******************************************************************************
** Function name:		EMAC_RxEnable/EMAC_RxDisable
**
** Descriptions:		EMAC RX API modules
**
** parameters:			None
** Returned value:		None
** 
******************************************************************************/
void EMAC_RxEnable( void )
{
    MAC_COMMAND |= 0x01;
    MAC_MAC1 |= 0x01;
    return;    
}

void EMAC_RxDisable( void )
{
    MAC_COMMAND &= ~0x01;
    MAC_MAC1 &= ~0x01;
    return;
}
void WritePHY( uint32 PHYReg, uint32 PHYData )
{
    MAC_MCMD = 0x0000;			/* write command */
    MAC_MADR = 0X0300 | PHYReg;	/* [12:8] == PHY addr, [4:0]=0x00(BMCR) register addr */
    MAC_MWTD = PHYData;
    while ( MAC_MIND != 0 );
    return;
}

void Write_PHY (uint16 phyadd,int PhyReg, int Value)
{
  unsigned int tout;

  MAC_MADR = (phyadd<<8) | PhyReg;
  MAC_MWTD = Value;

  /* Wait utill operation completed */
  tout = 0;
  for (tout = 0; tout < 50000; tout++) {
    if ((MAC_MIND & 1) == 0) {
      break;
    }
  }
}
/*****************************************************************************
** Function name:		ReadPHY
**
** Descriptions:		Read data from the PHY port
**
** parameters:			PHY register
** Returned value:		PHY data
** 
*****************************************************************************/

uint32 ReadPHY( uint16 phyadd,uint32 PHYReg )
{
    uint32 i32;
    MAC_MCMD = 0x0001;			/* read command */
    i32 = (phyadd<<8) | PHYReg;	/* [12:8] == PHY addr, [4:0]=0x00(BMCR) register addr */ 
    MAC_MADR = i32;
    while ( MAC_MIND != 0 );
    MAC_MCMD = 0x0000;
    return( MAC_MRDD );
}
unsigned short Read_PHY ( uint16 phyadd ,unsigned char PhyReg) 
{
  unsigned int tout;

  MAC_MADR = (phyadd<<8) | PhyReg;
  MAC_MCMD = 1;

  /* Wait until operation completed */
  for (tout = 0; tout < 50000; tout++) {
    if ((MAC_MIND & 1) == 0) {
      break;
    }
  }
  MAC_MCMD = 0;
  return (MAC_MRDD);
}

/*****************************************************************************
** Function name:		EMACTxDesciptorInit
**
** Descriptions:		initialize EMAC TX descriptor table
**
** parameters:			None
** Returned value:		None
** 
*****************************************************************************/
void EMACTxDescriptorInit( void )
{
    uint32 i;
    uint32 *tx_desc_addr, *tx_status_addr;
   
    /*-----------------------------------------------------------------------------      
     * setup the Tx status,descriptor registers -- 
     * Note, the actual tx packet data is loaded into the ahb2_sram16k memory as part
     * of the simulation
     *----------------------------------------------------------------------------*/ 
    MAC_TXDESCRIPTOR = TX_DESCRIPTOR_ADDR;	/* Base addr of tx descriptor array */
    MAC_TXSTATUS = TX_STATUS_ADDR;		/* Base addr of tx status */
    MAC_TXDESCRIPTORNUM = EMAC_TX_DESCRIPTOR_COUNT - 1;	/* number of tx descriptors, 16 */

    for ( i = 0; i < EMAC_TX_DESCRIPTOR_COUNT; i++ )
    {
		tx_desc_addr = (uint32 *)(TX_DESCRIPTOR_ADDR + i * 8);	/* two words at a time, packet and control */
		*tx_desc_addr = (uint32)(EMAC_TX_BUFFER_ADDR + i * EMAC_BLOCK_SIZE);
		*(tx_desc_addr+1) = (uint32)(EMAC_TX_DESC_INT | (EMAC_BLOCK_SIZE - 1));	/* set size only */
    }
    
    for ( i = 0; i < EMAC_TX_DESCRIPTOR_COUNT; i++ )
    {
		tx_status_addr = (uint32 *)(TX_STATUS_ADDR + i * 4);	/* TX status, one word only, status info. */
		*tx_status_addr = (uint32)0;		/* initially, set status info to 0 */
    }
    MAC_TXPRODUCEINDEX = 0x0;	/* TX descriptors point to zero */
    return;
}

/*****************************************************************************
** Function name:		EMACRxDesciptorInit
**
** Descriptions:		initialize EMAC RX descriptor table
**
** parameters:			None
** Returned value:		None
** 
*****************************************************************************/
void EMACRxDescriptorInit( void )
{
    uint32 i;
    uint32 *rx_desc_addr, *rx_status_addr;
   
    /*-----------------------------------------------------------------------------      
     * setup the Rx status,descriptor registers -- 
     * Note, the actual rx packet data is loaded into the ahb2_sram16k memory as part
     * of the simulation
     *----------------------------------------------------------------------------*/ 
    MAC_RXDESCRIPTOR = RX_DESCRIPTOR_ADDR;	/* Base addr of rx descriptor array */
    MAC_RXSTATUS = RX_STATUS_ADDR;			/* Base addr of rx status */
    MAC_RXDESCRIPTORNUM = EMAC_RX_DESCRIPTOR_COUNT - 1;	/* number of rx descriptors, 16 */

    for ( i = 0; i < EMAC_RX_DESCRIPTOR_COUNT; i++ )
    {
		/* two words at a time, packet and control */
		rx_desc_addr = (uint32 *)(RX_DESCRIPTOR_ADDR + i * 8);
		*rx_desc_addr = (uint32)(EMAC_RX_BUFFER_ADDR + i * EMAC_BLOCK_SIZE);
		*(rx_desc_addr+1) = (uint32)(EMAC_RX_DESC_INT | (EMAC_BLOCK_SIZE - 1));	/* set size only */    
    }
 
    for ( i = 0; i < EMAC_RX_DESCRIPTOR_COUNT; i++ )
    {
		/* RX status, two words, status info. and status hash CRC. */
		rx_status_addr = (uint32 *)(RX_STATUS_ADDR + i * 8);	
		*rx_status_addr = (uint32)0;	/* initially, set both status info and hash CRC to 0 */
		*(rx_status_addr+1) = (uint32)0; 
    }
    MAC_RXCONSUMEINDEX = 0x0;	/* RX descriptor points to zero */
    return;
}

/**********************************************************************
**函數原型:    void 	SetMacID()
**入口參數:		*mac_ptr
**出口參數:		無
**返 回 值:	無            
**說    明:	設置芯片物理地址,物理地址已經存儲在程序空間內 
************************************************************************/
void SetMacID(uint8 * mac_ptr)   
{

	MAC_SA0 = mac_ptr[0]*256+mac_ptr[1];
    MAC_SA1 = mac_ptr[2]*256+mac_ptr[3];
    MAC_SA2 = mac_ptr[4]*256+mac_ptr[5];
	//把MAC地址寫入MY——MAC——ID中
	
}
uint32 EMACSend( uint32 *EMACBuf, uint32 length )
{
    uint32 *tx_desc_addr;
    uint32 TxProduceIndex;
    uint32 TxConsumeIndex;
    uint32 i, templen;

    TxProduceIndex = MAC_TXPRODUCEINDEX;
    TxConsumeIndex = MAC_TXCONSUMEINDEX;

    if ( TxConsumeIndex != TxProduceIndex )
    {
		return ( FALSE );
    }

    if ( TxProduceIndex == EMAC_TX_DESCRIPTOR_COUNT )
    {
		/* reach the limit, that probably should never happen */
		/* To be tested */
		MAC_TXPRODUCEINDEX = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品美女在线播放| 欧美a一区二区| 亚洲欧洲性图库| 国产亚洲污的网站| 久久精品无码一区二区三区| 精品一区二区免费在线观看| 亚洲综合一区二区三区| 亚洲一区日韩精品中文字幕| 亚洲精品久久久蜜桃| 一区二区在线观看视频| 香蕉av福利精品导航| 日产国产欧美视频一区精品| 久久国产精品99精品国产| 久久av资源网| 国产99一区视频免费| 成人一区二区三区在线观看| 成人成人成人在线视频| 91免费观看国产| 欧美综合天天夜夜久久| 69久久夜色精品国产69蝌蚪网| 在线播放亚洲一区| 日韩一二三四区| 精品国产乱码久久久久久闺蜜| 久久久久国产精品免费免费搜索| 久久精品视频在线看| 中文字幕视频一区| 亚洲国产视频在线| 国内国产精品久久| 成人avav影音| 欧美日免费三级在线| 日韩三级高清在线| 国产欧美精品区一区二区三区 | 欧美精品少妇一区二区三区| 777a∨成人精品桃花网| 久久久蜜臀国产一区二区| 1区2区3区精品视频| 无码av免费一区二区三区试看 | 99久久婷婷国产综合精品电影| 日本精品一区二区三区高清| 蜜桃免费网站一区二区三区| 国产成人啪免费观看软件| 色婷婷国产精品久久包臀| 日韩一区二区影院| 国产精品天天摸av网| 亚洲国产成人tv| 国产成人无遮挡在线视频| 欧美少妇一区二区| 久久精品欧美日韩| 亚洲国产精品影院| 国产成人av电影免费在线观看| 欧美性大战xxxxx久久久| 26uuu久久综合| 亚洲午夜免费电影| 风间由美一区二区三区在线观看| 欧美人与性动xxxx| 国产精品毛片久久久久久| 亚洲成av人片观看| 成人app软件下载大全免费| 91精品国产入口| 亚洲天堂久久久久久久| 黑人精品欧美一区二区蜜桃 | 日韩一区国产二区欧美三区| 欧美激情自拍偷拍| 日本午夜精品视频在线观看 | 国内外成人在线| 欧美优质美女网站| 欧美激情一区二区三区蜜桃视频| 五月激情综合婷婷| 一本一道波多野结衣一区二区| 精品av综合导航| 同产精品九九九| 色综合久久天天| 欧美激情一区二区三区| 免费观看91视频大全| 色婷婷综合久久久久中文一区二区 | 精品一二三四在线| 欧美日韩国产大片| 亚洲自拍偷拍麻豆| eeuss鲁片一区二区三区| 精品99999| 麻豆一区二区99久久久久| 欧美日韩午夜在线视频| 亚洲三级理论片| 成人污污视频在线观看| 精品国产一区二区三区四区四 | 在线欧美日韩精品| 一区在线中文字幕| 成人免费视频caoporn| 欧美精品一区二区三区很污很色的| 日日噜噜夜夜狠狠视频欧美人 | 久久婷婷国产综合精品青草| 青青草91视频| 日韩欧美专区在线| 秋霞影院一区二区| 91精品国产色综合久久ai换脸| 午夜精品在线视频一区| 欧美日韩国产一二三| 亚洲国产三级在线| 欧美系列日韩一区| 亚洲一区二区3| 欧美日韩在线三级| 午夜精品aaa| 51精品视频一区二区三区| 五月婷婷久久综合| 欧美人与禽zozo性伦| 三级精品在线观看| 日韩免费看网站| 狠狠色综合日日| 国产偷国产偷精品高清尤物| 国产电影一区在线| 国产精品美女久久福利网站| 99视频精品免费视频| 最好看的中文字幕久久| 色先锋久久av资源部| 亚洲电影一级黄| 6080yy午夜一二三区久久| 美女诱惑一区二区| 久久综合九色综合97_久久久| 国产精品中文字幕日韩精品| 国产亚洲一本大道中文在线| 99久久综合精品| 一区二区三区高清| 欧美一区欧美二区| 国产一区二区三区在线观看免费视频| 精品国产91乱码一区二区三区 | 欧美艳星brazzers| 日产国产欧美视频一区精品| 欧美精品一区二区三区久久久| 东方欧美亚洲色图在线| 中文字幕一区二区三区不卡在线 | 日韩美女主播在线视频一区二区三区 | 亚洲午夜精品在线| 日韩一区二区在线看| 懂色av一区二区三区免费观看| 亚洲女与黑人做爰| 欧美一区二区人人喊爽| 国产一区二区在线观看视频| 一区二区中文字幕在线| 欧美日韩高清一区二区| 激情小说欧美图片| 中文字幕一区日韩精品欧美| 欧美美女bb生活片| 国产成人免费在线观看不卡| 一区二区三区在线免费播放| 日韩欧美国产一区在线观看| 国产不卡免费视频| 亚洲成人免费看| 久久久www免费人成精品| 在线亚洲一区观看| 麻豆91在线播放免费| 亚洲天堂2016| 精品久久久久香蕉网| 日本久久一区二区| 韩国精品主播一区二区在线观看 | 亚洲风情在线资源站| 久久久精品欧美丰满| 欧美性色欧美a在线播放| 国产精品一区二区久激情瑜伽| 亚洲猫色日本管| 久久综合99re88久久爱| 欧美亚洲综合久久| 大胆亚洲人体视频| 日本成人在线不卡视频| 亚洲欧美视频一区| 久久久不卡影院| 91精品国产欧美日韩| 99re8在线精品视频免费播放| 另类欧美日韩国产在线| 亚洲一区av在线| 中文字幕在线不卡一区二区三区| 精品久久久久久综合日本欧美| 91成人国产精品| av电影天堂一区二区在线| 老司机精品视频在线| 亚洲午夜电影在线观看| 一区在线观看视频| 久久精品夜色噜噜亚洲a∨| 日韩欧美高清一区| 欧美日韩视频第一区| 一本久久精品一区二区| 国产成人亚洲综合a∨猫咪| 久久精品理论片| 日韩影院精彩在线| 亚洲一区在线观看免费观看电影高清| 国产欧美日韩不卡免费| 久久免费视频一区| 日韩免费视频一区| 日韩欧美第一区| 亚洲3atv精品一区二区三区| 亚洲欧美另类小说视频| 中文字幕av一区二区三区高| 久久嫩草精品久久久精品| 欧美电影免费观看高清完整版在线 | 精品国产伦一区二区三区观看体验| 91福利在线导航| 91丨九色丨蝌蚪丨老版| 99久久久国产精品| 成人教育av在线| av爱爱亚洲一区| 成人18视频日本|