stm32以太网接口:MII和RMII

前言

使用stm32和lwip进行网络通信开发时,实现结构如下:

而MII和RMII就是stm32与PHY芯片之间的通信接口,类似于I2C、UART等。

stm32以太网模块有专用的DMA控制器,通过AHB接口将以太网内核和存储器相连。

数据发送时,先将数据从存储器以DMA传输到TX FIFO中进行缓冲,然后由MAC内核通过MII或RMII接口发送;

数据接收时,RX FIFO先通过MII或RMII接收以太网数据帧,再由DMA传输至存储器。

ETH功能系统框图如下:

MII和RMII用于连接stm32 MAC控制器和PHY芯片,提供数据传输路径。RMII接口是MII接口的简化版本,MII需要16跟通信线,RMII需要7根。

MII接口

MII接口连接示意图如下:

TX_CLK :为数据发送提供时钟信号,传输速率为10Mbit/s时,该时钟为2.5MHz,传输速率为100Mbit/s时,该时钟为25MHz(因为每次传4bit,所以时钟信号与传输速率之间是4倍关系)。
RX_CLK :为数据接收提供时钟信号,传输速率为10Mbit/s时,该时钟为2.5MHz,传输速率为100Mbit/s时,该时钟为25MHz。
TX_EN :数据发送使能信号,在整个数据发送过程中保持有效电平。
TXD[3:0] :数据发送数据线,每次发4bit数据,TXD[0]是数据最低位,TXD[3]是最高位。
RXD[3:0] :数据接收数据线,每次接收4bit数据,RXD[0]是数据最低位,RXD[3]是最高位。在RX_DV禁止、RX_ER使能时,PHY芯片会通过RXD[3:0]传输一组特殊数据,来告诉一些特殊信息。
RX_DV :接收数据有效信号,功能类似于TX_EN,由PHY芯片负责驱动。
RX_ER:接收错误信号线,由 PHY 驱动,向 MAC 控制器报告在帧某处检测到错误。

RMII接口

RMII接口示意图如下:

与MII接口相比区别如下:

1.接受数据线和发送数据线由4根变成了2根。

2.MII的CRS 和 RX_DV整合成RMII的CRS_DV 信号线。

3.没有了COL冲突检测信号。

4.没有了数据接收、发送时钟信号,取而代之的是REP_CLK时钟源。

SMI接口

在MII和RMII接口连接示意图中都有MDC和MDIO两个信号线,这两个信号线是SMI接口,类似与IIC,用于访问PHY芯片的寄存器。

SMI接口示意图如下:

MDC是周期性时钟信号,MDIO是数据输入输出线。

向PHY芯片寄存器写数据时序图如下:

从PHY芯片寄存器读数据时序图如下:

相关推荐
rufeike2 分钟前
UDP协议理解
网络·网络协议·udp
YuCaiH6 分钟前
数组理论基础
笔记·leetcode·c·数组
bicijinlian1 小时前
多语言笔记系列:使用导入魔法命令
笔记
YuforiaCode1 小时前
第十三届蓝桥杯 2022 C/C++组 修剪灌木
c语言·c++·蓝桥杯
GKoSon2 小时前
加入RPC shell指令 温箱长时间监控
网络·网络协议·rpc
少年、潜行2 小时前
【开源】STM32HAL库移植Arduino OneWire库驱动DS18B20和MAX31850
stm32·嵌入式硬件·开源·ds18b20·max31850
hgdlip3 小时前
关闭IP属地显示会影响账号的正常使用吗
网络·网络协议·tcp/ip·ip属地
Zz_waiting.3 小时前
网络原理 - 7(TCP - 4)
网络·网络协议·tcp/ip
小鹿鹿啊3 小时前
C语言编程--15.四数之和
c语言·数据结构·算法
zheshiyangyang3 小时前
HTTP相关
网络·网络协议·http