<RT1176系列8>ENET 基础以太网模块解读(MAC与PHY,寄存器配置表)

1、CPU/MAC/PHY 硬件架构

以太网是由CPU,MAC,PHY三部分组成的,常见有下列三种架构:

1.1 MAC 与 PHY集成在CPU中:

1.2 MAC集成在CPU中,而PHY 采用独立芯片:

1.3 MAC 和 PHY不集成在CPU 中,二者集成在同一芯片(形成独立的网卡):

2、MAC(Media Access Control,媒体访问控制层)

        MAC 属于 OSI 模型的数据链路层(第二层),主要负责数据帧的封装 / 解封装、协议规则执行和主机与 PHY 的交互。通过 MII 等接口与 PHY 交互,是数据链路层的核心。

3、PHY(Physical Layer,物理层)

        PHY 属于 OSI 模型的物理层(第一层),主要负责信号的电 / 光转换、信号驱动与接收、物理介质适配,是数据与物理网络(如网线、光纤)的直接接口。将 MAC 传来的数字信号转换为物理介质(如网线)可传输的电 / 光信号(发送时),或反之将接收的物理信号还原为数字信号(接收时),同时提供速率适配、信号调制解调等物理层功能。

4、MAC 与 PHY 的连接

        MAC 与 PHY 通过标准化接口(如 MII、RMII、RGMII)通信,接口定义了数据、时钟和控制信号(如发送使能、接收准备)。

5、MAC 与 PHY 的接口类型

接口类型时钟信号特点应用场景
MII发送时钟(TX_CLK)和接收时钟(RX_CLK),均由 PHY 提供,100Mbps 速率下为 25MHz,10Mbps 速率下为 2.5MHz接口共 16 根线,兼容 10/100M 以太网,信号较为全面,但引脚数较多早期 10/100M 以太网设备
RMII参考时钟(CLK_REF),由外部时钟源提供,频率为 50MHz引脚数目比 MII 大为减少,MAC 和 PHY 共用一个参考时钟,接口距离不能太远高密端口 PHY,适用于对引脚数量有要求的 10/100M 以太网设备
SMII参考时钟和同步信号,MAC 和 PHY 共用一个参考时钟管脚更少,但接口距离受限对引脚数量要求苛刻的 10/100M 以太网设备
SSMII收发采用单独的时钟和同步信号相对于 SMII,虽然增加了两个管脚,但接口之间的传输距离可以更远对引脚数量有要求且需要较远传输距离的 10/100M 以太网设备
GMII发送参考时钟(GTX_CLK)由 MAC 提供,接收时钟(RX_CLK)由 PHY 提供,频率均为 125MHz支持 1000Mbps 速率,数据位宽扩展为 8 位,时钟频率提升千兆以太网设备
RGMII参考时钟(REF_CLK),由外部提供,频率为 125MHz是 GMII 的简化版,引脚数量减少千兆以太网设备,对引脚数量有要求的场景
SGMII采用串行方式传输,有独立的发送和接收时钟基于 GMII,将数据信号串行化,可实现更远距离的传输千兆以太网设备,需要长距离传输的场景

6、ENET寄存器配置表:
 

偏移量寄存器名称位宽访问方式复位值功能解读
4hInterrupt Event Register (EIR)32RW0000_0000h中断事件的硬件状态映射寄存器,每一位对应特定中断源的触发标识。需通过软件读取并清零(写1清0),用于中断服务程序中快速定位触发源,优化中断响应效率。
8hInterrupt Mask Register (EIMR)32RW0000_0000h中断使能掩码寄存器,与EIR位域一一对应。置位允许对应中断触发,清零屏蔽。在嵌入式系统初始化时需根据实际需求配置,避免无关中断占用CPU资源。
10hReceive Descriptor Active Register - Ring 0 (RDAR)32RW0000_0000h管理接收描述符环0的激活状态,记录当前已分配但未完成处理的描述符数量。硬件通过此寄存器跟踪描述符使用情况,软件需配合更新以实现无锁化 descriptors 管理。
14hTransmit Descriptor Active Register - Ring 0 (TDAR)32RW0000_0000h控制发送描述符环0的激活状态,标识待发送队列中有效描述符的数量。用于硬件调度发送任务,软件需在填充描述符后更新此值,触发发送引擎工作。
24hEthernet Control Register (ECR)32RW7000_0000hMAC核心控制寄存器,包含复位、使能、工作模式(全双工/半双工)等关键配置位。复位值7000_0000h通常对应默认硬件配置,初始化时需根据PHY协商结果重新配置。
40hMII Management Frame Register (MMFR)32RW0000_0000hMII总线管理接口的数据寄存器,用于PHY寄存器读写操作。需配合SMI时序,通过此寄存器传输PHY地址、寄存器地址及数据,实现链路状态配置与查询。
44hMII Speed Control Register (MSCR)32RW0000_0000h配置MII接口的时钟频率及时序参数,支持10/100/1000Mbps速率适配。需根据PHY支持的速率等级配置,确保MAC与PHY之间的管理通信可靠。
64hMIB Control Register (MIBC)32RWC000_0000h管理信息库(MIB)统计控制寄存器,用于使能/禁用各类流量统计计数器。复位值C000_0000h通常对应默认使能关键统计项,调试阶段可全开,量产时按需关闭以降低硬件开销。
84hReceive Control Register (RCR)32RW05EE_0001h接收功能核心配置寄存器,包含过滤模式(单播/多播/广播)、帧长限制、校验使能等。复位值05EE_0001h对应默认接收配置,需根据应用场景(如是否需要接收所有帧)调整。
C4hTransmit Control Register (TCR)32RW0000_0000h发送功能核心配置寄存器,控制发送使能、CRC生成、流量控制等。默认值0000_0000h为禁用状态,初始化时需置位使能位,并配置与接收端匹配的流量控制策略。
E4hPhysical Address Lower Register (PALR)32RW0000_0000h存储MAC物理地址的低32位(4字节),与PAUR共同构成6字节MAC地址。初始化时需写入唯一的硬件地址,用于接收帧的地址过滤,确保只接收目标为本机的帧。
E8hPhysical Address Upper Register (PAUR)32RW0000_8808h存储MAC物理地址的高16位(2字节),复位值0000_8808h为默认厂商地址片段,实际应用中需替换为分配的唯一地址。
EChOpcode/Pause Duration Register (OPD)32RW0001_0000h配置流量控制帧的操作码和暂停时长,用于全双工模式下的XON/XOFF帧生成。默认值0001_0000h对应标准暂停时长,需根据网络负载调整,避免过度暂停导致吞吐量下降。
F0h - F8hTransmit Interrupt Coalescing Register (TXIC0 - TXIC2)32RW0000_0000h发送中断聚合配置寄存器,控制中断触发的帧计数阈值和时间阈值。通过设置合理的聚合参数(如累计N帧或超时T后触发一次中断),减少CPU中断响应次数,提升系统性能。
100h - 108hReceive Interrupt Coalescing Register (RXIC0 - RXIC2)32RW0000_0000h接收中断聚合配置寄存器,功能类似TXIC,针对接收路径优化。在高流量场景下,适当增大聚合阈值可显著降低中断开销,但会增加接收延迟,需权衡配置。
118hDescriptor Individual Upper Address Register (IAUR)32RW0000_0000h独立描述符的高32位地址寄存器,用于指定单个特殊描述符的内存位置。通常用于异常帧处理或优先级队列,需与IALR配合使用,指向连续的内存空间。
11ChDescriptor Individual Lower Address Register (IALR)32RW0000_0000h独立描述符的低32位地址寄存器,与IAUR组成32位或64位地址(取决于CPU架构),指向描述符在内存中的物理地址(需考虑MMU映射)。
120hDescriptor Group Upper Address Register (GAUR)32RW0000_0000h描述符组的高32位起始地址,用于指定描述符环的基地址高位。描述符环需分配在连续物理内存中,且按缓存行对齐,以提高DMA访问效率。
124hDescriptor Group Lower Address Register (GALR)32RW0000_0000h描述符组的低32位起始地址,与GAUR共同定义描述符环的基地址。初始化时需确保地址对齐正确,避免DMA访问未对齐地址导致的性能损失或错误。
144hTransmit FIFO Watermark Register (TFWR)32RW0000_0000h设置发送FIFO的水印阈值,当FIFO中数据量低于此值时触发DMA请求,补充发送数据。需根据发送速率和CPU处理能力配置,避免FIFO空导致的发送中断。
160hReceive Descriptor Ring 1 Start Register (RDSR1)32RW0000_0000h接收描述符环1的起始地址寄存器,用于多队列接收场景,实现不同类型帧的分类处理(如优先级队列)。需与RDSR0、RDSR2配合,分配独立的内存区域。
164hTransmit Buffer Descriptor Ring 1 Start Register (TDSR1)32RW0000_0000h发送描述符环1的起始地址寄存器,支持多队列发送,可用于QoS(服务质量)实现,按优先级调度不同队列的帧发送。
168hMaximum Receive Buffer Size Register - Ring 1 (MRBR1)32RW0000_0000h限制接收描述符环1的最大缓冲区大小,防止超大帧占用过多内存。需根据应用中预期接收的最大帧长配置,通常不超过MTU(如1500字节)。
16ChReceive Descriptor Ring 2 Start Register (RDSR2)32RW0000_0000h接收描述符环2的起始地址寄存器,功能同RDSR1,用于扩展多队列接收能力,适应复杂场景下的帧分类需求。
170hTransmit Buffer Descriptor Ring 2 Start Register (TDSR2)32RW0000_0000h发送描述符环2的起始地址寄存器,扩展多队列发送能力,支持更精细的QoS控制。
174hMaximum Receive Buffer Size Register - Ring 2 (MRBR2)32RW0000_0000h接收描述符环2的最大缓冲区大小限制,配置原则同MRBR1,根据环2处理的帧类型设置合适值。
180hReceive Descriptor Ring 0 Start Register (RDSR)32RW0000_0000h接收描述符环0的起始地址寄存器,默认接收队列,通常用于处理常规流量,需优先配置以保证基本通信功能。
184hTransmit Buffer Descriptor Ring 0 Start Register (TDSR)32RW0000_0000h发送描述符环0的起始地址寄存器,默认发送队列,用于常规数据发送,初始化时需首先配置此寄存器。
188hMaximum Receive Buffer Size Register - Ring 0 (MRBR)32RW0000_0000h接收描述符环0的最大缓冲区大小,通常设置为MTU值
190hReceive FIFO Section Full Threshold (RSFL)32RW0000_0000h接收FIFO分区满阈值,当对应分区数据量达到阈值时触发状态指示。用于FIFO分区管理,实现精细化的流量控制。
194hReceive FIFO Section Empty Threshold (RSEM)32RW0000_0000h接收FIFO分区空阈值,当对应分区数据量低于阈值时触发状态指示,用于触发数据读取操作。
198hReceive FIFO Almost Empty Threshold (RAEM)32RW0000_0004h接收FIFO近空阈值,默认值4字节,用于提前预警FIFO数据量过低,便于CPU及时准备接收新数据。
19ChReceive FIFO Almost Full Threshold (RAFL)32RW0000_0004h接收FIFO近满阈值,默认值4字节,用于提前预警FIFO数据量过高,触发CPU及时读取数据,避免FIFO溢出。
1A0hTransmit FIFO Section Empty Threshold (TSEM)32RW0000_0000h发送FIFO分区空阈值,当对应分区数据量低于阈值时触发状态指示,用于触发数据填充操作。
1A4hTransmit FIFO Almost Empty Threshold (TAEM)32RW0000_0004h发送FIFO近空阈值,默认值4字节,用于提前预警发送数据不足,触发CPU及时填充数据,避免发送中断。
1A8hTransmit FIFO Almost Full Threshold (TAFL)32RW0000_0008h发送FIFO近满阈值寄存器,默认8字节。当数据量达到此值时触发状态指示,用于限制FIFO填充深度,预留缓冲空间应对突发流量,防止FIFO溢出导致的数据丢失。
1AChTransmit Inter-Packet Gap (TIPG)32RW0000_000Ch发送帧间隔寄存器,默认12字节。配置以太网帧之间的最小发送间隔,需符合IEEE 802.3标准(100Mbps对应96bit时间),确保接收方有足够处理时间,避免帧冲突。
1B0hFrame Truncation Length (FTRL)32RW0000_07FFh帧截断长度寄存器,默认2047字节。超过此值的发送帧将被截断,适用于特殊场景下的帧大小限制,需注意截断可能导致接收方CRC校验失败。
1C0hTransmit Accelerator Function Configuration (TACC)32RW0000_0000h发送加速器配置寄存器,控制硬件加速功能(如校验和生成、TCP分段)。默认禁用,高吞吐量场景下开启可显著降低CPU负载,但需确保与协议栈适配。
1C4hReceive Accelerator Function Configuration (RACC)32RW0000_0000h接收加速器配置寄存器,控制接收硬件加速(如校验和验证、VLAN剥离)。默认禁用,开启后由硬件完成部分协议处理,减少中断响应时间,提升接收性能。
1C8h - 1CChReceive Classification Match Register for Class n (RCMR1 - RCMR2)32RW0000_0000h接收分类匹配寄存器,定义多队列接收的帧分类规则(如MAC地址、IP优先级)。通过掩码与模式匹配,实现帧到不同接收队列的定向分发,支持精细化流量管理。
1D8h - 1DChDMA Class Based Configuration (DMA1CFG - DMA2CFG)32RW0000_0000hDMA分类配置寄存器,为不同流量类别配置独立DMA参数(优先级、缓存策略)。支持基于业务的DMA资源调度,确保高优先级流量的传输时延,适用于QoS场景。
1E0hReceive Descriptor Active Register - Ring 1 (RDAR1)32RW0000_0000h接收描述符环1激活寄存器,管理环1中已分配未处理的描述符数量。与RDAR(环0)功能一致,用于多队列接收的独立管理,需确保与软件描述符管理逻辑同步。
1E4hTransmit Descriptor Active Register - Ring 1 (TDAR1)32RW0000_0000h发送描述符环1激活寄存器,标识环1中待发送的有效描述符数量。硬件发送完成后自动递减,软件填充后需更新此值触发发送,实现多队列发送的并行调度。
1E8hReceive Descriptor Active Register - Ring 2 (RDAR2)32RW0000_0000h接收描述符环2激活寄存器,扩展多队列接收能力,适用于三队列以上的复杂流量分类场景,配置原则同RDAR1。
1EChTransmit Descriptor Active Register - Ring 2 (TDAR2)32RW0000_0000h发送描述符环2激活寄存器,扩展多队列发送能力,支持更精细的QoS分级,需与调度算法配合实现优先级抢占。
1F0hQOS Scheme (QOS)32RW0000_0000h服务质量策略寄存器,配置优先级映射规则(如DSCP到硬件队列)。支持802.1p等优先级机制,确保关键业务的传输质量,需与网络拓扑中的QoS策略一致。
204hTx Packet Count Statistic Register (RMON_T_PACKETS)32R0000_0000h发送数据包计数寄存器(RMON标准),累计发送的总帧数(含错误帧)。只读,需软件定期读取清零,用于网络流量监控与带宽计算,支持SNMP等管理协议。
208hTx Broadcast Packets Statistic Register (RMON_T_BC_PKT)32R0000_0000h发送广播帧计数寄存器,累计发送的广播帧数。异常增长可能导致广播风暴,需在管理软件中设置阈值告警,避免网络拥塞。
20ChTx Multicast Packets Statistic Register (RMON_T_MC_PKT)32R0000_0000h发送多播帧计数寄存器,累计发送的多播帧数。用于评估多播业务的流量占比,优化组播路由配置。
210hTx Packets with CRC/Align Error Statistic Register (RMON_T_CRC_ALIGN)32R0000_0000h发送CRC/对齐错误帧计数寄存器,累计发送时出现CRC错误或帧对齐错误的帧数。非零值通常指示硬件故障(如PHY连接问题),需及时诊断。
214hTx Packets Less Than 64 Bytes and Good CRC Statistic Register (RMON_T_UNDERSIZE)32R0000_0000h发送小于64字节且CRC正确帧计数寄存器,累计短有效帧。过多短帧可能影响传输效率,需检查应用层是否存在不合理的小数据包发送。
218hTx Packets GT MAX_FL bytes and Good CRC Statistic Register (RMON_T_OVERSIZE)32R0000_0000h发送超长有效帧计数寄存器,累计超过最大帧长(MAX_FL)且CRC正确的帧。通常对应巨型帧(Jumbo Frame),需确保接收端支持,否则会被丢弃。
21ChTx Packets Less Than 64 Bytes and Bad CRC Statistic Register (RMON_T_FRAG)32R0000_0000h发送小于64字节且CRC错误帧计数寄存器,累计短错误帧(碰撞碎片)。半双工模式下常见,过多则指示信道竞争激烈,需考虑升级为全双工。
220hTx Packets Greater Than MAX_FL bytes and Bad CRC Statistic Register (RMON_T_JAB)32R0000_0000h发送超长错误帧计数寄存器,累计超过MAX_FL且CRC错误的帧(Jabber帧)。通常由硬件故障导致,需检查PHY与MAC的时钟同步。
224hTx Collision Count Statistic Register (RMON_T_COL)32R0000_0000h发送碰撞计数寄存器,累计发送过程中的碰撞次数。仅半双工模式有效,碰撞率过高(如超过5%)需优化网络拓扑。
228hTx 64-Byte Packets Statistic Register (RMON_T_P64)32R0000_0000h发送64字节帧计数寄存器,按帧长分布统计流量特征。用于分析应用层数据包大小分布,优化MTU配置。
22ChTx 65- to 127-byte Packets Statistic Register (RMON_T_P65TO127)32R0000_0000h发送65-127字节帧计数寄存器,属于帧长分布统计的一部分,用于网络流量模型分析。
230hTx 128- to 255-byte Packets Statistic Register (RMON_T_P128TO255)32R0000_0000h发送128-255字节帧计数寄存器,帧长分布统计,帮助评估网络承载的业务类型(如控制报文、数据报文)。
234hTx 256- to 511-byte Packets Statistic Register (RMON_T_P256TO511)32R0000_0000h发送256-511字节帧计数寄存器,帧长分布统计,用于流量特征分析与带宽规划。
238hTx 512- to 1023-byte Packets Statistic Register (RMON_T_P512TO1023)32R0000_0000h发送512-1023字节帧计数寄存器,帧长分布统计,反映中等大小数据包的占比。
23ChTx 1024- to 2047-byte Packets Statistic Register (RMON_T_P1024TO2047)32R0000_0000h发送1024-2047字节帧计数寄存器,帧长分布统计,常用于评估大数据包传输比例。
240hTx Packets Greater Than 2048 Bytes Statistic Register (RMON_T_P_GTE2048)32R0000_0000h发送大于2048字节帧计数寄存器,累计巨型帧发送量。需确保整个网络路径支持巨型帧,否则会导致分片或丢弃。
244hTx Octets Statistic Register (RMON_T_OCTETS)32R0000_0000h发送字节计数寄存器,累计发送的总字节数(含帧头)。用于计算发送带宽利用率(字节数/时间),评估网络负载。
24ChFrames Transmitted OK Statistic Register (IEEE_T_FRAME_OK)32R0000_0000h发送成功帧计数寄存器(IEEE标准),累计所有成功发送的有效帧(不含错误帧)。用于评估发送链路的有效性和数据传输成功率。
250hFrames Transmitted with Single Collision Statistic Register (IEEE_T_1COL)32R0000_0000h单次碰撞后发送成功帧计数寄存器,累计经历一次碰撞后成功发送的帧数。反映半双工模式下信道竞争程度,数值过高表明网络负载较重。
254hFrames Transmitted with Multiple Collisions Statistic Register (IEEE_T_MCOL)32R0000_0000h多次碰撞后发送成功帧计数寄存器,累计经历多次碰撞后成功发送的帧数。该值与总发送帧数的比例可用于评估网络冲突严重性。
258hFrames Transmitted after Deferral Delay Statistic Register (IEEE_T_DEF)32R0000_0000h延迟发送帧计数寄存器,累计因检测到信道忙而延迟发送的帧数。半双工模式下正常存在,比例过高表明网络拥堵。
25ChFrames Transmitted with Late Collision Statistic Register (IEEE_T_LCOL)32R0000_0000h晚期碰撞帧计数寄存器,累计发送过程中发生晚期碰撞(超过64字节后)的帧数。通常因线缆过长或硬件故障导致,需检查物理层连接。
260hFrames Transmitted with Excessive Collisions Statistic Register (IEEE_T_EXCOL)32R0000_0000h过多碰撞丢弃帧计数寄存器,累计因碰撞次数超过16次上限而丢弃的帧数。表明网络严重拥堵或存在故障,需优化网络拓扑。
264hFrames Transmitted with Tx FIFO Underrun Statistic Register (IEEE_T_MACERR)32R0000_0000h发送FIFO下溢错误帧计数寄存器,累计因FIFO数据不足导致发送失败的帧数。需调整TAEM阈值或优化CPU填充速度,避免传输中断。
268hFrames Transmitted with Carrier Sense Error Statistic Register (IEEE_T_CSERR)32R0000_0000h载波检测错误帧计数寄存器,累计发送时载波检测异常的帧数。通常指示PHY故障或链路质量问题,需进行硬件诊断。
26ChReserved Statistic Register (IEEE_T_SQE)32R0000_0000h预留统计寄存器,原用于SQE(信号质量错误)测试,现代以太网控制器中通常未使用,值恒为0。
270hFlow Control Pause Frames Transmitted Statistic Register (IEEE_T_FDXFC)32R0000_0000h发送流量控制暂停帧计数寄存器,累计发送的802.3x PAUSE帧数量。用于评估流量控制机制的活跃度,反映接收端的负载状态。
274hOctet Count for Frames Transmitted w/o Error Statistic Register (IEEE_T_OCTETS_OK)32R0000_0000h发送无错字节计数寄存器,累计成功发送的有效字节数(不含错误帧)。用于计算实际有效带宽利用率,评估传输效率。
284hRx Packet Count Statistic Register (RMON_R_PACKETS)32R0000_0000h接收数据包计数寄存器(RMON标准),累计接收的总帧数(含错误帧)。只读,需定期读取清零,用于接收流量监控与带宽计算。
288hRx Broadcast Packets Statistic Register (RMON_R_BC_PKT)32R0000_0000h接收广播帧计数寄存器,累计接收的广播帧数。异常增长可能预示广播风暴,需配置适当的广播过滤策略。
28ChRx Multicast Packets Statistic Register (RMON_R_MC_PKT)32R0000_0000h接收多播帧计数寄存器,累计接收的多播帧数。用于评估多播组加入情况和组播流量占比,优化组播过滤配置。
290hRx Packets with CRC/Align Error Statistic Register (RMON_R_CRC_ALIGN)32R0000_0000h接收CRC/对齐错误帧计数寄存器,累计接收时出现CRC错误或帧对齐错误的帧数。高数值表明链路质量差或存在物理层故障。
294hRx Packets with Less Than 64 Bytes and Good CRC Statistic Register (RMON_R_UNDERSIZE)32R0000_0000h接收小于64字节且CRC正确帧计数寄存器,累计短有效帧。过多可能表明存在异常流量或配置错误(如MTU设置过小)。
298hRx Packets Greater Than MAX_FL and Good CRC Statistic Register (RMON_R_OVERSIZE)32R0000_0000h接收超长有效帧计数寄存器,累计超过最大帧长且CRC正确的帧。需确认本地控制器是否启用巨型帧支持,否则会被丢弃。
29ChRx Packets Less Than 64 Bytes and Bad CRC Statistic Register (RMON_R_FRAG)32R0000_0000h接收小于64字节且CRC错误帧计数寄存器,累计短错误帧(碰撞碎片)。主要来自半双工网络,反映网络冲突情况。
2A0hRx Packets Greater Than MAX_FL Bytes and Bad CRC Statistic Register (RMON_R_JAB)32R0000_0000h接收超长错误帧计数寄存器,累计超过最大帧长且CRC错误的帧(Jabber帧)。通常由故障设备发送,需定位并排除故障节点。
2A8hRx 64-Byte Packets Statistic Register (RMON_R_P64)32R0000_0000h接收64字节帧计数寄存器,按帧长分布统计接收流量特征。用于分析应用层数据包大小模式,优化接收缓冲区配置。
2AChRx 65- to 127-Byte Packets Statistic Register (RMON_R_P65TO127)32R0000_0000h接收65-127字节帧计数寄存器,帧长分布统计的一部分,帮助分析网络中控制报文与数据报文的比例。
2B0hRx 128- to 255-Byte Packets Statistic Register (RMON_R_P128TO255)32R0000_0000h接收128-255字节帧计数寄存器,反映中等偏小数据包的接收比例,用于优化接收FIFO和缓冲区大小。
2B4hRx 256- to 511-Byte Packets Statistic Register (RMON_R_P256TO511)32R0000_0000h接收256-511字节帧计数寄存器,帧长分布统计,用于评估中等大小数据的传输需求。
2B8hRx 512- to 1023-Byte Packets Statistic Register (RMON_R_P512TO1023)32R0000_0000h接收512-1023字节帧计数寄存器,反映中等大小数据包的接收占比,用于缓冲区资源分配优化。
2BChRx 1024- to 2047-Byte Packets Statistic Register (RMON_R_P1024TO2047)32R0000_0000h接收1024-2047字节帧计数寄存器,累计较大数据包的接收量,用于评估大数据传输需求。
2C0hRx Packets Greater than 2048 Bytes Statistic Register (RMON_R_P_GTE2048)32R0000_0000h接收大于2048字节帧计数寄存器,累计接收的巨型帧数量。需确保本地MAC已启用巨型帧支持,否则这些帧会被丢弃。
2C4hRx Octets Statistic Register (RMON_R_OCTETS)32R0000_0000h接收字节计数寄存器,累计接收的总字节数(含帧头和错误帧)。用于计算接收带宽利用率,评估网络接收负载。
2C8hFrames not Counted Correctly Statistic Register (IEEE_R_DROP)32R0000_0000h计数错误丢弃帧寄存器,累计因内部错误未被正确计数的帧数。非零值通常指示硬件故障或严重的资源竞争,需诊断。
2CChFrames Received OK Statistic Register (IEEE_R_FRAME_OK)32R0000_0000h接收成功帧计数寄存器(IEEE标准),累计所有正确接收的有效帧。用于评估接收链路的有效性和数据接收成功率。
2D0hFrames Received with CRC Error Statistic Register (IEEE_R_CRC)32R0000_0000h接收CRC错误帧计数寄存器,累计CRC校验失败的接收帧。高数值表明链路质量差、存在干扰或物理层故障。
2D4hFrames Received with Alignment Error Statistic Register (IEEE_R_ALIGN)32R0000_0000h接收对齐错误帧计数寄存器,累计帧长度不是整数个字节的错误帧。通常由物理层同步问题或干扰导致。
2D8hReceive FIFO Overflow Count Statistic Register (IEEE_R_MACERR)32R0000_0000h接收FIFO溢出计数寄存器,累计因FIFO满导致丢失的帧数。需调整接收FIFO阈值或优化CPU/DMA读取速度,避免数据丢失。
2DChFlow Control Pause Frames Received Statistic Register (IEEE_R_FDXFC)32R0000_0000h接收流量控制暂停帧计数寄存器,累计接收的802.3x PAUSE帧数量。用于评估远程节点的流量控制需求,反映网络负载状况。
2E0hOctet Count for Frames Received without Error Statistic Register (IEEE_R_OCTETS_OK)32R0000_0000h接收无错字节计数寄存器,累计成功接收的有效字节数(不含错误帧)。用于计算实际有效接收带宽,评估接收链路效率。
400hAdjustable Timer Control Register (ATCR)32RW0000_0000h可调定时器控制寄存器,配置定时器的工作模式(自由运行/周期性)、中断使能等。默认禁用状态,需根据时间戳或定时需求配置。
404hTimer Value Register (ATVR)32RW0000_0000h定时器当前值寄存器,可读可写。读取返回当前计数值,写入可直接设置定时器值,用于同步或校准操作。
408hTimer Offset Register (ATOFF)32RW0000_0000h定时器偏移寄存器,用于设置时间戳的偏移量。可用于网络时钟同步,校准本地时间与网络时间的偏差。
40ChTimer Period Register (ATPER)32RW3B9A_CA00h定时器周期寄存器,默认值对应1秒(3B9ACA00h = 1,000,000,000)。配置周期性定时器的溢出周期,用于产生固定间隔的定时中断。
410hTimer Correction Register (ATCOR)32RW0000_0000h定时器校正寄存器,用于微调定时器频率。可补偿硬件时钟偏差,提高时间戳精度,适用于精确时间同步场景。
414hTime-Stamping Clock Period Register (ATINC)32RW0000_0000h时间戳时钟周期寄存器,配置时间戳计数器的增量值。根据系统时钟频率设置,确保时间戳单位准确(通常为纳秒)。
418hTimestamp of Last Transmitted Frame (ATSTMP)32R0000_0000h最后发送帧时间戳寄存器,记录最近一次帧发送完成的时间戳。用于计算传输时延、RTT等网络性能指标。
604hTimer Global Status Register (TGSR)32RW0000_0000h定时器全局状态寄存器,汇总所有定时器的状态标志(如溢出、比较匹配)。支持全局中断状态查询与清除,简化中断处理逻辑。
608hTimer Control Status Register (TCSR0)32RW0000_0000h定时器0控制状态寄存器,配置定时器0的工作模式、中断使能,并反映其当前状态。独立控制第一路定时器资源。
60ChTimer Compare Capture Register (TCCR0)32RW0000_0000h定时器0比较捕获寄存器,设置比较匹配值或捕获当前计数值。用于产生精确的时间间隔中断或记录外部事件发生时间。
610hTimer Control Status Register (TCSR1)32RW0000_0000h定时器1控制状态寄存器,功能同TCSR0,独立控制第二路定时器资源,可实现与定时器0不同的定时需求。
614hTimer Compare Capture Register (TCCR1)32RW0000_0000h定时器1比较捕获寄存器,功能同TCCR0,与TCSR1配合使用,实现第二路定时器的比较或捕获功能。
618hTimer Control Status Register (TCSR2)32RW0000_0000h定时器2控制状态寄存器,第三路独立定时器的控制接口,可用于实现多种定时功能的并行处理。
61ChTimer Compare Capture Register (TCCR2)32RW0000_0000h定时器2比较捕获寄存器,与TCSR2配合,提供第三路定时器的比较匹配或事件捕获能力。
620hTimer Control Status Register (TCSR3)32RW0000_0000h定时器3控制状态寄存器,第四路独立定时器的控制接口,满足复杂系统中多任务定时需求。
624hTimer Compare Capture Register (TCCR3)32RW0000_0000h定时器3比较捕获寄存器,与TCSR3配合,提供第四路定时器的比较匹配或事件捕获功能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值