网口调试步骤_万兆光口和千兆光口对接

网口调试步骤_万兆光口和千兆光口对接千兆网口、光口调试总结配置6096端:工作模式的配置方式:1、 硬件配置,通过电阻上下拉确定;6096的硬件配置不可以错,其在portstatus寄存器状态中有相应的寄存器位体现硬件配置的工作模式。2、 软件配置,主要是配置链路层的工作模式。主要是设置PCS(Physicalcodingsublayer)寄存器。3、 Marvell的PHY芯片有个特性,叫P

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

千兆网口、光口调试总结

配置

6096端:

工作模式的配置方式:

1、  硬件配置,通过电阻上下拉确定;6096的硬件配置不可以错,其在port status寄存器状态中有相应的寄存器位体现硬件配置的工作模式。

2、  软件配置,主要是配置链路层的工作模式。主要是设置PCS(Physical coding sublayer)寄存器。

3、  Marvell的PHY芯片有个特性,叫PPU(phy polling unit),PPU会和外部连接的PHY交换其自身的link、speed、Duplex、Pause的信息,这样就可以发现PHY,直观的表现是如果外接了link的LED,那么LED会被点亮,只有在传输数据时link才会是闪烁的状态。如果没有连接上。不过有点奇怪的是,6096的port10配置成RGMII模式时,其LED并不能指示port10的工作状态,在1000BASE-X方式下,该LED才起作用。

 

ARM端:

配置MAC工作模式,通常:

1、  硬件部分通过电阻上下拉实现控制,MII、GMII、RGMII等接口方式是否由外接电阻上下拉某些管脚确定需要注意。

2、  软件部分对寄存器设置,这个配置方式可能能够代替上述1中的配置,也可能硬件必须配置,对MAC工作模式的配置方式依赖于芯片手册。

PCS层所处位置极其意义

网口调试步骤_万兆光口和千兆光口对接

1000BASE-X模式下PCS所在的OSI七层模型

PCS是物理编码子层,通过将8bit的数据编码成10bit发送给PMA(physical media attach)层,千兆编码方式是8B/10B,每个传送码元表示5符号-2-1012中的一个符号,故每个码元代表2比特信息(4电平中每个电平代表2位,还有一个前向纠错码FEC),这比二电平编码提高了带宽利用率,并能把波特率和所需信号带宽减为原来的一半,但多电平编码需要用多位A/D,D/A转换,采用更高的传输信噪比和更好的接受均衡性能。

下图是MAC和PHY连接的图,通常MAC集成在ARM核内,PHY是集成在switch中的。下面这张图是SGMII的连接方式和这里的RGMII方式还有区别。不过这张图展现了MAC,PHY以及PCS的关系。上面的6096的PPU用来发现其对等的PHY,通常是网线的另一头,但是也有PHY级联的情况,6096就可以级联88e1111使用。

网口调试步骤_万兆光口和千兆光口对接

SGMII下MAC和PHY连接方式–摘自思科文档

RGMII收发数据线各四根,其在时钟的上升沿和下降沿都会锁存数据,RGMII发送侧在时钟的上升沿锁存[0:3]低四位,在时钟的下降沿,锁存[4:7]高四位,速率计算125Mbps*(4+4)=1000Mbps,有效载荷会小于该值。接收类似,MAC和PHY侧都有接收和发送这样的概念存在。时序调节,就是调节这里的上下沿和数据的关系,只有正确的数据配合适当时序,传输时校验和才会正确。

调试过程:

1、确认环境,光端机需要使用千兆的,而不是百兆的,百兆光纤可以比百兆网络传输的距离要远很多,单模下可以达到20KM~120KM。光纤线线头保持洁净,不要让灰尘阻塞。

光模块分为,多模;对于多模注意收发的波长要对应,一般光模块上有蓝色和黄色,收发使用两种不同的颜色,即蓝色配黄色才行。多模光纤使用一根光纤线,光纤线上的光波长为1.31um和1.55um居多。

2、单板加电看6096的LED灯是否亮,如果有对等的PCS层(PHY芯片、switch芯片会包括PCS),灯会亮,port8/9工作在1000BASE-X等也会亮。

3、uboot下通过mii命令读取和适当调节6096上电初始PCS寄存器的参数。如果设置参数包括速率、双工模式、link状态以及时序调节,需要根据不同的模式进行不同的设置。

4、uboot下使用ping命令测试网络是否通。注意观察ping时光端机和6096上的LED指示灯,如果ping不通,但是6096的灯有闪烁,则不同转入5,调节6096的时序,如果等无反应也请转入无调节时序试试。如果ping时通时不通,请转入5.

5、uboot下使用mii命令,调节6096时序调节寄存器,包括收、发及其组合的四种可能,再次转入4,当各种可能均试过后,依然不行,转入6.

6、示波器测试在ubootping时6096收发端口有无信号,测量时钟信号和数据线信号。百兆时,时钟是25MHz,千兆时是125MHz。数据线上的信号对于千兆时五电平信道编码、对于百兆是三电平信道编码。三电平和五电平信道编码看它们的电平表现还是挺有意思的,一些示波器能够诱导外届设备发送测试信号。这里指的测试只需要看看总线上是否有电平跳变就可以了。如果有信号,重复步骤3读取6096的状态寄存器,以确认6096PCS寄存器设置是否正确。如果没有信号,检查6096设计原理图和PCB以及器件的焊接。如果没有问题转入7。

7、使用mr、mw命令修改ARM端GMAC相关配置寄存器。查看DMA和EMAC相关信息、统计收发数据包寄存器。重复4下的ping过程。如果还是不行。

8、检查ARM端的原理图、PCB、硬件上拉、下拉的配置。

9、Linux下该芯片驱动代码添加在drivers/net/phy/目录。修改相关Makefile和配置脚本,编译。

另外:如果光口热插拔出问题,即光模块在上电完成后拔下再插上出现网络不通,此时端口设置成自协商模式,可以解决此问题。

 iperf性能测试

不同的网络测试环境结果可能有所差异。

# ./iperf -c 10.12.39.18 -b 1000M -t 120 -i1 u

[  5]112.0-113.0 sec  41.4 MBytes   347 Mbits/sec

[  5]113.0-114.0 sec  41.4 MBytes   348 Mbits/sec

[  5]114.0-115.0 sec  41.4 MBytes   348 Mbits/sec

[  5]115.0-116.0 sec  42.1 MBytes   353 Mbits/sec

[  5]116.0-117.0 sec  42.5 MBytes   356 Mbits/sec

[  5]117.0-118.0 sec  42.3 MBytes   355 Mbits/sec

[  5]118.0-119.0 sec  42.3 MBytes   355 Mbits/sec

[ 5]  0.0-120.0 sec  4.94 GBytes  354 Mbits/sec

[  5]Sent 3608196 datagrams

[  5]Server Report:

[ 5]  0.0-120.0 sec  4.65 GBytes  333 Mbits/sec   0.069 ms 212912/3608194(5.9%)

 

ping包延迟

# ping 10.12.39.18

PING 10.12.39.18 (10.12.39.18): 56 databytes

64 bytes from 10.12.39.18: icmp_seq=0ttl=128 time=0.7 ms

某百兆PHY测试结果:

Tcp网速

后pc端 iperf  -s -i 1 -w 1M

先client端# ./iperf -c 10.12.39.18 –w nk –t 20 –i

 [ID] Interval       Transfer     Bandwidth

[ 5]  0.0-20.0 sec   225 MBytes 94.1 Mbits/sec

 

Udp网速

 

pc端先 iperf.exe -s -i 10 -u

先client端# ./iperf -c 10.12.39.18 -b 100M -t 20 -i 1-u

 [ID] Interval       Transfer     Bandwidth

[ 5]  0.0- 1.0 sec  11.6 MBytes 97.3 Mbits/sec

[ 5]  1.0- 2.0 sec  11.4 MBytes 95.7 Mbits/sec

[ 5]  2.0- 3.0 sec  11.3 MBytes 94.8 Mbits/sec

[ 5]  3.0- 4.0 sec  11.4 MBytes 95.7 Mbits/sec

[ 5]  4.0- 5.0 sec  11.4 MBytes 95.8 Mbits/sec

[  5]Sent 162892 datagrams

[  5]Server Report:

[ 5]  0.0-20.0 sec   223 MBytes 93.4 Mbits/sec   0.602 ms 3887/162891(2.4%)

[ 5]  0.0-20.0 sec  1 datagrams received out-of-order

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/194145.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 抽出SqlHelper

    抽出SqlHelper

    2021年12月14日
  • 【Custom Mutator Fuzz】AFL++自定义突变API「建议收藏」

    【Custom Mutator Fuzz】AFL++自定义突变API「建议收藏」前言其实这篇是临时加进来的,因为下一篇文章是libprotobuf+AFL++的内容,所以写的时候需要使用AFL++自定义突变的API,觉得还是需要单独写一篇API的介绍,一共十一个方法,也不是很多,下一篇文章就不再用大篇幅描述API了~编写不易,如果能够帮助到你,希望能够点赞收藏加关注哦Thanks♪(・ω・)ノPS:文章末尾有联系方式,交个朋友吧~本文链接:模糊测试系列往期回顾:【CustomMutatorFuzz】Libprotobuf+LibFuzzerCustomM.

  • Flowable 快速入门教程:Flowable 入门开发案例,结合流程设计器详细讲解

    Flowable 快速入门教程:Flowable 入门开发案例,结合流程设计器详细讲解Flowable快速入门教程:Flowable入门开发案例,结合流程设计器详细讲解前言流程设计器集成整体流程图项目结构流程部署启动流程流程节点说明第一审核人节点:实际设置审核人配置信息说明第二审核人:参数设置审核人配置信息说明第三审核人:参数分支判断与实际组配置配置信息说明h前言本文以一个简答的Demo为案例,按节点讲解,目的是为了让刚接触流程引擎的人能更快的熟悉流程引擎开发,了解业务…

  • 阴影样式的边框_html圆角边框底

    阴影样式的边框_html圆角边框底边框样式点线式边框破折线式边框直线式边框双线式边框槽线式边框脊线式边框内嵌效果的边框突起效果的边框边框样式点线式边框破折线式边框直线式边框双线式边框槽线式边框脊线式边框

  • Python自动化测试webdriver下载地址「建议收藏」

    Python自动化测试webdriver下载地址「建议收藏」主要浏览器WebDriver地址如下:Chrome:http://chromedriver.storage.proxy.ustclug.org/index.htmlFirefox:https://github.com/mozilla/geckodriver/releases/IE:http://selenium-release.storage.proxy.ustclug.org/index.htm…

  • cuda包卸载_之前安装过cuda卸载不彻底

    cuda包卸载_之前安装过cuda卸载不彻底不小心把/usr/local/cuda删除了,卸载cuda后安装cuda后/usr/local下没有cuda文件夹.运行:sudoapt-getautoremove–purgecuda

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号