想利用手头上的DE2-115 写一个关于以太网通信的驱动,经过了这么多天的实验调试终于有了一些认识。

1、我在观察网卡发送数据与接收数据的过程中发现,我从fpga上的一个网卡发送数据,然后另一个网卡接收数据,接收到的数据前面会有55h这8bit的数据。我从PC上发送数据,用fpga上的网卡接收数据,那么在接收到的数据前面会有55h,55h,55h,55h,55h,55h,55h,5dh这64bit的数据。那么如果55h这8bit数据是PHY发送时自动添加那么从PC上接收到的最后应该是55而不应该是5d。那么只能是网卡在接收的时候自动添加的55h这8bit位。那剩下的56bit应该是自己添加在数据中发送的。

2、我用signaltap ii设置的采样频率是50Mh,而数据的带宽是100Mhz。当我用小兵以太网测试仪设置的发送频率为1000000/次时,发现siganltap ii 中rx_data的数据很久才会变化,其余时刻都是零,但是用led通过对接收数据进行观察时就符合发送的频率,那么signal tap ii 很长时间观察不到数据的情景应该和时钟的设置有关。

3、有一段时间我从PC上发送数据,然后fpga上接收的数据,一段数据的个别位发生错误。等我把板子上两个phy的配置都设置正确时。就能正确的接收数据了。

4、signaltap 接收到的PC数据高四位与第四位颠倒,比如说如果发送的数据是56h 75h 83h 那么接收到的数据就是65h 57h 38h。说明数据在发送的过程中高先发送低四位后发送高四位。

5、88E1111 采用100M ,全双工 能从Pc接收数据的寄存器设置。

a、PHY的物理地址为10000,板子连接JP1的23.

b、读寄存器以及写寄存器。读寄存器主要是为了观察PHY配置是否正确。在调试的过程中正确的读寄存器非常重要。

代码如下

 if(flag) begin
case(mdc_num)
:begin RST_N<=;mdio_reg<=mdio_reg+;if(mdio_reg&'hffffffff==32'hffffffff) begin RST_N<=; mdc_num<=;end
              else mdc_num<=;end
:begin mdio_reg<='hffff_ffff__585a__0000_ffff_ffff;mdc_num<=2;end //选择page0 copper
:begin mdc_count<=mdc_count+;
if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end
else begin mdc_num<=;mdc_count<=;end end
:begin mdio_reg<='hffff_ffff__5812_0101_ffff_ffff;mdc_num<=6;end //4 100full duplex,802.3
:begin mdc_count<=mdc_count+; if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end
else begin mdc_num<=;mdc_count<=;end end
:begin mdio_reg<='hffff_ffff__5826__0400_ffff_ffff;mdc_num<=10;end //9自动主从,multi port device
:begin mdc_count<=mdc_count+; if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end else begin mdc_num<=;mdc_count<=;end end
:begin mdio_reg<='hffff_ffff__5842__0068_ffff_ffff;mdc_num<=14;end //16 power up
:begin mdc_count<=mdc_count+; if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end                else begin mdc_num<=;mdc_count<=;end end
2       :begin mdio_reg<='hffff_ffff__5852_9051_ffff_ffff;mdc_num<=18;end //9051
:begin mdc_count<=mdc_count+;if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end                  else begin mdc_num<=;mdc_count<=;end end
:begin mdio_reg<='hffff_ffff__5802_a100_ffff_ffff;mdc_num<=20;end
:begin mdc_count<=mdc_count+; if(mdc_count<)begin mdio<=mdio_reg[]; wr_rd<=;mdio_reg<=mdio_reg<<;mdc_num<=;end                  else begin mdc_num<=;mdc_count<= ;end end
:begin mdc_count<=mdc_count+;if(mdc_count<)begin mdio<='b1; wr_rd<=1;mdc_num<=21;end
else begin flag<=;wr_rd<=;end end
endcase       end
else
begin case(timenum)
:begin mdio_reg<='b11111111111111111111111111111111_01101000010001z1_zzzzzzzzzzzzzzzz_11111111111111111111111111111111;timenum<=1;wr_rd<=1;mdc_count<=0;end
:begin mdc_count<=mdc_count+; if(mdc_count<)begin mdio<=mdio_reg[]; mdio_reg<=mdio_reg<<;timenum<=;end else begin wr_rd<=;timenum<=;end end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
:begin data1[]<=mdio_in;timenum<=;end
 :begin data1[]<=mdio_in;mdc_count<=;timenum<=;end
:begin mdc_count<=mdc_count+;wr_rd<=;mdio<=;if(mdc_count=='h3f)mdc_count<=0;timenum<=0; end
endcase end

DE2-115 以太网通信之一88E1111网卡接收PC数据的更多相关文章

  1. ETH—Lwip以太网通信

    第39章     ETH—Lwip以太网通信 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...

  2. 第39章 ETH—Lwip以太网通信

    第39章     ETH—Lwip以太网通信 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...

  3. 第39章 ETH—Lwip以太网通信—零死角玩转STM32-F429系列

    第39章     ETH—Lwip以太网通信 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...

  4. S7-200系列PLC与WINCC以太网通信CP243i的实例

    S7-200系列PLC与WINCC以太网通信CP243i的实例 ----选用大连德嘉国际电子www.dl-winbest.cn的CP243i作为连接S7-200的PPI口转以太网RJ45的接口转换器. ...

  5. AB PLC与西门子S7-1200以太网通信

    前言:在项目实际应用中,经常会遇到两个不同厂家的PLC需要互联进行通信交换数据,由于各自的通信协议有所不同,实现起来的难度较大,通常的做法是借助第三方的网关.本文介绍的是AB PLC与西门子S7-12 ...

  6. C#串口通信—向串口发送数据,同步接收返回数据

    最近写C#串口通信程序,系统是B/S架构.SerialPort类有一个DataReceived事件,用来接收串口返回的数据,但这种方式在C/S架构下很好用,但B/S就不好处理了.所以写了一个同步模式接 ...

  7. C语言实现ifconfig获取网卡接收和发送流量统计

    在Windows下我们可以利用ipconfig命令获取网卡的相关信息,在Linux下命令是ifconfig 我们可以获取的信息更为丰富,其中包括网卡接收和发送的流量,用C语言实现这个命令并不是一件简单 ...

  8. TCP通信实现对接硬件发送与接收十六进制数据 & int与byte的转换原理 & java中正负数的表示

    今天收到的一份需求任务是对接硬件,TCP通信,并给出通信端口与数据包格式,如下: 1.首先编写了一个简单的十六进制转byte[]数组与byte[]转换16进制字符串的两个方法,如下: /** * 将十 ...

  9. 微信小程序UDP通信,注意点 接收 onMessage 收到的message是ArrayBuffer缓冲,不能直接输出,要另转String处理

    1.WXML 页面代码 <!--index.wxml--> <view class="container"> <view class="us ...

随机推荐

  1. UOJ208 UOIP十合一(提交答案)

    首先对每张图都去掉自环. 1:给出的就是DAG.答案即为2m. 2.5:显然每个SCC之间互相独立.这两个点都满足SCC中的点很少.于是对每个SCC暴力枚举边集判环,而SCC之间的边显然选不选没有影响 ...

  2. 不遮挡人物弹幕是怎么实现的——图片蒙版效果-webkit-mask

    这是一个实验中的功能,用于设置元素上遮罩层的图像. 一.Values none:默认值,透明的黑色图像层,也就是没有遮罩层. <mask-source>:<mask>或CSS图 ...

  3. 定时任务FluentScheduler

    1.Nuget 安装包 2.创建3个不同的任务 public class MyJob : IJob { void IJob.Execute() { Trace.WriteLine("现在时间 ...

  4. vue elment table根据返回值修改样式

    今天在写vue项目的时候,查询出的数据库的数据想根据条件修改显示.查询资料有一个 :formatter,可以实现这个效果,废话不多说,这个是我的例子: <el-table-column prop ...

  5. Linux 命令集锦

    linux 一切从根开始,一切皆文件~ 让我们从一些命令开始了解吧 基本命令 man  command:manual:查看命令帮助手册 ls:list:查看当前文件夹下的内容 -a 查看所有内容,包含 ...

  6. openmp 和 thread 性能实测

    #include <stdio.h> #include <iostream> #include <thread> #include<omp.h> //# ...

  7. 页面中的div居中

    div的居中 一.页面的水平居中 #article{ position: relative; margin: 0 auto; width: 80%; background-color: aquamar ...

  8. c#NPOI导出2007版本excel

    2003和2007版本区别: HSSFWorkbook(2003) IWorkbook(2007版本) 写完之后会有个问题,导出会报错[流已关闭]. NPOI生产.xlsx文件件时,在使用book.W ...

  9. 通用mapper的增删改查方法 留存 备忘

    Mybatis通用Mapper介绍与使用   前言 使用Mybatis的开发者,大多数都会遇到一个问题,就是要写大量的SQL在xml文件中,除了特殊的业务逻辑SQL之外,还有大量结构类似的增删改查SQ ...

  10. jmeter——http、jdbc、soap请求

    1.jmeter——http 请求 1.1添加线程组 1.2添加http请求 1.3发起http请求 1.协议:通常一个http请求都会有相对应的协议,如HTTP,HTTPS等.这里除非有特殊要求,一 ...