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

    文章

    16983

    浏览量

    350224
  • 以太网
    +关注

    关注

    40

    文章

    5373

    浏览量

    171046
  • 性能测试
    +关注

    关注

    0

    文章

    205

    浏览量

    21304

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

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

收藏 人收藏

    评论

    相关推荐

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

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

    是否可以用MIMXRT117H替换MIMXRT1176

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

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

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

    BLADE和Voltaire推出高密度10Gb以太网网络方案

    高密度10Gb以太网网络方案(BLADE和Voltaire) BLADE和Voltaire携手推出了行业最高密度的10Gb 以太网数据中心交换网络。 基于Voltaire的Vant
    发表于 04-23 09:54 1354次阅读

    基于SOPC技术的嵌入式以太网网络终端设备解决方案设计详解

    近年来随着网络的快速发展,以太网因其宽带、扩展性强、组网灵活而成为应用最广泛的数据接入网络以太网网络终端设备是
    发表于 03-01 15:07 1292次阅读
    基于SOPC技术的嵌入式<b class='flag-5'>以太网网络</b>终端设备解决方案设计详解

    TE Connectivity推出工业以太网交换机 意图实现更快的千兆以太网网络

    全球连接与传感领域领军企业TE Connectivity (TE) 的功能强大且符合EN50155标准的以太网交换机采用 M12 连接,旨在实现更快、更可靠的千兆以太网网络。坚固耐用的设计与内置
    发表于 11-14 17:24 1268次阅读

    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支持8位列地址的SDRAM器件W9864G6

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

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

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

    如何使用1G/10G/25GSwitching以太网IP切换速率

    本文介绍1G/10G/25G Switching以太网IP的手动和自动两种切换速率的原理和方法
    的头像 发表于 07-10 16:29 1393次阅读
    如何使用<b class='flag-5'>1G</b>/10<b class='flag-5'>G</b>/25GSwitching<b class='flag-5'>以太网</b>IP切换速率

    基于PS和PL的1G/10G以太网解决方案应用笔记

    电子发烧友网站提供《基于PS和PL的1G/10G以太网解决方案应用笔记.pdf》资料免费下载
    发表于 09-15 10:29 3次下载
    基于PS和PL的<b class='flag-5'>1G</b>/10<b class='flag-5'>G</b><b class='flag-5'>以太网</b>解决方案应用笔记

    基于PS和PL的1G/10G以太网解决方案

    电子发烧友网站提供《基于PS和PL的1G/10G以太网解决方案.pdf》资料免费下载
    发表于 09-15 10:05 2次下载
    基于PS和PL的<b class='flag-5'>1G</b>/10<b class='flag-5'>G</b><b class='flag-5'>以太网</b>解决方案

    CANopen以太网网关怎么用?

    关的使用方法,包括其功能、配置和应用。 一、CANopen以太网网关的功能 CANopen以太网网关具有以下主要功能: 1. 数据传输:CANopen以太网网关可以实现CANopen
    的头像 发表于 02-02 16:59 3246次阅读

    NVIDIA Spectrum-X 以太网网络平台已被业界广泛使用

    平台已被业界广泛使用,并且将进一步加快新品发布计划。 Spectrum-X 是全球首款专为 AI 打造的以太网网络平台,可将生成式 AI 网络性能较传统以太网网络平台提升 1.6 倍。
    的头像 发表于 06-03 18:20 925次阅读

    以太网速率对网络性能的影响

    速率的历史发展 10Mbps以太网 :最早的以太网标准,适用于小型网络。 100Mbps快速以太网 :提高了数据传输速率,适用于更大的网络
    的头像 发表于 11-08 09:11 215次阅读