小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

DIY_DE2之DM9000A網(wǎng)卡調(diào)試系列例程(二)——DM9000A測試、自收發(fā)、實現(xiàn)UDP 一

 春華_秋實 2012-04-26

DIY_DE2之DM9000A網(wǎng)卡調(diào)試系列例程(二)——DM9000A測試、自收發(fā)、實現(xiàn)UDP

一、摘要

  通過在SOPC中定制軟核,在Quartus II中建立硬件工程,然后在NIOS II中建立3個工程,分別實現(xiàn)DM9000A測試、DM9000A自收發(fā)和基于DM9000A的UDP協(xié)議的例子。3個例子所使用的DM9000A的驅(qū)動是一樣的。

 

二、實驗平臺

軟件平臺:Quartus II 9.0 + Nios II 9.0

硬件平臺:DIY_DE2

 

三、實驗內(nèi)容1——>DM9000A測試

  通過對DM9000A的初始化,測試DM9000A是否能夠正常的初始化,能否正常的運行。該內(nèi)容不需要使用網(wǎng)線。以下為實現(xiàn)步驟。

1、采用SOPC定制軟核

 

 

定制軟核的詳細(xì)步驟不再贅述,以上為定制的軟核。

cpu_0需要設(shè)置的地方:

Reset Vector:cfi_flash_0、

Exception Vector:sram_16bit_512k_0

第二個標(biāo)簽頁:Data Master處,Data Cache設(shè)置為None

之后分配地址,分配中斷號,生成即可。

2、硬件電路

采用原理圖的形式,創(chuàng)建頂層文件。

(1)添加生成的軟核;

(2)調(diào)用鎖相環(huán)IP核;

(3)連線、分配管腳;

(4)編譯、綜合,生成配置文件。

最后原理圖如下圖所示。

 

 

 

需要注意的問題:

(1)軟核程序在SDRAM里面運行,為了使軟核的速度提升,因此SDRAM的頻率和cpu的頻率都設(shè)置為100M。cpu時鐘clk_100和sdram操作時鐘clk_50都接PLL的c0,100M,無相位偏移;SDRAM的時鐘管腳SDRAM_CLK連接PLL的c1,100M,偏移-3ns。

(2)DM9000A的時鐘管腳接50M,直接連接晶振的輸入端即可。

(3)復(fù)位管腳接高電平VCC即可。

(4)CFI_FLASH的復(fù)位管腳FLASH_RESET接高電平VCC即可。

3、軟件方面

(1)打開NIOS II,新建工程,調(diào)用一個空的工程模板。

(2)添加DM9000A驅(qū)動:dm9000a.h和dm9000a.c,將上述兩個文件包括basic_io復(fù)制到上步建立的工程文件夾下。見附錄。

(3)添加一個新的.c文件,命名為main.c。將下列代碼復(fù)制到main.c內(nèi)。

 

  main.c文件

  1. #include "basic_io.h"
  2. #include "DM9000A.C"
  3. int main()
  4.     unsigned int a;
  5.     a=DM9000_init();
  6.     DM9000_init();  // initialize DM9000 LAN chip //
  7.     if(!a)
  8.     {
  9.         printf("Success");
  10. //   TransmitPacket(unsigned char *data_ptr,unsigned int tx_len);
  11. //   ReceivePacket (unsigned char *data_ptr,unsigned int *rx_len);
  12.     }
  13.     else
  14.         printf("Failed");
  15.     
  16. }

(4)編譯、下載、運行,之前要先將.sof的配置文件下載到FPGA內(nèi)。就可以看到RJ-45的黃色的燈和綠色的燈亮了起來。另外,在NIOS II的控制臺Console中也能看到輸出了 Success 。這時,說明DM9000A能正常運行,且初始化正常。

 

四、實驗內(nèi)容2——>實現(xiàn)DM9000A自收發(fā)

  通過DM9000A將數(shù)據(jù)包發(fā)送出去,之后通過中斷接收。需要使用到網(wǎng)線A。

  不需要改動硬件系統(tǒng),在上一步的基礎(chǔ)上,直接在NOIS II中新建工程,添加main.c文件。

  

  main.c文件內(nèi)容如下:

  1. #include "basic_io.h"
  2. #include "DM9000A.C"
  3. #include "altera_avalon_pio_regs.h"
  4.  
  5. unsigned int aaa,rx_len,i,packet_num;                     
  6. unsigned char RXT[68] = { 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
  7.                           0x01,0x60,0x6E,0x11,0x02,0x0F,
  8.                           0x08,0x00,0x11,0x22,0x33,0x44,
  9.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  10.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  11.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  12.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  13.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  14.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  15.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  16.                           0x00,0x00,0x00,0x20 };
  17.                          
  18.  
  19. void ethernet_interrupts()
  20. {
  21.     packet_num++;
  22.     aaa=ReceivePacket (RXT,&rx_len);
  23.     if(!aaa)
  24.     {
  25.       printf("\n\nReceive Packet Length = %d",rx_len);
  26.       for(i=0;i<rx_len;i++)
  27.       {
  28.         if(i%8==0)
  29.         printf("\n");
  30.         printf("0x%2X,",RXT[i]);
  31.         if(RXT[i] == 0x3f)
  32.         IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, 0xff);
  33.       }
  34.     }
  35. }
  36.  
  37. int main(void)
  38. {
  39.   unsigned char TXT[] = { 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
  40.                           0x01,0x60,0x6E,0x11,0x02,0x0F,
  41.                           0x08,0x00,0x11,0x22,0x33,0x44,
  42.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  43.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  44.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  45.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  46.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  47.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  48.                           0x55,0x66,0x77,0x88,0x99,0xAA,
  49.                           0x00,0x00,0x00,0x20 };
  50.   DM9000_init();
  51.   alt_irq_register( DM9000A_IRQ, NULL, (void*)ethernet_interrupts );
  52.   packet_num=0;
  53.   while (1)
  54.   {
  55.     TransmitPacket(TXT,0x40);
  56.     msleep(500);
  57.   }
  58.  
  59.   return 0;
  60. }
  61. //
  62. //-------------------------------------------------------------------------

  編譯、下載、運行。這時候?qū)⒕W(wǎng)線A插入DIY_DE2開發(fā)板的RJ-45,能夠看到黃色的燈閃爍,綠色的燈一直亮,另外,在NIOS II控制臺也能看到收到的數(shù)據(jù)。

 

五、簡單UDP協(xié)議的實現(xiàn)

  DM9000A與PC的簡單通信,采用UDP協(xié)議,用B網(wǎng)線連接DIY_DE2與PC。FPGA內(nèi)部產(chǎn)生遞增數(shù)據(jù),夠一個數(shù)據(jù)包后,通過網(wǎng)絡(luò)將數(shù)據(jù)傳輸給PC,PC也可以通過網(wǎng)絡(luò)給FPGA發(fā)送數(shù)據(jù),F(xiàn)PGA則通過中斷接收數(shù)據(jù)。

  同樣,直接在NOIS II中新建工程,添加main.c文件。

  可以使用Wireshark軟件來捕捉數(shù)據(jù)包,并測試其傳輸速度。經(jīng)過測試:

cpu采用100MHz時,

(1)cpu/e:SRAM運行,速度3Mbps;

    SDRAM運行,50MHz時,速度600Kbps;

    SDRAM運行,100MHz時,速度1.0Mbps;

(2)cpu/f:SRAM運行,速度11Mbps。

 

main.c文件內(nèi)容如下:

  1. main.c文件
  2. #include <io.h>
  3. #include <stdio.h>
  4. #include <unistd.h>
  5. #include <stdlib.h>
  6. #include <string.h>
  7. #include "system.h"
  8. #include "DM9000A.C"
  9. unsigned int aaa,rx_len,i,counter;
  10. unsigned char RXT[70];
  11.  
  12. unsigned int IPsource_1,IPsource_2,IPsource_3,IPsource_4;
  13. unsigned int IPdestination_1,IPdestination_2,IPdestination_3,IPdestination_4;
  14. unsigned int IPchecksum1,IPchecksum2,IPchecksum3,IPchecksum4,IPchecksum5;
  15. unsigned int Mac_source1, Mac_source2, Mac_source3, Mac_source4, Mac_source5, Mac_source6;
  16. unsigned int Mac_dest1, Mac_dest2, Mac_dest3, Mac_dest4, Mac_dest5, Mac_dest6;
  17. unsigned int times, lenght_h, lenght_l;
  18. unsigned int flenght, IPlenght_h, IPlenght_l, data_lenght, IPlenght;
  19.  
  20. /*
  21. // Next step try to recieve packets. (not available now). 
  22. void ethernet_interrupts()
  23. {
  24.     aaa=ReceivePacket (RXT,&rx_len);
  25.     if(!aaa)
  26.     {
  27.       printf("\n\nReceive Packet Length = %d",rx_len);
  28.       for(i=0;i<rx_len;i++)
  29.       {
  30.         if(i%8==0)
  31.         printf("\n");
  32.         printf("0x%2X,",RXT[i]);
  33.       }
  34.     }
  35. }
  36. */
  37. int main(void)
  38. {
  39.  IPsource_1 = 0xC0;        // Assign ie: 192.168.0.44 IP for the DE2
  40.  IPsource_2 = 0xA8;
  41.  IPsource_3 = 0x00;
  42.  IPsource_4 = 0x2C;
  43.  IPdestination_1 = 0xCA;   // Insert your IP data here
  44.  IPdestination_2 = 0x76;
  45.  IPdestination_3 = 0xBB;
  46.  IPdestination_4 = 0x57;
  47.  Mac_dest1 = 0x00;         // Insert your MAC address data here
  48.  Mac_dest2 = 0x0F;
  49.  Mac_dest3 = 0xEA;
  50.  Mac_dest4 = 0xFD;
  51.  Mac_dest5 = 0x9F;
  52.  Mac_dest6 = 0x96;
  53.  Mac_source1 =  0x01;      // Assign an MAC address for DE2
  54.  Mac_source2 =  0x60;
  55.  Mac_source3 =  0x6E;
  56.  Mac_source4 =  0x11;
  57.  Mac_source5 =  0x02;
  58.  Mac_source6 =  0x0F;
  59.  
  60.  data_lenght = 1468;              // Maximun Data lenght 1468 bytes
  61.  
  62.  flenght = data_lenght + 0x2E;    //Total packet lenght
  63.  lenght_h = ((data_lenght+8) & 0xFF00)>>8; // Convert in H byte and L byte
  64.  lenght_l = ((data_lenght+8) & 0x00FF);
  65.  
  66.  IPlenght = data_lenght + 8 + 20;     // IP Lenght for IP header
  67.  IPlenght_h = (IPlenght & 0xFF00)>>8; // Convert in H byte and L byte
  68.  IPlenght_l = (IPlenght & 0x00FF);
  69.  
  70.  // Calculating the IP checksum
  71.  IPchecksum1 = 0x0000C511 + (IPsource_1<<8)+IPsource_2+(IPsource_3<<8)+IPsource_4+
  72.          (IPdestination_1<<8)+IPdestination_2+(IPdestination_3<<8)+(IPdestination_4)+
  73.          (IPlenght_h<<8) + IPlenght_l;
  74.  IPchecksum2 =  ((IPchecksum1&0x0000FFFF)+(IPchecksum1>>16));
  75.  IPchecksum3 = 0x0000FFFF - IPchecksum2;
  76.  IPchecksum4 = (IPchecksum3 & 0xFF00)>>8;
  77.  IPchecksum5 = (IPchecksum3 & 0x00FF);
  78.  
  79.  unsigned char SND[flenght]; // Payload buffer
  80.  
  81.    unsigned char TXT[] =  { Mac_dest1, Mac_dest2, Mac_dest3, Mac_dest4 ,Mac_dest5, Mac_dest6,
  82.                             Mac_source1, Mac_source2, Mac_source3, Mac_source4, Mac_source5, Mac_source6,
  83.                             0x08, 0x00, 0x45, 0x00, IPlenght_h, IPlenght_l,
  84.                             0x00, 0x00, 0x00, 0x00, 0x80, 0x11,
  85.                             IPchecksum4, IPchecksum5, IPsource_1, IPsource_2, IPsource_3, IPsource_4,
  86.                             IPdestination_1, IPdestination_2, IPdestination_3, IPdestination_4, 0x04, 0x00,
  87.                             0x04, 0x00, lenght_h, lenght_l, 0x00, 0x00};
  88.  
  89.     for (i = 0; i < 42; i++) // Load the TXT[] in the SND (ethernet packet).
  90.      SND[i] = TXT[i];
  91.    
  92.     for (i = 42; i < flenght-4; i++) // generating the data to send.
  93.      SND[i] = i-42;
  94.  
  95.     SND[i++] = 0x35;   // This checksum is not correct... but also the net recieve the packets correctly.
  96.     SND[i++] = 0x15;   // To do, calculate checksum.
  97.     SND[i++] = 0xF0;
  98.     SND[i++] = 0x13;
  99.                          
  100.   DM9000_init();  // Initialize the DM9000A.
  101. // Next step try to recieve packets.(not available now). 
  102. //  alt_irq_register( DM9000A_IRQ, NULL, (void*)ethernet_interrupts );
  103.   
  104.   while (1)
  105.   {
  106.     TransmitPacket(SND,flenght); // Send repetitively 1468 bytes of data.
  107. //    printf("0x%2X,",ior(NSR)); // For check if 10Mbps or 100Mbps active, 0x80 = 10Mbps, 0x40 = 100Mbps.
  108. //    may happend an RX overflow buffer = 0x42
  109. //    msleep(500);
  110.   }
  111.   return 0;
  112. }
  113. //---------------------------------------------------------------

六、說明

  UDP屬于無連接的通信,這里不必把IP設(shè)置成同一網(wǎng)段即可完成通信。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多