Download presentation
Presentation is loading. Please wait.
Published byLaurel Thompson Modified over 8 years ago
1
Full Adder Verilog(HO: wires/regs, always) Section 4.5 (Full adder)
2
Schedule 62/3MondayBinary addition: full adder 72/5Wednesday Binary addition: four-bit adder/subtractor L2/6ThursdayLab canceled 82/10MondayClass canceled 92/12WednesdayBinary multiplication
3
Outline Observations Wire Versus reg Using always @() – Blocking statement – Non-Blocking Statement Full Adder
4
Observations V IL,V IH, V OH, V OL Power Supply of a Chip Orientation of a chip Outputs of the test bench Context of a variable
5
V IL,V IH, V OH, V OL
6
Power Supply of a Chip
7
Orientation of a Chip
8
Context of a Module Variable
10
Module Template module module_name (,, ) endmodule Input, output wires reg Program Body
11
wire
12
Wires (1): Connect Gates w1 connects the output of G1 to an input of G3.
13
Wires (2): Connect input/output ports to elements within a module IMPORTANT: wire is the only legal type on the left hand side of = in an assign statement. s and c are both wires in this example.
14
Error Message error!correct!
15
Wires (3): Not on the LHS of = or <= t_clock is a reg. This is OK.
16
Error Message
17
module half_adder_tb (X,Y); //output, wires, regs output X,Y; wire X,Y; wire S,C; reg t_X[10000:0]; reg t_Y[10000:0]; reg t_clock; reg [31:0] vectornum; integer fp; …. always @(negedge t_clock) begin X<=t_X[vectornum]; Y<=t_Y[vectornum]; vectornum<=vectornum+1; end ….. endmodule
18
More Examples on the of the wire
19
reg All outputs generated by the always block must be declared to be of type reg. reg is used to suggest that the values behaves like a variable that might be stored in a register.
20
reg
21
A,B, C are connected to the input ports of fig3p37 module.
22
module....endmodule module fig3p37 (A,B,C,D,E); output D,E; input A,B,C; wire w1; and G1(w1,A,B); not G2(E,C); or G3(D,w1,E); endmodule Always start the verilog program with the keyword pair module…endmodule The keyword module must always be terminated by the keyword endmodule.
24
module half_adder_tb (X,Y); //output, wires, regs output X,Y; reg X,Y; wire S,C; reg t_X[10000:0]; reg t_Y[10000:0]; reg t_clock; reg [31:0] vectornum; integer fp; …. always @(negedge t_clock) begin X<=t_X[vectornum]; Y<=t_Y[vectornum]; vectornum<=vectornum+1; end ….. endmodule
27
Legal Uses of reg
28
wire and reg are sometimes Interchangable
29
always statement The sensitivity list contains a list of all signals that will affect the outputs generated by the always block.
30
always @(*) * in the sensitivity list will automatically include all signals on the right side of your statements always @(*) can be used when you want your elements to change their values as one or more of its inputs change. always@ can be used with either non-blocking statement (if you want to execute statements in parallel) or blocking statement (if you want to execute statements sequentially) module half_adder_tb (X,Y); //output, wires, regs output X,Y; reg X,Y; wire S,C; reg t_X[10000:0]; reg t_Y[10000:0]; reg t_clock; reg [31:0] vectornum; integer fp; …. always @(negedge t_clock) begin X<=t_X[vectornum]; Y<=t_Y[vectornum]; vectornum<=vectornum+1; end ….. endmodule
31
Why using always @(*) (Desirable) (incorrect!)
32
Blocking (=)Statements “when the sensitivity list is satisfied, B gets A, C gets B, and D gets C.” But, by the time C gets B, B has been set to A. Likewise, by the time D gets C, C has been set to B, which, as we stated above, has been set to A. Important: Statements with = executes sequentially.
33
(<=) Non-Blocking Statements Important: B gets A’s value, C gets B’s old value, and D gets C’s old value
34
Truth Table for a Full Adder carry-in
35
Karnaugh Map For the Sum Bit (ES112 Review)
36
Karnaugh Map For the Carry-Out Bit (ES112 Review)
37
Implementation of a Full Adder (carry-in)
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.