mirror of
https://github.com/YosysHQ/yosys
synced 2025-08-30 06:50:09 +00:00
Add tests for Xilinx UG901 examples
This commit is contained in:
parent
0d037bf9d8
commit
2ae7dec530
89 changed files with 2962 additions and 0 deletions
33
tests/xilinx_ug901/mult_unsigned.v
Normal file
33
tests/xilinx_ug901/mult_unsigned.v
Normal file
|
@ -0,0 +1,33 @@
|
|||
// Unsigned 16x24-bit Multiplier
|
||||
// 1 latency stage on operands
|
||||
// 3 latency stage after the multiplication
|
||||
// File: multipliers2.v
|
||||
//
|
||||
module mult_unsigned (clk, A, B, RES);
|
||||
//Default parameters were changed because of slow test
|
||||
//parameter WIDTHA = 16;
|
||||
//parameter WIDTHB = 24;
|
||||
parameter WIDTHA = 8;
|
||||
parameter WIDTHB = 12;
|
||||
input clk;
|
||||
input [WIDTHA-1:0] A;
|
||||
input [WIDTHB-1:0] B;
|
||||
output [WIDTHA+WIDTHB-1:0] RES;
|
||||
|
||||
reg [WIDTHA-1:0] rA;
|
||||
reg [WIDTHB-1:0] rB;
|
||||
reg [WIDTHA+WIDTHB-1:0] M [3:0];
|
||||
|
||||
integer i;
|
||||
always @(posedge clk)
|
||||
begin
|
||||
rA <= A;
|
||||
rB <= B;
|
||||
M[0] <= rA * rB;
|
||||
for (i = 0; i < 3; i = i+1)
|
||||
M[i+1] <= M[i];
|
||||
end
|
||||
|
||||
assign RES = M[3];
|
||||
|
||||
endmodule
|
Loading…
Add table
Add a link
Reference in a new issue