source: XOpenSparcT1/trunk/T1-CPU/spu/spu_maaddr.v @ 6

Revision 6, 34.2 KB checked in by pntsvt00, 14 years ago (diff)

versione iniziale opensparc

Line 
1// ========== Copyright Header Begin ==========================================
2//
3// OpenSPARC T1 Processor File: spu_maaddr.v
4// Copyright (c) 2006 Sun Microsystems, Inc.  All Rights Reserved.
5// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES.
6//
7// The above named program is free software; you can redistribute it and/or
8// modify it under the terms of the GNU General Public
9// License version 2 as published by the Free Software Foundation.
10//
11// The above named program is distributed in the hope that it will be
12// useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
13// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14// General Public License for more details.
15//
16// You should have received a copy of the GNU General Public
17// License along with this work; if not, write to the Free Software
18// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
19//
20// ========== Copyright Header End ============================================
21////////////////////////////////////////////////////////////////////////
22/*
23//      Description:    adderss generator for MA.
24//                      MPA,MA_ADDR,LENGTH,I_PTR,J_PTR...
25*/
26////////////////////////////////////////////////////////////////////////
27// Global header file includes
28////////////////////////////////////////////////////////////////////////
29
30module spu_maaddr (
31
32/*outputs*/
33spu_maaddr_len_neqz,
34spu_maaddr_mpa1maddr0,
35spu_maaddr_memindx,
36spu_maaddr_mamem_eveodd_sel_l,
37spu_maaddr_iequtwolenplus2,
38spu_maaddr_iequtwolenplus1,
39spu_maaddr_jequiminus1,
40spu_maaddr_jequlen,
41
42spu_maaddr_halfpnt_set,
43
44spu_maaddr_len_eqmax,
45
46spu_maaddr_esmax,
47spu_maaddr_esmod64,
48
49spu_maaddr_nooddwr_on_leneq1,
50
51spu_maaddr_mpa_addrinc,
52spu_maaddr_mpa_wen,
53spu_maaddr_mpa_incr_val,
54
55spu_maaddr_len_cntr,
56
57spu_maaddr_wrindx_0,
58spu_maaddr_jptr_eqz_mared,
59
60/*inputs*/
61
62spu_mald_force_mpa_add16,
63
64spu_mactl_iss_pulse_pre,
65spu_mactl_iss_pulse,
66
67
68//spu_mactl_mulop,
69spu_mactl_ldop,
70spu_madp_maaddr_reg_in,
71spu_madp_mactl_reg,
72
73spu_mald_maaddr_addrinc,
74spu_mald_mpa_addrinc,
75spu_mast_maaddr_addrinc,
76spu_mast_mpa_addrinc,
77
78spu_mamul_memwen,
79
80spu_mamul_rst_iptr,
81spu_mamul_rst_jptr,
82spu_mamul_incr_iptr,
83spu_mamul_incr_jptr,
84
85spu_mamul_a_rd_oprnd_sel,
86spu_mamul_ax_rd_oprnd_sel,
87spu_mamul_b_rd_oprnd_sel,
88spu_mamul_ba_rd_oprnd_sel,
89spu_mamul_m_rd_oprnd_sel,
90spu_mamul_n_rd_oprnd_sel,
91spu_mamul_m_wr_oprnd_sel,
92
93spu_mared_me_rd_oprnd_sel,
94spu_mared_xe_wr_oprnd_sel,
95spu_mamul_me_rd_oprnd_sel,
96spu_mamul_me_wr_oprnd_sel,
97
98spu_mamul_i_ptr_sel,
99spu_mamul_iminus1_ptr_sel,
100spu_mamul_j_ptr_sel,
101spu_mamul_iminusj_ptr_sel,
102spu_mamul_iminuslenminus1_sel,
103
104spu_mamul_jjptr_wen,
105
106spu_mared_m_rd_oprnd_sel,
107spu_mared_nm_rd_oprnd_sel,
108spu_mared_x_wr_oprnd_sel,
109spu_mared_a_rd_oprnd_sel,
110spu_mared_nr_rd_oprnd_sel,
111spu_mared_r_wr_oprnd_sel,
112spu_mared_memwen,
113spu_mared_j_ptr_sel,
114spu_mared_update_jptr,
115spu_mared_rst_jptr,
116spu_mared_maxlen_wen,
117spu_mared_cin_set_4sub,
118
119spu_mast_memren,
120spu_mared_start_wen,
121spu_mared_start_sel,
122
123spu_maexp_incr_es_ptr,
124spu_maexp_e_rd_oprnd_sel,
125spu_maexp_es_max_init,
126spu_maexp_es_e_ptr_rst,
127
128spu_madp_mpa_addr_3,
129
130
131
132spu_maaddr_jequiminus1rshft,
133spu_maaddr_iequtwolen,
134spu_maaddr_ieven,
135spu_maaddr_ieq0,
136
137spu_maaddr_aequb,
138
139spu_maaeqb_memwen,
140spu_maaeqb_irshft_sel,
141
142spu_mared_update_redwr_jptr,
143spu_mared_jjptr_wen,
144
145spu_mamul_jjptr_sel,
146
147mem_bypass,
148sehold,
149
150spu_mamul_rst,
151
152se,
153reset,
154rclk);
155
156// ---------------------------------------------------------------
157input reset;
158input rclk;
159input se;
160
161
162input spu_mald_force_mpa_add16;
163
164input spu_mactl_ldop;
165//input spu_mactl_mulop;
166input [47:0] spu_madp_maaddr_reg_in;
167input [5:0] spu_madp_mactl_reg;
168
169input spu_mald_maaddr_addrinc;
170input spu_mald_mpa_addrinc;
171input spu_mast_maaddr_addrinc;
172input spu_mast_mpa_addrinc;
173
174input spu_mamul_memwen;
175input spu_mamul_rst_iptr;
176input spu_mamul_rst_jptr;
177input spu_mamul_incr_iptr;
178input spu_mamul_incr_jptr;
179
180input spu_mamul_a_rd_oprnd_sel;
181input spu_mamul_ax_rd_oprnd_sel;
182input spu_mamul_b_rd_oprnd_sel;
183input spu_mamul_ba_rd_oprnd_sel;
184input spu_mamul_m_rd_oprnd_sel;
185input spu_mamul_n_rd_oprnd_sel;
186input spu_mamul_m_wr_oprnd_sel;
187
188input spu_mared_me_rd_oprnd_sel;
189input spu_mared_xe_wr_oprnd_sel;
190input spu_mamul_me_rd_oprnd_sel;
191input spu_mamul_me_wr_oprnd_sel;
192
193input spu_mamul_i_ptr_sel;
194input spu_mamul_iminus1_ptr_sel;
195input spu_mamul_j_ptr_sel;
196input spu_mamul_iminusj_ptr_sel;
197input spu_mamul_iminuslenminus1_sel;
198
199input spu_mamul_jjptr_wen;
200
201input spu_mactl_iss_pulse_pre;
202input spu_mactl_iss_pulse;
203
204input spu_mared_m_rd_oprnd_sel;
205input spu_mared_nm_rd_oprnd_sel;
206input spu_mared_x_wr_oprnd_sel;
207input spu_mared_a_rd_oprnd_sel;
208input spu_mared_nr_rd_oprnd_sel;
209input spu_mared_r_wr_oprnd_sel;
210input spu_mared_memwen;
211input spu_mared_j_ptr_sel;
212input spu_mared_update_jptr;
213input spu_mared_rst_jptr;
214input spu_mared_maxlen_wen;
215input spu_mared_cin_set_4sub;
216
217input spu_mast_memren;
218input spu_mared_start_wen;
219input spu_mared_start_sel;
220
221input spu_maexp_incr_es_ptr;
222input spu_maexp_e_rd_oprnd_sel;
223input spu_maexp_es_max_init;
224input spu_maexp_es_e_ptr_rst;
225
226
227input spu_madp_mpa_addr_3;
228input spu_maaeqb_memwen;
229input spu_maaeqb_irshft_sel;
230
231input spu_mared_update_redwr_jptr;
232input spu_mared_jjptr_wen;
233
234input spu_mamul_jjptr_sel;
235
236input mem_bypass;
237input sehold;
238
239input spu_mamul_rst;
240// ---------------------------------------------------------------
241output spu_maaddr_len_neqz;
242
243output spu_maaddr_mpa1maddr0;
244
245output [7:1] spu_maaddr_memindx;
246output [3:0] spu_maaddr_mamem_eveodd_sel_l;
247
248output spu_maaddr_iequtwolenplus2;
249output spu_maaddr_iequtwolenplus1;
250output spu_maaddr_jequiminus1;
251output spu_maaddr_jequlen;
252
253output spu_maaddr_halfpnt_set;
254
255output spu_maaddr_len_eqmax;
256
257output spu_maaddr_esmod64;
258output spu_maaddr_esmax;
259
260output spu_maaddr_nooddwr_on_leneq1;
261
262output spu_maaddr_mpa_addrinc;
263output spu_maaddr_mpa_wen;
264output [4:0] spu_maaddr_mpa_incr_val;
265
266
267
268
269output spu_maaddr_jequiminus1rshft;
270output spu_maaddr_iequtwolen;
271output spu_maaddr_ieven;
272output spu_maaddr_ieq0;
273
274output spu_maaddr_aequb;
275
276output [5:0] spu_maaddr_len_cntr;
277
278output spu_maaddr_wrindx_0;
279output spu_maaddr_jptr_eqz_mared;
280
281// ---------------------------------------------------------------
282// ---------------------------------------------------------------
283// ---------------------------------------------------------------
284
285wire reset_local = reset | spu_mactl_iss_pulse_pre;
286
287// ---------------------------------------------------------------
288// ---------------------------------------------------------------
289// ---------------------------------------------------------------
290
291wire [47:0] spu_madp_maaddr_reg;
292wire [6:0] len_decr_val,len_ptr_sub_q,len_ptr_mx,len_ptr_sub;
293wire incr_2wd;
294wire [1:0] len_1or2_dec;
295
296wire [7:0] maaddr_mx,maaddr_incr_val,spu_maaddr_maaddr_add,spu_maaddr_maaddr_q;
297wire maaddr_wen;
298
299wire [6:0] j_ptr_data;
300// ---------------------------------------------------------------
301// ---------------------------------------------------------------
302
303dffe_s  #(48) maaddr_reg_ff  (
304        .din(spu_madp_maaddr_reg_in[47:0]) ,
305        .q(spu_madp_maaddr_reg[47:0]),
306        .en(spu_mactl_iss_pulse_pre),
307        .clk (rclk), .se(se), .si(), .so());
308
309
310// ---------------------------------------------------------------
311wire spu_maaddr_maaddr_addrinc = spu_mald_maaddr_addrinc | spu_mast_maaddr_addrinc;
312assign spu_maaddr_mpa_addrinc = spu_mald_mpa_addrinc | spu_mast_mpa_addrinc;
313// ---------------------------------------------------------------
314// ***************** LEN *******************
315// --------------------------------------------------------------
316
317wire len_wen = spu_maaddr_maaddr_addrinc | spu_mactl_iss_pulse;
318
319mux2ds  #(7) len_issorex_mx (
320        .in0    (len_ptr_sub_q[6:0]), 
321        .in1    ({1'b0,spu_madp_mactl_reg[5:0]}), 
322        .sel0   (spu_maaddr_maaddr_addrinc), 
323        .sel1   (~spu_maaddr_maaddr_addrinc),
324        .dout   (len_ptr_mx[6:0])
325);
326
327// for memload decr by 16bytes(2words) and for memstore & mulop decr by
328// 8bytes(1word) or when transferring one word rather than two from
329// ld buf to mamem.
330
331
332mux2ds  #(2) len_1or2_mx (
333        .in0    (2'b01), // already inverted
334        .in1    (2'b10), 
335        .sel0   (incr_2wd),
336        .sel1   (~incr_2wd),
337        .dout   (len_1or2_dec[1:0])
338);
339
340
341mux2ds  #(7) len_ptr_iss_mx (
342        .in0    (7'b0000000), 
343        .in1    ({5'b11111,len_1or2_dec[1:0]}), 
344        .sel0   (spu_mactl_iss_pulse), 
345        .sel1   (~spu_mactl_iss_pulse),
346        .dout   (len_decr_val[6:0])
347);
348
349assign len_ptr_sub[6:0] = len_ptr_mx[6:0] + len_decr_val[6:0] + 
350                                                7'b0000001; 
351
352dffre_s  #(7) len_ptr_ff  (
353        .din(len_ptr_sub[6:0]) ,
354        .q(len_ptr_sub_q[6:0]),
355        .en(len_wen),
356        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
357
358assign spu_maaddr_len_neqz = |len_ptr_sub_q[6:0];
359
360// his for the case when the len has been decremented to 1 and there
361// is possibilty the next decr will be -2 which makes the len be a
362// neg number.
363
364wire allow_incr_2wd = (|len_ptr_sub_q[6:1]) & spu_mactl_ldop;
365
366
367
368// when mpa0maddr0 make sure the last write does not happen to
369// odd side when len has reached one. mpa=0 and maddr=0 are checked in
370// spu_mactl.v.
371
372assign spu_maaddr_nooddwr_on_leneq1 = ~(~allow_incr_2wd & len_ptr_sub_q[0]); 
373
374
375wire [5:0] spu_maaddr_len_cntr_l;
376assign spu_maaddr_len_cntr_l[5:0] = ~len_ptr_sub_q[5:0];
377assign spu_maaddr_len_cntr[5:0] = ~spu_maaddr_len_cntr_l[5:0];
378
379// --------------------------------------------------------------
380// ***************** MPA *******************
381// --------------------------------------------------------------
382
383wire mpa_incr_2wd = incr_2wd | spu_mald_force_mpa_add16;
384
385
386mux2ds  #(5) mpa_iss_mx (
387        .in0    (5'b10000),
388        .in1    (5'b01000),
389        .sel0   (mpa_incr_2wd), 
390        .sel1   (~mpa_incr_2wd),
391        .dout   (spu_maaddr_mpa_incr_val[4:0])
392);
393
394
395assign spu_maaddr_mpa_wen = spu_maaddr_mpa_addrinc | spu_mactl_iss_pulse;
396
397// --------------------------------------------------------------
398// ***************** MA_ADDR *******************
399// --------------------------------------------------------------
400
401mux2ds  #(8) maaddr_issorex_mx (
402        .in0    (spu_maaddr_maaddr_add[7:0]), 
403        .in1    (spu_madp_maaddr_reg[7:0]), 
404        .sel0   (spu_maaddr_maaddr_addrinc), 
405        .sel1   (~spu_maaddr_maaddr_addrinc),
406        .dout   (maaddr_mx[7:0])
407);
408
409
410mux2ds  #(8) maaddr_iss_mx (
411        .in0    (8'b00000010),
412        .in1    (8'b00000001), 
413        .sel0   (incr_2wd), 
414        .sel1   (~incr_2wd),
415        .dout   (maaddr_incr_val[7:0])
416);
417
418assign spu_maaddr_maaddr_add[7:0] = spu_maaddr_maaddr_q[7:0] + maaddr_incr_val[7:0];
419
420assign maaddr_wen = spu_maaddr_maaddr_addrinc | spu_mactl_iss_pulse;
421
422dffre_s  #(8) maaadr_pa_mx  (
423        .din(maaddr_mx[7:0]) ,
424        .q(spu_maaddr_maaddr_q[7:0]),
425        .en(maaddr_wen),
426        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
427
428
429// --------------------------------------------------------------
430// ***************** INCR VALUE DECODE *******************
431// --------------------------------------------------------------
432
433// 16byte increments for load from L2 and 8byte increment for
434// store to L2 or if its 8byte transfer from ld buff to mamem.
435
436
437assign incr_2wd = ~spu_madp_mpa_addr_3 & ~spu_maaddr_maaddr_q[0] & spu_mactl_ldop &
438                                allow_incr_2wd;
439
440
441
442assign spu_maaddr_mpa1maddr0 = spu_madp_mpa_addr_3 & ~spu_maaddr_maaddr_q[0] & 
443                                        spu_mactl_ldop;
444
445
446// --------------------------------------------------------------
447// --------------------------------------------------------------
448// ******************* A == B ******************
449// --------------------------------------------------------------
450// --------------------------------------------------------------
451
452assign spu_maaddr_aequb = (spu_madp_maaddr_reg[7:0] == spu_madp_maaddr_reg[15:8]);
453
454// --------------------------------------------------------------
455// --------------------------------------------------------------
456// ***************** MEMINDEX *******************
457// --------------------------------------------------------------
458// --------------------------------------------------------------
459
460wire [7:0] memld_wroffset,x_mul_wroffset,m_mul_wroffset,r_red_wroffset,
461                x_exp_wroffset,memst_rdoffset,mmx_mulredexp_rdoffset,nrn_mulredexp_rdoffset,
462                bnm_mulredexp_rdoffset,aaa_mulredexp_rdoffset,e_exp_rdoffset;
463
464
465assign memld_wroffset = spu_maaddr_maaddr_q[7:0];
466
467assign x_mul_wroffset = spu_madp_maaddr_reg[39:32];
468assign m_mul_wroffset = spu_madp_maaddr_reg[31:24];
469assign r_red_wroffset = spu_madp_maaddr_reg[23:16];
470assign x_exp_wroffset = spu_madp_maaddr_reg[31:24];
471
472assign memst_rdoffset = spu_maaddr_maaddr_q[7:0];
473
474assign mmx_mulredexp_rdoffset = spu_madp_maaddr_reg[31:24];
475assign nrn_mulredexp_rdoffset = spu_madp_maaddr_reg[23:16];
476assign bnm_mulredexp_rdoffset = spu_madp_maaddr_reg[15:8];
477assign aaa_mulredexp_rdoffset = spu_madp_maaddr_reg[7:0];
478assign e_exp_rdoffset = spu_madp_maaddr_reg[39:32];
479
480// --------------- WR INDEX -------------------------------------
481
482wire [7:0] wroffset_a,wroffset_b,wr_offset;
483wire [7:0] rdoffset_a,rdoffset_b,rd_offset;
484
485wire wr_a_sel = spu_mactl_ldop | spu_mamul_m_wr_oprnd_sel |
486                spu_mared_x_wr_oprnd_sel;
487
488/******
489// converting muxes to AO logic to fix 0in problems.
490mux3ds  #(8) wroffset_a_mx (
491        .in0    (memld_wroffset[7:0]),
492        .in1    (x_mul_wroffset[7:0]),
493        .in2    (m_mul_wroffset[7:0]),
494        .sel0   (spu_mactl_ldop), 
495        .sel1   (spu_mared_x_wr_oprnd_sel),
496        .sel2   (spu_mamul_m_wr_oprnd_sel),
497        .dout   (wroffset_a[7:0])
498);
499
500mux3ds  #(8) wroffset_b_mx (
501        .in0    (r_red_wroffset[7:0]),
502        .in1    (x_exp_wroffset[7:0]),
503        .in2    (spu_madp_maaddr_reg[15:8]),
504        .sel0   (spu_mared_r_wr_oprnd_sel), 
505        .sel1   (spu_mared_xe_wr_oprnd_sel),
506        .sel2   (spu_mamul_me_wr_oprnd_sel),
507        .dout   (wroffset_b[7:0])
508);
509
510******/
511
512assign wroffset_a[7:0] = 
513                        (memld_wroffset[7:0] & {8{spu_mactl_ldop}}) |
514                        (x_mul_wroffset[7:0] & {8{spu_mared_x_wr_oprnd_sel}}) |
515                        (m_mul_wroffset[7:0] & {8{spu_mamul_m_wr_oprnd_sel}}) ;
516
517assign wroffset_b[7:0] =
518                        (r_red_wroffset[7:0] & {8{spu_mared_r_wr_oprnd_sel}}) |
519                        (x_exp_wroffset[7:0] & {8{spu_mared_xe_wr_oprnd_sel}}) |
520                        (spu_madp_maaddr_reg[15:8] & {8{spu_mamul_me_wr_oprnd_sel}}) ;
521
522
523
524
525mux2ds  #(8) wroffset_mx (
526        .in0    (wroffset_a[7:0]),
527        .in1    (wroffset_b[7:0]), 
528        .sel0   (wr_a_sel), 
529        .sel1   (~wr_a_sel),
530        .dout   (wr_offset[7:0])
531);
532
533// --------------- RD INDEX -------------------------------------
534wire [2:0] rd_a_sel;
535wire [2:0] rd_b_sel;
536
537// sel for store needs to be added
538wire rd_a_select = spu_mamul_m_rd_oprnd_sel | spu_mamul_n_rd_oprnd_sel |
539                spu_mared_m_rd_oprnd_sel | spu_mared_nm_rd_oprnd_sel |
540                spu_mamul_ax_rd_oprnd_sel | 
541                        spu_mast_memren; 
542
543assign rd_a_sel[0] = spu_mast_memren;
544assign rd_a_sel[1] = spu_mamul_m_rd_oprnd_sel | spu_mared_m_rd_oprnd_sel |
545                        spu_mamul_ax_rd_oprnd_sel ;
546assign rd_a_sel[2] = spu_mamul_n_rd_oprnd_sel | spu_mared_nm_rd_oprnd_sel;
547
548assign rd_b_sel[0] = spu_mamul_b_rd_oprnd_sel | spu_mared_nr_rd_oprnd_sel |
549                        spu_mared_me_rd_oprnd_sel | spu_mamul_me_rd_oprnd_sel;
550assign rd_b_sel[1] = spu_mamul_a_rd_oprnd_sel | spu_mared_a_rd_oprnd_sel |
551                        spu_mamul_ba_rd_oprnd_sel;
552assign rd_b_sel[2] = spu_maexp_e_rd_oprnd_sel;
553
554
555/***************
556mux3ds  #(8) rdoffset_a_mx (
557        .in0    (memst_rdoffset[7:0]),
558        .in1    (mmx_mulredexp_rdoffset[7:0]),
559        .in2    (nrn_mulredexp_rdoffset[7:0]),
560        .sel0   (rd_a_sel[0]), 
561        .sel1   (rd_a_sel[1]),
562        .sel2   (rd_a_sel[2]),
563        .dout   (rdoffset_a[7:0])
564);
565
566mux3ds  #(8) rdoffset_b_mx (
567        .in0    (bnm_mulredexp_rdoffset[7:0]),
568        .in1    (aaa_mulredexp_rdoffset[7:0]),
569        .in2    (e_exp_rdoffset[7:0]),
570        .sel0   (rd_b_sel[0]), 
571        .sel1   (rd_b_sel[1]),
572        .sel2   (rd_b_sel[2]),
573        .dout   (rdoffset_b[7:0])
574);
575****************/
576
577assign rdoffset_a[7:0] =
578                        (memst_rdoffset[7:0] & {8{rd_a_sel[0]}}) |
579                        (mmx_mulredexp_rdoffset[7:0] & {8{rd_a_sel[1]}}) |
580                        (nrn_mulredexp_rdoffset[7:0] & {8{rd_a_sel[2]}}) ;
581
582assign rdoffset_b[7:0] =
583                        (bnm_mulredexp_rdoffset[7:0] & {8{rd_b_sel[0]}}) |
584                        (aaa_mulredexp_rdoffset[7:0] & {8{rd_b_sel[1]}}) |
585                        (e_exp_rdoffset[7:0] & {8{rd_b_sel[2]}}) ;
586
587
588
589
590mux2ds  #(8) rdoffset_mx (
591        .in0    (rdoffset_a[7:0]),
592        .in1    (rdoffset_b[7:0]), 
593        .sel0   (rd_a_select), 
594        .sel1   (~rd_a_select),
595        .dout   (rd_offset[7:0])
596);
597
598
599// --------------------------------------------------------------
600
601// spu_mamul_memwen is true when m[i] operand is updated.
602wire mem_wr_op = spu_mactl_ldop | spu_mamul_memwen | spu_mared_memwen |
603                                spu_maaeqb_memwen;
604
605wire [7:0] memoffset;
606
607mux2ds  #(8) memoffset_rd_wr (
608        .in0    (wr_offset[7:0]),
609        .in1    (rd_offset[7:0]), 
610        .sel0   (mem_wr_op), 
611        .sel1   (~mem_wr_op),
612        .dout   (memoffset[7:0])
613);
614
615
616// --------------------------------------------------------------
617// --------------------------------------------------------------
618// --------------------------------------------------------------
619// --------------------------------------------------------------
620// --------------------------------------------------------------
621
622wire [6:0] j_ptr,j_ptr_add;
623wire [5:0] len;
624wire [6:0] twolen,lenplus1,twolenplus2,iminus1_rshft,i_rshft,
625                twolenplus1,iminus1_ptr,iminus_len,i_ptr_add,i_ptr;
626
627wire i_equ_lenplus1,j_equ_iminus1rshft,
628                j_equ_iminus1,
629                i_ptr_rst;
630
631//wire i_equ_zero;
632               
633
634// --------------------------------------------------------------
635// --------------------------------------------------------------
636// --------------------------------------------------------------
637// ------------ FINAL ADDER & ADDVAL MUX FOR MEMINDEX -----------
638// --------------------------------------------------------------
639// --------------------------------------------------------------
640// --------------------------------------------------------------
641wire [6:0] jj_ptr;
642wire [6:0] e_ptr;
643wire [6:0] j_ptr_redwr_val;
644
645wire [6:0] add_val,addval_a,addval_b;
646wire [6:0] iminusj_ptr,iminus1_lenminus1;
647
648wire add_a_sel = spu_mamul_iminuslenminus1_sel |
649                        spu_mamul_iminus1_ptr_sel | 
650                        spu_mamul_i_ptr_sel | spu_maaeqb_irshft_sel; 
651
652wire mulred_j_ptr_sel = spu_mamul_j_ptr_sel | spu_mared_j_ptr_sel;
653wire add_b_sel = mulred_j_ptr_sel | spu_mamul_iminusj_ptr_sel |
654                                spu_maexp_e_rd_oprnd_sel | spu_mared_memwen;
655
656//wire add_c_sel = ~(add_a_sel | add_b_sel);
657
658/*****
659mux4ds  #(7) addval_a_mux (
660        .in0    (iminus1_lenminus1[6:0]),
661        .in1    (iminus1_ptr[6:0]),
662        .in2    (i_rshft[6:0]),
663        .in3    (i_ptr[6:0]),
664        .sel0   (spu_mamul_iminuslenminus1_sel), 
665        .sel1   (spu_mamul_iminus1_ptr_sel),
666        .sel2   (spu_maaeqb_irshft_sel),
667        .sel3   (spu_mamul_i_ptr_sel),
668        .dout   (addval_a[6:0])
669);
670
671*******/
672
673assign addval_a[6:0] = 
674                        (iminus1_lenminus1[6:0] & {7{spu_mamul_iminuslenminus1_sel}}) |
675                        (iminus1_ptr[6:0] & {7{spu_mamul_iminus1_ptr_sel}}) |
676                        (i_rshft[6:0] & {7{spu_maaeqb_irshft_sel}}) |
677                        (i_ptr[6:0] & {7{spu_mamul_i_ptr_sel}}) ;
678
679/******
680mux4ds  #(7) addval_b_mux (
681        .in0    (jj_ptr[6:0]),
682        .in1    (iminusj_ptr[6:0]),
683        .in2    (e_ptr[6:0]),
684        .in3    (j_ptr_redwr_val[6:0]),
685        .sel0   (mulred_j_ptr_sel),
686        .sel1   (spu_mamul_iminusj_ptr_sel),
687        .sel2   (spu_maexp_e_rd_oprnd_sel),
688        .sel3   (spu_mared_memwen),
689        .dout   (addval_b[6:0])
690);
691**********/
692
693assign addval_b[6:0] = 
694                        (jj_ptr[6:0] & {7{mulred_j_ptr_sel}}) |
695                        (iminusj_ptr[6:0] & {7{spu_mamul_iminusj_ptr_sel}}) |
696                        (e_ptr[6:0] & {7{spu_maexp_e_rd_oprnd_sel}}) |
697                        (j_ptr_redwr_val[6:0] & {7{spu_mared_memwen}}) ;
698                       
699
700/*******
701mux3ds  #(7) addval_mux (
702        .in0    (addval_a[6:0]),
703        .in1    (addval_b[6:0]),
704        .in2    (7'b0000000),
705        .sel0   (add_a_sel), 
706        .sel1   (add_b_sel),
707        .sel2   (add_c_sel),
708        .dout   (add_val[6:0])
709);
710
711********/
712
713assign add_val[6:0] =
714                        (addval_a[6:0] & {7{add_a_sel}}) |
715                        (addval_b[6:0] & {7{add_b_sel}}) ;
716
717wire spu_maaddr_memindx_0;
718assign {spu_maaddr_memindx[7:1],spu_maaddr_memindx_0} = {1'b0,add_val[6:0]} + memoffset[7:0];
719
720
721assign spu_maaddr_wrindx_0 = wr_offset[0] + add_val[0];
722
723
724// ----------------------
725// check for out of range
726// ----------------------
727wire spu_maaddr_memindx_outofrange_q;
728
729wire spu_maaddr_memindx_outofrange = (spu_maaddr_memindx[7] & spu_maaddr_memindx[6]) | 
730                                        (spu_maaddr_memindx[7] & spu_maaddr_memindx[5]) ;
731
732
733wire spu_maaddr_memindx_outofrange_sehold = sehold ? spu_maaddr_memindx_outofrange_q :
734                                                        spu_maaddr_memindx_outofrange;
735
736dff_s #(1) spu_maaddr_memindx_outofrange_ff (
737        .din(spu_maaddr_memindx_outofrange_sehold) ,
738        .q(spu_maaddr_memindx_outofrange_q),
739        .clk (rclk), .se(1'b0),.si (),.so ()
740        );
741
742// ----------------------
743wire spu_maaddr_memindx_0_q;
744
745wire spu_maaddr_memindx_0_sehold = sehold ? spu_maaddr_memindx_0_q :
746                                                spu_maaddr_memindx_0;
747
748dff_s #(1) mem_indx_0_ff (
749        .din(spu_maaddr_memindx_0_sehold) ,
750        .q(spu_maaddr_memindx_0_q),
751        .clk (rclk), .se(1'b0),.si (),.so ()
752        );
753
754wire [3:0] spu_maaddr_mamem_eveodd_sel;
755assign spu_maaddr_mamem_eveodd_sel[0] = ~(mem_bypass | spu_maaddr_memindx_outofrange_q) & ~spu_maaddr_memindx_0_q;
756assign spu_maaddr_mamem_eveodd_sel[1] = ~(mem_bypass | spu_maaddr_memindx_outofrange_q) & spu_maaddr_memindx_0_q;
757assign spu_maaddr_mamem_eveodd_sel[2] = ~mem_bypass & spu_maaddr_memindx_outofrange_q;
758assign spu_maaddr_mamem_eveodd_sel[3] =  mem_bypass;
759
760assign spu_maaddr_mamem_eveodd_sel_l = ~spu_maaddr_mamem_eveodd_sel;
761
762// --------------------------------------------------------
763// --------------------------------------------------------
764// --------------------------------------------------------
765// --------------------------------------------------------
766// --------------------------------------------------------
767// ---------------- POINTERS ------------------------------
768// --------------------------------------------------------
769// --------------------------------------------------------
770// --------------------------------------------------------
771// --------------------------------------------------------
772
773
774// ---------------------------------------------------------------
775
776assign len[5:0] = spu_madp_mactl_reg[5:0];
777assign twolen[6:0] = {spu_madp_mactl_reg[5],spu_madp_mactl_reg[4],
778                    spu_madp_mactl_reg[3],spu_madp_mactl_reg[2],
779                    spu_madp_mactl_reg[1],spu_madp_mactl_reg[0],1'b0};
780assign lenplus1[6:0] = {1'b0,spu_madp_mactl_reg[5:0]} + 7'b0000001;
781//assign lenminus1[5:0] = spu_madp_mactl_reg[5:0] - 1'b1;
782assign twolenplus1[6:0] = twolen[6:0] + 7'b0000001;
783assign twolenplus2[6:0] = twolen[6:0] + 7'b0000010;
784
785
786
787assign iminus1_rshft[6:0] = {1'b0,iminus1_ptr[6],iminus1_ptr[5],
788                                iminus1_ptr[4],iminus1_ptr[3],
789                                iminus1_ptr[2],iminus1_ptr[1]};
790
791assign i_rshft[6:0] = {1'b0,i_ptr[6],i_ptr[5],i_ptr[4],i_ptr[3],
792                                i_ptr[2],i_ptr[1]};
793
794// ---------------------------------------------------------------
795// ---------------------------------------------------------------
796// start pointer comparisons.
797// ---------------------------------------------------------------
798
799//assign i_equ_len = (i_ptr_add[6:0] == {1'b0,len[5:0]});
800assign i_equ_lenplus1 = (i_ptr[6:0] == lenplus1[6:0]); 
801
802wire i_equ_twolenplus2_pre = (i_ptr_add[6:0] == twolenplus2[6:0]); 
803wire i_equ_twolenplus1_pre = (i_ptr_add[6:0] == twolenplus1[6:0]); 
804
805wire i_equ_twolen_pre = (i_ptr_add[6:0] == twolen[6:0]); 
806wire i_equ_zero_pre = (i_ptr[6:0] == 7'b0000000); 
807
808assign j_equ_iminus1rshft = (j_ptr[6:0] == iminus1_rshft[6:0]); 
809//assign j_equ_iminuslen = (j_ptr[6:0] == iminus_len[6:0]);
810assign j_equ_iminus1 = (j_ptr[6:0] == iminus1_ptr[6:0]); 
811//wire j_equ_iminus1_pre = (j_ptr_data[6:0] == i_ptr[6:0]);
812wire j_equ_len_pre = (j_ptr_data[6:0] == {1'b0,len[5:0]}); 
813
814//assign spu_maaddr_iequtwolenplus2 = i_equ_twolenplus2;
815//assign spu_maaddr_iequtwolenplus1 = i_equ_twolenplus1;
816//assign spu_maaddr_iequtwolen = i_equ_twolen_pre;
817
818//assign spu_maaddr_jequiminus1 = j_equ_iminus1;
819//assign spu_maaddr_jequlen = j_equ_len;
820//assign spu_maaddr_jequiminus1rshft = j_equ_iminus1rshft;
821
822assign spu_maaddr_ieq0 = i_equ_zero_pre;
823assign spu_maaddr_ieven = ~i_ptr[0];
824
825// ***************************************************************
826// start of pointers
827// ***************************************************************
828// ---------------------------------------------------------------
829
830wire rst_halfpnt,halfpnt_set;
831
832//assign rst_halfpnt = reset_local | spu_mamul_rst_iptr | ~spu_mactl_mulop;
833assign rst_halfpnt = reset_local | spu_mamul_rst_iptr | spu_mamul_rst ;
834
835dffre_s  #(1) halfpnt_ff (
836        .din(1'b1) ,
837        .q(halfpnt_set),
838        .en(i_equ_lenplus1),
839        .rst(rst_halfpnt), .clk (rclk), .se(se), .si(), .so());
840
841assign spu_maaddr_halfpnt_set = halfpnt_set ;
842
843
844// --------------------
845 
846wire halfpnt_set_pulse,halfpnt_set_q;
847
848dff_s  #(1) halfpnt_set_pulse_ff (
849        .din(halfpnt_set) ,
850        .q(halfpnt_set_q),
851        .clk (rclk), .se(se), .si(), .so());
852
853assign halfpnt_set_pulse = ~halfpnt_set_q & halfpnt_set;
854 
855// ---------------------------------------------------------------
856// J pointer (used for mamul and mared)
857// ---------------------------------------------------------------
858
859wire [6:0] jj_ptr_val;
860wire [2:0] jptr_rst_sel;
861
862wire j_ptr_wen = (spu_mamul_incr_jptr | spu_mamul_rst_jptr | halfpnt_set_pulse) |
863                 (spu_mared_update_jptr | spu_mared_rst_jptr) |
864                         spu_mared_start_wen;
865
866
867// in the case of mamul we need to incr and for mared we
868// need to start from msw and decr, and if we find that M is
869// greater than N then we need to start from 0 and incr.
870
871wire carryin = spu_mared_cin_set_4sub; 
872
873wire [6:0] incr_decr_val;
874mux2ds  #(7) incr_decr_val_mx2 (
875        .in0    (7'b1111110),
876        .in1    (7'b0000001), 
877        .sel0   (carryin), 
878        .sel1   (~carryin),
879        .dout   (incr_decr_val[6:0])
880);
881
882
883assign j_ptr_add[6:0] = j_ptr[6:0] + incr_decr_val[6:0] + {6'b000000,carryin};
884
885wire jptr_eqz_pre = ~(|j_ptr_data[6:0]);
886
887wire jptr_eqz_q;
888wire spu_maaddr_jequlen_q;
889
890dffre_s  #(7) j_ptr_ff (
891        .din(j_ptr_data[6:0]) ,
892        .q(j_ptr[6:0]),
893        .en(j_ptr_wen),
894        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
895
896dffre_s  #(2) j_ptr_b_ff (
897        .din({jptr_eqz_pre, j_equ_len_pre}) ,
898        .q({jptr_eqz_q, spu_maaddr_jequlen_q}),
899        .en(j_ptr_wen),
900        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
901
902assign spu_maaddr_jequlen = spu_maaddr_jequlen_q;
903
904assign spu_maaddr_jptr_eqz_mared = jptr_eqz_q;
905
906//assign spu_maaddr_jptr_eqz = ~(|j_ptr[6:0]);
907
908/*
909assign jptr_rst_sel[0] = (spu_mamul_rst_jptr & spu_maaddr_halfpnt_set) | halfpnt_set_pulse ;
910assign jptr_rst_sel[1] = (spu_mamul_rst_jptr & ~spu_maaddr_halfpnt_set) | spu_mared_rst_jptr;
911assign jptr_rst_sel[2] = ~(halfpnt_set_pulse | spu_mamul_rst_jptr | spu_mared_rst_jptr |
912                                spu_mared_start_sel);
913assign jptr_rst_sel[3] =  spu_mared_start_sel;
914*/
915
916assign jptr_rst_sel[0] = (spu_mamul_rst_jptr & spu_maaddr_halfpnt_set) | halfpnt_set_pulse ;
917assign jptr_rst_sel[1] = ~(halfpnt_set_pulse | spu_mamul_rst_jptr | spu_mared_rst_jptr |
918                                spu_mared_start_sel);
919assign jptr_rst_sel[2] =  spu_mared_start_sel;
920
921/*
922mux3ds  #(7) jptr_rst_mux (
923        .in0    (iminus_len[6:0]),
924        .in1    (7'b0000000),
925        .in2    (j_ptr_add[6:0]),
926        .sel0   (jptr_rst_sel[0]),
927        .sel1   (jptr_rst_sel[1]),
928        .sel2   (jptr_rst_sel[2]),
929        .dout   (j_ptr_data[6:0])
930);*/
931
932/*********
933mux4ds  #(7) jptr_rst_mux (
934        .in0    (iminus_len[6:0]),
935        .in1    (7'b0000000),
936        .in2    (j_ptr_add[6:0]),
937        .in3    ({1'b0,spu_madp_mactl_reg[5:0]}),//when mared op starts,load the LEN into jptr.
938        .sel0   (jptr_rst_sel[0]),
939        .sel1   (jptr_rst_sel[1]),
940        .sel2   (jptr_rst_sel[2]),
941        .sel3   (jptr_rst_sel[3]),
942        .dout   (j_ptr_data[6:0])
943);
944************/
945
946assign j_ptr_data[6:0] =
947                        (iminus_len[6:0] & {7{jptr_rst_sel[0]}}) |
948                        (j_ptr_add[6:0] & {7{jptr_rst_sel[1]}}) |
949                        ({1'b0,spu_madp_mactl_reg[5:0]} & {7{jptr_rst_sel[2]}}) ;
950 
951wire jj_ptr_update = spu_mamul_jjptr_wen | spu_mared_jjptr_wen;
952dffre_s  #(7) jj_ptr_ff (
953        .din(j_ptr_add[6:0]) ,
954        .q(jj_ptr_val[6:0]),
955        .en(jj_ptr_update),
956        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
957
958//wire jptr_oldnew_sel = spu_mamul_incr_jptr | spu_mared_update_jptr;
959wire jptr_oldnew_sel = spu_mamul_jjptr_sel | spu_mared_update_jptr;
960mux2ds  #(7) jptr_oldnew_mx2 (
961        .in0    (jj_ptr_val[6:0]), 
962        .in1    (j_ptr[6:0]),
963        .sel0   (jptr_oldnew_sel), 
964        .sel1   (~jptr_oldnew_sel),
965        .dout   (jj_ptr[6:0])
966);
967
968
969dffre_s  #(7) j_ptr_redwr_ff (
970        .din(j_ptr[6:0]) ,
971        .q(j_ptr_redwr_val[6:0]),
972        .en(spu_mared_update_redwr_jptr),
973        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
974
975// ----------------------
976//saving the jptr this will be the maxlen
977// for the mared subtract count.
978wire [6:0] maxlen;
979dffre_s  #(7) maxlen_ff (
980        .din(j_ptr[6:0]) ,
981        .q(maxlen[6:0]),
982        .en(spu_mared_maxlen_wen),
983        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
984
985//assign spu_maaddr_len_eqmax = (j_ptr[6:0] == maxlen[6:0]);
986wire spu_maaddr_len_eqmax_pre = (j_ptr_data[6:0] == maxlen[6:0]);
987
988
989dffre_s  #(1) len_eqmax_ff (
990        .din(spu_maaddr_len_eqmax_pre) ,
991        .q(spu_maaddr_len_eqmax),
992        .en(j_ptr_wen),
993        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
994
995
996// ---------------------------------------------------------------
997// I pointer
998// ---------------------------------------------------------------
999
1000assign i_ptr_rst = reset_local | spu_mamul_rst_iptr;
1001
1002assign i_ptr_add[6:0] = i_ptr[6:0] + 7'b0000001;
1003
1004dffre_s  #(7) i_ptr_ff (
1005        .din(i_ptr_add[6:0]) ,
1006        .q(i_ptr[6:0]),
1007        .en(spu_mamul_incr_iptr),
1008        .rst(i_ptr_rst), .clk (rclk), .se(se), .si(), .so());
1009
1010dffre_s  #(7) iminus1_ptr_ff (
1011        .din(i_ptr[6:0]) ,
1012        .q(iminus1_ptr[6:0]),
1013        .en(spu_mamul_incr_iptr),
1014        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
1015
1016
1017wire spu_maaddr_jequiminus1_q;
1018wire spu_maaddr_jequiminus1rshft_q;
1019dffre_s  #(2) j_equ_iminus1_ff (
1020        .din({j_equ_iminus1, j_equ_iminus1rshft}) ,
1021        .q({spu_maaddr_jequiminus1_q, spu_maaddr_jequiminus1rshft_q}),
1022        .en(1'b1),
1023        .rst(reset_local), .clk (rclk), .se(se), .si(), .so());
1024
1025assign spu_maaddr_jequiminus1 = spu_maaddr_jequiminus1_q;
1026assign spu_maaddr_jequiminus1rshft = spu_maaddr_jequiminus1rshft_q;
1027
1028
1029        // added this to fix timing path.
1030dffre_s  #(3) i_equ_stuff_pre_ff (
1031        .din({i_equ_twolenplus2_pre,i_equ_twolenplus1_pre,i_equ_twolen_pre}) ,
1032        .q({spu_maaddr_iequtwolenplus2,spu_maaddr_iequtwolenplus1,spu_maaddr_iequtwolen}),
1033        .en(spu_mamul_incr_iptr),
1034        .rst(i_ptr_rst), .clk (rclk), .se(se), .si(), .so());
1035
1036// ---------------------------------------------------------------
1037// I-J pointer
1038// ---------------------------------------------------------------
1039
1040wire [6:0] iminusj_ptr_pre;
1041assign iminusj_ptr_pre[6:0] = i_ptr[6:0] + ~jj_ptr[6:0] + 7'b0000001;
1042
1043dff_s  #(7) iminusj_ff (
1044        .din(iminusj_ptr_pre[6:0]) ,
1045        .q(iminusj_ptr[6:0]),
1046        .clk (rclk), .se(se), .si(), .so());
1047
1048// assign iminusj_ptr = iminusj_ptr_pre;
1049
1050// ---------------------------------------------------------------
1051// I-LEN-1 pointer
1052// ---------------------------------------------------------------
1053
1054// assign iminus_lenminus1 = i_ptr[6:0] + {1'b1,~lenminus1[5:0]} + 1'b1;
1055//assign iminus_lenminus1[6:0] = (i_ptr[6:0] + {1'b1,~len[5:0]} + 1'b1) - 1'b1;
1056assign iminus1_lenminus1[6:0] = (iminus1_ptr[6:0] + {1'b1,~len[5:0]} + 7'b0000001) - 
1057                                                        7'b0000001;
1058
1059// ---------------------------------------------------------------
1060// I-LEN pointer
1061// ---------------------------------------------------------------
1062
1063assign iminus_len[6:0] = i_ptr[6:0] + {1'b1,~len[5:0]} + 7'b0000001;
1064
1065// ---------------------------------------------------------------
1066
1067/*
1068always @(posedge clk) begin
1069
1070$display ("%t iminus1_ptr",$time);
1071end
1072*/
1073
1074// ---------------------------------------------------------------
1075// ---------------------------------------------------------------
1076// --------------------- MA EXP ----------------------------------
1077// ---------------------------------------------------------------
1078// ---------------------------------------------------------------
1079
1080// ---------------------------------------------------------------
1081// ^^^^^^^^^^^^^^ ES COUNTER ^^^^^^^^^^^
1082// ---------------------------------------------------------------
1083
1084wire [10:0] es_add,es_ptr;
1085
1086assign es_add = es_ptr  + 11'b00000000001;
1087
1088dffre_s  #(11) es_ptr_ff (
1089        .din(es_add[10:0]) ,
1090        .q(es_ptr[10:0]),
1091        .en(spu_maexp_incr_es_ptr),
1092        .rst(spu_maexp_es_e_ptr_rst), .clk (rclk), .se(se), .si(), .so());
1093
1094// ---------------------------------------------------------------
1095// ^^^^^^^^^ ES_MAX_MINUS1 & COMPARE ^^^^^^^^^
1096// ---------------------------------------------------------------
1097wire [10:0] es_max_minus1_q,es_max_minus1;
1098//wire [8:0] es_max_plus1;
1099wire [7:0] es_max_plus1;
1100
1101//assign es_max_plus1[8:0] = {1'b0,spu_madp_maaddr_reg[47:40]} + 9'b000000001;
1102assign es_max_plus1[7:0] = spu_madp_maaddr_reg[47:40] + 8'b00000001;
1103
1104// vlint error:left size: 11,  right size: 12
1105//assign es_max_minus1[10:0] = {es_max_plus1[8:0],3'b000} - 11'b00000000001;
1106assign es_max_minus1[10:0] = {es_max_plus1[7:0],3'b000} - 11'b00000000001;
1107
1108dffre_s  #(11) esmax_minus1_ptr_ff (
1109        .din(es_max_minus1[10:0]) ,
1110        .q(es_max_minus1_q[10:0]),
1111        .en(spu_maexp_es_max_init),//save es_max at start of maexp_op
1112        .rst(spu_maexp_es_e_ptr_rst), .clk (rclk), .se(se), .si(), .so());
1113
1114assign spu_maaddr_esmax = (es_max_minus1_q[10:0] == es_ptr[10:0]);
1115
1116
1117// ---------------------------------------------------------------
1118// ^^^^^^^^^^^^^^ MOD64 CHECK ^^^^^^^^^^^
1119// ---------------------------------------------------------------
1120
1121wire max_mod64_reached;
1122wire max_mod64_reached_q;
1123wire max_mod64_reached_pulse;
1124
1125
1126assign max_mod64_reached = &es_ptr[5:0];
1127
1128assign spu_maaddr_esmod64 = max_mod64_reached;
1129
1130dff_s  #(1) mod64_pulse_ff (
1131        .din(max_mod64_reached) ,
1132        .q(max_mod64_reached_q),
1133        .clk (rclk), .se(se), .si(), .so());
1134
1135assign max_mod64_reached_pulse = ~max_mod64_reached_q & max_mod64_reached;
1136
1137// ---------------------------------------------------------------
1138// ^^^^^^^^^^^^^^ E PTR ^^^^^^^^^^^
1139// ---------------------------------------------------------------
1140// E ptr
1141wire [6:0] e_add;
1142
1143assign e_add = e_ptr + 7'b0000001;
1144
1145dffre_s  #(7) e_ptr_ff (
1146        .din(e_add[6:0]) ,
1147        .q(e_ptr[6:0]),
1148        .en(max_mod64_reached_pulse),
1149        .rst(spu_maexp_es_e_ptr_rst), .clk (rclk), .se(se), .si(), .so());
1150
1151
1152endmodule
1153
Note: See TracBrowser for help on using the repository browser.