blob: 4ac6464a83d07e94e4c62376556d15e93dbe9073 (
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
|
module lzc_128 (
input [127:0] a,
output [6:0] c,
output v
);
logic [5:0] z0;
logic [5:0] z1;
logic v0;
logic v1;
logic s0;
logic s1;
logic s2;
logic s3;
logic s4;
logic s5;
logic s6;
logic s7;
logic s8;
logic s9;
logic s10;
logic s11;
logic s12;
logic s13;
logic s14;
lzc_64 lzc_64_comp_0 (
.a(a[63:0]),
.c(z0),
.v(v0)
);
lzc_64 lzc_64_comp_1 (
.a(a[127:64]),
.c(z1),
.v(v1)
);
assign s0 = v1 | v0;
assign s1 = (~v1) & z0[0];
assign s2 = z1[0] | s1;
assign s3 = (~v1) & z0[1];
assign s4 = z1[1] | s3;
assign s5 = (~v1) & z0[2];
assign s6 = z1[2] | s5;
assign s7 = (~v1) & z0[3];
assign s8 = z1[3] | s7;
assign s9 = (~v1) & z0[4];
assign s10 = z1[4] | s9;
assign s11 = (~v1) & z0[5];
assign s12 = z1[5] | s11;
assign v = s0;
assign c[0] = s2;
assign c[1] = s4;
assign c[2] = s6;
assign c[3] = s8;
assign c[4] = s10;
assign c[5] = s12;
assign c[6] = v1;
endmodule
|