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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? emac.c

?? easy web build on NXP LPC2300 LPc2400
?? C
字號:
/******************************************************************
 *****                                                        *****
 *****  Name: cs8900.c                                        *****
 *****  Ver.: 1.0                                             *****
 *****  Date: 07/05/2001                                      *****
 *****  Auth: Andreas Dannenberg                              *****
 *****        HTWK Leipzig                                    *****
 *****        university of applied sciences                  *****
 *****        Germany                                         *****
 *****  Func: ethernet packet-driver for use with LAN-        *****
 *****        controller CS8900 from Crystal/Cirrus Logic     *****
 *****                                                        *****
 *****  Keil: Module modified for use with Philips            *****
 *****        LPC2378 EMAC Ethernet controller                *****
 *****                                                        *****
 ******************************************************************/

#include "EMAC.h"
#include "tcpip.h"
#include <LPC23xx.h>

static unsigned short *rptr;
static unsigned short *tptr;

// Keil: function added to write PHY
void write_PHY (int PhyReg, int Value)
{
  unsigned int tout;

  MAC_MADR = DP83848C_DEF_ADR | PhyReg;
  MAC_MWTD = Value;

  /* Wait utill operation completed */
  tout = 0;
  for (tout = 0; tout < MII_WR_TOUT; tout++) {
    if ((MAC_MIND & MIND_BUSY) == 0) {
      break;
    }
  }
}


// Keil: function added to read PHY
unsigned short read_PHY (unsigned char PhyReg) 
{
  unsigned int tout;

  MAC_MADR = DP83848C_DEF_ADR | PhyReg;
  MAC_MCMD = MCMD_READ;

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


// Keil: function added to initialize Rx Descriptors
void rx_descr_init (void)
{
  unsigned int i;

  for (i = 0; i < NUM_RX_FRAG; i++) {
    RX_DESC_PACKET(i)  = RX_BUF(i);
    RX_DESC_CTRL(i)    = RCTRL_INT | (ETH_FRAG_SIZE-1);
    RX_STAT_INFO(i)    = 0;
    RX_STAT_HASHCRC(i) = 0;
  }

  /* Set EMAC Receive Descriptor Registers. */
  MAC_RXDESCRIPTOR    = RX_DESC_BASE;
  MAC_RXSTATUS        = RX_STAT_BASE;
  MAC_RXDESCRIPTORNUM = NUM_RX_FRAG-1;

  /* Rx Descriptors Point to 0 */
  MAC_RXCONSUMEINDEX  = 0;
}


// Keil: function added to initialize Tx Descriptors
void tx_descr_init (void) {
  unsigned int i;

  for (i = 0; i < NUM_TX_FRAG; i++) {
    TX_DESC_PACKET(i) = TX_BUF(i);
    TX_DESC_CTRL(i)   = 0;
    TX_STAT_INFO(i)   = 0;
  }

  /* Set EMAC Transmit Descriptor Registers. */
  MAC_TXDESCRIPTOR    = TX_DESC_BASE;
  MAC_TXSTATUS        = TX_STAT_BASE;
  MAC_TXDESCRIPTORNUM = NUM_TX_FRAG-1;

  /* Tx Descriptors Point to 0 */
  MAC_TXPRODUCEINDEX  = 0;
}


// configure port-pins for use with LAN-controller,
// reset it and send the configuration-sequence

void Init_EMAC(void)
{
// Keil: function modified to access the EMAC
// Initializes the EMAC ethernet controller
  unsigned int regv,tout,id1,id2;

   /* Power Up the EMAC controller. */
   PCONP |= 0x40000000;

  /* Enable P1 Ethernet Pins. */
  if (MAC_MODULEID == OLD_EMAC_MODULE_ID) { 
    /* For the first silicon rev.'-' ID P1.6 should be set. */
    PINSEL2 = 0x50151105;
  }
  else {
    /* on rev. 'A' and later, P1.6 should NOT be set. */
    PINSEL2 = 0x50150105;
  }
  PINSEL3 = (PINSEL3 & ~0x0000000F) | 0x00000005;

  /* Reset all EMAC internal modules. */
  MAC_MAC1 = MAC1_RES_TX | MAC1_RES_MCS_TX | MAC1_RES_RX | MAC1_RES_MCS_RX |
             MAC1_SIM_RES | MAC1_SOFT_RES;
  MAC_COMMAND = CR_REG_RES | CR_TX_RES | CR_RX_RES;

  /* A short delay after reset. */
  for (tout = 100; tout; tout--);

  /* Initialize MAC control registers. */
  MAC_MAC1 = MAC1_PASS_ALL;
  MAC_MAC2 = MAC2_CRC_EN | MAC2_PAD_EN;
  MAC_MAXF = ETH_MAX_FLEN;
  MAC_CLRT = CLRT_DEF;
  MAC_IPGR = IPGR_DEF;

  /* Enable Reduced MII interface. */
  MAC_COMMAND = CR_RMII | CR_PASS_RUNT_FRM;

  /* Reset Reduced MII Logic. */
  MAC_SUPP = SUPP_RES_RMII;
  for (tout = 100; tout; tout--);
  MAC_SUPP = 0;

  /* Put the DP83848C in reset mode */
  write_PHY (PHY_REG_BMCR, 0x8000);

  /* Wait for hardware reset to end. */
  for (tout = 0; tout < 0x100000; tout++) {
    regv = read_PHY (PHY_REG_BMCR);
    if (!(regv & 0x8000)) {
      /* Reset complete */
      break;
    }
  }

  /* Check if this is a DP83848C PHY. */
  id1 = read_PHY (PHY_REG_IDR1);
  id2 = read_PHY (PHY_REG_IDR2);
  if (((id1 << 16) | (id2 & 0xFFF0)) == DP83848C_ID) {
    /* Configure the PHY device */

    /* Use autonegotiation about the link speed. */
    write_PHY (PHY_REG_BMCR, PHY_AUTO_NEG);
    /* Wait to complete Auto_Negotiation. */
    for (tout = 0; tout < 0x100000; tout++) {
      regv = read_PHY (PHY_REG_BMSR);
      if (regv & 0x0020) {
        /* Autonegotiation Complete. */
        break;
      }
    }
  }

  /* Check the link status. */
  for (tout = 0; tout < 0x10000; tout++) {
    regv = read_PHY (PHY_REG_STS);
    if (regv & 0x0001) {
      /* Link is on. */
      break;
    }
  }

  /* Configure Full/Half Duplex mode. */
  if (regv & 0x0004) {
    /* Full duplex is enabled. */
    MAC_MAC2    |= MAC2_FULL_DUP;
    MAC_COMMAND |= CR_FULL_DUP;
    MAC_IPGT     = IPGT_FULL_DUP;
  }
  else {
    /* Half duplex mode. */
    MAC_IPGT = IPGT_HALF_DUP;
  }

  /* Configure 100MBit/10MBit mode. */
  if (regv & 0x0002) {
    /* 10MBit mode. */
    MAC_SUPP = 0;
  }
  else {
    /* 100MBit mode. */
    MAC_SUPP = SUPP_SPEED;
  }

  /* Set the Ethernet MAC Address registers */
  MAC_SA0 = (MYMAC_1 << 8) | MYMAC_2;
  MAC_SA1 = (MYMAC_3 << 8) | MYMAC_4;
  MAC_SA2 = (MYMAC_5 << 8) | MYMAC_6;

  /* Initialize Tx and Rx DMA Descriptors */
  rx_descr_init ();
  tx_descr_init ();

  /* Receive Broadcast and Perfect Match Packets */
  MAC_RXFILTERCTRL = RFC_UCAST_EN | RFC_BCAST_EN | RFC_PERFECT_EN;

  /* Enable EMAC interrupts. */
  MAC_INTENABLE = INT_RX_DONE | INT_TX_DONE;

  /* Reset all interrupts */
  MAC_INTCLEAR  = 0xFFFF;

  /* Enable receive and transmit mode of MAC Ethernet core */
  MAC_COMMAND  |= (CR_RX_EN | CR_TX_EN);
  MAC_MAC1     |= MAC1_REC_EN;
}


// reads a word in little-endian byte order from RX_BUFFER

unsigned short ReadFrame_EMAC(void)
{
  return (*rptr++);
}

// reads a word in big-endian byte order from RX_FRAME_PORT
// (useful to avoid permanent byte-swapping while reading
// TCP/IP-data)

unsigned short ReadFrameBE_EMAC(void)
{
  unsigned short ReturnValue;

  ReturnValue = SwapBytes (*rptr++);
  return (ReturnValue);
}


// copies bytes from frame port to MCU-memory
// NOTES: * an odd number of byte may only be transfered
//          if the frame is read to the end!
//        * MCU-memory MUST start at word-boundary

void CopyFromFrame_EMAC(void *Dest, unsigned short Size)
{
  unsigned short * piDest;                       // Keil: Pointer added to correct expression

  piDest = Dest;                                 // Keil: Line added
  while (Size > 1) {
    *piDest++ = ReadFrame_EMAC();
    Size -= 2;
  }
  
  if (Size) {                                         // check for leftover byte...
    *(unsigned char *)piDest = (char)ReadFrame_EMAC();// the LAN-Controller will return 0
  }                                                   // for the highbyte
}

// does a dummy read on frame-I/O-port
// NOTE: only an even number of bytes is read!

void DummyReadFrame_EMAC(unsigned short Size)    // discards an EVEN number of bytes
{                                                // from RX-fifo
  while (Size > 1) {
    ReadFrame_EMAC();
    Size -= 2;
  }
}

// Reads the length of the received ethernet frame and checks if the 
// destination address is a broadcast message or not
// returns the frame length
unsigned short StartReadFrame(void) {
  unsigned short RxLen;
  unsigned int idx;

  idx = MAC_RXCONSUMEINDEX;
  RxLen = (RX_STAT_INFO(idx) & RINFO_SIZE) - 3;
  rptr = (unsigned short *)RX_DESC_PACKET(idx);
  return(RxLen);
}

void EndReadFrame(void) {
  unsigned int idx;

  /* DMA free packet. */
  idx = MAC_RXCONSUMEINDEX;
  if (++idx == NUM_RX_FRAG) idx = 0;
  MAC_RXCONSUMEINDEX = idx;
}

unsigned int CheckFrameReceived(void) {             // Packet received ?

  if (MAC_RXPRODUCEINDEX != MAC_RXCONSUMEINDEX)     // more packets received ?
    return(1);
  else 
    return(0);
}

// requests space in EMAC memory for storing an outgoing frame

void RequestSend(unsigned short FrameSize)
{
  unsigned int idx;

  idx  = MAC_TXPRODUCEINDEX;
  tptr = (unsigned short *)TX_DESC_PACKET(idx);
  TX_DESC_CTRL(idx) = FrameSize | TCTRL_LAST;
}

// check if ethernet controller is ready to accept the
// frame we want to send

unsigned int Rdy4Tx(void)
{
  return (1);   // the ethernet controller transmits much faster
}               // than the CPU can load its buffers


// writes a word in little-endian byte order to TX_BUFFER
void WriteFrame_EMAC(unsigned short Data)
{
  *tptr++ = Data;
}

// copies bytes from MCU-memory to frame port
// NOTES: * an odd number of byte may only be transfered
//          if the frame is written to the end!
//        * MCU-memory MUST start at word-boundary

void CopyToFrame_EMAC(void *Source, unsigned int Size)
{
  unsigned short * piSource;
  unsigned int idx;

  piSource = Source;
  Size = (Size + 1) & 0xFFFE;    // round Size up to next even number
  while (Size > 0) {
    WriteFrame_EMAC(*piSource++);
    Size -= 2;
  }

  idx = MAC_TXPRODUCEINDEX;
  if (++idx == NUM_TX_FRAG) idx = 0;
  MAC_TXPRODUCEINDEX = idx;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲三级小视频| 亚洲人精品午夜| 91丝袜国产在线播放| 天天av天天翘天天综合网色鬼国产| 精品入口麻豆88视频| 色婷婷综合中文久久一本| 国产一区二区三区免费观看| 午夜久久久久久电影| 亚洲欧美影音先锋| 久久影音资源网| 日韩亚洲欧美综合| 欧美日韩精品三区| 91网站在线观看视频| 粉嫩蜜臀av国产精品网站| 麻豆精品精品国产自在97香蕉| 夜夜揉揉日日人人青青一国产精品| 国产人久久人人人人爽| 日韩欧美一级特黄在线播放| 欧美丰满少妇xxxxx高潮对白| 日本久久一区二区| 色天天综合久久久久综合片| 成人午夜视频免费看| 国产乱人伦精品一区二区在线观看 | 蜜桃视频在线观看一区二区| 一二三四区精品视频| 亚洲码国产岛国毛片在线| 国产欧美一区二区精品性色| 久久―日本道色综合久久| 欧美va亚洲va香蕉在线| 欧美精品乱码久久久久久按摩| 欧美性猛交xxxxxxxx| 日本精品视频一区二区| 日本精品一区二区三区四区的功能| 成人伦理片在线| 成人av资源下载| www.成人在线| 91欧美激情一区二区三区成人| av中文字幕在线不卡| 成人av第一页| www.日本不卡| 色综合久久88色综合天天| 日本韩国精品在线| 欧美日韩在线三级| 欧美美女bb生活片| 91精品免费观看| 日韩美女在线视频| 国产日韩欧美精品电影三级在线| 久久人人97超碰com| 国产人成一区二区三区影院| 国产精品理论在线观看| 国产精品短视频| 一区二区三区四区在线| 亚洲成人av一区二区| 日本欧美一区二区| 美女视频网站久久| 国产高清视频一区| 国产成人精品一区二| 91首页免费视频| 欧美精品123区| 欧美xxx久久| 中文字幕亚洲在| 亚洲成人av福利| 久久成人综合网| av一区二区三区黑人| 欧美偷拍一区二区| 精品美女被调教视频大全网站| 日本一区二区三区在线观看| 一区二区在线看| 美女视频一区在线观看| 成人性生交大片| 欧美三区免费完整视频在线观看| 欧美一区二区三区不卡| 国产女人水真多18毛片18精品视频| 亚洲天堂中文字幕| 日本麻豆一区二区三区视频| 成人中文字幕合集| 欧美日韩亚洲丝袜制服| 久久综合狠狠综合| 亚洲精品视频在线看| 奇米影视一区二区三区| 成人国产一区二区三区精品| 欧美日韩精品一区二区三区四区| 久久―日本道色综合久久| 亚洲一区二区在线免费看| 久久av中文字幕片| 色婷婷av一区| 国产日韩亚洲欧美综合| 日本视频一区二区| 色综合久久久久| 久久久久久久久久久电影| 亚洲综合精品自拍| 国产一区二区精品久久99| 日本道色综合久久| 久久久久99精品国产片| 午夜免费欧美电影| 91片在线免费观看| 国产亚洲制服色| 免费av成人在线| 91国产免费观看| 国产精品区一区二区三区| 日韩综合小视频| 一本一道久久a久久精品| 国产亚洲一本大道中文在线| 日本不卡在线视频| 欧美性感一类影片在线播放| 日本一二三不卡| 国产一区二区三区电影在线观看 | 91麻豆免费看片| 久久新电视剧免费观看| 日本不卡视频在线观看| 91麻豆免费在线观看| 国产精品私人影院| 国产成人亚洲综合a∨婷婷 | 久久久久久久久免费| 奇米888四色在线精品| 欧美午夜精品久久久久久超碰| 日本一区二区三区四区在线视频| 精品一区二区免费| 日韩欧美在线观看一区二区三区| 悠悠色在线精品| av成人动漫在线观看| 久久久久久电影| 九九**精品视频免费播放| 91精品婷婷国产综合久久性色 | 欧美在线免费视屏| 亚洲精品免费在线观看| www.日韩精品| 亚洲欧美自拍偷拍色图| 99精品桃花视频在线观看| 欧美国产激情二区三区| 成人免费高清在线观看| 国产女主播视频一区二区| 国产91在线观看| 久久久不卡网国产精品二区| 国产麻豆成人精品| 久久久久久久久久久久久女国产乱| 九九**精品视频免费播放| 久久综合色鬼综合色| 国产河南妇女毛片精品久久久| 欧美激情一二三区| 91在线观看一区二区| 亚洲精品国产成人久久av盗摄 | 欧美成人高清电影在线| 久久精品国产亚洲a| 精品国产91乱码一区二区三区| 精品制服美女丁香| 久久人人97超碰com| 白白色亚洲国产精品| 综合久久一区二区三区| 91福利区一区二区三区| 亚洲成人在线网站| 日韩亚洲欧美成人一区| 国内成人自拍视频| 国产精品久久久久一区二区三区| 色综合天天综合给合国产| 午夜视频在线观看一区二区三区| 欧美精品日韩综合在线| 国产乱码精品一品二品| 国产精品久久久久久妇女6080| 色老综合老女人久久久| 秋霞成人午夜伦在线观看| 国产婷婷精品av在线| 91国内精品野花午夜精品| 蜜臀av亚洲一区中文字幕| 久久久夜色精品亚洲| 色婷婷av久久久久久久| 毛片一区二区三区| 国产精品国产三级国产三级人妇 | 日韩三级在线观看| 国产风韵犹存在线视精品| 亚洲精品免费在线| 久久综合五月天婷婷伊人| 91视频在线看| 精品无码三级在线观看视频 | 国产呦精品一区二区三区网站| 中文字幕在线观看不卡| 欧美日韩激情在线| 国产成人综合网| 亚洲成人免费av| 国产欧美综合在线观看第十页| 91福利视频在线| 国产成人免费视频一区| 亚洲综合在线第一页| 精品国产一区久久| 日本久久电影网| 国产乱子轮精品视频| 一区二区三区在线影院| 久久老女人爱爱| 欧美精品粉嫩高潮一区二区| 不卡在线观看av| 国产一区二区三区四| 午夜成人免费电影| |精品福利一区二区三区| 欧美变态tickle挠乳网站| 欧美综合视频在线观看| 成人网页在线观看| 精品一区二区三区在线播放| 亚洲影视在线播放| 国产精品天天看| ww亚洲ww在线观看国产|