OpenCores
URL https://opencores.org/ocsvn/yacc/yacc/trunk

Subversion Repositories yacc

[/] [yacc/] [trunk/] [syn/] [xilinx/] [pipelined_rfile.v] - Blame information for rev 2

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 tak.sugawa
//Jun.30.2004 Mux sentibity list bug fix
2
//Jul.2.2004 Cleanup
3
//Jul.7.2004 int bug fix
4
//Jan.20.2005 apply @*
5
`include "define.h"
6
module Pipelined_RegFile(clock,sync_reset,
7
        dest_addrD2,source_addr,target_addr,    wren,memory_wdata,
8
      A_Right_SELD1,A_Left_SELD1,PCD1,IMMD1,ALU_FuncD2,Shift_FuncD2,
9
      Shift_amountD2,RRegSelD1,MOUT,RF_inputD2,alu_source,alu_target,
10
        MWriteD2,MWriteD1,mul_alu_selD2,mul_div_funcD2,pause_out,
11
        Shift_Amount_selD2,int_stateD1,PCCDD
12
        );
13
    parameter adder_type="GENERIC";
14
`ifdef RAM4K
15
        input   [11:0]  PCD1;
16
`else
17
        input   [25:0]  PCD1;
18
`endif
19
        input     [15:0] IMMD1;//Jul.6.2004
20
        input   [4:0]  dest_addrD2;
21
        input   [4:0]  source_addr;
22
        input   [4:0]  target_addr;
23
        input   wren;
24
        input   clock;
25
        input   A_Left_SELD1;
26
        input  [3:0] ALU_FuncD2;
27
        input  [4:0] Shift_amountD2;
28
        input  [1:0]  Shift_FuncD2;
29
        input [1:0] A_Right_SELD1;
30
        input sync_reset;
31
        input [1:0] RRegSelD1;
32
        output  [31:0]  alu_target,alu_source;
33
        output  [31:0]  memory_wdata;
34
        input [31:0] MOUT;
35
        input [1:0] RF_inputD2;
36
        input MWriteD2,MWriteD1;
37
        input   [1:0] mul_alu_selD2;
38
        input [3:0]  mul_div_funcD2;
39
        output pause_out;
40
        input Shift_Amount_selD2;
41
        input int_stateD1;
42
 
43
        reg [31:0] AReg,NReg,RReg,DReg;
44
        reg [31:0] alu_left_latch,alu_right_latch;
45
        reg [31:0] memory_wdata;
46
 
47
`ifdef RAM4K
48
        input [11:0] PCCDD;
49
        reg [11:0] PCD2;
50
`else
51
        input [25:0] PCCDD;
52
        reg [25:0] PCD2;
53
`endif
54
 
55
        reg [15:0] IMMD2;//Jul.6.2004
56
 
57
      reg [4:0]  dadrD3,dadrD4,dadrD5,dadrD6;
58
        reg [4:0]  sadrD1,sadrD2;
59
        reg [4:0]  tadrD1,tadrD2;
60
        reg WD3,WD4,WD5,WD6;
61
        reg [1:0] A_Right_SELD2;
62
        reg [1:0] RRegSelD2,  RRegSelD3, RRegSelD4;
63
        reg [31:0] RRegin;
64
        reg test1D,test2D;
65
        wire  [31:0] alu_right;
66
        reg [31:0] alu_left;
67
 
68
        wire [31:0] source_out,target_out;
69
        wire [31:0] alu_out,shift_out;
70
        wire [31:0] alu_source=alu_left;
71
        wire [31:0] alu_target=alu_right;
72
        wire [31:0] regfile_in;
73
      wire [31:0] test,test2;
74
        wire test1;
75
 
76
        reg  stest1D,stest2D;
77
        reg  stest1D_dup1,stest1D_dup2,stest1D_dup3,stest1D_dup4;
78
        reg [31:0] mul_alu_out;
79
        reg div_mode_ff;
80
        reg sign_ff;
81
        reg RRegSelD4_dup1,RRegSelD4_dup2,RRegSelD4_dup3;
82
 
83
 
84
        wire  mul_div_enable,mul_div_sign,mul_div_mode;
85
 
86
        wire  [31:0] mul_div_out;
87
        wire [31:0] c_mult;
88
        wire [4:0] Shift_Amount;
89
 
90
        localparam [4:0] zero_=0,
91
                                     at_=1,
92
                                     v0_=2,
93
                                     v1_=3,
94
                                     a0_=4,
95
                                     a1_=5,
96
                                     a2_=6,
97
                                     a3_=7,
98
                                     t0_=8, t1_=9,t2_=10,t3_=11,t4_=12,t5_=13,t6_=14,t7_=15,
99
                                     s0_=16,s1_=17,s2_=18,s3_=19,s4_=20,s5_=21,s6_=22,s7_=23,t8_=24,t9_=25,
100
                                     k0_=26,k1_=27,gp_=28,sp_=29,s8_=30,ra_=31;
101
 
102
 
103
 
104
 
105
 
106
        always @(posedge clock) begin
107
 
108
                        dadrD3<=dest_addrD2;
109
                        dadrD4<=dadrD3;
110
                        dadrD5<=dadrD4;
111
                        dadrD6<=dadrD5;
112
 
113
                        tadrD1<=target_addr;
114
                        tadrD2<=tadrD1;
115
 
116
                        sadrD1<=source_addr;
117
                        sadrD2<=sadrD1;
118
 
119
 
120
                        if ( (mul_div_funcD2 ==4'b0000 ) ||
121
                             (mul_div_funcD2 ==4'b0001 ) ||
122
                             (mul_div_funcD2 ==4'b0010 ) ) WD3<=wren;//NOTHING,READLO/HI ˆÈŠO‚ł̓‰ƒCƒg‚ðŽ~‚ß‚é
123
                        else                    WD3<=1'b0;
124
 
125
                        WD4<=WD3;
126
                        WD5<=WD4;
127
                        WD6<=WD5;
128
 
129
                        A_Right_SELD2<=A_Right_SELD1;
130
 
131
                        IMMD2<=IMMD1;
132
                        if (int_stateD1) PCD2<=PCCDD;//Jul.7.2004
133
                        else PCD2<=PCD1;
134
 
135
 
136
                        RRegSelD2<=RRegSelD1;
137
                        RRegSelD3<=RRegSelD2;
138
                        RRegSelD4<=RRegSelD3;
139
                        RRegSelD4_dup1<=RRegSelD3[0];
140
                        RRegSelD4_dup2<=RRegSelD3[0];
141
                        RRegSelD4_dup3<=RRegSelD3[0];
142
 
143
 
144
        end
145
 
146
 
147
 
148
//AReg
149
        always @(posedge clock) begin
150
 
151
                        case (RF_inputD2)
152
                                `RF_ALU_sel :     AReg<=alu_out;
153
                              `RF_Shifter_sel:  AReg<=shift_out;
154
                              `SHIFT16_SEL:   AReg<= {IMMD2[15:0],16'h00};
155
                                `RF_PC_SEL :     AReg<=mul_alu_out;
156
                        endcase
157
        end
158
 
159
//ARegSel
160
        always @(*) begin//Mar.5.2005
161
                        if (! mul_alu_selD2[1] ) mul_alu_out={6'b00_0000,PCD2};
162
                        else    mul_alu_out=c_mult;
163
        end
164
 
165
 
166
 
167
 
168
//NReg
169
        always @(posedge clock)         NReg<=AReg;
170
 
171
 
172
//RReg
173
        always @(posedge clock)         begin
174
                case (RRegSelD4_dup1)
175
                                `MOUT_SEL :     RReg<=MOUT;
176
                                `NREG_SEL:      RReg<=NReg;
177
                               default :         RReg<=MOUT;
178
                        endcase
179
        end
180
 
181
//DReg
182
        always @(posedge clock)         begin
183
                             DReg<=RReg;
184
        end
185
 
186
 
187
 
188
 
189
        always @(*) begin
190
                        case (RRegSelD4_dup2)
191
                                `MOUT_SEL :     RRegin=MOUT;
192
                                `NREG_SEL:      RRegin=NReg;
193
 
194
                              default :         RRegin=MOUT;
195
                        endcase
196
        end
197
//target_reg
198
        always @(*)     memory_wdata=alu_right;
199
 
200
mul_div MulDiv(.clock(clock),.sync_reset(sync_reset),.a(alu_left),.b(alu_right),
201
                          .mul_div_out(c_mult),.mul_div_sign(mul_div_funcD2[1]),
202
                          .mul_div_word(1'b1),.mul_div_mode(mul_div_funcD2[2]),
203
                          .stop_state(pause_out),.mul_div_enable(mul_div_funcD2[3]),.lohi(mul_div_funcD2[0]));
204
 
205
assign mul_div_enable= mul_div_funcD2;
206
        always @(posedge clock) begin
207
                if (sync_reset) div_mode_ff<=1'b0;
208
                else if (mul_div_enable) div_mode_ff<=mul_div_mode;
209
        end
210
 
211
        always @(posedge clock) begin
212
                if (sync_reset) sign_ff<=1'b0;
213
                else if (mul_div_enable) sign_ff<=mul_div_sign;
214
        end
215
 
216
assign mul_div_mode=!(IMMD2[1] ==`MUL_DIV_MUL_SEL);//div high / mul low
217
assign mul_div_sign=!IMMD2[0];
218
 
219
 
220
 
221
alu  alu1(.a(alu_left),.b(alu_right),.alu_func(ALU_FuncD2),.alu_out(alu_out));
222
 
223
 
224
 
225
shifter sh1(.a(alu_right),.shift_out(shift_out),.shift_func(Shift_FuncD2),
226
                  .shift_amount(Shift_Amount));
227
 
228
        assign Shift_Amount=Shift_Amount_selD2==`SHIFT_AMOUNT_REG_SEL ?
229
                                                alu_left[4:0] : Shift_amountD2;
230
 
231
 
232
//alu left latch
233
        always @(posedge clock) begin
234
        begin
235
                        if (sadrD1==dadrD4 && WD4) alu_left_latch<=RRegin;
236
//OK
237
                        else if       (sadrD1==dadrD5 && WD5)   alu_left_latch<=RReg;//This must be priority encoder
238
                        else if    (sadrD1==dadrD6 && WD6)   alu_left_latch<=DReg;
239
                        else  alu_left_latch<=source_out;
240
                                end
241
        end
242
 
243
 
244
//alu right latch
245
        always @(posedge clock) begin
246
        begin
247
                        case (A_Right_SELD1)
248
                                `Imm_signed   :
249
                                                        alu_right_latch<={ {16{IMMD1[15]}},IMMD1[15:0]};
250
                                `Imm_unsigned :
251
                                                        alu_right_latch<={ 16'h000,IMMD1[15:0]};
252
                                `A_RIGHT_ERT  :begin
253
 
254
                                                      if (tadrD1==dadrD4 && WD4 ) alu_right_latch<=RRegin;
255
                                                        else
256
//OK
257
                                                        if (tadrD1==dadrD5 && WD5 )  alu_right_latch<=RReg;
258
                                                        else if (tadrD1==dadrD6 && WD6) alu_right_latch<=DReg;
259
                                                        else alu_right_latch<=target_out;
260
                                             end
261
                                `IMM_26_SEL: begin
262
                                                                alu_right_latch<={6'b00_0000,IMMD1};
263
                                                         end
264
                                default       : alu_right_latch<={ {16{IMMD1[15]}},IMMD1[15:0]};
265
                        endcase
266
                end
267
        end
268
`ifdef ALTERA
269
ram_regfile32xx32 RFile(
270
        .data(regfile_in),
271
        .wraddress(dadrD5),
272
        .rdaddress_a(target_addr),
273
        .rdaddress_b(source_addr),
274
        .wren(WD5),
275
        .clock(clock),
276
        .qa(target_out),
277
        .qb(source_out));
278
`else
279
 
280
ram32x32_xilinx  RFile (
281
        .data(regfile_in),
282
        .wraddress(dadrD5),
283
        .rdaddress_a(target_addr),
284
        .rdaddress_b(source_addr),
285
        .wren(WD5),
286
        .clock(clock),
287
        .qa(target_out),
288
        .qb(source_out));
289
`endif
290
        assign regfile_in=dadrD5==5'b0_0000 ? 32'h0000_0000 :RReg;
291
 
292
 
293
 
294
 
295
        always @* begin //
296
                case (stest1D_dup1)
297
                        1'b1: alu_left[7:0]=AReg[7:0];
298
                        1'b0:
299
                                case(stest2D)
300
                                        1'b1:
301
                                                case (RRegSelD4_dup3)
302
                                                        `MOUT_SEL :     alu_left[7:0]=MOUT[7:0];
303
                                                        `NREG_SEL:      alu_left[7:0]=NReg[7:0];
304
                                                endcase
305
                                        1'b0:   alu_left[7:0]=alu_left_latch[7:0];
306
                                endcase
307
                endcase
308
        end
309
 
310
      always @* begin //
311
                case (stest1D_dup2)
312
                        1'b1: alu_left[15:8]=AReg[15:8];
313
                        1'b0:
314
                                case(stest2D)
315
                                        1'b1:
316
                                                case (RRegSelD4_dup3)
317
                                                        `MOUT_SEL :     alu_left[15:8]=MOUT[15:8];
318
                                                        `NREG_SEL:      alu_left[15:8]=NReg[15:8];
319
                                                endcase
320
                                        1'b0:   alu_left[15:8]=alu_left_latch[15:8];
321
                                endcase
322
                endcase
323
        end
324
 
325
always @* begin//
326
                case (stest1D_dup3)
327
                        1'b1: alu_left[23:16]=AReg[23:16];
328
                        1'b0:
329
                                case(stest2D)
330
                                        1'b1:
331
                                                case (RRegSelD4_dup3)
332
                                                        `MOUT_SEL :     alu_left[23:16]=MOUT[23:16];
333
                                                        `NREG_SEL:      alu_left[23:16]=NReg[23:16];
334
                                                endcase
335
                                        1'b0:   alu_left[23:16]=alu_left_latch[23:16];
336
                                endcase
337
                endcase
338
        end
339
 
340
always @* begin //
341
                case (stest1D_dup4)
342
                        1'b1: alu_left[31:24]=AReg[31:24];
343
                        1'b0:
344
                                case(stest2D)
345
                                        1'b1:
346
                                                case (RRegSelD4_dup3)
347
                                                        `MOUT_SEL :     alu_left[31:24]=MOUT[31:24];
348
                                                        `NREG_SEL:      alu_left[31:24]=NReg[31:24];
349
                                                endcase
350
                                        1'b0:   alu_left[31:24]=alu_left_latch[31:24];
351
                                endcase
352
                endcase
353
        end
354
 
355
 
356
 
357
 
358
        assign alu_right=test1D ? AReg :
359
                         test2D ?   RRegin : alu_right_latch;
360
 
361
        always @(posedge clock) begin
362
                        stest1D<=(sadrD1==dest_addrD2) && wren;
363
                        stest1D_dup1<=(sadrD1==dest_addrD2) && wren;
364
                        stest1D_dup2<=(sadrD1==dest_addrD2) && wren;
365
                        stest1D_dup3<=(sadrD1==dest_addrD2) && wren;
366
                        stest1D_dup4<=(sadrD1==dest_addrD2) && wren;
367
 
368
        end
369
        always @(posedge clock) begin
370
                stest2D<=(sadrD1==dadrD3) && WD3  ;
371
        end
372
 
373
 
374
 
375
 
376
        always @(posedge clock) begin
377
                        test1D<=tadrD1==dest_addrD2 && (wren )  && A_Right_SELD1==`A_RIGHT_ERT;
378
        end
379
 
380
        always @(posedge clock) begin
381
                        test2D<=tadrD1==dadrD3 && (WD3 )  && A_Right_SELD1==`A_RIGHT_ERT;
382
        end
383
 
384
 
385
`ifdef Veritak
386
        reg [30*8:1] alu_function;
387
        reg [30*8:1] shift_function;
388
        reg [30*8:1] AReg_Input_Sel;
389
 
390
        always @*//Jan.20.2005 @(ALU_FuncD2,alu_left,alu_right)
391
                case (ALU_FuncD2)
392
                        `ALU_NOTHING : $sprintf(alu_function,"non_operation");
393
                        `ALU_ADD        : $sprintf(alu_function,"ADD %h,%h",alu_left,alu_right);
394
                        `ALU_SUBTRACT :$sprintf(alu_function,"SUB %h,%h,alu_left,alu_right");
395
                        `ALU_LESS_THAN_UNSIGNED :$sprintf(alu_function ,"LT_Unsigned %h,%h",alu_left,alu_right);
396
                        `ALU_LESS_THAN_SIGNED   : $sprintf(alu_function,"LT_Signed %h,%h",alu_left,alu_right);
397
                        `ALU_OR   : $sprintf(alu_function,"OR %h,%h",alu_left,alu_right);
398
                        `ALU_AND : $sprintf(alu_function,"XOR %h,%h,alu_left,alu_right");
399
                        `ALU_XOR : $sprintf(alu_function,"AND %h,%h",alu_left,alu_right);
400
                        `ALU_NOR : $sprintf(alu_function,"NOR %h,%h",alu_left,alu_right);
401
                        default: $sprintf(alu_function,"non_operation");
402
                endcase
403
 
404
        always @* begin //
405
                case (Shift_FuncD2)
406
                        `SHIFT_LEFT : $sprintf(shift_function,"SLL %d",Shift_Amount);
407
                        `SHIFT_RIGHT_UNSIGNED : $sprintf(shift_function,"SLR %d",Shift_Amount);
408
                        `SHIFT_RIGHT_SIGNED : $sprintf(shift_function,"SAR %d",Shift_Amount);
409
                        default: $sprintf(shift_function,"non_operation");
410
                endcase
411
        end
412
 
413
 
414
        always @* begin //
415
                        case (RF_inputD2)
416
                                `RF_ALU_sel :     $sprintf(AReg_Input_Sel,"ALU");
417
                              `RF_Shifter_sel:  $sprintf(AReg_Input_Sel,"Shifter");
418
                              `SHIFT16_SEL:   $sprintf(AReg_Input_Sel,"IMM16<<16");
419
                                `RF_PC_SEL :     $sprintf(AReg_Input_Sel,"PC/MulOutSEL");
420
                        endcase
421
        end
422
 
423
 
424
`endif
425
 
426
 
427
 
428
 
429
endmodule

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.