11.3.2. 功能描述

11.3.2.1. RMII接口时钟选择

  1. 支持内部参考时钟,即MAC提供50MHz时钟源至外部PHY:

    • MAC内部选通PLL_EMAC_50M作为RMII 50MHz参考时钟源(通过SYSCFG的寄存器配置);

    • RMII_TX_CK输出时钟,提供给外部PHY使用。

  2. 支持外部参考时钟,即MAC接收PHY提供的RMII 50MHz参考时钟源:

    • REF_CLK时钟使能,并且选通作为RMII 50MHz参考时钟源(通过SYSCFG的寄存器配置);

    • RMII_TX_CK不使能,无需提供时钟信号。

11.3.2.2. MDIO

EMAC通过MDIO(Management Data In/Out)接口,可以对PHY的寄存器进行读写操作,进而控制PHY的工作模式以及获取PHY的工作状态。操作MDIO接口,可以操作寄存器MDIO_CTL和MDIO_DAT实现。

MDIO接口由MDC以及MDIO实现:

  • MDC,时钟输出信号,提供给PHY,需要根据AHB总线的时钟来配置时钟分频系数获得,具体配置见寄存器MDIO_CTL描述;

  • MDIO,数据输入输出信号,MDIO的帧的格式为:Idle + Preamble + Start + Opcode + Phy Addr + Reg Addr + TA + Data。

MDIO帧域

描述

IDLE

IDLE域

PREAMBLE

32个连续的bit 1

START

标志帧的起始位置,2’b10

OPCODE

操作标识域,2’b10表示读,2’b01表示写

PHY ADDR

5-bit的PHY地址域

REG ADDR

PHY寄存器地址

TA

Turnaround域,读操作为2’bZ0,写操作为2’b10

DATA

16 bit数据,读操作MAC为接收数据,写操作MAC为发送数据。

11.3.2.3. MAC发送功能

  1. SA源地址自动插入或替换功能

    • 配置MAC_TX_FUNC寄存器[14:12],MAC TX支持自动插入或替换发送帧的源地址,源地址可通过寄存器MAC_ADDR0或MAC_ADDR1配置。

  2. TX Jabber Timer

    • MAC TX支持Jabber Timer,用于检测发送的帧长度,若关闭Jabber Timer,发送帧的长度可以达到16383 bytes;若未关闭Jabber Timer的功能,最多只能发送2048 bytes(使能Jumbo Frame后,最大发送的长度为10240 bytes),并且会在TDES0的BIT14置1,指示发送的数据过长,发生Jabber Timeout。

  3. CRC 插入/替换

    • 配置TX DMA描述符TDES0 [27],可以对发送帧进行CRC的插入;

    • 配置TX DMA描述符TDES0 [24],可以对发送帧进行CRC的替换,此时需要设置TDES0[27] = 1,关闭CRC的插入功能。

  4. 自动补0

    • 配置TX DMA描述符TDES0 [27],可以对长度低于64 bytes的发送帧进行自动补0,并且此时会强制产生4 bytes的CRC,即short frame + 0 pad + CRC = 64 bytes。若不需要进行自动补0,可以设置TDES0[27] = 1。

  5. TX IP校验和插入

    • MAC支持对发送帧的IP校验和进行计算和插入,通过配置MAC_CFG[7] = 1,打开IP Offload功能,然后通过TDES0[23:22]选择IP检验和的计算类型,MAC支持IP header校验和、IP Payload校验和以及伪header校验的硬件加速计算;

    • 另外打开IP Offload功能后,TDES0[16]可以指示发送帧的IP校验和是否正确,置1表示发送帧存在IP校验和错误。

11.3.2.4. MAC接收功能

  1. 地址过滤

    对于接收帧,MAC可以进行地址过滤,包括:

    • 单播地址过滤

      • 源地址过滤

      • 反向源地址过滤

      • 目的地址过滤

      • 反向目的地址过滤

    • 广播地址过滤

    • 多播帧过滤

    • 控制帧过滤

    另外,RDES0[30]、[13]分别指示接收帧的目的地址、源地址过滤是否成功。

  2. RX Watchdog

    • MAC RX支持RX Watchdog,用于检测接收的帧长度,若关闭RX Watchdog,发送帧的长度可以达到16383 bytes;若未关闭RX Watchdog的功能,最多只能接收2048 bytes(使能Jumbo Frame后,最大接收的长度为10240 bytes),并且会在RDES0 [4]置1,指示接收的数据过长,发生Watchdog Timeout。

  3. CRC/PAD剥离

    MAC支持对接收帧进行CRC/PAD剥离:

    • 配置EN_STRIP_FCS = 1,可以对长度≥1536 bytes的接收帧进行CRC剥离;

    • 配置EN_STRIP_NML = 1,可以对长度<1536 bytes的接收帧进行CRC以及PAD剥离。

  4. RX IP校验和计算

    • MAC支持对接收帧的IP校验和进行计算,通过配置MAC_CFG[7] = 1,打开IP Offload功能。此时需要设置ALT_DES_SIZ = 0x1,激活RDES4的状态,软件通过RDES4可以获取接收帧IP检验和的校验结果,从而得知接收的IP帧的校验和结果。

11.3.2.5. 流控

流控功能包括如下,可通过寄存器FLOW_CTL控制:

  1. TX流控

    • 在全双工模式下,支持Pause帧的发送

    • 在半双工模式下,支持背压操作

  2. RX流控

    • 支持Pause帧的解析,以及停止发送约定的Pause时间

  3. 单播Pause帧

    • MAC模块支持单播的Pause帧

11.3.2.6. DMA结构

EMAC内部具有DMA,用于将发送BUFFER(DRAM地址)的数据传送到TXFIFO, RXFIFO接收到的数据传送到接收BUFFER(DRAM地址)。DMA可以支持两种结构,分别是环型结构和链型结构。

11.3.2.6.1. 环形结构

环型结构(Ring)的描述符,可以通过DES_SKIP_LEN来配置设定,两两描述符之间的跳跃长度,而另外通过描述符的START_DES和END_DES来决定环形结构的第一个描述符和最后一个描述符,从而形成环路。

../../../_images/ringdma.png

11.3.2.6.2. 链型结构

链型结构(Chain)的描述符,则通过描述符的Next Descriptor Address来进行指向连接,在最后一个描述符的Next Descriptor Address域上设置为第一个描述符地址,此时也同样形成环路。

../../../_images/chaindma.png

11.3.2.7. DMA发送描述符

注意

发送描述符TDES4~7(TDES4~5 Reserved,TDES6~7 时钟戳信息)的应用,需要设置寄存器DMA0/1_CONF的ALT_DES_SIZ = 1。

11.3.2.7.1. 发送描述符TDES0

Bit

域描述

31

TX_PRC
Transmit in Process,发送进行中。
0x0:DMA空闲,DMA完成当前的描述符的数据发送
0x1:DMA发送进行中

30

EN_TX_COMP_INT
Enable Transmit Complete Interrupt,使能发送完成中断,此位只有在BIT29有效时才有效。
0x0:未使能
0x1:使能,此位只有在BIT29有效

29

END_DES
End Descriptor,最后一个描述符。
0x0:无效
0x1:有效,表示此描述符为最后一个描述符

28

START_DES
Start Descriptor,第一个描述符。
0x0:无效
0x1:有效,表示此描述符为第一个描述符

27

DIS_CRC
Disable CRC,禁止CRC功能,这里生效,只需在第一个描述符设置此位即可。
0x0:无效
0x1:有效,禁止CRC

26

DIS_PAD
Disable Padding,禁止补0功能,这里生效,只需在第一个描述符设置此位即可。
0x0:无效
0x1:有效,禁止对帧长低于64 bytes进行补0

25

EN_TX_TMSTMP
Enable Transmit Timestamp,使能发送添加时间戳功能,只需在第一个描述符设置此位即可。
0x0:未使能
0x1:使能

24

EN_CRC_REP
Enable CRC Replacement,使能CRC替代功能。这里需要软件保证发送帧的内容包含了CRC,使能CRC替代功能后,会
进行CRC重新计算并替代。另外为了避免CRC重复,需要DIS_CRC =1 禁止CRC插入。在第一个描述符设置此位即可。
0x0:未使能
0x1:使能

23:22

EN_CIC
Enable Checksum Insertion Control,使能校验和插入功能,只需在第一个描述符设置此位即可。
0x0:禁止校验和插入
0x1:开启IP Header校验和计算以及插入功能
0x2:开启IP Header、Payload校验和的计算及插入功能,未开启伪Header的校验和计算
0x3:开启IP Header、Payload校验和的计算及插入功能,并且开启伪Header的校验和计算

21

TX_END_RNG
Transmit End of Ring,DMA发送环的末端,表示此描述符为DMA发送环的最后一个描述符,结束后跳回起始描述符。
0x0:无效
0x1:生效

20

EN_DMA_CHN_MOD
Enable DMA Chain Mode,使能DMA Chain模式。
0x0:未使能,采用DMA Ring模式
0x1:使能,采用DMA Chain模式

19:18

VLAN_TAG_CTL
VLAN Tag Control,VLAN 标签控制,只需在第一个描述符设置此位即可。
0x0:无效操作
0x1:删除发送帧中的VLAN标签内容
0x2:插入VLAN标签,标签内容
0x3:替代VLAN标签

17

TX_TMSTMP_STS
Transmit Timestamp Status,发送时间戳状态,此域只有在最后一个描述符有效。
0x0:无操作
0x1:完成发送时间戳的捕捉,时间戳写入在TDES6和TDES7

16

IP_HD_ERR
IP Header Error,此位置1表示MAC检测发送的IP报文的Header存在错误,此域只有在最后一个描述符有效。

15

TXERR_STS
Transmit Error Status,发送错误状态指示位。
0x0:无错误
0x1:出现错误,错误源可能由于BIT16/14/13/12/11/10/9/8/2/1相应的错误状态引起

14

JAB_TO_ERR
Jabber Timout Error,发送Jabber超时错误,此位只有在Jabber检测功能未禁止的情况下有效。
0x0:无异常
0x1:出现发送超时错误

13

TXFIFO_FLSH_ERR
TXFIFO Flush Error,清除错误,出现软件清除TXFIFO的帧数据的操作导致的错误。
0x0:无异常
0x1:出现错误状态

12

IP_PL_ERR
IP Payload Error,此位置1指示MAC检测到发送的TCP、UDP、ICMP IP数据包payload存在错误。

11

LOS_CR
Loss Carrier,此位置1指示在帧发送发生了载波丢失,此位只有在半双工模式下有效。

10

NO_CR
No Carrier,此位置1指示在发送的过程中,PHY的载波侦听CS信号并没有生效,即没有检测到载波。

9

LT_COL
Late Collision,此位置1指示由于碰撞导致发送终止,此碰撞发生在碰撞窗口之后。此位在TXFIFO_UF_ERR = 1的时候
无效。

8

EXS_COL
Excessive Collision,此位置1指示当前帧尝试发送的过程中,由于连续的16次碰撞的产生终止发送帧。如果取消重传
(DIS_RETRY = 1),只要出现1次的碰撞,此位则立即置1。

7

VLAN_STS
VLAN Status,VLAN帧状态。
0x0:发送帧为非VLAN帧
0x1:发送帧为VLAN帧

6:3

COL_CNT
Collision Count,此域指示在发送前发生多少次碰撞。此域在TDES0. Bit8 =1的时候无效。

2

EX_DEF_ERR
Excessive Deferral Error,发送终止由于回退时间过长,此位只有在EN_DEF_CHECK = 1的情况下有效。
0x0:未发生错误
0x1:出现回退过量错误

1

TXFIFO_UF_ERR
TXFIFO Underflow Error,TXFIFO下溢出错误,DMA从Buffer地址读取帧数据错误。
0x0:未出现错误
0x1:发生下溢出错误

0

DEF_STS
Defer Status,回退状态,在发送前检测到载波而引起的回退,此位只对于半双工模式有效。
0x0:未出现回退
0x1:发送时出现回退

11.3.2.7.2. 发送描述符TDES1

Bit

域描述

31:29

TX_SA_CTL
Transmit Source Address Control,发送源地址控制。
BIT31 = 1,表示采用MAC Address1进行插入或替代;
BIT31 = 0,表示采用MAC Address0 进行插入或替代。

Bit30:29
0x0:无操作
0x1:插入源地址
0x2:替代源地址
0x3:保留

28:16

TX_BUF2_SIZ
Transmit Buffer2 Size,发送缓存2的空间大小。

15:13

Reserved

12:0

TX_BUF1_SIZ
Transmit Buffer1 Size,接收缓存1的空间大小。

11.3.2.7.3. 发送描述符TDES2

Bit

域描述

31:0

BUF1_ADDR
Buffer1 Address,Buffer1地址指针,Buffer1的物理地址。

11.3.2.7.4. 发送描述符TDES3

Bit

域描述

31:0

BUF2_ADDR/NXT_DES_ADDR
在DMA采用Ring模式时,这里为BUF2_ADDR,而采用Chain模式时,这里为NXT_DES_ADDR。

BUF2_ADDR
Buffer2 Address,Buffer2地址指针,Buffer2的物理地址。

NXT_DES_ADDR
Next Descriptor Address,下一个描述符的地址,指向下一个描述符的物理地址,从而将描述符连接起来。

11.3.2.7.5. 发送描述符TDES6

Bit

域描述

31:0

TX_STMP_LO
Transmit Timestamp Low 32bit,发送时间戳的低32位,此域由DMA自动填写,与TDES7的高32bit组成完整的时间戳。

11.3.2.7.6. 发送描述符TDES7

Bit

域描述

31:0

TX_STMP_HI
Transmit Timestamp High 32bit,发送时间戳的高32位,此域由DMA自动填写,与TDES6的低32bit组成完整的时间戳。

11.3.2.8. DMA接收描述符

注意

接收描述符RDES4~7(RDES4状态信息,RDES5 Reserved,RDES6~7 时钟戳信息)的应用,需要设置寄存器DMA0/1_CONF的ALT_DES_SIZ = 1。

11.3.2.8.1. 接收描述符RDES0

Bit

域描述

31

RX_PRC
Receive in Process,接收进行中。
0x0:DMA空闲,DMA完成当前的描述符的数据接收
0x1:DMA接收进行中

30

DA_FLT
Destination Address Filter Fail,目的地址过滤失败。
0x0:无效
0x1:指示接收帧的目的地址过滤失败

29:16

RX_FRM_LEN
Receive Frame Length,接收到的帧的长度,此域在最后一个描述符有效,并且无异常发生。

15

RXERR_STS
Receive Error Status,接收错误状态指示位。
0x0:无错误
0x1:出现错误,错误源可能由于RDES0的BIT14/11/7/6/4/3/1或RDES4的[4:3]相应的错误状态引起

14

RX_DES_ERR
Receive Descriptor Error,接收描述符错误,此域在最后一个描述符有效。
0x0:无效
0x1:由于描述符异常导致的接收中断

13

SA_FLT
Source Address Filter Fail,源地址过滤失败。
0x0:无效
0x1:指示接收帧的源地址过滤失败

12

RX_LEN_ERR
Receive Length Error,接收长度错误。
0x0:无效
0x1:指示接收长度错误,接收帧的实际长度与帧的长度域值不一致

11

RXFIFO_OF_ERR
RXFIFO Overflow Error,接收溢出错误。
0x0:无效
0x1:指示接收溢出错误,由于RXFIFO溢出,导致接收帧的损坏

10

VLAN_TAG
VLAN Tag,此位置1表示接收的帧位VLAN帧。

9

START_DES
Start Descriptor,第一个描述符。
0x0:无效
0x1:有效,表示此描述符为第一个描述符

8

END_DES
End Descriptor,最后一个描述符。
0x0:无效
0x1:有效,表示此描述符为最后一个描述符

7

TMSTMP_AVL/ IP_CHSM_ERR/ GNT_FRM
此位可指示三种状态:
TMSTMP_AVL,Timestamp Available,置1表示接收的帧已打时间戳,从RDES6~7可获得;
IP_CHSM_ERR,IP Checksum Error,置1表示IP校验和错误或表示接收帧位非IPv4帧;
GNT_FRM,Giant Frame,置1表示接收的帧位Giant Frame。

6

LT_COL_ERR
Late Collision Error,Late Collision错误。
0x0:无效
0x1:接收发生Late Collision错误

5

RX_FRM_TYP
Receive Frame Type,接收帧的类型。
0x0:接收帧为IEEE 802.3类型的帧
0x1:接收帧为以太网类型的帧

4

RX_WD_TO_ERR
Receive Watchdog Timeout Error,接收看门狗的超时错误。
0x0:无效
0x1:发生接收看门狗的超时错误

3

RX_ERR
Receive Error,接收过程出现RX_ERR信号。
0x0:无效
0x1:接收过程出现RX_ERR信号

2

Reserved

1

RX_CRC_ERR
Receive CRC Error,接收CRC错误,此域只有在最后一个描述符有效。
0x0:无效
0x1:接收帧出现CRC错误

0

EXT_STS_AVA/ RX_MAC_ADDR
EXT_STS_AVA
Extend Status Available,当时钟戳或IP校验和Offload功能使能,此位置1表示RDES4生效。
RX_MAC_ADDR
Rx MAC Address,当时钟戳、IP校验和Offload功能均未使能,此位置1表示接收帧的目的地址匹配MAC
Address1~7之一。此位清0表示接收帧的目的地址匹配MAC Address0。

11.3.2.8.2. 接收描述符RDES1

Bit

域描述

31

DIS_COMP_INT
Disable Complete Interrupt,禁止接收完成中断的产生。
0x0:未禁止
0x1:禁止

30:29

Reserved

28:16

RX_BUF2_SIZ
Receive Buffer2 Size,接收缓存2的空间大小。

15

RX_END_RNG
Receive End of Ring,指示在DMA的Ring模式下,此描述为最后的描述符,完成后跳转回起始描述符。

14

RX_DMA_MOD
Receive DMA Mode,接收DMA的模式。
0x0:Ring模式
0x1:Chain模式

13

Reserved

12:0

RX_BUF1_SIZ
Receive Buffer1 Size,接收缓存1的空间大小。

11.3.2.8.3. 接收描述符RDES2

Bit

域描述

31:0

BUF1_ADDR
Buffer1 Address,Buffer1地址指针,Buffer1的物理地址。

11.3.2.8.4. 接收描述符RDES3

Bit

域描述

31:0

BUF2_ADDR/NXT_DES_ADDR
在DMA采用Ring模式时,这里为BUF2_ADDR,而采用Chain模式时,这里为NXT_DES_ADDR。

BUF2_ADDR
Buffer2 Address,Buffer2地址指针,Buffer2的物理地址。

NXT_DES_ADDR
Next Descriptor Address,下一个描述符的地址,指向下一个描述符的物理地址,从而将描述符连接起来。

11.3.2.8.5. 接收描述符RDES4

Bit

域描述

31:21

Reserved

20:18

VLAN_TAG_PRI_V
VLAN Tag Priority Value,此域内容填入接收到的包的VLAN TAG用户值域。

17

AV_TAG_PKT_RCD
AV Tagged Packet Received,此位置1表示接收到带AV标签的数据包。

16

AV_PKT_RCD
AV Packet Received,此位置1表示接收到AV包。

15

Reserved

14

TMSTMP_DRP
Timestamp Dropped,时钟戳丢失,由于RXFIFO溢出,导致时钟戳丢失。
0x0:无效
0x1:时钟戳丢失

13

PTP_VER
PTP Version,PTP版本。
0x0:IEEE1588
0x1:IEEE1588V2

12

RX_PTP_FRM
Received PTP Frame Type,接收到PTP帧的类型。
0x0:接收到PTP报文通过UDP-IPV4或UDP-IPV6的形式传送
0x1:接收到PTP报文直接通过以太网帧形式传送

11:8

PTP_RX_MSG_TYP
Received PTP Message Type,接收到的PTP消息报文类型。
0x0:无PTP报文
0x1:SYNC报文
0x2:Follow Up报文
0x3:Delay_Req报文
0x4:Delay_Resp报文
0x5:Pdelay_Req报文
0x6:Pdelay_Resp报文
0x7:Pdelay_Resp_Follow_Up报文
0x8:Announce报文
0x9:Management报文
0xA:Signaling报文
0xB~0xE:Reserved
0xF:PTP Packet with Reserved message type

7

RX_IPV6_PKT
Received IPV6 Packet,接收到IPV6包。
0x0:无效
0x1:接收到的IP包为IPV6包

6

RX_IPV4_PKT
Received IPV4 Packet,接收到IPV4包。
0x0:无效
0x1:接收到的IP包为IPV4包

5

DIS_IP_CHSUM
Disable IP Checksum Function,关闭IP校验和功能。
0x0:未关闭
0x1:关闭IP校验和功能

4

IP_PL_ERR
IP Payload Error,IP包校验错误,接收到的IP包的TCP/UDP/ICMP的校验和错误,或长度错误。
0x0:无错误
0x1:出现IP包校验和错误

3

IP_HD_ERR
IP Header Error,接收到的IP包的首部校验和与计算的校验和不一致,或者IP版本与Ethernet Type域值
不一致。
0x0:无错误
0x1:出现首部校验和错误

2:0

IP_PKT_TYP
IP Packet Type,IP包类型,此域只有在BIT6/7生效时才有效。
0x0:未知类型
0x1:UDP包
0x2:TCP包
0x3:ICMP包
others:Reserved

11.3.2.8.6. 接收描述符RDES6

Bit

域描述

31:0

RX_STMP_LO
Receive Timestamp Low 32bit,接收时间戳的低32位,此域由DMA自动填写,与TDES7的高32bit组成完整
的时间戳。

11.3.2.8.7. 接收描述符RDES7

Bit

域描述

31:0

RX_STMP_HI
Receive Timestamp High 32bit,发送时间戳的高32位,此域由DMA自动填写,与TDES7的低32bit组成完整
的时间戳。

11.3.2.9. IEEE1588

11.3.2.9.1. 时钟戳收发

  • IEEE1588 时钟戳的收发,在MAC发送或接收到报文后,则触发时钟戳的捕捉,对应的发送或接收描述符会记录相应的Timestamp信息在TDES6、TDES7和RDES6、RDES7。为了让DMA能够记录Timestamp,寄存器ALT_DES_SIZ = 1,配置描述符的大小为8 words。同时TDES0的TTSE(Transmit Timestamp Enable)需要使能。而接收需在Timestamp控制寄存器上配置对应的接收帧类型使能即可。

11.3.2.9.2. 时钟校准

  • IEEE1588功能支持内部系统时钟的校准,可以支持粗糙和精准校准两种方式。粗糙的校准通过PTP协议报文的交互计算出时钟偏差,通过Update寄存器更新系统时间;精准的校准则通过PTP协议报文的交互计数时钟偏差的频率比,更新Timestamp Addend寄存器,实现同步时钟。

../../../_images/ptp.png

图 11.7 PTP时钟校准