ECE 310-001

Project #1 Report

Charles Zhu

1. Snapshot of the RTL synthesized in Quartus.

|  |
| --- |
|  |

*Part 1: Fill in the synthesis results*

|  |
| --- |
| **Synthesis Results** |
| Number of logic elements  7,302 / 15,408 ( 47 % ) |
| Number of registers:  68 |
| Number of tri-state buffers:  27 / 79 ( 34 % ) |
| Number of memory bits:  0 / 516,096 ( 0 % ) |
| Please attach to the end of this report all text from the *Analysis and Synthesis Messages* section of your **.map.rpt** file. If you have warnings and/or errors, please provide your best one- or two- sentence explanation for why each warning or error is occurring. |

Info: \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

Info: Running Quartus Prime Analysis & Synthesis

Info: Version 20.1.0 Build 711 06/05/2020 SJ Lite Edition

Info: Processing started: Mon Oct 26 17:25:12 2020

Info: Command: quartus\_map --read\_settings\_files=on --write\_settings\_files=off proj1 -c proj1

Warning (18236): Number of processors has not been specified which may cause overloading on shared machines. Set the global assignment NUM\_PARALLEL\_PROCESSORS in your QSF to an appropriate value for best performance.

Info (20030): Parallel compilation is enabled and will use 2 of the 2 processors detected

Info (12021): Found 10 design units, including 10 entities, in source file proj1.v

Info (12023): Found entity 1: ram

Info (12023): Found entity 2: half\_adder

Info (12023): Found entity 3: full\_adder

Info (12023): Found entity 4: my16bitadder

Info (12023): Found entity 5: my8bitmultiplier

Info (12023): Found entity 6: alu

Info (12023): Found entity 7: ctr

Info (12023): Found entity 8: registers

Info (12023): Found entity 9: datapath

Info (12023): Found entity 10: proj1

Warning (10236): Verilog HDL Implicit Net warning at proj1.v(690): created implicit net for "Zflag\_reg"

Fixed by assigning zflag\_reg to be not an implicit net

Info (12127): Elaborating entity "proj1" for the top level hierarchy

Info (12128): Elaborating entity "ram" for hierarchy "ram:tomato"

Warning (10240): Verilog HDL Always Construct warning at proj1.v(20): inferring latch(es) for variable "q", which holds its previous value in one or more paths through the always construct

Fixed by assigning adding else statement to fix the latch.

Info (10041): Inferred latch for "q[0]" at proj1.v(20)

Info (10041): Inferred latch for "q[1]" at proj1.v(20)

Info (10041): Inferred latch for "q[2]" at proj1.v(20)

Info (10041): Inferred latch for "q[3]" at proj1.v(20)

Info (10041): Inferred latch for "q[4]" at proj1.v(20)

Info (10041): Inferred latch for "q[5]" at proj1.v(20)

Info (10041): Inferred latch for "q[6]" at proj1.v(20)

Info (10041): Inferred latch for "q[7]" at proj1.v(20)

Info (10041): Inferred latch for "q[8]" at proj1.v(20)

Info (10041): Inferred latch for "q[9]" at proj1.v(20)

Info (10041): Inferred latch for "q[10]" at proj1.v(20)

Info (10041): Inferred latch for "q[11]" at proj1.v(20)

Info (10041): Inferred latch for "q[12]" at proj1.v(20)

Info (10041): Inferred latch for "q[13]" at proj1.v(20)

Info (10041): Inferred latch for "q[14]" at proj1.v(20)

Info (10041): Inferred latch for "q[15]" at proj1.v(20)

Info (12128): Elaborating entity "ctr" for hierarchy "ctr:potato"

Warning (10230): Verilog HDL assignment warning at proj1.v(280): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(296): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(312): truncated value with size 8 to match size of target (4)

Tried to fix using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(330): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(331): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(332): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(333): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(334): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(335): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(336): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(337): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(353): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(369): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(387): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(404): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(423): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(438): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(454): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(471): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(488): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(504): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(522): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10230): Verilog HDL assignment warning at proj1.v(538): truncated value with size 8 to match size of target (4)

Tried to fix Using a comparison logic when value does not match

Warning (10199): Verilog HDL Case Statement warning at proj1.v(541): case item expression never matches the case expression

This is a special case where for when it needs to branch out to the jump when value is zero

Warning (10240): Verilog HDL Always Construct warning at proj1.v(267): inferring latch(es) for variable "opALU", which holds its previous value in one or more paths through the always construct

This is a special case where for when it needs to branch out to the jump when value is zero

Info (10041): Inferred latch for "opALU[0]" at proj1.v(267)

Info (10041): Inferred latch for "opALU[1]" at proj1.v(267)

Info (12128): Elaborating entity "datapath" for hierarchy "datapath:datapath\_name"

Info (12128): Elaborating entity "alu" for hierarchy "datapath:datapath\_name|alu:start1"

Warning (10235): Verilog HDL Always Construct warning at proj1.v(167): variable "A" is read inside the Always Construct but isn't in the Always Construct's Event Control

Fixed by putting always(\*)

Warning (10235): Verilog HDL Always Construct warning at proj1.v(167): variable "B" is read inside the Always Construct but isn't in the Always Construct's Event Control

Fixed by putting always(\*)

Warning (10235): Verilog HDL Always Construct warning at proj1.v(168): variable "SumOutput" is read inside the Always Construct but isn't in the Always Construct's Event Control

Fixed by putting always(\*)

Warning (10235): Verilog HDL Always Construct warning at proj1.v(169): variable "product0utput" is read inside the Always Construct but isn't in the Always Construct's Event Control

Fixed by putting always(\*)

Warning (10235): Verilog HDL Always Construct warning at proj1.v(170): variable "A" is read inside the Always Construct but isn't in the Always Construct's Event Control

Fixed by putting always(\*)

Info (12128): Elaborating entity "my16bitadder" for hierarchy "datapath:datapath\_name|alu:start1|my16bitadder:addie"

Info (12128): Elaborating entity "full\_adder" for hierarchy "datapath:datapath\_name|alu:start1|my16bitadder:addie|full\_adder:Add0"

Info (12128): Elaborating entity "half\_adder" for hierarchy "datapath:datapath\_name|alu:start1|my16bitadder:addie|full\_adder:Add0|half\_adder:a1"

Info (12128): Elaborating entity "my8bitmultiplier" for hierarchy "datapath:datapath\_name|alu:start1|my8bitmultiplier:multiplie"

Warning (10230): Verilog HDL assignment warning at proj1.v(112): truncated value with size 32 to match size of target (16)

Tried to fix the size of target to match output since multiplier had size 32

Info (12128): Elaborating entity "registers" for hierarchy "datapath:datapath\_name|registers:another\_one"

Info (278001): Inferred 1 megafunctions from design logic

Info (278003): Inferred multiplier megafunction ("lpm\_mult") from the following logic: "datapath:datapath\_name|alu:start1|Mult0"

Info (12130): Elaborated megafunction instantiation "datapath:datapath\_name|alu:start1|lpm\_mult:Mult0"

Info (12133): Instantiated megafunction "datapath:datapath\_name|alu:start1|lpm\_mult:Mult0" with the following parameter:

Info (12134): Parameter "LPM\_WIDTHA" = "8"

Info (12134): Parameter "LPM\_WIDTHB" = "8"

Info (12134): Parameter "LPM\_WIDTHP" = "16"

Info (12134): Parameter "LPM\_WIDTHR" = "16"

Info (12134): Parameter "LPM\_WIDTHS" = "1"

Info (12134): Parameter "LPM\_REPRESENTATION" = "UNSIGNED"

Info (12134): Parameter "INPUT\_A\_IS\_CONSTANT" = "NO"

Info (12134): Parameter "INPUT\_B\_IS\_CONSTANT" = "NO"

Info (12134): Parameter "MAXIMIZE\_SPEED" = "5"

Info (12021): Found 1 design units, including 1 entities, in source file db/mult\_3at.tdf

Info (12023): Found entity 1: mult\_3at

Warning (13012): Latch ctr:potato|opALU[1] has unsafe behavior

Tried to fix the ctr potato to have safe behavior

Warning (13013): Ports D and ENA on the latch are fed by the same signal ctr:potato|present\_state[3]

Fixed by changing to different signals instead of duplicate signals.

Warning (13012): Latch ctr:potato|opALU[0] has unsafe behavior

Tried to fix the ctr potato to have safe behavior

Warning (13013): Ports D and ENA on the latch are fed by the same signal ctr:potato|present\_state[0]

Info (286030): Timing-Driven Synthesis is running

Info (17049): 22 registers lost all their fanouts during netlist optimizations.

Info (144001): Generated suppressed messages file C:/Users/charlie/Desktop/ece310/Verilog/something/output\_files/proj1.map.smsg

Info (16010): Generating hard\_block partition "hard\_block:auto\_generated\_inst"

Info (16011): Adding 0 node(s), including 0 DDIO, 0 PLL, 0 transceiver and 0 LCELL

Info (21057): Implemented 7328 device resources after synthesis - the final resource count might be different

Info (21058): Implemented 2 input pins

Info (21059): Implemented 25 output pins

Info (21061): Implemented 7300 logic cells

Info (21062): Implemented 1 DSP elements

Info: Quartus Prime Analysis & Synthesis was successful. 0 errors, 38 warnings

Info: Peak virtual memory: 4787 megabytes

Info: Processing ended: Mon Oct 26 17:25:53 2020

Info: Elapsed time: 00:00:41

Info: Total CPU time (on all processors): 00:00:46

**Name: Charles Zhu Student ID:200217093**

I certify that I did not copy the answers to this homework and did not let

anyone copy my answers (sign):

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

![](data:image/png;base64,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)