aboutsummaryrefslogtreecommitdiffstats
path: root/tests/simple/constmuldivmod.v
blob: 5dd8f9295afe07d80ede06d906a9b2b9390dc5bf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
module constmuldivmod(input [7:0] A, input [5:0] mode, output reg [7:0] Y);
	always @* begin
		case (mode)
			0: Y = A / 8'd0;
			1: Y = A % 8'd0;
			2: Y = A * 8'd0;

			3: Y = A / 8'd1;
			4: Y = A % 8'd1;
			5: Y = A * 8'd1;

			6: Y = A / 8'd2;
			7: Y = A % 8'd2;
			8: Y = A * 8'd2;

			9: Y = A / 8'd4;
			10: Y = A % 8'd4;
			11: Y = A * 8'd4;

			12: Y = A / 8'd8;
			13: Y = A % 8'd8;
			14: Y = A * 8'd8;

			15: Y = $signed(A) / $signed(8'd0);
			16: Y = $signed(A) % $signed(8'd0);
			17: Y = $signed(A) * $signed(8'd0);

			18: Y = $signed(A) / $signed(8'd1);
			19: Y = $signed(A) % $signed(8'd1);
			20: Y = $signed(A) * $signed(8'd1);

			21: Y = $signed(A) / $signed(8'd2);
			22: Y = $signed(A) % $signed(8'd2);
			23: Y = $signed(A) * $signed(8'd2);

			24: Y = $signed(A) / $signed(8'd4);
			25: Y = $signed(A) % $signed(8'd4);
			26: Y = $signed(A) * $signed(8'd4);

			27: Y = $signed(A) / $signed(8'd8);
			28: Y = $signed(A) % $signed(8'd8);
			29: Y = $signed(A) * $signed(8'd8);

			30: Y = $signed(A) / $signed(-8'd0);
			31: Y = $signed(A) % $signed(-8'd0);
			32: Y = $signed(A) * $signed(-8'd0);

			33: Y = $signed(A) / $signed(-8'd1);
			34: Y = $signed(A) % $signed(-8'd1);
			35: Y = $signed(A) * $signed(-8'd1);

			36: Y = $signed(A) / $signed(-8'd2);
			37: Y = $signed(A) % $signed(-8'd2);
			38: Y = $signed(A) * $signed(-8'd2);

			39: Y = $signed(A) / $signed(-8'd4);
			40: Y = $signed(A) % $signed(-8'd4);
			41: Y = $signed(A) * $signed(-8'd4);

			42: Y = $signed(A) / $signed(-8'd8);
			43: Y = $signed(A) % $signed(-8'd8);
			44: Y = $signed(A) * $signed(-8'd8);

			default: Y = 8'd16 * A;
		endcase
	end
endmodule