在一周多的时间,从软件的协议到芯片接口最后到硬件描述,我觉得是时候试一试芯片了,看一看能不能ping通。两天时间终于完成第一次ping,也挺不容易的。
首先想要ping通,要先知道ping是什么
它所利用的原理是这样的:利用网络上机器IP地址的唯一性,给目标IP地址发送一个数据包,再要求对方返回一个同样大小的数据包来确定两台网络机器是否连接相通,时延是多少。
而对于W5500能够ping通,官方博客的解释是这样:
W5500 若想Ping通的话需要保证以下2点:
1)物理信道通信正常:初步判定Link 灯及状态灯指示正常。
2)配置了W5500的IP,网关,子网掩码,MAC地址这些特殊寄存器
由于W5500内部硬件逻辑电路实现了ARP协议。所以,一旦收到ping包请求的话,会自动回复。以上的设置不过是为了保证基本信道及通讯能够建立的而已。
反向而言,如果Ping不通,也可以先从这两方面着手。
看上去并不是很难,如果想ping通的话只是需要配置好W5500的寄存器即可。
下面我们开始动手
器件选择basys2,开发环境ISE,以及野火的W5500网络扩展模块
根据W5500的说明书,我们通过SPI协议来完成与W5500的通信,共有SCSn,SCLK,MOSI,MISO4路信号,且作为SPI从机工作。其工作方式有可变长度模式和固定数据长度
SPI协议定义了四种工作模式,每种模式的区别就是根据SCLK的极性和相位不同。W5500支持SPI模式0及模式3,