陈飞龙 发表于 2017-10-14 15:16:09

Verilog HDL Unsigned Multiply-Accumulator

Example 12-5: Verilog HDL Unsigned Multiply-Accumulator
module unsig_altmult_accum (dataout, dataa, datab, clk, aclr, clken);
input dataa, datab;
input clk, aclr, clken;
output reg dataout;
reg dataa_reg, datab_reg;
reg multa_reg;
wire multa;
wire adder_out;
assign multa = dataa_reg * datab_reg;
assign adder_out = multa_reg + dataout;
always @ (posedge clk or posedge aclr)
begin
if (aclr)
begin
dataa_reg <= 8'b0;
datab_reg <= 8'b0;
multa_reg <= 16'b0;
dataout <= 17'b0;
end
else if (clken)
begin
dataa_reg <= dataa;
datab_reg <= datab;
multa_reg <= multa;
dataout <= adder_out;
end
end
endmodule

陈飞龙 发表于 2017-10-14 15:21:34

8位乘法器的写法,ALTERA的代码

小舍YZ 发表于 2017-10-14 17:01:38

谢谢分享。。。。。。。。。。。。。。:lol
页: [1]
查看完整版本: Verilog HDL Unsigned Multiply-Accumulator