#### **LeWiz Ethernet MAC Controller**

## **Directory Description of Core 3 Code Release**



#### LeWiz Communications, Inc.

"The Wizard of Internet Communications"

July 31, 2019 Revision 1.02

PO Box 9276 San Jose, CA 95157 www.lewiz.com Email: support@lewiz.com

Copyright (C) 2018 LeWiz Communications, Inc.

This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this library release; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA

LeWiz can be contacted at: support@lewiz.com or address: PO Box 9276, San Jose, CA 95157-9276

www.lewiz.com

Author: LeWiz Communications, Inc.

# **Change Log**

| Version   | Significant Changes              |
|-----------|----------------------------------|
| 1.00      | Release version (pending review) |
| 1.01 OSrc | Open source release              |
| 1.02      | Modified for Core3               |
|           |                                  |
|           |                                  |

## **Table of Contents**

| 1 | Dire | ectory Map:                         | . 4 |
|---|------|-------------------------------------|-----|
| 2 | Abb  | previations:                        | . 4 |
| 3 | Des  | cription of each directory          | . 4 |
|   | 3.1  | LMAC3_INFO:                         | . 4 |
|   | 3.2  | ASYNCH_FIFO: (behavioral code)      | . 4 |
|   | 3.3  | AXIS_BRIDGE:                        |     |
|   | 3.4  | AXIS_LMAC_TB: (behavioral code)     | . 4 |
|   | 3.5  | AXIS_LMAC_TOP:                      | . 5 |
|   | 3.6  | AXIS_MASTER: (behavioral code)      | . 5 |
|   | 3.7  | LMAC_CORE_TOP: (synthesizable code) | . 5 |
|   | 3.8  | PHY_EMULATOR: (behavioral code)     |     |
|   | 3.9  | TESTS: (script code)                |     |
|   | 3.10 | waveforms: (Modelsim info)          | . 5 |
|   | 3.11 | work: (Modelsim info)               |     |

4

NOTE: This document is intended for HW users using LeWiz MAC IP Core Test Bench.

## 1 Directory Map:

LMAC3 INFO

ASYNCH\_FIFO - containing technology independent behavioral FIFO model

AXIS BRIDGE - AXI4 Stream (AXIS) bus bridge model

AXIS LMAC TB - AXIS LeWiz MAC testbench

AXIS\_LMAC\_TOP - top level of LMAC with AXIS interface

AXIS MASTER - AXIS bus master behavioral model

LMAC\_CORE\_TOP - main LMAC core model with FIFO interface

PHY\_EMULATOR - behavioral model of PHY emulator to test various PHY speeds

TESTS – contain TX/RX tests and results

waveforms - examples of waveforms for Modelsim

work - Modelsim specific database

#### 2 Abbreviations:

AXIS = AXI4 stream

LMAC = LeWiz MAC

PHY = Physical layer

TB = TestBench

TX = Transmit

RX = Receive

## 3 Description of each directory

#### 3.1 LMAC3 INFO:

This is the top directory that contains all the subfolders described below including the verification results and all other relevant information.

#### 3.2 ASYNCH\_FIFO: (behavioral code)

This directory only contains the behavioral model of the FIFO to be used as a base FIFO module throughout the entire project. All other FIFOs used in this project are created by designing a wrapper on top of this base FIFO. This model is ASIC/FPGA technology independent.

#### 3.3 AXIS\_BRIDGE:

This directory contains the behavioral code for the AXI4 stream interface bridge. It includes a top-level module named AXIS\_BRIDGE\_TOP which instantiated 4 FIFOs and 4 control logic modules for transmitting and receiving data and control information between the AXIS\_MASTER module and LMAC\_CORE\_TOP module.

#### 3.4 AXIS LMAC TB: (behavioral code)

This directory contains a top level testbench named AXIS\_LMAC\_TB for system level testing of the LMAC\_CORE\_TOP module.

#### 3.5 AXIS\_LMAC\_TOP:

This directory contains a top-level module that instantiates the AXIS\_BRIDGE\_TOP module and LMAC\_CORE\_TOP module.

### 3.6 AXIS\_MASTER: (behavioral code)

This directory contains the code of the AXI\_STREAM\_MASTER module. AXI\_STREAM\_MASTER is mainly used for generating the desired number of the packet to the AXIS\_BRIDGE\_TOP. It also contains the memory write and read modules to store the data and control information for the simulation purpose.

## 3.7 LMAC\_CORE\_TOP: (synthesizable code)

This directory contains the code of the main LMAC IP Core (Core3) design. The top module is named LMAC\_CORE\_TOP. It contains the core logic for both Tx and Rx sides. It supports all five speed modes 100G, 50G, 40G, 25G, and 10G bit per second.

## 3.8 PHY\_EMULATOR: (behavioral code)

This directory contains the behavioral code to emulate the 256-bit CGMII PHY interface. It supports loopback testing or allows the user to generate stored packets into the LMAC Core using the rx\_pkt\_gen\_100G module inside the PHY Emulator. For loopback mode, it causes the packets transmitted by LMAC core looping back into the RX side of the LMAC core. In network generated mode, it enables user to generate packets into the Rx side of the LMAC core.

## 3.9 TESTS: (script code)

Contains all the test examples, test scripts, test files, test results.

#### 3.10 waveforms: (Modelsim info)

Contains example waveform configuration files. These files can be opened in Modelsim's wave window.

## 3.11 work: (Modelsim info)

Contains Modelsim specific data files.