The GRETH_GBIT core implements a 10/100/1000 Mbit/s Ethernet Media Access Controller (MAC) with AMBA host interface. The core implements the 802.3-2002 Ethernet standard. Receive and transmit data is autonomously transferred between the Ethernet MAC and the AMBA AHB bus using DMA transfers. Through the use of receive and transmit descriptors, multiple ethernet packets can be received and transmitted without CPU involvement. The GRETH_GBIT provides support for the MII and GMII PHY interfaces. Hardware support is also provided for the EDCL UDP debugging protocol. For critical space applications, a fault-tolerant version of GRETH_GBIT is available with full SEU protection of all RAM blocks.
Features
Deliverables
Area and timing
The GRETH_GBIT is inherently portable and can be implemented on most FPGA and ASIC technologies.
Estimation of the resource utilization for the GRETH_GBIT can be found here:
The GRETH_GBIT core can be licensed commercially, either stand-alone or as part of the GRLIB IP library. It is delivered either as VHDL source-code or as a netlist. Evaluation netlists can also be delivered for most technologies.
EDCL
The EDCL is an optional hardware unit providing read/write access to the AHB bus through Ethernet using an UDP based protocol. It operates in parallel with the MAC DMA and does not interfere with the normal network traffic other than lowering performance. Speeds up to 500 Mbit/s effective throughput have been achieved when accessing the AHB bus through the EDCL using the GRMON debug monitor.
Speed with TCP/IP software stacks
Although the theoretical maximum speed is near 1 Gbit/s for a gigabit network this is never reached in practice. When using software TCP/IP stacks from the supported operating systems the limiting factor will be the processing power of the CPU. The tables below show the speed that can typically be achieved with different CPU configurations using Linux 2.6 which has the most extensive support for the offloading features in the GRETH_GBIT. The other operating systems will usually be slower since they lack support for one or more of these features. The speed measurements were done with the Test TCP (TTCP) utility which is a benchmarking tool for measuring TCP and UDP performance. The Tx and Rx columns in the tables refer to the speed achieved when transmitting and receiving with TTCP respectively. All the tests were run in TCP mode.
Spartan 3 100 Mbit network
Freq | I-cache | D-cache |
Tx | Rx |
40 MHz | 1 * 1 k | 1 * 1 k | 15 Mbit/s | 21 Mbit/s |
40 MHz | 1 * 16 k | 1 * 16 k | 24 Mbit/s | 30 Mbit/s |
45 MHz | 1 * 16 k | 1 * 16 k | 27 Mbit/s | 34 Mbit/s |
46 MHz | 1 * 32 k | 1 * 8 k | 30 Mbit/s | 37 Mbit/s |
Virtex 4 1000 Mbit network
Freq | I-cache | D-cache | Tx | Rx |
70 MHz | 1 * 32 k | 1 * 16 k | 41 Mbit/s | 45 Mbit/s |
Virtex 5 1000 Mbit network
Freq | I-cache | D-cache | Tx | Rx |
85 MHz | 2 * 8 k | 1 * 8 k | 40 Mbit/s | 55 Mbit/s |
85 MHz | 4 * 8 k | 4 * 4 k | 62 Mbit/s | 67 Mbit/s |