0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MIMXRT1176AVM8A 1G以太网网络性能测试

li1756686189 来源:嵌入式 MCU 作者:嵌入式 MCU 2022-11-09 10:48 次阅读

之前使用I.MX6Q/I.MX6Q(imx_3.0.35_4.1.0), 1GB RGMII 以太网测试性能大概 495Mbits/sec, 如下是iperf测试过程。

iperf -c 192.168.0.112-u -b 800M -t 10 -l 1000

Client connecting to 192.168.112.125, UDP port 5002

Sending 1000 byte datagrams

UDP buffer size: 208 KByte (default)

[ 3] local 192.168.112.6 port 45230 connected with 192.168.112.125 port 5002

[ ID] Interval Transfer Bandwidth

[ 3] 0.0-10.0 sec 590 MBytes 495 Mbits/sec

[ 3] Sent 618437 datagrams

[ 3] WARNING: did not receive ack of last datagram after 10 tries.

读勘误手册 "Chip Errata for the i.MX 6",里面有如下描述ERR004512:

IMX6DQCE (nxp.com.cn) 确实和测试比较吻合。

085d7ac8-5f4a-11ed-8abf-dac502259ad0.png

08726b5e-5f4a-11ed-8abf-dac502259ad0.png

目前使用 MIMXRT1176AVM8A MCU 芯片内置的1G 以太网。

096c4a7a-5f4a-11ed-8abf-dac502259ad0.png

为了验证网络性能,使用Iperf 吞吐性能测试如下:硬件电路板——MIMXRT1170-EVK C2,软件包—— SDK_2.12.0-MIMXRT1170-EVK,下载链接如下。添加 iperf 代码到 lwip_ping_freertos_cm7中,使用flexspi nor sdram 调试。

0a27532e-5f4a-11ed-8abf-dac502259ad0.png

lwipopts.h文件需要做如下配置才能达到比较高的网络速率,如下是测试结果。

0a52aab0-5f4a-11ed-8abf-dac502259ad0.png

这些结果不完全相同,与主机操作系统也存在性能差异,不同的主机性能也存在显著差异。总体来讲 MIMXRT1176 MCU的 1G网络性能是没有I.MX6上面的速率限制的问题。

lwipopts.h 配置文件如下:

/** @file lwipopts.h

* This file is based on srcincludelwipopt.h*/

#ifndef __LWIPOPTS_H__

#define __LWIPOPTS_H__

#include "fsl_device_registers.h"

#if USE_RTOS

/*SYS_LIGHTWEIGHT_PROT==1: if you want inter-task protection for certain critical regions during buffer allocation, deallocation and memoryallocation and deallocation. */

#define SYS_LIGHTWEIGHT_PROT 1

/*NO_SYS==0: Use RTOS */

#define NO_SYS 0

/*LWIP_NETCONN==1: Enable Netconn API (require to use api_lib.c)*/

#define LWIP_NETCONN 1

/** LWIP_SOCKET==1: Enable Socket API (require to use sockets.c)*/

#define LWIP_SOCKET 1

/**LWIP_SO_RCVTIMEO==1: Enable receive timeout for sockets/netconns andSO_RCVTIMEO processing.*/

#define LWIP_SO_RCVTIMEO 1

#else

/** NO_SYS==1: Bare metal lwIP*/

#define NO_SYS 1

/*LWIP_NETCONN==0: Disable Netconn API (require to use api_lib.c)*/

#define LWIP_NETCONN 0

/** LWIP_SOCKET==0: Disable Socket API (require to use sockets.c)*/

#define LWIP_SOCKET 0

/** LWIP_ALLOW_MEM_FREE_FROM_OTHER_CONTEXT=1: we need to free PBUF_RAM pbufsfrom ISR context on LPC.*/

#if defined(FSL_FEATURE_SOC_LPC_ENET_COUNT) && (FSL_FEATURE_SOC_LPC_ENET_COUNT > 0)

#ifndef LWIP_ALLOW_MEM_FREE_FROM_OTHER_CONTEXT

#define LWIP_ALLOW_MEM_FREE_FROM_OTHER_CONTEXT 1

#endif

#endif

#endif

/* ---------- Core locking ---------- */

void sys_check_core_locking(void);

#define LWIP_ASSERT_CORE_LOCKED() sys_check_core_locking()

/* ---------- Memory options ---------- */

/**

* MEM_ALIGNMENT: should be set to the alignment of the CPU

* 4 byte alignment -> #define MEM_ALIGNMENT 4

* 2 byte alignment -> #define MEM_ALIGNMENT 2

*/

#ifndef MEM_ALIGNMENT

#define MEM_ALIGNMENT 4

#endif

/**

* MEM_SIZE: the size of the heap memory. If the application will send

* a lot of data that needs to be copied, this should be set high.

*/

#ifndef MEM_SIZE

#define MEM_SIZE (22 * 1024)

#endif

/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the applicationsends a lot of data out of ROM (or other static memory), this should be set high. */

#ifndef MEMP_NUM_PBUF

#define MEMP_NUM_PBUF ((TCP_WND + TCP_SND_BUF) / TCP_MSS)//15

#endif

/* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. Oneper active UDP "connection". */

#ifndef MEMP_NUM_UDP_PCB

#define MEMP_NUM_UDP_PCB 6

#endif

/* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP

connections. */

#ifndef MEMP_NUM_TCP_PCB

#define MEMP_NUM_TCP_PCB 10

#endif

/* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP

connections. */

#ifndef MEMP_NUM_TCP_PCB_LISTEN

#define MEMP_NUM_TCP_PCB_LISTEN 6

#endif

/* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP

segments. */

#ifndef MEMP_NUM_TCP_SEG

#define MEMP_NUM_TCP_SEG ((3 * TCP_SND_BUF) / TCP_MSS + 1)//22

#endif

/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active

timeouts. */

#ifndef MEMP_NUM_SYS_TIMEOUT

#define MEMP_NUM_SYS_TIMEOUT 10

#endif

/* ---------- Pbuf options ---------- */

/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */

#ifndef PBUF_POOL_SIZE

#define PBUF_POOL_SIZE 20//9

#endif

/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */

/* Default value is defined in lwipsrcincludelwipopt.h as

LWIP_MEM_ALIGN_SIZE(TCP_MSS+40+PBUF_LINK_ENCAPSULATION_HLEN+PBUF_LINK_HLEN)*/

/* ---------- TCP options ---------- */

#ifndef LWIP_TCP

#define LWIP_TCP 1

#endif

#ifndef TCP_TTL

#define TCP_TTL 255

#endif

/* Controls if TCP should queue segments that arrive out of

order. Define to 0 if your device is low on memory. */

#ifndef TCP_QUEUE_OOSEQ

#define TCP_QUEUE_OOSEQ 0

#endif

/* TCP Maximum segment size. */

#ifndef TCP_MSS

#define TCP_MSS (1500 - 40) /* TCP_MSS = (Ethernet MTU - IP header size - TCP header size) */

#endif

/* TCP sender buffer space (bytes). */

#ifndef TCP_SND_BUF

#define TCP_SND_BUF (40 * TCP_MSS)//(6 * TCP_MSS) // 2

#endif

/* TCP sender buffer space (pbufs). This must be at least = 2 *

TCP_SND_BUF/TCP_MSS for things to work. */

#ifndef TCP_SND_QUEUELEN

#define TCP_SND_QUEUELEN (3 * TCP_SND_BUF) / TCP_MSS // 6

#endif

/* TCP receive window. */

#ifndef TCP_WND

#define TCP_WND (20 * TCP_MSS)//(2 * TCP_MSS)

#endif

/* Enable backlog*/

#ifndef TCP_LISTEN_BACKLOG

#define TCP_LISTEN_BACKLOG 1

#endif

/* ---------- ICMP options ---------- */

#ifndef LWIP_ICMP

#define LWIP_ICMP 1

#endif

/* ---------- DHCP options ---------- */

/* Enable DHCP module. */

#ifndef LWIP_DHCP

#define LWIP_DHCP 1

#endif

/* ---------- UDP options ---------- */

#ifndef LWIP_UDP

#define LWIP_UDP 1

#endif

#ifndef UDP_TTL

#define UDP_TTL 255

#endif

/* ---------- Statistics options ---------- */

#ifndef LWIP_STATS

#define LWIP_STATS 0

#endif

#ifndef LWIP_PROVIDE_ERRNO

#define LWIP_PROVIDE_ERRNO 1

#endif

/*---------- Checksum options ----------

*/

/*Some MCU allow computing and verifying the IP, UDP, TCP and ICMP checksums by hardware:

- To use this feature let the following define uncommented.

- To disable it and process by CPU comment the the checksum.

*/

//#define CHECKSUM_BY_HARDWARE

#ifdef CHECKSUM_BY_HARDWARE

/* CHECKSUM_GEN_IP==0: Generate checksums by hardware for outgoing IP packets.*/

#define CHECKSUM_GEN_IP 0

/* CHECKSUM_GEN_UDP==0: Generate checksums by hardware for outgoing UDP packets.*/

#define CHECKSUM_GEN_UDP 0

/* CHECKSUM_GEN_TCP==0: Generate checksums by hardware for outgoing TCP packets.*/

#define CHECKSUM_GEN_TCP 0

/* CHECKSUM_CHECK_IP==0: Check checksums by hardware for incoming IP packets.*/

#define CHECKSUM_CHECK_IP 0

/* CHECKSUM_CHECK_UDP==0: Check checksums by hardware for incoming UDP packets.*/

#define CHECKSUM_CHECK_UDP 0

/* CHECKSUM_CHECK_TCP==0: Check checksums by hardware for incoming TCP packets.*/

#define CHECKSUM_CHECK_TCP 0

#else

/* CHECKSUM_GEN_IP==1: Generate checksums in software for outgoing IP packets.*/

#define CHECKSUM_GEN_IP 1

/* CHECKSUM_GEN_UDP==1: Generate checksums in software for outgoing UDP packets.*/

#define CHECKSUM_GEN_UDP 1

/* CHECKSUM_GEN_TCP==1: Generate checksums in software for outgoing TCP packets.*/

#define CHECKSUM_GEN_TCP 1

/* CHECKSUM_CHECK_IP==1: Check checksums in software for incoming IP packets.*/

#define CHECKSUM_CHECK_IP 1

/* CHECKSUM_CHECK_UDP==1: Check checksums in software for incoming UDP packets.*/

#define CHECKSUM_CHECK_UDP 1

/* CHECKSUM_CHECK_TCP==1: Check checksums in software for incoming TCP packets.*/

#define CHECKSUM_CHECK_TCP 1

#endif

/*DEFAULT_THREAD_STACKSIZE: The stack size used by any other lwIP thread.The stack size value itself is platform-dependent, but is passed tosys_thread_new() when the thread is created.*/

#ifndef DEFAULT_THREAD_STACKSIZE

#define DEFAULT_THREAD_STACKSIZE 3000

#endif

/*DEFAULT_THREAD_PRIO: The priority assigned to any other lwIP thread.The priority value itself is platform-dependent, but is passed tosys_thread_new() when the thread is created.*/

#ifndef DEFAULT_THREAD_PRIO

#define DEFAULT_THREAD_PRIO 3

#endif

#define LWIP_DEBUG

#ifdef LWIP_DEBUG

#define U8_F "c"

#define S8_F "c"

#define X8_F "02x"

#define U16_F "u"

#define S16_F "d"

#define X16_F "x"

#define U32_F "u"

#define S32_F "d"

#define X32_F "x"

#define SZT_F "u"

#endif

#define TCPIP_MBOX_SIZE 32

#define TCPIP_THREAD_STACKSIZE 1024

#define TCPIP_THREAD_PRIO 8

/*DEFAULT_RAW_RECVMBOX_SIZE: The mailbox size for the incoming packets on aNETCONN_RAW. The queue size value itself is platform-dependent, but is passedto sys_mbox_new() when the recvmbox is created.*/

#define DEFAULT_RAW_RECVMBOX_SIZE 12

/*DEFAULT_UDP_RECVMBOX_SIZE: The mailbox size for the incoming packets on aNETCONN_UDP. The queue size value itself is platform-dependent, but is passedto sys_mbox_new() when the recvmbox is created.*/

#define DEFAULT_UDP_RECVMBOX_SIZE 12

/*DEFAULT_TCP_RECVMBOX_SIZE: The mailbox size for the incoming packets on aNETCONN_TCP. The queue size value itself is platform-dependent, but is passedto sys_mbox_new() when the recvmbox is created. */

#define DEFAULT_TCP_RECVMBOX_SIZE 12

/**DEFAULT_ACCEPTMBOX_SIZE: The mailbox size for the incoming connections.The queue size value itself is platform-dependent, but is passed tosys_mbox_new() when the acceptmbox is created.*/

#define DEFAULT_ACCEPTMBOX_SIZE 12

#if (LWIP_DNS || LWIP_IGMP || LWIP_IPV6) && !defined(LWIP_RAND)

/* When using IGMP or IPv6, LWIP_RAND() needs to be defined to a random-function returning an u32_t random value*/

#include "lwip/arch.h"

u32_t lwip_rand(void);

#define LWIP_RAND() lwip_rand()

#endif

#endif /* __LWIPOPTS_H__ */

/*****END OF FILE****/

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    16019

    浏览量

    343657
  • 以太网
    +关注

    关注

    40

    文章

    5078

    浏览量

    166239
  • 性能测试
    +关注

    关注

    0

    文章

    189

    浏览量

    21213

原文标题:MIMXRT1176AVM8A 1G 以太网网络性能测试

文章出处:【微信号:嵌入式 MCU,微信公众号:嵌入式 MCU】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    千兆以太网网线线芯定义

    大家都知道100M或以下的以太网网线其实只需用到4根线芯,即1,2,3,6就行了,但是更高速率的以太网就必须用到8根线芯,有没有高手知道,8
    发表于 08-07 18:09

    以太网网关目前的趋势

    乘用车的以太网网关现在 哪家做的比较好,哪家的方案成熟
    发表于 03-28 21:42

    为什么ML402以太网1G传输时只有led100是绿色?

    大家好,我使用ML402板,想在这块板上测试1Gbps以太网。我使用TEMAC v4.5 IP Core及其附带的示例。首先,我通过这个IPCore测试100Mbps
    发表于 09-09 10:36

    Kintex XCKU040 SGMII 1G以太网同步顺序错误该怎么办?

    你好我有XCKU040定制板与DP83867类似于KCU116,VCU116连接sgmii 6wire。 (同步模式)我将1g pcs / pma ip core连接到三模式以太网ip核心。但在
    发表于 10-09 08:21

    是否可以用MIMXRT117H替换MIMXRT1176

    你好!有一个与视觉或语音处理无关的定制 PCB 和定制应用程序。PCB/应用专为 MIMXRT1176 而设计。但是这部分很难买到,而MIMXRT117H部分是可以买到
    发表于 04-18 07:03

    MIMXRT1175xxxxx是否像MIMXRT1176xxxxx一样支持多核启动?

    1- MIMXRT1175xxxxx 是否像 MIMXRT1176xxxxx 一样支持多核启动?例如,我们首先启动 CM7,使用 mcmgr 库启动 CM4。为什么 MIMXRT
    发表于 04-25 06:51

    MIMXRT1176DVMAA更改为MIMXRT1176AVM8A时出现的问题怎么解决?

    以前是1G,改的(MIMXRT1176AVM8A)是800M。 似乎没有太大的问题。 图形处理会不会有什么大问题?
    发表于 04-26 06:55

    嵌入式系统以太网网络接口卡的实现

    介绍了以10M/100M 自适应以太网控制器和DSP 为基础的嵌入式系统以太网网络接口卡(NIC) 的接口电路及软硬件实现方法。 当今社会己经进入数字信息技术和网络技术高速发展的后PC 时代,
    发表于 08-29 16:38 95次下载
    嵌入式系统<b class='flag-5'>以太网网络</b>接口卡的实现

    以太网行业趋势

    。而现在,大数据、云服务、人工智能、新媒体和VR正在进一步加速数据和流量的空前爆炸,推动互联网、数据中心和5G蜂窝网络不断采用更快的以太网网络速度。因此,对大容量以太网网络和组件的性能
    的头像 发表于 12-07 18:16 1853次阅读

    EE-214:ADSP-BF535 Blackfin®处理器的以太网网络接口

    EE-214:ADSP-BF535 Blackfin®处理器的以太网网络接口
    发表于 04-16 17:09 0次下载
    EE-214:ADSP-BF535 Blackfin®处理器的<b class='flag-5'>以太网网络</b>接口

    使用MIMXRT1176 MCU创建双核的C++应用项目工程

    MIMXRT1176, 1175,117H系列(工业级,消费级,汽车级)里面都具有双核模式Cortex M7和Cortex M4。芯片出厂默认是M7内核作为主核先启动,M4作为从核由主核激活启动
    的头像 发表于 10-27 09:38 1524次阅读

    MIMXRT1176支持8位列地址的SDRAM器件W9864G6

    MIMXRT1176的开发板配套的 SDRAM是W9825G6KH,对应的列地址是9位的。
    的头像 发表于 12-01 15:04 1293次阅读

    软件代码配置进入MIMXRT1176 ISP模式

    介绍通过软件代码IAP(In-Application Programming)进入MIMXRT1176的ISP模式,IMXRT1176 参考手册提到了IAP相关信息如下。
    的头像 发表于 01-30 09:24 859次阅读

    评测沃比得 W1000K千兆以太网测试性能

    沃比得 W1000K千兆以太网测试仪是一款手持式、掌上型10M/100M/1000M以太网测试,可用于以太网的安装、开通和维护周期。设计小巧
    的头像 发表于 01-30 13:16 141次阅读

    CANopen以太网网关怎么用?

    CANopen以太网网关怎么用? CANopen以太网网关是一种连接CANopen总线和以太网的设备,它提供了在CANopen网络以太网
    的头像 发表于 02-02 16:59 243次阅读