



# **EE 533: Network Processor Design and Programming**

**Instructor: Young Cho, Ph.D.**

**Zhongqi Zhao: 7864803206**

## **Github link:**

<https://github.com/ZzqXAUT/EE533.git>

## **Questions**

### **Verilog & Schematic**

The generated Verilog code is functionally reasonable and synthesizable, but it is clearly an auto-generated schematic netlist, which makes it verbose, hard to read, and difficult to maintain. It correctly represents the intended hardware, but it is not suitable for manual modification or long-term reuse.

In general, writing Verilog is easier than drawing schematics because it is more concise, scalable, and easier to debug, simulate, and maintain. Complex logic can be expressed clearly in a small amount of code, which is not practical with schematics.

Schematics are mainly useful for learning, visualization, or very small and simple designs, while Verilog is preferred for larger, more complex, or reusable designs.

#### **a) Explain the pattern matching algorithm in the report**

The pattern matching algorithm works by comparing incoming data with a stored pattern. The data is divided into smaller parts, and each part is checked at the same time. Some bits can be ignored using a mask, so the match does not have to be exact. If the required parts match, the circuit reports a pattern match.

#### **b-i) What is the purpose of AMASK[6:0]?**

AMASK[6:0] is used to control which bits are compared and which bits are ignored. A masked bit is treated as “don’t care,” which allows flexible matching instead of strict bit-by-bit comparison.

#### **b-ii) What exactly does busmerge.v do?**

The busmerge.v module combines two input buses into one wider bus. It simply concatenates the inputs so that they can be processed together by other modules.

#### **b-iii) What do the comp8 modules do in this schematic?**

The comp8 module compares two 8-bit values and outputs a signal when they are equal. It is used to check whether parts of the data match the expected values.

#### **b-iv) What is the purpose of dual9Bmem in dropfifo.sch?**

In dropfifo.sch, the dual9Bmem module is a dual-port memory used as a FIFO buffer. It stores 72-bit data words and allows reading and writing at the same time, which helps manage data flow through the circuit.

# Schematics

## comp8



## comparator



## wordmatch



## detect7B



**reg9B**



## dropfifo

