

## Structural Example

module majority (major, V1, V2, V3);

output major;

input V1, V2, V3;

wire N1, N2, N3;

and A0 (N1, V1, V2),  
A1 (N2, V2, V3),  
A2 (N3, V3, V1);

or Or0 (major, N1, N2, N3);

endmodule



## ECE 551 Exercise 02

### Master-slave latch

This is the last problem of HW1 <sup>pos</sup><sub>edge</sub> (Flip flop)

Submit whatever you have for both the DUT and the testbench to the dropbox by end of class time.



- Code this circuit structurally in Verilog (in Modelsim environment) (attach the Verilog code for this module) (Note: tri-state gates might need a 1 time unit delay modeled for proper simulation, an inverting tri-state is verilog primitive `notif1`).
- Create a testbench, instantiate and simulate this circuit. Attach a print out of the waveforms, and the Verilog of the test bench
- Add an active high asynchronous reset input to this circuit. Code this new circuit in Verilog and update your test bench to test the new input. Again attach Verilog and waveforms
- Was the cost of adding the asynch reset high, medium, or low? Think in terms of number of transistors.

## Test Bench

module mystery\_tb();

reg D\_stim;

Superset

reg clk;

wire q\_out; // DUT will drive

System logic d\_stim, clk, q\_out;

// Instantiate DUT//

mystery ; DUT(.clk(clk), .d(d\_stim), .q(q\_out))

initial begin

clk = 0;

d\_stim = 0;

#10; <sup>generic</sup> @ (posedge clk); #1;

clk = 1;

if (q\_out != 1'60) begin

~~#1;~~

// is q\\_out == 0

~~#10~~

~~clk=0;~~

end

always

#5 clk = ~clk;

endmodule

Brute force \$display ("ERR:

q\\_out should be 0"  
\$stop();  
end

asynch nseedge



## Asynch reset

ECE 551

Exercise02

This is the last problem of HW1

Submit whatever you have for both the DUT and the testbench to the dropbox by end of class time.



- a) Code this circuit structurally in Verilog (in Modelsim environment)(attach the Verilog code for this module)(Note: tri-state gates might need a 1 time unit delay modeled for proper simulation, an inverting tri-state is verilog primitive `notifl`).
- b) Create a testbench, instantiate and simulate this circuit. Attach a print out of the waveforms, and the Verilog of the test bench
- c) Add an active high asynchronous reset input to this circuit. Code this new circuit in Verilog and update your test bench to test the new input. Again attach Verilog and waveforms
- d) Was the cost of adding the asynch reset high, medium, or low? Think in terms of number of transistors.