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

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

?? test_rtl8019.c

?? rt8019的驅動程序源代碼和驅動測試程序源代碼
?? C
字號:

#include "pic.h"
#include "rs232.h"
#include "RTL8019.h"

// Local functions
static void WaitDMAComplete(void);

// ********************************************************
// 
//  Wait for DMA complete interrupt...
//
// ********************************************************
static void WaitDMAComplete(void)
{
  unsigned int i = 0;
    
  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2);

  // Check DMA complete flag, retry ONLY(!) 60000 times...
  for(i=0;i<60000;i++){
    if(RTL8019RD(ETH_PG0_ISR) & ETH_ISR_RDC){
      break;      
    }
  }
        
  RTL8019WR(ETH_PG0_ISR, ETH_ISR_RDC);
}

// ********************************************************
// 
//  Test - Send Arp request...
//
// ********************************************************
void EthernetSend(void)
{
  int i  = 0;
  int j  = 0;
  unsigned int sz = 60;
  unsigned int count = 0;
  
  // 
  unsigned char EthDestAddr[6] = {0xFF,0xFF,0xFF,0xFF,0xFF,0xFF};
  unsigned char EthType[2] = {0x08,0x06};
  
  unsigned char ArpReq[28] = {
  0x00,0x01, // Hardware type
  0x08,0x00, // Protocol type
  0x06,      // Hardware address length
  0x04,      // Protocol address length
  0x00,0x01, // Operation - Arp request!
  0x00,0x3B,0xDB,0xE8,0xC7,0x83, // OWN ETH ADDR
  0xC0,0xA8,0x0F,0x3A,           // Gandalf - Own IP address
  0x00,0x00,0x00,0x00,0x00,0x00, // Dest Eth address
  0xC0,0xA8,0x0F,0x01            // Dest IP (blulnt01)
  };
  
  // Set remote DM byte count and start address
  RTL8019WR(ETH_PG0_RSAR0, 0);
  RTL8019WR(ETH_PG0_RSAR1, 0x40); // Start address of remote DMA
  RTL8019WR(ETH_PG0_RBCR0, sz);
  RTL8019WR(ETH_PG0_RBCR1, sz >> 8);
      
  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD1);
        
  // Transfer ETHERNET HEADER
  for(i=0;i<6;i++){
    RTL8019WR(ETH_IOPORT, EthDestAddr[i]);
  }  
  for(i=0;i<6;i++){
    RTL8019WR(ETH_IOPORT, ArpReq[8+i]);
  }
  for(i=0;i<2;i++){
    RTL8019WR(ETH_IOPORT, EthType[i]);
  }

  // Arp - Message 
  for(i=0;i<28;i++){
    RTL8019WR(ETH_IOPORT, ArpReq[i]);
  }
  
  // Padding
  for(i=0;i<18;i++){
    RTL8019WR(ETH_IOPORT,0x00);
  }
  
  // DMA complete
  WaitDMAComplete();
  
  // Set send register - send data...
  RTL8019WR(ETH_PG0_TBCR0, sz);
  RTL8019WR(ETH_PG0_TBCR1, sz >> 8);   
  RTL8019WR(ETH_PG0_TPSR, 0x40); // Transmitt start page
  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_TXP | ETH_CR_RD2);
}

// ********************************************************
// 
//  Write to RTL8019AS chip...
//
// ********************************************************
void RTL8019WR(unsigned char Address, unsigned char data)
{
  // Kick watch-dog!
  RB7 = !RB7;
    
  // Write data setup rising edge of WRITE= 10 ns.
  // Write data hold from rising edge of WRITE=10 ns.
  PORTD = data;
  TRISD = 0x00; // Set data bus pins as outputs
  PORTA = Address & 0x1f; // Set address output, mask bit 0-4

  WRITE  = 0;    
  WRITE  = 1;
  TRISD=0xFF;  // Set data bus pins as inputs
}

// ********************************************************
// 
//  Read from RTL8019AS chip...
//
// ********************************************************
unsigned char RTL8019RD(unsigned char Address)
{    
  // Read data valid from falling edge of READ= 0-60 ns.
  // Read data hold from rising edge of READ=10 ns.
  unsigned char data = 0;
  
  // Kick watch-dog!
  RB7 = !RB7;
  
  TRISD  = 0xFF; // Set data bus pins as inputs
  PORTA  = Address & 0x1f;  // Set address output, mask bit 0-4

  READ   = 0;
  data   = PORTD;
  READ   = 1;

  return data;
}

// ********************************************************
// 
//  Check some regs...
//
// ********************************************************
void ReadRegs(void)
{
  SendRS232('I',RTL8019RD(ETH_PG0_ISR));

  SendRS232('+',RTL8019RD(ETH_PG0_CRDA0));
  SendRS232('+',RTL8019RD(ETH_PG0_CRDA1));
  SendRS232('#',RTL8019RD(ETH_PG0_CNTR0));
  SendRS232('#',RTL8019RD(ETH_PG0_CNTR1));
  SendRS232('#',RTL8019RD(ETH_PG0_CNTR2));

  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2 | ETH_CR_PS0 | ETH_CR_PS1); // Page3
  SendRS232(':',RTL8019RD(ETH_PG3_CONFIG0));
  SendRS232(':',RTL8019RD(ETH_PG3_CONFIG1));
  SendRS232(':',RTL8019RD(ETH_PG3_CONFIG2));
  SendRS232(':',RTL8019RD(ETH_PG3_CONFIG3));
  SendRS232(':',RTL8019RD(ETH_PG3_CONFIG4));

  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2); // PAGE0  
}

// ********************************************************
// 
//  TEST - Initiate RTL8019AS chip...
//
// ********************************************************
void EthInitRTL8019()
{
  int i = 0;
  int j = 0;
  unsigned int Data = 0;
  
  IOCHRDY = 1;

  // Inactivate chip---
  RTL8019WR(ETH_CR, ETH_CR_STP | ETH_CR_RD2);
  // Delay for a while...
  for(i=0;i<10000;i++){
    for(j=0;j<500;j++){
      RB7 = !RB7; // Kick watch-dog...
    }
  }  

  RTL8019WR(ETH_RESET, 0xFF);
  // Let chip restart, initiate procedure 1sec, wait a while---
  for(i=0;i<10000;i++){
    for(j=0;j<500;j++){
      RB7 = !RB7; // Kick watch-dog...
    }
  }  

  // Check if chip reset, if NOT software reset again...
  if(!(RTL8019RD(ETH_PG0_ISR) & ETH_ISR_RST)){
    RTL8019WR(ETH_RESET, RTL8019RD(ETH_RESET));

    // Let chip restart, initiate procedure <=2ms.
    for(i=0;i<10000;i++){
      for(j=0;j<100;j++){
        RB7 = !RB7; // Kick watch-dog...
        if(RTL8019RD(ETH_PG0_ISR) & ETH_ISR_RST){
          break;
        }
      }
    }
  }

  // Switch media type (initial from EEPROM?) to TP link test enable
  RTL8019WR(ETH_CR, ETH_CR_STP | ETH_CR_RD2 | ETH_CR_PS0 | ETH_CR_PS1); // Page3
  RTL8019WR(ETH_PG3_EECR, ETH_EECR_EEM0 | ETH_EECR_EEM1); // Write enable...
  RTL8019WR(ETH_PG3_CONFIG2, ETH_CONFIG2_BSELB); // Enable TP link test 
  RTL8019WR(ETH_PG3_EECR, 0); // Write disable...

  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2); // Start page0, dma abort...
  // Wait...
  for(i=0;i<10000;i++){
    for(j=0;j<100;j++){
      RB7 = !RB7; // Kick watch-dog...
    }
  }  
  
  // Set mode - ? - 8bits...
  RTL8019WR(ETH_PG0_DCR, ETH_DCR_LS | ETH_DCR_FT1);
  
  // Read DMA!!!
  RTL8019WR(ETH_PG0_RBCR0, 12);
  RTL8019WR(ETH_PG0_RBCR1, 0);
  RTL8019WR(ETH_PG0_RSAR0, 0);
  RTL8019WR(ETH_PG0_RSAR1, 0);
  
  RTL8019WR(ETH_CR, 0x08); // Start DMA remote read
  // Wait...
  for(i=0;i<10000;i++){
    for(j=0;j<50;j++){
      RB7 = !RB7; // Kick watch-dog...
    }
  }  
  
  // READ MAC Address loaded from EEPROM!!!
  for(i=0;i<14;i++){
    SendRS232(':',RTL8019RD(ETH_IOPORT));
  }

  RTL8019WR(ETH_CR, 0x61);
  // Wait...
  for(i=0;i<10000;i++){
    for(j=0;j<100;j++){
      RB7 = !RB7; // Kick watch-dog...
    }
  }  

  RTL8019WR(ETH_CR, ETH_CR_STP | ETH_CR_RD2); // Page0
  
  RTL8019WR(ETH_PG0_RBCR0, 0);
  RTL8019WR(ETH_PG0_RBCR1, 0);
  
  RTL8019WR(ETH_PG0_RCR, ETH_RCR_MON);
  
  RTL8019WR(ETH_PG0_TCR, ETH_TCR_LB0);
  
  RTL8019WR(ETH_PG0_TPSR, 0x40);
  // Receive... FIFO ring...
  RTL8019WR(ETH_PG0_BNRY, 0x4c);
  RTL8019WR(ETH_PG0_PSTART, 0x4c);
  RTL8019WR(ETH_PG0_PSTOP, 0x60);

  RTL8019WR(ETH_PG0_IMR,0);
  RTL8019WR(ETH_PG0_ISR,0xff);

  RTL8019WR(ETH_CR, ETH_CR_STP | ETH_CR_RD2 | ETH_CR_PS0); // Page1

  // Write MAC
  for(i=0;i<6;i++){
    RTL8019WR(ETH_PG1_PAR0+i, MACAddr[i]);
  }
  // Write MCast...
  for(i=0;i<8;i++){
    RTL8019WR(ETH_PG1_MAR0+i, 0x00);
  }
    
  // Set current page...
  RTL8019WR(ETH_PG1_CURR,0x4c);

  RTL8019WR(ETH_CR, ETH_CR_STP | ETH_CR_RD2); // Page0

  RTL8019WR(ETH_PG0_RCR, ETH_RCR_AB);

  RTL8019WR(ETH_PG0_ISR, 0xff);
  RTL8019WR(ETH_PG0_IMR, ETH_IMR_PRXE | ETH_IMR_PTXE);
  
  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2);
  RTL8019WR(ETH_PG0_TCR, 0);
}

// ********************************************************
// 
//  Will fetch packet from remote DMA - received packet
//
// ********************************************************
void FetchPacket(void)
{
  unsigned char recBoundary           = 0;
  unsigned char recCurrentPage        = 0;
  unsigned char recDataByteCount      = 0;
  unsigned char NextPage              = 0;
  unsigned char packageHeaderStatus   = 0; // Contents of RSR-register
  unsigned char packageHeaderNextPage = 0; // Page for next package
  unsigned short packageHeaderSize    = 0; // Size of header and packet in octets ??
  int i = 0;

  // Update global counter...
  receivedPackets--;
  
  // Get next user read packet page 
  recBoundary=RTL8019RD(ETH_PG0_BNRY)+1;
  if(recBoundary>=ETH_STOP_PAGE){
    recBoundary=ETH_FIRST_RX_PAGE;
  }
  SendRS232('#',recBoundary);
  
  RTL8019WR(ETH_CR,ETH_CR_STA | ETH_CR_RD2 | ETH_CR_PS0); // Set reg page 1
  // Read current page register (pointer to first recieive buffer page).
  recCurrentPage=RTL8019RD(ETH_PG1_CURR);    // Next receive packet page
  SendRS232('#',recCurrentPage);
  RTL8019WR(ETH_CR,ETH_CR_STA | ETH_CR_RD2); // Set reg page 0
  if(recBoundary==recCurrentPage){ 
    SendRS232('N',0x00); // No package to read
    return;
  }
  //Set remote DMA byte and start address
  RTL8019WR(ETH_PG0_RBCR0, 4);                     // Remote DMA count byte register LSB
  RTL8019WR(ETH_PG0_RBCR1, 0);                     // Remote DMA count byte register MSB
  RTL8019WR(ETH_PG0_RSAR0, 0);                     // Remote DMA start address register LSB
  RTL8019WR(ETH_PG0_RSAR1,recBoundary);            // Remote DMA start address register MSB

  // Read from buffer
  RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD0);   // Set remote read, Set reg page 0

  packageHeaderStatus   = RTL8019RD(ETH_IOPORT);
  SendRS232('#', packageHeaderStatus);
  packageHeaderNextPage = RTL8019RD(ETH_IOPORT);
  SendRS232('#', packageHeaderNextPage);
  packageHeaderSize     = RTL8019RD(ETH_IOPORT) << 8;
  SendRS232('#', (unsigned char)(packageHeaderSize >> 8));
  packageHeaderSize     = packageHeaderSize | RTL8019RD(ETH_IOPORT);
  SendRS232('#', (unsigned char)(packageHeaderSize));

  WaitDMAComplete();

  recDataByteCount = packageHeaderSize-4;
  SendRS232('#',(unsigned char)(recDataByteCount >> 8));
  SendRS232('#',(unsigned char)(recDataByteCount));

  // Some error...
  if(/*packageHeaderNextPage<ETH_FIRST_RX_PAGE || packageHeaderNextPage>=ETH_STOP_PAGE ||*/
     recDataByteCount<42 || recDataByteCount > 1518){ // Some wierd...
    RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2 | ETH_CR_PS0);
    recCurrentPage = RTL8019RD(ETH_PG1_CURR);
    RTL8019WR(ETH_CR, ETH_CR_STA | ETH_CR_RD2);
    recBoundary = recCurrentPage-1;
    if(recBoundary<ETH_FIRST_RX_PAGE){
      recBoundary = ETH_STOP_PAGE-1;
    }
    RTL8019WR(ETH_PG0_BNRY, recBoundary);
    return;
  }

  // Start reading after the packet header
  RTL8019WR(ETH_PG0_RBCR0,(unsigned char)(recDataByteCount));      // Remote DMA count byte register LSB
  RTL8019WR(ETH_PG0_RBCR1,(unsigned char)(recDataByteCount >> 8)); // Remote DMA count byte register MSB
  RTL8019WR(ETH_PG0_RSAR0,4); //Ignore packetheader;        // Remote DMA start address register LSB
  RTL8019WR(ETH_PG0_RSAR1,recBoundary);                  // Remote DMA start address register MSB

  // Read data from DMA channel
  RTL8019WR(ETH_CR,ETH_CR_STA | ETH_CR_RD0);   // Set remote read, Set reg page 0
  for(i=0;i<recDataByteCount;i++){
    SendRS232('>',RTL8019RD(ETH_IOPORT));
  }
  WaitDMAComplete();

  NextPage=packageHeaderNextPage-1;  
  if(NextPage<ETH_FIRST_RX_PAGE){
    NextPage=ETH_STOP_PAGE-1;
  }
  RTL8019WR(ETH_PG0_BNRY,NextPage); // Page where this packet was retrieved
}

// ********************************************************
// 
//  Interrupt routine for RTL8019AS chip interrupt on line 0
//
// ********************************************************
void RTL8019_Interrupt(void)
{
  unsigned char isrData = 0;

  isrData = INT_RTL8019RD(ETH_PG0_ISR);
  ISendRS232('I',isrData);
    
  // Package received with no errors
  if(isrData & ETH_ISR_PRX){
    // Handle receive buffer indication
    ISendRS232('R', INT_RTL8019RD(ETH_PG0_RSR));
    receivedPackets++;
  }
  // Package transmitted with no errors
  if(isrData & ETH_ISR_PTX){
    // Handle transmit buffer indication
    //ISendRS232('.',0x02);
    ISendRS232('T', INT_RTL8019RD(ETH_PG0_TSR));
  }
 
  if(isrData & ETH_ISR_RST){
    ISendRS232('.',0x04);
  }
  
  if(isrData & ETH_ISR_RDC){
    ISendRS232('.',0x08);
  }  

  // Clear interrupt status register RDC
  INT_RTL8019WR(ETH_PG0_ISR, 0xff);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区.www| 国产精品视频一二三区| 中文字幕欧美日本乱码一线二线| 国产精品不卡视频| 开心九九激情九九欧美日韩精美视频电影 | 亚洲成人综合视频| 国产成人av一区二区三区在线| 精品婷婷伊人一区三区三| 国产三级精品在线| 激情综合网av| 91精品国产综合久久久久久 | 成人福利视频网站| 精品国产成人系列| 日韩和欧美一区二区三区| 91激情五月电影| 亚洲欧洲成人自拍| 国产精品亚洲第一| 精品国一区二区三区| 奇米色777欧美一区二区| 欧美性生活一区| 一区二区三区精品在线观看| av网站一区二区三区| 国产精品三级av| 国产成人精品免费在线| 久久亚洲综合色一区二区三区| 蜜臀av一区二区三区| 欧美区视频在线观看| 亚洲成a天堂v人片| 欧美日韩国产区一| 日韩av在线发布| 欧美一区二区三区视频免费 | 久久99精品视频| 欧美成人激情免费网| 久久精品国产**网站演员| 日韩一区二区三区高清免费看看| 日韩电影一二三区| 日韩一区二区在线看| 精品在线亚洲视频| 国产亚洲福利社区一区| 粉嫩绯色av一区二区在线观看| 中文字幕精品在线不卡| 99精品欧美一区| 亚洲一区在线观看免费| 欧美一区永久视频免费观看| 久久不见久久见中文字幕免费| 久久青草欧美一区二区三区| 国产精品资源在线| 中文字幕在线不卡国产视频| 91麻豆国产在线观看| 亚洲成人av免费| 精品福利在线导航| 97se亚洲国产综合自在线观| 亚洲啪啪综合av一区二区三区| 欧美日韩一区二区在线观看| 麻豆91免费观看| 国产精品久久看| 欧美亚州韩日在线看免费版国语版| 视频精品一区二区| www一区二区| 欧洲亚洲精品在线| 精品一区二区三区影院在线午夜| 中文字幕精品一区| 欧美电影影音先锋| 丰满少妇在线播放bd日韩电影| 亚洲自拍都市欧美小说| 精品免费视频.| 91蝌蚪porny九色| 久久成人免费网| 一区二区三区在线视频观看| 欧美成人video| 91麻豆蜜桃一区二区三区| 麻豆国产精品官网| 亚洲日本va午夜在线影院| 欧美一区二区成人| 色综合中文字幕国产 | 国产精品久久久一本精品| 99久久免费精品| 日韩av一级电影| 中文字幕一区三区| 精品久久久久久久一区二区蜜臀| 99久久精品免费看国产免费软件| 日本三级韩国三级欧美三级| 国产精品不卡一区| 久久日一线二线三线suv| 欧美在线综合视频| 成人99免费视频| 国产综合久久久久影院| 亚洲电影一级黄| 亚洲特级片在线| 中文字幕av免费专区久久| 欧美一卡2卡3卡4卡| 色8久久精品久久久久久蜜| 国产精品一区二区久久不卡| 日韩成人免费看| 亚洲国产精品一区二区www在线| 国产拍欧美日韩视频二区| 日韩一级免费观看| 欧美日韩国产bt| 欧美性感一类影片在线播放| 99久久精品久久久久久清纯| 国产精品1区2区3区在线观看| 免费在线欧美视频| 日韩高清不卡在线| 午夜影院久久久| 夜色激情一区二区| 亚洲狠狠丁香婷婷综合久久久| 国产精品免费视频观看| 国产视频911| 国产欧美日韩卡一| 国产亚洲欧美日韩日本| 久久精品一区二区三区av| 亚洲精品在线一区二区| 欧美tk—视频vk| ww亚洲ww在线观看国产| 26uuu另类欧美| 国产日韩欧美a| 国产精品日产欧美久久久久| 欧美国产精品中文字幕| 国产精品无遮挡| 国产精品高潮久久久久无| 自拍视频在线观看一区二区| 国产精品福利一区| 亚洲精品日韩综合观看成人91| 亚洲欧美色综合| 亚洲成人av在线电影| 免费观看在线综合色| 精品一区二区在线观看| 国产一区激情在线| 日韩欧美一区二区视频| 亚洲成a人片综合在线| 亚洲成年人网站在线观看| 日韩 欧美一区二区三区| 久久精品国产精品亚洲综合| 国产一区二三区| av不卡在线观看| 欧美三级电影在线观看| 日韩欧美国产wwwww| 久久久精品免费观看| 国产精品福利一区二区| 亚洲h在线观看| 黑人巨大精品欧美黑白配亚洲 | 亚洲精品亚洲人成人网在线播放| 亚洲国产视频一区| 美女爽到高潮91| av在线一区二区| 51精品秘密在线观看| 久久婷婷国产综合精品青草| 中文字幕视频一区| 日本在线播放一区二区三区| 国产成人日日夜夜| 欧美在线一区二区三区| 久久亚洲精精品中文字幕早川悠里 | 国产精品亚洲а∨天堂免在线| 91伊人久久大香线蕉| 91麻豆精品91久久久久久清纯| 久久久久九九视频| 亚洲一区二区五区| 韩国一区二区三区| 欧美在线观看18| 国产亚洲成年网址在线观看| 一区二区三区在线免费播放| 激情文学综合网| 欧美日韩在线免费视频| 欧美国产日本视频| 日韩av电影免费观看高清完整版| 成人激情开心网| 精品免费国产二区三区| 亚洲精品高清在线观看| 国产精品888| 欧美一区2区视频在线观看| 亚洲免费毛片网站| 国产成人福利片| 欧美mv和日韩mv的网站| 亚洲综合激情网| 成人激情小说乱人伦| 日韩欧美一区在线| 亚洲成年人网站在线观看| 色综合久久综合网| 国产精品五月天| 高清成人在线观看| 亚洲精品一区二区精华| 免费高清视频精品| 欧美日韩国产首页| 亚欧色一区w666天堂| 欧美综合一区二区三区| 国产精品高潮呻吟久久| 丁香桃色午夜亚洲一区二区三区| 精品嫩草影院久久| 美女网站视频久久| 日韩精品一区二区三区四区视频 | 樱花影视一区二区| av中文字幕亚洲| 国产亚洲欧洲997久久综合| 精品一区二区三区在线播放 | 精品国产91亚洲一区二区三区婷婷 | 国产精品系列在线播放| 久久欧美一区二区| 国产一区二区中文字幕| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 亚洲狠狠爱一区二区三区|