I am writing Verilog code for a 4-bit BCD adder. I am having trouble writing the top module and understanding how to call the other modules into the top module. Here are my codes.
module topmodule(x, y, cin, cout, hex0, hex1, hex2, hex3, hex4, hex5, L5, fulladder, ssdxconverter, ssdyconverter, sumconverter);
input [3:0] x;
input [3:0] y;
input cin;
output cout;
output [13:0] hex0;
output [13:0] hex2;
output [13:0] hex4;
wire
///4-bit adder///////////////////////////////////////////////////////////////////////////
module L5(cin, x, y, sum, cout);
input [3:0] x;
input [3:0] y;
input cin;
output cout;
output [3:0] sum;
wire [3:1] carryout;// since carryout starts with 1 ends wtih 2 (total 3) for this 4 bit adder
fulladder(cin, x[0], y[0], sum[0], carryout[1]);// need cin, x0,y0, to produce cout1 and sum0
fulladder(carryout[1], x[1], y[1], sum[1], carryout[2]);// need cout1, x1,y1, to produce cout2 and sum1
fulladder(carryout[2], x[2], y[2], sum[2], carryout[3]);// need cout2, x2,y2, to produce cout3 and sum2
fulladder(carryout[3], x[3], y[3], sum[3], cout);// need cout3, x3,y3, to produce cout and sum3
endmodule
//singlebit adder//////////////////////////////////////////////////////////////////////////////////////////
module fulladder(x, y, cin, sum, cout); // declaring the name of this project FA(full adder) and all the elements within the code
input x, y, cin;// inputs are a, b, and cin
output sum, cout;// outputs are sum and cout
wire w0, w1, w2;// using wire to connect input and output with some other element in the circuit
xor u0(w0,x,y);
xor u1(sum,w0,cin);
and u2(w1,cin,w0);
and u3(w2,x,y);
or u4(cout,w1,w2); // we are adding gate names before the bracketA
endmodule
//x converter//////////////////////////////////////////////////////////////////
module ssdxconverter(x, hex0);
input [3:0] x;
input [3:0] y;
output reg [13:0] hex0;
always @(x)
begin
case(x)
4'b0000:hex0 = 14'b1111111_1000000;//0
4'b0001:hex0 = 14'b1111111_1111001;//1
4'b0010:hex0 = 14'b1111111_0100100;//2
4'b0011:hex0 = 14'b1111111_0110000;//3
4'b0100:hex0 = 14'b1111111_0011001;//4
4'b0101:hex0 = 14'b1111111_0010010;//5
4'b0110:hex0 = 14'b1111111_0000010;//6
4'b0111:hex0 = 14'b1111111_1111000;//7
4'b1000:hex0 = 14'b1111111_0000000;//8
4'b1001:hex0 = 14'b1111111_0010000;//9
4'b1010:hex0 = 14'b1111001_1000000;//10
4'b1011:hex0 = 14'b1111001_1111001;//11
4'b1100:hex0 = 14'b1111001_0100100;//12
4'b1101:hex0 = 14'b1111001_0110000;//13
4'b1110:hex0 = 14'b1111001_0011001;//14
4'b1111:hex0 = 14'b1111001_0010010;//15
endcase
end
endmodule
///y converter
module ssdyconverter(y,hex2);
input [3:0] y;
output reg [13:0] hex2;
always @(y)
begin
case(y)
4'b0000:hex2 = 14'b1111111_1000000;//0
4'b0001:hex2 = 14'b1111111_1111001;//1
4'b0010:hex2 = 14'b1111111_0100100;//2
4'b0011:hex2 = 14'b1111111_0110000;//3
4'b0100:hex2 = 14'b1111111_0011001;//4
4'b0101:hex2 = 14'b1111111_0010010;//5
4'b0110:hex2 = 14'b1111111_0000010;//6
4'b0111:hex2 = 14'b1111111_1111000;//7
4'b1000:hex2 = 14'b1111111_0000000;//8
4'b1001:hex2 = 14'b1111111_0010000;//9
4'b1010:hex2 = 14'b1111001_1000000;//10
4'b1011:hex2 = 14'b1111001_1111001;//11
4'b1100:hex2 = 14'b1111001_0100100;//12
4'b1101:hex2 = 14'b1111001_0110000;//13
4'b1110:hex2 = 14'b1111001_0011001;//14
4'b1111:hex2 = 14'b1111001_0010010;//15
endcase
end
endmodule
///bcdoutput converter///////////////////////////////////////////////////////////////////////////
module sumconverter(sum, c, hex4);
input c;
input [3:0]sum;
output reg [13:0] hex4;
always @(sum)
begin
if(c==0)
case(sum)
4'b0000:hex4 = 14'b1111111_1000000;//0
4'b0001:hex4 = 14'b1111111_1111001;//1
4'b0010:hex4 = 14'b1111111_0100100;//2
4'b0011:hex4 = 14'b1111111_0110000;//3
4'b0100:hex4 = 14'b1111111_0011001;//4
4'b0101:hex4 = 14'b1111111_0010010;//5
4'b0110:hex4 = 14'b1111111_0000010;//6
4'b0111:hex4 = 14'b1111111_1111000;//7
4'b1000:hex4 = 14'b1111111_0000000;//8
4'b1001:hex4 = 14'b1111111_0010000;//9
4'b1010:hex4 = 14'b1111001_1000000;//10
4'b1011:hex4 = 14'b1111001_1111001;//11
4'b1100:hex4 = 14'b1111001_0100100;//12
4'b1101:hex4 = 14'b1111001_0110000;//13
4'b1110:hex4 = 14'b1111001_0011001;//14
4'b1111:hex4 = 14'b1111001_0010010;//15
endcase
else if(c==1)
begin
case(sum)
4'b0000:hex4 = 14'b1111001_0000010;//16//c4 is 1
4'b0001:hex4 = 14'b1111001_1111000;//17
4'b0010:hex4 = 14'b1111001_0000000;//18
4'b0011:hex4 = 14'b1111001_0010000;//19
4'b0100:hex4 = 14'b0100100_1000000;//20
4'b0101:hex4 = 14'b0100100_1111001;//21
4'b0110:hex4 = 14'b0100100_0100100;//22
4'b0111:hex4 = 14'b0100100_0110000;//23
4'b1000:hex4 = 14'b0100100_0011001;//24
4'b1001:hex4 = 14'b0100100_0010010;//25
4'b1010:hex4 = 14'b0100100_0000010;//26
4'b1011:hex4 = 14'b0100100_1111000;//27
4'b1100:hex4 = 14'b0100100_0000000;//28
4'b1101:hex4 = 14'b0100100_0010000;//29
4'b1110:hex4 = 14'b0110000_1000000;//30
4'b1111:hex4 = 14'b0110000_1111001;//31
endcase
end
end
endmodule
```
fulladder adder_1(...ports...);. \$\endgroup\$