Triple-Speed Ethernet Intel® FPGA IP User Guide

ID 683402
Date 10/12/2023
Public
Document Table of Contents

4.1.4.7. Length Checking

The MAC function checks the frame and payload lengths of basic, VLAN, and stacked VLAN tagged frames. The jumbo frame does not go through the length check.

The frame length must be at least 64 (0x40) bytes and not exceed the following maximum value for the different frame types:

  • Basic frames—the value specified in the frm_length register
  • VLAN tagged frames—the value specified in the frm_length register plus four
  • Stacked VLAN tagged frames—the value specified in the frm_length register plus eight

To prevent FIFO buffer overflow, the MAC function truncates the frame if it is more than 11 bytes longer than the allowed maximum length.

For frames of a valid length, the MAC function continues to check the payload length if the NO_LGTH_CHECK bit in the command_config register is set to 0. The MAC function keeps track of the payload length as it receives a frame, and checks the length against the length/type field in basic MAC frames or the client length/type field in VLAN tagged frames. The payload length is valid if it satisfies the following conditions:

  • The actual payload length matches the value in the length/type or client length/type field.
  • Basic frames—the payload length is between 46 (0x2E)and 1536 (0x0600) bytes, excluding 1536.
  • VLAN tagged frames—the payload length is between 42 (0x2A)and 1536 (0x0600), excluding 1536.
  • Stacked VLAN tagged frames—the payload length is between 38 (0x26) and 1536 (0x0600), excluding 1536.

If the frame or payload length is not valid, the MAC function asserts one of the following signals to indicate length error:

  • rx_err[1] in MACs with internal FIFO buffers.
  • data_rx_error[0] in MACs without internal FIFO buffers.