-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathentropy_encoder.v
151 lines (145 loc) · 5.65 KB
/
entropy_encoder.v
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
module entropy_encoder #(
parameter TOP_RANGE_WIDTH = 16,
parameter TOP_LOW_WIDTH = 24,
parameter TOP_SYMBOL_WIDTH = 4,
parameter TOP_LUT_ADDR_WIDTH = 8,
parameter TOP_LUT_DATA_WIDTH = 16,
parameter TOP_BITSTREAM_WIDTH = 8,
parameter TOP_D_SIZE = 5,
parameter TOP_ADDR_CARRY_WIDTH = 4
)(
input top_clk,
input top_reset,
input top_flag_first,
/* top_final_flag will be sent in 1 exactly in the next clock cycle after
the last input. */
input top_final_flag,
input [(TOP_RANGE_WIDTH-1):0] top_fl, top_fh,
input [(TOP_SYMBOL_WIDTH-1):0] top_symbol_1, top_symbol_2, top_symbol_3,
input [(TOP_SYMBOL_WIDTH-1):0] top_symbol_4,
input [TOP_SYMBOL_WIDTH:0] top_nsyms,
input top_bool_1, top_bool_2, top_bool_3, top_bool_4,
output wire [(TOP_BITSTREAM_WIDTH-1):0] OUT_BIT_1_1, OUT_BIT_1_2, OUT_BIT_1_3,
output wire [(TOP_BITSTREAM_WIDTH-1):0] OUT_BIT_1_4, OUT_BIT_1_5,
output wire [(TOP_BITSTREAM_WIDTH-1):0] OUT_BIT_2_1, OUT_BIT_2_2, OUT_BIT_2_3,
output wire [(TOP_BITSTREAM_WIDTH-1):0] OUT_BIT_2_4, OUT_BIT_2_5,
output wire [2:0] OUT_FLAG_BITSTREAM_1, OUT_FLAG_BITSTREAM_2,
output wire OUT_FLAG_LAST
);
/*In order to ensure that all the necessary flags in the Carry propagation
block will be correctly initiated, I will propagate a flag called flag_first
able to set all flags to zero without requiring any other flag.
This is a temporary way to ensure that all flags are correctly defined
when the first bitstream comes through.
The following lines will just propagate this signal between the blocks
*/
reg reg_first_1_2, reg_first_2_3, reg_first_3_4;
always @ (posedge top_clk) begin
reg_first_1_2 <= top_flag_first;
reg_first_2_3 <= reg_first_1_2;
reg_first_3_4 <= reg_first_2_3;
// reg_first_3_4 register is also the input for the Stage_4
end
// The 3 following registers will be used to keep the final 1 flag
reg reg_final_exec_1_2, reg_final_exec_2_3, reg_final_exec_3_4;
always @ (posedge top_clk) begin
if(top_reset) begin
reg_final_exec_1_2 <= 1'b0;
reg_final_exec_2_3 <= 1'b0;
reg_final_exec_3_4 <= 1'b0;
end else begin
reg_final_exec_1_2 <= top_final_flag;
reg_final_exec_2_3 <= reg_final_exec_1_2;
reg_final_exec_3_4 <= reg_final_exec_2_3;
end
end
// ARITHMETIC ENCODER OUTPUT CONNECTIONS
// ALl arithmetic encoder outputs come from registers
// Therefore, it isn't necessary to create more registers here
wire [(TOP_RANGE_WIDTH-1):0] pb_1_1, pb_1_2, pb_2_1, pb_2_2;
wire [(TOP_RANGE_WIDTH-1):0] pb_3_1, pb_3_2, pb_4_1, pb_4_2;
wire [(TOP_RANGE_WIDTH-1):0] out_arith_range;
wire [(TOP_D_SIZE-1):0] out_arith_cnt;
wire [(TOP_LOW_WIDTH-1):0] out_arith_low;
wire [1:0] pb_flag_1, pb_flag_2, pb_flag_3, pb_flag_4;
arithmetic_encoder #(
.GENERAL_RANGE_WIDTH (TOP_RANGE_WIDTH),
.GENERAL_LOW_WIDTH (TOP_LOW_WIDTH),
.GENERAL_SYMBOL_WIDTH (TOP_SYMBOL_WIDTH),
.GENERAL_LUT_ADDR_WIDTH (TOP_LUT_ADDR_WIDTH),
.GENERAL_LUT_DATA_WIDTH (TOP_LUT_DATA_WIDTH),
.GENERAL_D_SIZE (TOP_D_SIZE)
) arith_encoder (
.general_clk (top_clk),
.reset (top_reset), // send to the arith_encoder only the reset itself
.general_fl (top_fl),
.general_fh (top_fh),
.general_nsyms (top_nsyms),
.general_symbol_1 (top_symbol_1),
.general_symbol_2 (top_symbol_2),
.general_symbol_3 (top_symbol_3),
.general_symbol_4 (top_symbol_4),
.general_bool_1 (top_bool_1),
.general_bool_2 (top_bool_2),
.general_bool_3 (top_bool_3),
.general_bool_4 (top_bool_4),
// outputs
.RANGE_OUTPUT (out_arith_range),
.LOW_OUTPUT (out_arith_low),
.CNT_OUTPUT (out_arith_cnt),
.PB_1_1 (pb_1_1),
.PB_1_2 (pb_1_2),
.PB_2_1 (pb_2_1),
.PB_2_2 (pb_2_2),
.PB_3_1 (pb_3_1),
.PB_3_2 (pb_3_2),
.PB_4_1 (pb_4_1),
.PB_4_2 (pb_4_2),
.PB_FLAG_1 (pb_flag_1),
.PB_FLAG_2 (pb_flag_2),
.PB_FLAG_3 (pb_flag_3),
.PB_FLAG_4 (pb_flag_4)
);
stage_4 #(
.S4_RANGE_WIDTH (TOP_RANGE_WIDTH),
.S4_LOW_WIDTH (TOP_LOW_WIDTH),
.S4_SYMBOL_WIDTH (TOP_SYMBOL_WIDTH),
.S4_LUT_ADDR_WIDTH (TOP_LUT_ADDR_WIDTH),
.S4_LUT_DATA_WIDTH (TOP_LUT_DATA_WIDTH),
.S4_BITSTREAM_WIDTH (TOP_BITSTREAM_WIDTH),
.S4_D_SIZE (TOP_D_SIZE),
.S4_ADDR_CARRY_WIDTH (TOP_ADDR_CARRY_WIDTH)
) state_pipeline_4 (
.s4_clk (top_clk),
.s4_reset (top_reset),
.s4_flag_first (reg_first_3_4),
.s4_final_flag (reg_final_exec_3_4),
.s4_final_flag_2_3 (reg_final_exec_2_3),
.in_arith_bitstream_1_1 (pb_1_1), .in_arith_bitstream_1_2 (pb_1_2),
.in_arith_bitstream_2_1 (pb_2_1), .in_arith_bitstream_2_2 (pb_2_2),
.in_arith_bitstream_3_1 (pb_3_1), .in_arith_bitstream_3_2 (pb_3_2),
.in_arith_bitstream_4_1 (pb_4_1), .in_arith_bitstream_4_2 (pb_4_2),
.in_arith_range (out_arith_range),
.in_arith_cnt(out_arith_cnt),
.in_arith_low (out_arith_low),
.in_arith_flag_1 (pb_flag_1),
.in_arith_flag_2 (pb_flag_2),
.in_arith_flag_3 (pb_flag_3),
.in_arith_flag_4 (pb_flag_4),
// outputs
.out_carry_flag_bitstream_1 (OUT_FLAG_BITSTREAM_1),
.out_carry_bit_1_1 (OUT_BIT_1_1),
.out_carry_bit_1_2 (OUT_BIT_1_2),
.out_carry_bit_1_3 (OUT_BIT_1_3),
.out_carry_bit_1_4 (OUT_BIT_1_4),
.out_carry_bit_1_5 (OUT_BIT_1_5),
// ---
.out_carry_flag_bitstream_2 (OUT_FLAG_BITSTREAM_2),
.out_carry_bit_2_1 (OUT_BIT_2_1),
.out_carry_bit_2_2 (OUT_BIT_2_2),
.out_carry_bit_2_3 (OUT_BIT_2_3),
.out_carry_bit_2_4 (OUT_BIT_2_4),
.out_carry_bit_2_5 (OUT_BIT_2_5),
.output_flag_last (OUT_FLAG_LAST)
);
endmodule