source: XOpenSparcT1/trunk/T1-FPU/fpu_mul_ctl.v @ 6

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

versione iniziale opensparc

Line 
1// ========== Copyright Header Begin ==========================================
2//
3// OpenSPARC T1 Processor File: fpu_mul_ctl.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//      Multiply pipeline synthesizable logic
24//              - special input cases
25//              - opcode pipeline
26//              - sign logic
27//              - exception logic
28//              - datapath control- select lines and control logic
29//
30///////////////////////////////////////////////////////////////////////////////
31
32
33module fpu_mul_ctl (
34        inq_in1_51,
35        inq_in1_54,
36        inq_in1_53_0_neq_0,
37        inq_in1_50_0_neq_0,
38        inq_in1_53_32_neq_0,
39        inq_in1_exp_eq_0,
40        inq_in1_exp_neq_ffs,
41        inq_in2_51,
42        inq_in2_54,
43        inq_in2_53_0_neq_0,
44        inq_in2_50_0_neq_0,
45        inq_in2_53_32_neq_0,
46        inq_in2_exp_eq_0,
47        inq_in2_exp_neq_ffs,
48        inq_op,
49        inq_mul,
50        inq_rnd_mode,
51        inq_id,
52        inq_in1_63,
53        inq_in2_63,
54        mul_dest_rdy,
55        mul_dest_rdya,
56        m5stg_exp,
57        m5stg_fracadd_cout,
58        m5stg_frac_neq_0,
59        m5stg_frac_dbl_nx,
60        m5stg_frac_sng_nx,
61        m1stg_ld0_1,
62        m1stg_ld0_2,
63        m3stg_exp,
64        m3stg_expadd_eq_0,
65        m3stg_expadd_lte_0_inv,
66        m3stg_ld0_inv,
67        m4stg_exp,
68        m4stg_frac_105,
69        m5stg_frac,
70        arst_l,
71        grst_l,
72        rclk,
73
74        mul_pipe_active,
75        m1stg_snan_sng_in1,
76        m1stg_snan_dbl_in1,
77        m1stg_snan_sng_in2,
78        m1stg_snan_dbl_in2,
79        m1stg_step,
80        m1stg_sngop,
81        m1stg_dblop,
82        m1stg_dblop_inv,
83        m1stg_fmul,
84        m1stg_fsmuld,
85        m2stg_fmuls,
86        m2stg_fmuld,
87        m2stg_fsmuld,
88        m5stg_fmuls,
89        m5stg_fmuld,
90        m5stg_fmulda,
91        m6stg_fmul_in,
92        m6stg_id_in,
93        m6stg_fmul_dbl_dst,
94        m6stg_fmuls,
95        m6stg_step,
96        mul_sign_out,
97        m5stg_in_of,
98        mul_exc_out,
99        m2stg_frac1_dbl_norm,
100        m2stg_frac1_dbl_dnrm,
101        m2stg_frac1_sng_norm,
102        m2stg_frac1_sng_dnrm,
103        m2stg_frac1_inf,
104        m2stg_frac2_dbl_norm,
105        m2stg_frac2_dbl_dnrm,
106        m2stg_frac2_sng_norm,
107        m2stg_frac2_sng_dnrm,
108        m2stg_frac2_inf,
109        m1stg_inf_zero_in,
110        m1stg_inf_zero_in_dbl,
111        m2stg_exp_expadd,
112        m2stg_exp_0bff,
113        m2stg_exp_017f,
114        m2stg_exp_04ff,
115        m2stg_exp_zero,
116        m3bstg_ld0_inv,
117        m4stg_sh_cnt_in,
118        m4stg_inc_exp_54,
119        m4stg_inc_exp_55,
120        m4stg_inc_exp_105,
121        m4stg_left_shift_step,
122        m4stg_right_shift_step,
123        m5stg_to_0,
124        m5stg_to_0_inv,
125        mul_frac_out_fracadd,
126        mul_frac_out_frac,
127        mul_exp_out_exp_plus1,
128        mul_exp_out_exp,
129        mula_rst_l,
130
131        se,
132        si,
133        so
134);
135
136
137parameter
138                FMULS=  8'h49,
139                FMULD=  8'h4a,
140                FSMULD= 8'h69;
141
142
143input           inq_in1_51;             // request operand 1[51]
144input           inq_in1_54;             // request operand 1[54]
145input           inq_in1_53_0_neq_0;     // request operand 1[53:0]!=0
146input           inq_in1_50_0_neq_0;     // request operand 1[50:0]!=0
147input           inq_in1_53_32_neq_0;    // request operand 1[53:32]!=0
148input           inq_in1_exp_eq_0;       // request operand 1[62:52]==0
149input           inq_in1_exp_neq_ffs;    // request operand 1[62:52]!=0x7ff
150input           inq_in2_51;             // request operand 2[51]
151input           inq_in2_54;             // request operand 2[54]
152input           inq_in2_53_0_neq_0;     // request operand 2[53:0]!=0
153input           inq_in2_50_0_neq_0;     // request operand 2[50:0]!=0
154input           inq_in2_53_32_neq_0;    // request operand 2[53:32]!=0
155input           inq_in2_exp_eq_0;       // request operand 2[62:52]==0
156input           inq_in2_exp_neq_ffs;    // request operand 2[62:52]!=0x7ff
157input [7:0]     inq_op;                 // request opcode to op pipes
158input           inq_mul;                // multiply pipe request
159input [1:0]     inq_rnd_mode;           // request rounding mode to op pipes
160input [4:0]     inq_id;                 // request ID to the operation pipes
161input           inq_in1_63;             // request[63] operand 1 to op pipes
162input           inq_in2_63;             // request[63] operand 2 to op pipes
163input           mul_dest_rdy;           // multiply result req accepted for CPX
164input           mul_dest_rdya;          // multiply result req accepted for CPX
165input [12:0]    m5stg_exp;              // exponent input- multiply 5 stage
166input           m5stg_fracadd_cout;     // fraction rounding adder carry out
167input           m5stg_frac_neq_0;       // fraction input to mul 5 stage != 0
168input           m5stg_frac_dbl_nx;      // double precision inexact result
169input           m5stg_frac_sng_nx;      // single precision inexact result
170input [5:0]     m1stg_ld0_1;            // denorm operand 1 leading 0's
171input [5:0]     m1stg_ld0_2;            // denorm operand 2 leading 0's
172input [12:0]    m3stg_exp;              // exponent input- multiply 3 stage
173input           m3stg_expadd_eq_0;      // mul stage 3 exponent adder sum == 0
174input           m3stg_expadd_lte_0_inv; // mul stage 3 exponent adder sum <= 0
175input [5:0]     m3stg_ld0_inv;          // leading 0's in multiply operands
176input [12:0]    m4stg_exp;              // exponent input- multiply 4 stage
177input           m4stg_frac_105; // multiply stage 4a fraction input[105]
178input [32:0]    m5stg_frac;             // multiply stage 5 fraction input
179input           arst_l;                 // asynchronous global reset- asserted low
180input           grst_l;                 // synchronous global reset- asserted low
181input           rclk;           // global clock
182
183output          mul_pipe_active;        // mul pipe is executing a valid instr
184output          m1stg_snan_sng_in1;     // operand 1 is single signalling NaN
185output          m1stg_snan_dbl_in1;     // operand 1 is double signalling NaN
186output          m1stg_snan_sng_in2;     // operand 2 is single signalling NaN
187output          m1stg_snan_dbl_in2;     // operand 2 is double signalling NaN
188output          m1stg_step;             // multiply pipe load
189output          m1stg_sngop;            // single precision operation- mul 1 stg
190output          m1stg_dblop;            // double precision operation- mul 1 stg
191output          m1stg_dblop_inv;        // single or int operation- mul 1 stg
192output          m1stg_fmul;             // multiply operation- mul 1 stage
193output          m1stg_fsmuld;           // fsmuld- multiply 1 stage
194output          m2stg_fmuls;            // fmuls- multiply 2 stage
195output          m2stg_fmuld;            // fmuld- multiply 2 stage
196output          m2stg_fsmuld;           // fsmuld- multiply 2 stage
197output          m5stg_fmuls;            // fmuls- multiply 5 stage
198output          m5stg_fmuld;            // fmuld- multiply 5 stage
199output          m5stg_fmulda;           // fmuld- multiply 5 stage copy
200output          m6stg_fmul_in;          // mul pipe output request next cycle
201output [9:0]    m6stg_id_in;            // mul pipe output ID next cycle
202output          m6stg_fmul_dbl_dst;     // double precision multiply result
203output          m6stg_fmuls;            // fmuls- multiply 6 stage
204output          m6stg_step;             // advance the multiply pipe
205output          mul_sign_out;           // multiply sign output
206output          m5stg_in_of;            // multiply overflow- select exp out
207output [4:0]    mul_exc_out;            // multiply pipe result- exception flags
208output          m2stg_frac1_dbl_norm;   // select line to m2stg_frac1
209output          m2stg_frac1_dbl_dnrm;   // select line to m2stg_frac1
210output          m2stg_frac1_sng_norm;   // select line to m2stg_frac1
211output          m2stg_frac1_sng_dnrm;   // select line to m2stg_frac1
212output          m2stg_frac1_inf;        // select line to m2stg_frac1
213output          m2stg_frac2_dbl_norm;   // select line to m2stg_frac2
214output          m2stg_frac2_dbl_dnrm;   // select line to m2stg_frac2
215output          m2stg_frac2_sng_norm;   // select line to m2stg_frac2
216output          m2stg_frac2_sng_dnrm;   // select line to m2stg_frac2
217output          m2stg_frac2_inf;        // select line to m2stg_frac2
218output          m1stg_inf_zero_in;      // 1 operand is infinity; other is 0
219output          m1stg_inf_zero_in_dbl;  // 1 opnd is infinity; other is 0- dbl
220output          m2stg_exp_expadd;       // select line to m2stg_exp
221output          m2stg_exp_0bff;         // select line to m2stg_exp
222output          m2stg_exp_017f;         // select line to m2stg_exp
223output          m2stg_exp_04ff;         // select line to m2stg_exp
224output          m2stg_exp_zero;         // select line to m2stg_exp
225output [6:0]    m3bstg_ld0_inv;         // leading 0's in multiply operands
226output [5:0]    m4stg_sh_cnt_in;        // multiply normalization shift count
227output          m4stg_inc_exp_54;       // select line to m5stg_exp
228output          m4stg_inc_exp_55;       // select line to m5stg_exp
229output          m4stg_inc_exp_105;      // select line to m5stg_exp
230output          m4stg_left_shift_step;  // select line to m5stg_frac
231output          m4stg_right_shift_step; // select line to m5stg_frac
232output          m5stg_to_0;             // result to max finite on overflow
233output          m5stg_to_0_inv;         // result to infinity on overflow
234output          mul_frac_out_fracadd;   // select line to mul_frac_out
235output          mul_frac_out_frac;      // select line to mul_frac_out
236output          mul_exp_out_exp_plus1;  // select line to mul_exp_out
237output          mul_exp_out_exp;        // select line to mul_exp_out
238output    mula_rst_l; // reset for mul64
239
240input           se;                     // scan_enable
241input           si;                     // scan in
242output          so;                     // scan out
243
244
245wire            reset;
246wire            mul_frac_in1_51;
247wire            mul_frac_in1_54;
248wire            mul_frac_in1_53_0_neq_0;
249wire            mul_frac_in1_50_0_neq_0;
250wire            mul_frac_in1_53_32_neq_0;
251wire            mul_exp_in1_exp_eq_0;
252wire            mul_exp_in1_exp_neq_ffs;
253wire            mul_frac_in2_51;
254wire            mul_frac_in2_54;
255wire            mul_frac_in2_53_0_neq_0;
256wire            mul_frac_in2_50_0_neq_0;
257wire            mul_frac_in2_53_32_neq_0;
258wire            mul_exp_in2_exp_eq_0;
259wire            mul_exp_in2_exp_neq_ffs;
260wire            m1stg_denorm_sng_in1;
261wire            m1stg_denorm_dbl_in1;
262wire            m1stg_denorm_sng_in2;
263wire            m1stg_denorm_dbl_in2;
264wire            m1stg_denorm_in1;
265wire            m1stg_denorm_in2;
266wire            m1stg_norm_sng_in1;
267wire            m1stg_norm_dbl_in1;
268wire            m1stg_norm_sng_in2;
269wire            m1stg_norm_dbl_in2;
270wire            m1stg_snan_sng_in1;
271wire            m1stg_snan_dbl_in1;
272wire            m1stg_snan_sng_in2;
273wire            m1stg_snan_dbl_in2;
274wire            m1stg_qnan_sng_in1;
275wire            m1stg_qnan_dbl_in1;
276wire            m1stg_qnan_sng_in2;
277wire            m1stg_qnan_dbl_in2;
278wire            m1stg_snan_in1;
279wire            m1stg_snan_in2;
280wire            m1stg_qnan_in1;
281wire            m1stg_qnan_in2;
282wire            m2stg_snan_in1;
283wire            m2stg_snan_in2;
284wire            m2stg_qnan_in1;
285wire            m2stg_qnan_in2;
286wire            m1stg_nan_sng_in1;
287wire            m1stg_nan_dbl_in1;
288wire            m1stg_nan_sng_in2;
289wire            m1stg_nan_dbl_in2;
290wire            m1stg_nan_in1;
291wire            m1stg_nan_in2;
292wire            m2stg_nan_in2;
293wire            m1stg_inf_sng_in1;
294wire            m1stg_inf_dbl_in1;
295wire            m1stg_inf_sng_in2;
296wire            m1stg_inf_dbl_in2;
297wire            m1stg_inf_in1;
298wire            m1stg_inf_in2;
299wire            m1stg_inf_in;
300wire            m2stg_inf_in1;
301wire            m2stg_inf_in2;
302wire            m2stg_inf_in;
303wire            m1stg_infnan_sng_in1;
304wire            m1stg_infnan_dbl_in1;
305wire            m1stg_infnan_sng_in2;
306wire            m1stg_infnan_dbl_in2;
307wire            m1stg_infnan_in1;
308wire            m1stg_infnan_in2;
309wire            m1stg_infnan_in;
310wire            m1stg_zero_in1;
311wire            m1stg_zero_in2;
312wire            m1stg_zero_in;
313wire            m2stg_zero_in1;
314wire            m2stg_zero_in2;
315wire            m2stg_zero_in;
316wire            m1stg_step;
317wire [7:0]      m1stg_op_in;
318wire [7:0]      m1stg_op;
319wire            m1stg_mul_in;
320wire            m1stg_mul;
321wire            m1stg_sngop;
322wire [3:0]      m1stg_sngopa;
323wire            m1stg_dblop;
324wire [3:0]      m1stg_dblopa;
325wire            m1stg_dblop_inv_in;
326wire            m1stg_dblop_inv;
327wire [1:0]      m1stg_rnd_mode;
328wire [4:0]      m1stg_id;
329wire            m1stg_fmul;
330wire            m1stg_fmul_dbl_dst;
331wire            m1stg_fmuls;
332wire            m1stg_fmuld;
333wire            m1stg_fsmuld;
334wire [4:0]      m1stg_opdec;
335wire [4:0]      m2stg_opdec;
336wire [1:0]      m2stg_rnd_mode;
337wire [4:0]      m2stg_id;
338wire            m2stg_fmul;
339wire            m2stg_fmuls;
340wire            m2stg_fmuld;
341wire            m2stg_fsmuld;
342wire [4:1]      m3astg_opdec;
343wire [1:0]      m3astg_rnd_mode;
344wire [4:0]      m3astg_id;
345wire [4:1]      m3bstg_opdec;
346wire [1:0]      m3bstg_rnd_mode;
347wire [4:0]      m3bstg_id;
348wire [4:1]      m3stg_opdec;
349wire [1:0]      m3stg_rnd_mode;
350wire [4:0]      m3stg_id;
351wire            m3stg_fmul;
352wire [4:1]      m4stg_opdec;
353wire [1:0]      m4stg_rnd_mode;
354wire [4:0]      m4stg_id;
355wire            m4stg_fmul;
356wire            m4stg_fmuld;
357wire [4:1]      m5stg_opdec;
358wire [1:0]      m5stg_rnd_mode;
359wire [4:0]      m5stg_id;
360wire            m5stg_fmul;
361wire            m5stg_fmuls;
362wire            m5stg_fmuld;
363wire            m5stg_fmulda;
364wire            m6stg_fmul_in;
365wire [4:2]      m6stg_opdec;
366wire [9:0]      m6stg_id_in;
367wire [9:0]      m6stg_id;
368wire            m6stg_fmul;
369wire            m6stg_fmul_dbl_dst;
370wire            m6stg_fmuls;
371wire            m6stg_hold;
372wire            m6stg_holda;
373wire            m6stg_step;
374wire            m6stg_stepa;
375wire            m1stg_sign1;
376wire            m1stg_sign2;
377wire            m2stg_sign1;
378wire            m2stg_sign2;
379wire            m1stg_of_mask;
380wire            m2stg_of_mask;
381wire            m2stg_sign;
382wire            m3astg_sign;
383wire            m2stg_nv;
384wire            m3astg_nv;
385wire            m3astg_of_mask;
386wire            m3bstg_sign;
387wire            m3bstg_nv;
388wire            m3stg_sign;
389wire            m3stg_nv;
390wire            m3stg_of_mask;
391wire            m4stg_sign;
392wire            m4stg_nv;
393wire            m4stg_of_mask;
394wire            m5stg_sign;
395wire            m5stg_nv;
396wire            m5stg_of_mask;
397wire            mul_sign_out;
398wire            mul_nv_out;
399wire            m5stg_in_of;
400wire            mul_of_out_tmp1_in;
401wire            mul_of_out_tmp1;
402wire            mul_of_out_tmp2;
403wire            mul_of_out_cout;
404wire            mul_of_out;
405wire            mul_uf_out_in;
406wire            mul_uf_out;
407wire            mul_nx_out_in;
408wire            mul_nx_out;
409wire [4:0]      mul_exc_out;
410wire            m2stg_frac1_dbl_norm;
411wire            m2stg_frac1_dbl_dnrm;
412wire            m2stg_frac1_sng_norm;
413wire            m2stg_frac1_sng_dnrm;
414wire            m2stg_frac1_inf;
415wire            m2stg_frac2_dbl_norm;
416wire            m2stg_frac2_dbl_dnrm;
417wire            m2stg_frac2_sng_norm;
418wire            m2stg_frac2_sng_dnrm;
419wire            m2stg_frac2_inf;
420wire            m1stg_inf_zero_in;
421wire            m1stg_inf_zero_in_dbl;
422wire [5:0]      m2stg_ld0_1_in;
423wire [5:0]      m2stg_ld0_1;
424wire [5:0]      m2stg_ld0_2_in;
425wire [5:0]      m2stg_ld0_2;
426wire            m2stg_exp_expadd;
427wire            m2stg_exp_0bff;
428wire            m2stg_exp_017f;
429wire            m2stg_exp_04ff;
430wire            m2stg_exp_zero;
431wire [6:0]      m2stg_ld0;
432wire [6:0]      m2stg_ld0_inv;
433wire [6:0]      m3astg_ld0_inv;
434wire [6:0]      m3bstg_ld0_inv;
435wire            m4stg_expadd_eq_0;
436wire            m3stg_exp_lte_0;
437wire            m4stg_right_shift_in;
438wire            m4stg_right_shift;
439wire [5:0]      m3stg_exp_minus1;
440wire [5:0]      m3stg_exp_inv_plus2;
441wire            m3stg_exp_lt_neg57;
442wire [5:0]      m4stg_sh_cnt_in;
443wire            m4stg_left_shift_step;
444wire            m4stg_right_shift_step;
445wire            m4stg_inc_exp_54;
446wire            m4stg_inc_exp_55;
447wire            m4stg_inc_exp_105;
448wire            m5stg_rndup;
449wire            m5stg_to_0;
450wire            m5stg_to_0_inv;
451wire            mul_frac_out_fracadd;
452wire            mul_frac_out_frac;
453wire            mul_exp_out_exp_plus1;
454wire            mul_exp_out_exp;
455wire            mul_pipe_active_in;
456wire            mul_pipe_active;
457wire    mula_rst_l;
458
459
460dffrl_async #(1)  dffrl_mul_ctl (
461  .din  (grst_l),
462  .clk  (rclk),
463  .rst_l(arst_l),
464  .q    (mul_ctl_rst_l),
465        .se (se),
466        .si (),
467        .so ()
468  );
469
470assign reset= (!mul_ctl_rst_l);
471
472// 3/14/03 reset signal for mul64
473assign mula_rst_l = mul_ctl_rst_l;
474
475
476///////////////////////////////////////////////////////////////////////////////
477//
478//      Multiply pipeline special input cases.
479//
480///////////////////////////////////////////////////////////////////////////////
481
482dffe_s #(1) i_mul_frac_in1_51 (
483        .din    (inq_in1_51),
484        .en     (m6stg_step),
485        .clk    (rclk),
486 
487        .q      (mul_frac_in1_51),
488
489        .se     (se),
490        .si     (),
491        .so     ()
492);
493
494dffe_s #(1) i_mul_frac_in1_54 (
495        .din    (inq_in1_54),
496        .en     (m6stg_step),
497        .clk    (rclk),
498 
499        .q      (mul_frac_in1_54),
500
501        .se     (se),
502        .si     (),
503        .so     ()
504);
505
506dffe_s #(1) i_mul_frac_in1_53_0_neq_0 (
507        .din    (inq_in1_53_0_neq_0),
508        .en     (m6stg_step),
509        .clk    (rclk),
510 
511        .q      (mul_frac_in1_53_0_neq_0),
512
513        .se     (se),
514        .si     (),
515        .so     ()
516);
517
518dffe_s #(1) i_mul_frac_in1_50_0_neq_0 (
519        .din    (inq_in1_50_0_neq_0),
520        .en     (m6stg_step),
521        .clk    (rclk),
522
523        .q      (mul_frac_in1_50_0_neq_0),
524
525        .se     (se),
526        .si     (),
527        .so     ()
528);
529
530dffe_s #(1) i_mul_frac_in1_53_32_neq_0 (
531        .din    (inq_in1_53_32_neq_0),
532        .en     (m6stg_step),
533        .clk    (rclk),
534
535        .q      (mul_frac_in1_53_32_neq_0),
536
537        .se     (se),
538        .si     (),
539        .so     ()
540);
541
542dffe_s #(1) i_mul_exp_in1_exp_eq_0 (
543        .din    (inq_in1_exp_eq_0),
544        .en     (m6stg_step),
545        .clk    (rclk),
546 
547        .q      (mul_exp_in1_exp_eq_0),
548 
549        .se     (se),
550        .si     (),
551        .so     ()
552);
553
554dffe_s #(1) i_mul_exp_in1_exp_neq_ffs (
555        .din    (inq_in1_exp_neq_ffs),
556        .en     (m6stg_step),
557        .clk    (rclk),
558
559        .q      (mul_exp_in1_exp_neq_ffs),
560
561        .se     (se),
562        .si     (),
563        .so     ()
564);
565
566dffe_s #(1) i_mul_frac_in2_51 (
567        .din    (inq_in2_51),
568        .en     (m6stg_step),
569        .clk    (rclk),
570
571        .q      (mul_frac_in2_51),
572
573        .se     (se),
574        .si     (),
575        .so     ()
576);
577
578dffe_s #(1) i_mul_frac_in2_54 (
579        .din    (inq_in2_54),
580        .en     (m6stg_step),
581        .clk    (rclk),
582
583        .q      (mul_frac_in2_54),
584
585        .se     (se),
586        .si     (),
587        .so     ()
588);
589
590dffe_s #(1) i_mul_frac_in2_53_0_neq_0 (
591        .din    (inq_in2_53_0_neq_0),
592        .en     (m6stg_step),
593        .clk    (rclk),
594
595        .q      (mul_frac_in2_53_0_neq_0),
596
597        .se     (se),
598        .si     (),
599        .so     ()
600);
601
602dffe_s #(1) i_mul_frac_in2_50_0_neq_0 (
603        .din    (inq_in2_50_0_neq_0),
604        .en     (m6stg_step),
605        .clk    (rclk),
606
607        .q      (mul_frac_in2_50_0_neq_0),
608
609        .se     (se),
610        .si     (),
611        .so     ()
612);
613
614dffe_s #(1) i_mul_frac_in2_53_32_neq_0 (
615        .din    (inq_in2_53_32_neq_0),
616        .en     (m6stg_step),
617        .clk    (rclk),
618
619        .q      (mul_frac_in2_53_32_neq_0),
620
621        .se     (se),
622        .si     (),
623        .so     ()
624);
625
626dffe_s #(1) i_mul_exp_in2_exp_eq_0 (
627        .din    (inq_in2_exp_eq_0),
628         .en    (m6stg_step),
629        .clk    (rclk),
630
631        .q      (mul_exp_in2_exp_eq_0),
632
633        .se     (se),
634        .si     (),
635        .so     ()
636);
637
638dffe_s #(1) i_mul_exp_in2_exp_neq_ffs (
639        .din    (inq_in2_exp_neq_ffs),
640        .en     (m6stg_step),
641        .clk    (rclk),
642 
643        .q      (mul_exp_in2_exp_neq_ffs),
644 
645        .se     (se),
646        .si     (),
647        .so     ()
648);
649
650
651///////////////////////////////////////////////////////////////////////////////
652//
653//      Denorm multiply inputs.
654//
655///////////////////////////////////////////////////////////////////////////////
656
657assign m1stg_denorm_sng_in1= mul_exp_in1_exp_eq_0 && m1stg_sngopa[0];
658
659assign m1stg_denorm_dbl_in1= mul_exp_in1_exp_eq_0 && m1stg_dblopa[0];
660
661assign m1stg_denorm_sng_in2= mul_exp_in2_exp_eq_0 && m1stg_sngopa[0];
662
663assign m1stg_denorm_dbl_in2= mul_exp_in2_exp_eq_0 && m1stg_dblopa[0];
664
665assign m1stg_denorm_in1= m1stg_denorm_sng_in1 || m1stg_denorm_dbl_in1;
666
667assign m1stg_denorm_in2= m1stg_denorm_sng_in2 || m1stg_denorm_dbl_in2;
668
669
670///////////////////////////////////////////////////////////////////////////////
671//
672//      Non-denorm multiply inputs.
673//
674///////////////////////////////////////////////////////////////////////////////
675
676assign m1stg_norm_sng_in1= (!mul_exp_in1_exp_eq_0) && m1stg_sngopa[0];
677
678assign m1stg_norm_dbl_in1= (!mul_exp_in1_exp_eq_0) && m1stg_dblopa[0];
679
680assign m1stg_norm_sng_in2= (!mul_exp_in2_exp_eq_0) && m1stg_sngopa[0];
681
682assign m1stg_norm_dbl_in2= (!mul_exp_in2_exp_eq_0) && m1stg_dblopa[0];
683
684
685///////////////////////////////////////////////////////////////////////////////
686//
687//      Nan multiply inputs.
688//
689///////////////////////////////////////////////////////////////////////////////
690
691assign m1stg_snan_sng_in1= (!mul_exp_in1_exp_neq_ffs) && (!mul_frac_in1_54)
692                && (mul_frac_in1_53_32_neq_0) && m1stg_sngopa[1];
693
694assign m1stg_snan_dbl_in1= (!mul_exp_in1_exp_neq_ffs)
695                && (!mul_frac_in1_51) && mul_frac_in1_50_0_neq_0
696                && m1stg_dblopa[1];
697
698assign m1stg_snan_sng_in2= (!mul_exp_in2_exp_neq_ffs) && (!mul_frac_in2_54)
699                && (mul_frac_in2_53_32_neq_0) && m1stg_sngopa[1];
700
701assign m1stg_snan_dbl_in2= (!mul_exp_in2_exp_neq_ffs)
702                && (!mul_frac_in2_51) && mul_frac_in2_50_0_neq_0
703                && m1stg_dblopa[1];
704
705assign m1stg_qnan_sng_in1= (!mul_exp_in1_exp_neq_ffs) && mul_frac_in1_54
706                && m1stg_sngopa[1];
707
708assign m1stg_qnan_dbl_in1= (!mul_exp_in1_exp_neq_ffs) && mul_frac_in1_51
709                && m1stg_dblopa[1];
710
711assign m1stg_qnan_sng_in2= (!mul_exp_in2_exp_neq_ffs) && mul_frac_in2_54
712                && m1stg_sngopa[1];
713
714assign m1stg_qnan_dbl_in2= (!mul_exp_in2_exp_neq_ffs) && mul_frac_in2_51
715                && m1stg_dblopa[1];
716
717assign m1stg_snan_in1= m1stg_snan_sng_in1 || m1stg_snan_dbl_in1;
718
719assign m1stg_snan_in2= m1stg_snan_sng_in2 || m1stg_snan_dbl_in2;
720
721assign m1stg_qnan_in1= m1stg_qnan_sng_in1 || m1stg_qnan_dbl_in1;
722 
723assign m1stg_qnan_in2= m1stg_qnan_sng_in2 || m1stg_qnan_dbl_in2;
724
725dffe_s #(1) i_m2stg_snan_in1 (
726        .din    (m1stg_snan_in1),
727        .en     (m6stg_step),
728        .clk    (rclk),
729
730        .q      (m2stg_snan_in1),
731
732        .se     (se),
733        .si     (),
734        .so     ()
735);
736
737dffe_s #(1) i_m2stg_snan_in2 (
738        .din    (m1stg_snan_in2),
739        .en     (m6stg_step),
740        .clk    (rclk),
741
742        .q      (m2stg_snan_in2),
743
744        .se     (se),
745        .si     (),
746        .so     ()
747);
748
749dffe_s #(1) i_m2stg_qnan_in1 (
750        .din    (m1stg_qnan_in1),
751        .en     (m6stg_step),
752        .clk    (rclk),
753
754        .q      (m2stg_qnan_in1),
755
756        .se     (se),
757        .si     (),
758        .so     ()
759);
760
761dffe_s #(1) i_m2stg_qnan_in2 (
762        .din    (m1stg_qnan_in2),
763        .en     (m6stg_step),
764        .clk    (rclk),
765
766        .q      (m2stg_qnan_in2),
767
768        .se     (se),
769        .si     (),
770        .so     ()
771);
772
773assign m1stg_nan_sng_in1= (!mul_exp_in1_exp_neq_ffs)
774                && (mul_frac_in1_54 || mul_frac_in1_53_32_neq_0)
775                && m1stg_sngopa[2];
776
777assign m1stg_nan_dbl_in1= (!mul_exp_in1_exp_neq_ffs)
778                && (mul_frac_in1_51 || mul_frac_in1_50_0_neq_0)
779                && m1stg_dblopa[2];
780
781assign m1stg_nan_sng_in2= (!mul_exp_in2_exp_neq_ffs)
782                && (mul_frac_in2_54 || mul_frac_in2_53_32_neq_0)
783                && m1stg_sngopa[2];
784
785assign m1stg_nan_dbl_in2= (!mul_exp_in2_exp_neq_ffs)
786                && (mul_frac_in2_51 || mul_frac_in2_50_0_neq_0)
787                && m1stg_dblopa[2];
788
789assign m1stg_nan_in1= m1stg_nan_sng_in1 || m1stg_nan_dbl_in1;
790
791assign m1stg_nan_in2= m1stg_nan_sng_in2 || m1stg_nan_dbl_in2;
792
793dffe_s #(1) i_m2stg_nan_in2 (
794        .din    (m1stg_nan_in2),
795        .en     (m6stg_step),
796        .clk    (rclk),
797
798        .q      (m2stg_nan_in2),
799
800        .se     (se),
801        .si     (),
802        .so     ()
803);
804
805
806///////////////////////////////////////////////////////////////////////////////
807//
808//      Infinity multiply inputs.
809//
810///////////////////////////////////////////////////////////////////////////////
811
812assign m1stg_inf_sng_in1= (!mul_exp_in1_exp_neq_ffs)
813                && (!mul_frac_in1_54) && (!mul_frac_in1_53_32_neq_0)
814                && m1stg_sngopa[2];
815
816assign m1stg_inf_dbl_in1= (!mul_exp_in1_exp_neq_ffs)
817                && (!mul_frac_in1_51) && (!mul_frac_in1_50_0_neq_0)
818                && m1stg_dblopa[2];
819
820assign m1stg_inf_sng_in2= (!mul_exp_in2_exp_neq_ffs)
821                && (!mul_frac_in2_54) && (!mul_frac_in2_53_32_neq_0)
822                && m1stg_sngopa[2];
823
824assign m1stg_inf_dbl_in2= (!mul_exp_in2_exp_neq_ffs)
825                && (!mul_frac_in2_51) && (!mul_frac_in2_50_0_neq_0)
826                && m1stg_dblopa[2];
827
828assign m1stg_inf_in1= m1stg_inf_sng_in1 || m1stg_inf_dbl_in1;
829
830assign m1stg_inf_in2= m1stg_inf_sng_in2 || m1stg_inf_dbl_in2;
831
832assign m1stg_inf_in= m1stg_inf_in1 || m1stg_inf_in2;
833
834dffe_s #(1) i_m2stg_inf_in1 (
835        .din    (m1stg_inf_in1),
836        .en     (m6stg_step),
837        .clk    (rclk),
838
839        .q      (m2stg_inf_in1),
840
841        .se     (se),
842        .si     (),
843        .so     ()
844);
845
846dffe_s #(1) i_m2stg_inf_in2 (
847        .din    (m1stg_inf_in2),
848        .en     (m6stg_step),
849        .clk    (rclk),
850
851        .q      (m2stg_inf_in2),
852 
853        .se     (se),
854        .si     (),
855        .so     ()
856);
857
858dffe_s #(1) i_m2stg_inf_in (
859        .din    (m1stg_inf_in),
860        .en     (m6stg_step),
861        .clk    (rclk),
862
863        .q      (m2stg_inf_in),
864 
865        .se     (se),
866        .si     (),
867        .so     ()
868);
869
870
871///////////////////////////////////////////////////////////////////////////////
872//
873//      Infinity/Nan multiply inputs.
874//
875///////////////////////////////////////////////////////////////////////////////
876
877assign m1stg_infnan_sng_in1= (!mul_exp_in1_exp_neq_ffs) && m1stg_sngopa[3];
878
879assign m1stg_infnan_dbl_in1= (!mul_exp_in1_exp_neq_ffs) && m1stg_dblopa[3];
880
881assign m1stg_infnan_sng_in2= (!mul_exp_in2_exp_neq_ffs) && m1stg_sngopa[3];
882
883assign m1stg_infnan_dbl_in2= (!mul_exp_in2_exp_neq_ffs) && m1stg_dblopa[3];
884
885assign m1stg_infnan_in1= m1stg_infnan_sng_in1 || m1stg_infnan_dbl_in1;
886
887assign m1stg_infnan_in2= m1stg_infnan_sng_in2 || m1stg_infnan_dbl_in2;
888
889assign m1stg_infnan_in= m1stg_infnan_in1 || m1stg_infnan_in2;
890
891
892///////////////////////////////////////////////////////////////////////////////
893//
894//      Zero multiply inputs.
895//
896///////////////////////////////////////////////////////////////////////////////
897
898assign m1stg_zero_in1= mul_exp_in1_exp_eq_0
899                && (!mul_frac_in1_53_0_neq_0) && (!mul_frac_in1_54);
900
901assign m1stg_zero_in2= mul_exp_in2_exp_eq_0
902                && (!mul_frac_in2_53_0_neq_0) && (!mul_frac_in2_54);
903
904assign m1stg_zero_in= m1stg_zero_in1 || m1stg_zero_in2;
905
906dffe_s #(1) i_m2stg_zero_in1 (
907        .din    (m1stg_zero_in1),
908        .en     (m6stg_step),
909        .clk    (rclk),
910
911        .q      (m2stg_zero_in1),
912
913        .se     (se),
914        .si     (),
915        .so     ()
916);
917
918dffe_s #(1) i_m2stg_zero_in2 (
919        .din    (m1stg_zero_in2),
920        .en     (m6stg_step),
921        .clk    (rclk),
922
923        .q      (m2stg_zero_in2),
924
925        .se     (se),
926        .si     (),
927        .so     ()
928);
929
930dffe_s #(1) i_m2stg_zero_in (
931        .din    (m1stg_zero_in),
932        .en     (m6stg_step),
933        .clk    (rclk),
934
935        .q      (m2stg_zero_in),
936 
937        .se     (se),
938        .si     (),
939        .so     ()
940);
941 
942
943///////////////////////////////////////////////////////////////////////////////
944//
945//      Floating point multiply control pipeline.
946//
947///////////////////////////////////////////////////////////////////////////////
948
949///////////////////////////////////////////////////////////////////////////////
950//
951//      Opcode pipeline- multiply input stage.
952//
953///////////////////////////////////////////////////////////////////////////////
954
955assign m1stg_step= m6stg_stepa && (!m1stg_mul);
956
957assign m1stg_op_in[7:0]= ({8{(m1stg_step && (!reset))}}
958                            & (inq_op[7:0] & {8{inq_mul}}))
959                | ({8{((!m6stg_step) && (!reset))}}
960                            & m1stg_op[7:0]);
961
962dff_s #(8) i_m1stg_op (
963        .din    (m1stg_op_in[7:0]),
964        .clk    (rclk),
965
966        .q      (m1stg_op[7:0]),
967
968        .se     (se),
969        .si     (),
970        .so     ()
971);
972
973assign m1stg_mul_in= (m1stg_step && (!reset) && inq_mul)
974                || ((!m6stg_step) && (!reset) && m1stg_mul);
975
976dff_s #(1) i_m1stg_mul (
977        .din    (m1stg_mul_in),
978        .clk    (rclk),
979 
980        .q      (m1stg_mul),
981 
982        .se     (se),
983        .si     (),
984        .so     ()
985);
986
987dffe_s #(1) i_m1stg_sngop (
988        .din    (inq_op[0]),
989        .en     (m6stg_step),
990        .clk    (rclk),
991
992        .q      (m1stg_sngop),
993
994        .se     (se),
995        .si     (),
996        .so     ()
997);
998
999dffe_s #(4) i_m1stg_sngopa (
1000        .din    ({4{inq_op[0]}}),
1001        .en     (m6stg_step),
1002        .clk    (rclk),
1003 
1004        .q      (m1stg_sngopa[3:0]),
1005 
1006        .se     (se),
1007        .si     (),
1008        .so     ()
1009);
1010
1011dffe_s #(1) i_m1stg_dblop (
1012        .din    (inq_op[1]),
1013        .en     (m6stg_step),
1014        .clk    (rclk),
1015 
1016        .q      (m1stg_dblop),
1017
1018        .se     (se),
1019        .si     (),
1020        .so     ()
1021);
1022
1023dffe_s #(4) i_m1stg_dblopa (
1024        .din    ({4{inq_op[1]}}),
1025        .en     (m6stg_step),
1026        .clk    (rclk),
1027
1028         .q     (m1stg_dblopa[3:0]),
1029
1030        .se     (se),
1031        .si     (),
1032        .so     ()
1033);
1034
1035assign m1stg_dblop_inv_in= (!inq_op[1]);
1036
1037dffe_s #(1) i_m1stg_dblop_inv (
1038        .din    (m1stg_dblop_inv_in),
1039        .en     (m6stg_step),
1040        .clk    (rclk),
1041 
1042        .q      (m1stg_dblop_inv),
1043 
1044        .se     (se),
1045        .si     (),
1046        .so     ()
1047);
1048
1049dffe_s #(2) i_m1stg_rnd_mode (
1050        .din    (inq_rnd_mode[1:0]),
1051        .en     (m6stg_step),
1052        .clk    (rclk),
1053
1054        .q      (m1stg_rnd_mode[1:0]),
1055
1056        .se     (se),
1057        .si     (),
1058        .so     ()
1059);
1060
1061dffe_s #(5) i_m1stg_id (
1062        .din    (inq_id[4:0]),
1063        .en     (m6stg_step),
1064        .clk    (rclk),
1065 
1066        .q      (m1stg_id[4:0]),
1067
1068        .se     (se),
1069        .si     (),
1070        .so     ()
1071);
1072
1073
1074///////////////////////////////////////////////////////////////////////////////
1075//
1076//      Opcode decode- multiply stage 1.
1077//
1078///////////////////////////////////////////////////////////////////////////////
1079
1080assign m1stg_fmul= (m1stg_op[7:0]==FMULS) || (m1stg_op[7:0]==FMULD)
1081                || (m1stg_op[7:0]==FSMULD);
1082
1083assign m1stg_fmul_dbl_dst= (m1stg_op[7:0]==FMULD) || (m1stg_op[7:0]==FSMULD);
1084
1085assign m1stg_fmuls= (m1stg_op[7:0]==FMULS);
1086
1087assign m1stg_fmuld= (m1stg_op[7:0]==FMULD);
1088
1089assign m1stg_fsmuld= (m1stg_op[7:0]==FSMULD);
1090
1091assign m1stg_opdec[4:0]= {m1stg_fmul,
1092                        m1stg_fmul_dbl_dst,
1093                        m1stg_fmuls,
1094                        m1stg_fmuld,
1095                        m1stg_fsmuld};
1096
1097dffre_s #(5) i_m2stg_opdec (
1098        .din    (m1stg_opdec[4:0]),
1099        .en     (m6stg_step),
1100        .rst    (reset),
1101        .clk    (rclk),
1102
1103        .q      (m2stg_opdec[4:0]),
1104
1105        .se     (se),
1106        .si     (),
1107        .so     ()
1108);
1109
1110dffe_s #(2) i_m2stg_rnd_mode (
1111        .din    (m1stg_rnd_mode[1:0]),
1112        .en     (m6stg_step),
1113        .clk    (rclk),
1114 
1115        .q      (m2stg_rnd_mode[1:0]),
1116
1117        .se     (se),
1118        .si     (),
1119        .so     ()
1120);
1121 
1122dffe_s #(5) i_m2stg_id (
1123        .din    (m1stg_id[4:0]),
1124        .en     (m6stg_step),
1125        .clk    (rclk),
1126 
1127        .q      (m2stg_id[4:0]),
1128
1129        .se     (se),
1130        .si     (),
1131        .so     ()
1132);
1133
1134
1135///////////////////////////////////////////////////////////////////////////////
1136//
1137//      Opcode pipeline- multiply stage 2.
1138//
1139///////////////////////////////////////////////////////////////////////////////
1140
1141assign m2stg_fmul= m2stg_opdec[4];
1142assign m2stg_fmuls= m2stg_opdec[2];
1143assign m2stg_fmuld= m2stg_opdec[1];
1144assign m2stg_fsmuld= m2stg_opdec[0];
1145
1146dffre_s #(4) i_m3astg_opdec (
1147        .din    (m2stg_opdec[4:1]),
1148        .en     (m6stg_step),
1149        .rst    (reset),
1150        .clk    (rclk),
1151
1152        .q      (m3astg_opdec[4:1]),
1153
1154        .se     (se),
1155        .si     (),
1156        .so     ()
1157);
1158
1159dffe_s #(2) i_m3astg_rnd_mode (
1160        .din    (m2stg_rnd_mode[1:0]),
1161        .en     (m6stg_step),
1162        .clk    (rclk),
1163
1164        .q      (m3astg_rnd_mode[1:0]),
1165
1166        .se     (se),
1167        .si     (),
1168        .so     ()
1169);
1170
1171dffe_s #(5) i_m3astg_id (
1172        .din    (m2stg_id[4:0]),
1173        .en     (m6stg_step),
1174        .clk    (rclk),
1175
1176        .q      (m3astg_id[4:0]),
1177
1178        .se     (se),
1179        .si     (),
1180        .so     ()
1181);
1182
1183
1184///////////////////////////////////////////////////////////////////////////////
1185//
1186//      Opcode pipeline- multiply stage 3a.
1187//
1188///////////////////////////////////////////////////////////////////////////////
1189
1190dffre_s #(4) i_m3bstg_opdec (
1191        .din    (m3astg_opdec[4:1]),
1192        .en     (m6stg_step),
1193        .rst    (reset),
1194        .clk    (rclk),
1195
1196        .q      (m3bstg_opdec[4:1]),
1197
1198        .se     (se),
1199        .si     (),
1200        .so     ()
1201);
1202
1203dffe_s #(2) i_m3bstg_rnd_mode (
1204        .din    (m3astg_rnd_mode[1:0]),
1205        .en     (m6stg_step),
1206        .clk    (rclk),
1207 
1208        .q      (m3bstg_rnd_mode[1:0]),
1209
1210        .se     (se),
1211        .si     (),
1212        .so     ()
1213);
1214
1215dffe_s #(5) i_m3bstg_id (
1216        .din    (m3astg_id[4:0]),
1217        .en     (m6stg_step),
1218        .clk    (rclk),
1219
1220        .q      (m3bstg_id[4:0]),
1221 
1222        .se     (se),
1223        .si     (),
1224        .so     ()
1225);
1226
1227
1228///////////////////////////////////////////////////////////////////////////////
1229//
1230//      Opcode pipeline- multiply stage 3b.
1231//
1232///////////////////////////////////////////////////////////////////////////////
1233
1234dffre_s #(4) i_m3stg_opdec (
1235        .din    (m3bstg_opdec[4:1]),
1236        .en     (m6stg_step),
1237        .rst    (reset),
1238        .clk    (rclk),
1239
1240        .q      (m3stg_opdec[4:1]),
1241
1242        .se     (se),
1243        .si     (),
1244        .so     ()
1245);
1246
1247dffe_s #(2) i_m3stg_rnd_mode (
1248        .din    (m3bstg_rnd_mode[1:0]),
1249        .en     (m6stg_step),
1250        .clk    (rclk),
1251
1252        .q      (m3stg_rnd_mode[1:0]),
1253
1254        .se     (se),
1255        .si     (),
1256        .so     ()
1257);
1258
1259dffe_s #(5) i_m3stg_id (
1260        .din    (m3bstg_id[4:0]),
1261        .en     (m6stg_step),
1262        .clk    (rclk),
1263 
1264        .q      (m3stg_id[4:0]),
1265 
1266        .se     (se),
1267        .si     (),
1268        .so     ()
1269);
1270
1271
1272///////////////////////////////////////////////////////////////////////////////
1273//
1274//      Opcode pipeline- multiply stage 3.
1275//
1276///////////////////////////////////////////////////////////////////////////////
1277
1278assign m3stg_fmul= m3stg_opdec[4];
1279
1280dffre_s #(4) i_m4stg_opdec (
1281        .din    (m3stg_opdec[4:1]),
1282        .en     (m6stg_step),
1283        .rst    (reset),
1284        .clk    (rclk),
1285
1286        .q      (m4stg_opdec[4:1]),
1287
1288        .se     (se),
1289        .si     (),
1290        .so     ()
1291);
1292
1293dffe_s #(2) i_m4stg_rnd_mode (
1294        .din    (m3stg_rnd_mode[1:0]),
1295        .en     (m6stg_step),
1296        .clk    (rclk),
1297
1298        .q      (m4stg_rnd_mode[1:0]),
1299
1300        .se     (se),
1301        .si     (),
1302        .so     ()
1303);
1304
1305dffe_s #(5) i_m4stg_id (
1306        .din    (m3stg_id[4:0]),
1307        .en     (m6stg_step),
1308        .clk    (rclk),
1309
1310        .q      (m4stg_id[4:0]),
1311
1312        .se     (se),
1313        .si     (),
1314        .so     ()
1315);
1316
1317
1318///////////////////////////////////////////////////////////////////////////////
1319//
1320//      Opcode pipeline- multiply stage 4.
1321//
1322///////////////////////////////////////////////////////////////////////////////
1323
1324assign m4stg_fmul= m4stg_opdec[4];
1325assign m4stg_fmuld= m4stg_opdec[1];
1326
1327dffre_s #(4) i_m5stg_opdec (
1328        .din    (m4stg_opdec[4:1]),
1329        .en     (m6stg_step),
1330        .rst    (reset),
1331        .clk    (rclk),
1332
1333        .q      (m5stg_opdec[4:1]),
1334
1335        .se     (se),
1336        .si     (),
1337        .so     ()
1338);
1339
1340dffe_s #(2) i_m5stg_rnd_mode (
1341        .din    (m4stg_rnd_mode[1:0]),
1342        .en     (m6stg_step),
1343        .clk    (rclk),
1344
1345        .q      (m5stg_rnd_mode[1:0]),
1346
1347        .se     (se),
1348        .si     (),
1349        .so     ()
1350);
1351
1352dffe_s #(5) i_m5stg_id (
1353        .din    (m4stg_id[4:0]),
1354        .en     (m6stg_step),
1355        .clk    (rclk),
1356
1357        .q      (m5stg_id[4:0]),
1358
1359        .se     (se),
1360        .si     (),
1361        .so     ()
1362);
1363
1364dffre_s #(1) i_m5stg_fmulda (
1365        .din    (m4stg_fmuld),
1366        .en     (m6stg_step),
1367        .rst    (reset),
1368        .clk    (rclk),
1369
1370        .q      (m5stg_fmulda),
1371
1372        .se     (se),
1373        .si     (),
1374        .so     ()
1375);
1376
1377
1378///////////////////////////////////////////////////////////////////////////////
1379//
1380//      Opcode pipeline- multiply stage 5.
1381//
1382///////////////////////////////////////////////////////////////////////////////
1383
1384assign m5stg_fmul= m5stg_opdec[4];
1385assign m5stg_fmuls= m5stg_opdec[2];
1386assign m5stg_fmuld= m5stg_opdec[1];
1387
1388assign m6stg_fmul_in= (m6stg_stepa && (!reset)
1389                        && m5stg_fmul)
1390                || ((!m6stg_stepa) && (!reset)
1391                        && m6stg_fmul);
1392
1393dffre_s #(3) i_m6stg_opdec (
1394        .din    (m5stg_opdec[4:2]),
1395        .en     (m6stg_step),
1396        .rst    (reset),
1397        .clk    (rclk),
1398
1399        .q      (m6stg_opdec[4:2]),
1400
1401        .se     (se),
1402        .si     (),
1403        .so     ()
1404);
1405
1406assign m6stg_id_in[9:0]= ({10{m6stg_stepa}}
1407                            & {(m5stg_id[4:2]==3'o7),
1408                                (m5stg_id[4:2]==3'o6),
1409                                (m5stg_id[4:2]==3'o5),
1410                                (m5stg_id[4:2]==3'o4),
1411                                (m5stg_id[4:2]==3'o3),
1412                                (m5stg_id[4:2]==3'o2),
1413                                (m5stg_id[4:2]==3'o1),
1414                                (m5stg_id[4:2]==3'o0),
1415                                m5stg_id[1:0]})
1416                | ({10{(!m6stg_stepa)}}
1417                            & m6stg_id[9:0]);
1418
1419dffe_s #(10) i_m6stg_id (
1420        .din    (m6stg_id_in[9:0]),
1421        .en     (m6stg_step),
1422        .clk    (rclk),
1423
1424        .q      (m6stg_id[9:0]),
1425
1426        .se     (se),
1427        .si     (),
1428        .so     ()
1429);
1430
1431
1432///////////////////////////////////////////////////////////////////////////////
1433//
1434//      Opcode pipeline- multiply pipeline output.
1435//
1436///////////////////////////////////////////////////////////////////////////////
1437
1438assign m6stg_fmul= m6stg_opdec[4];
1439assign m6stg_fmul_dbl_dst= m6stg_opdec[3];
1440assign m6stg_fmuls= m6stg_opdec[2];
1441
1442assign m6stg_hold= m6stg_fmul && (!mul_dest_rdy);
1443assign m6stg_holda= m6stg_fmul && (!mul_dest_rdya);
1444
1445assign m6stg_step= (!m6stg_hold);
1446assign m6stg_stepa= (!m6stg_holda);
1447
1448// Austin update
1449// Power management update
1450
1451assign mul_pipe_active_in =  // mul pipe is executing a valid instr
1452   m1stg_fmul || m2stg_fmul || m3astg_opdec[4] || m3bstg_opdec[4] ||
1453   m3stg_fmul || m4stg_fmul || m5stg_fmul      || m6stg_fmul;
1454
1455dffre_s #(1) i_mul_pipe_active (
1456        .din    (mul_pipe_active_in),
1457        .en     (1'b1),
1458        .rst    (reset),
1459        .clk    (rclk),
1460
1461        .q      (mul_pipe_active),
1462
1463        .se     (se),
1464        .si     (),
1465        .so     ()
1466);
1467
1468
1469///////////////////////////////////////////////////////////////////////////////
1470//
1471//      Multiply sign and exception logic.
1472//
1473///////////////////////////////////////////////////////////////////////////////
1474
1475///////////////////////////////////////////////////////////////////////////////
1476//
1477//      Multiply sign inputs.
1478//
1479///////////////////////////////////////////////////////////////////////////////
1480
1481dffe_s #(1) i_m1stg_sign1 (
1482        .din    (inq_in1_63),
1483        .en     (m6stg_step),
1484        .clk    (rclk),
1485
1486        .q      (m1stg_sign1),
1487
1488        .se     (se),
1489        .si     (),
1490        .so     ()
1491);
1492
1493dffe_s #(1) i_m1stg_sign2 (
1494        .din    (inq_in2_63),
1495        .en     (m6stg_step),
1496        .clk    (rclk),
1497
1498        .q      (m1stg_sign2),
1499
1500        .se     (se),
1501        .si     (),
1502        .so     ()
1503);
1504
1505
1506///////////////////////////////////////////////////////////////////////////////
1507//
1508//      Multiply sign and exceptions.
1509//
1510//      Multiply stage 1.
1511//
1512///////////////////////////////////////////////////////////////////////////////
1513
1514dffe_s #(1) i_m2stg_sign1 (
1515        .din    (m1stg_sign1),
1516        .en     (m6stg_step),
1517        .clk    (rclk),
1518 
1519        .q      (m2stg_sign1),
1520 
1521        .se     (se),
1522        .si     (),
1523        .so     ()
1524);
1525 
1526dffe_s #(1) i_m2stg_sign2 (
1527        .din    (m1stg_sign2),
1528        .en     (m6stg_step),
1529        .clk    (rclk),
1530 
1531        .q      (m2stg_sign2),
1532 
1533        .se     (se),
1534        .si     (),
1535        .so     ()
1536);
1537
1538assign m1stg_of_mask= (!m1stg_infnan_in);
1539
1540dffe_s #(1) i_m2stg_of_mask (
1541        .din    (m1stg_of_mask),
1542        .en     (m6stg_step),
1543        .clk    (rclk),
1544
1545        .q      (m2stg_of_mask),
1546 
1547        .se     (se),
1548        .si     (),
1549        .so     ()
1550);
1551
1552
1553///////////////////////////////////////////////////////////////////////////////
1554//
1555//      Multiply sign and exceptions.
1556//
1557//      Multiply stage 2.
1558//
1559///////////////////////////////////////////////////////////////////////////////
1560
1561assign m2stg_sign= ((m2stg_sign1
1562                                && (!m2stg_snan_in2)
1563                                && (!(m2stg_qnan_in2 && (!m2stg_snan_in1))))
1564                        ^ (m2stg_sign2
1565                                && (!(m2stg_snan_in1 && (!m2stg_snan_in2)))
1566                                && (!(m2stg_qnan_in1 && (!m2stg_nan_in2)))))
1567                && (!(m2stg_inf_in && m2stg_zero_in));
1568
1569dffe_s #(1) i_m3astg_sign (
1570        .din    (m2stg_sign),
1571        .en     (m6stg_step),
1572        .clk    (rclk),
1573
1574        .q      (m3astg_sign),
1575
1576        .se     (se),
1577        .si     (),
1578        .so     ()
1579);
1580
1581assign m2stg_nv= m2stg_snan_in1
1582                || m2stg_snan_in2
1583                || (m2stg_zero_in1 && m2stg_inf_in2)
1584                || (m2stg_inf_in1 && m2stg_zero_in2);
1585
1586dffe_s #(1) i_m3astg_nv (
1587        .din    (m2stg_nv),
1588        .en     (m6stg_step),
1589        .clk    (rclk),
1590
1591        .q      (m3astg_nv),
1592
1593        .se     (se),
1594        .si     (),
1595        .so     ()
1596);
1597
1598dffe_s #(1) i_m3astg_of_mask (
1599        .din    (m2stg_of_mask),
1600        .en     (m6stg_step),
1601        .clk    (rclk),
1602
1603        .q      (m3astg_of_mask),
1604
1605        .se     (se),
1606        .si     (),
1607        .so     ()
1608);
1609
1610
1611///////////////////////////////////////////////////////////////////////////////
1612//
1613//      Multiply sign and exceptions.
1614//
1615//      Multiply stage 3a.
1616//
1617///////////////////////////////////////////////////////////////////////////////
1618
1619dffe_s #(1) i_m3bstg_sign (
1620        .din    (m3astg_sign),
1621        .en     (m6stg_step),
1622        .clk    (rclk),
1623
1624        .q      (m3bstg_sign),
1625
1626        .se     (se),
1627        .si     (),
1628        .so     ()
1629);
1630
1631dffe_s #(1) i_m3bstg_nv (
1632        .din    (m3astg_nv),
1633        .en     (m6stg_step),
1634        .clk    (rclk),
1635
1636        .q      (m3bstg_nv),
1637
1638        .se     (se),
1639        .si     (),
1640        .so     ()
1641);
1642
1643dffe_s #(1) i_m3bstg_of_mask (
1644        .din    (m3astg_of_mask),
1645        .en     (m6stg_step),
1646        .clk    (rclk),
1647
1648        .q      (m3bstg_of_mask),
1649
1650        .se     (se),
1651        .si     (),
1652        .so     ()
1653);
1654
1655
1656///////////////////////////////////////////////////////////////////////////////
1657//
1658//      Multiply sign and exceptions.
1659//
1660//      Multiply stage 3b.
1661//
1662///////////////////////////////////////////////////////////////////////////////
1663
1664dffe_s #(1) i_m3stg_sign (
1665        .din    (m3bstg_sign),
1666        .en     (m6stg_step),
1667        .clk    (rclk),
1668
1669        .q      (m3stg_sign),
1670
1671        .se     (se),
1672        .si     (),
1673        .so     ()
1674);
1675
1676dffe_s #(1) i_m3stg_nv (
1677        .din    (m3bstg_nv),
1678        .en     (m6stg_step),
1679        .clk    (rclk),
1680
1681        .q      (m3stg_nv),
1682
1683        .se     (se),
1684        .si     (),
1685        .so     ()
1686);
1687
1688dffe_s #(1) i_m3stg_of_mask (
1689        .din    (m3bstg_of_mask),
1690        .en     (m6stg_step),
1691        .clk    (rclk),
1692
1693        .q      (m3stg_of_mask),
1694
1695        .se     (se),
1696        .si     (),
1697        .so     ()
1698);
1699
1700
1701///////////////////////////////////////////////////////////////////////////////
1702//
1703//      Multiply sign and exceptions.
1704//
1705//      Multiply stage 3.
1706//
1707///////////////////////////////////////////////////////////////////////////////
1708 
1709dffe_s #(1) i_m4stg_sign (
1710        .din    (m3stg_sign),
1711        .en     (m6stg_step),
1712        .clk    (rclk),
1713 
1714        .q      (m4stg_sign),
1715 
1716        .se     (se),
1717        .si     (),
1718        .so     ()
1719);
1720 
1721dffe_s #(1) i_m4stg_nv (
1722        .din    (m3stg_nv),
1723        .en     (m6stg_step),
1724        .clk    (rclk),
1725 
1726        .q      (m4stg_nv),
1727 
1728        .se     (se),
1729        .si     (),
1730        .so     ()
1731);
1732 
1733dffe_s #(1) i_m4stg_of_mask (
1734        .din    (m3stg_of_mask),
1735        .en     (m6stg_step),
1736        .clk    (rclk),
1737 
1738        .q      (m4stg_of_mask),
1739 
1740        .se     (se),
1741        .si     (),
1742        .so     ()
1743);
1744
1745
1746///////////////////////////////////////////////////////////////////////////////
1747//
1748//      Multiply sign and exceptions.
1749//
1750//      Multiply stage 4.
1751//
1752///////////////////////////////////////////////////////////////////////////////
1753
1754dffe_s #(1) i_m5stg_sign (
1755        .din    (m4stg_sign),
1756        .en     (m6stg_step),
1757        .clk    (rclk),
1758
1759        .q      (m5stg_sign),
1760
1761        .se     (se),
1762        .si     (),
1763        .so     ()
1764);
1765
1766dffe_s #(1) i_m5stg_nv (
1767        .din    (m4stg_nv),
1768        .en     (m6stg_step),
1769        .clk    (rclk),
1770
1771        .q      (m5stg_nv),
1772
1773        .se     (se),
1774        .si     (),
1775        .so     ()
1776);
1777
1778dffe_s #(1) i_m5stg_of_mask (
1779        .din    (m4stg_of_mask),
1780        .en     (m6stg_step),
1781        .clk    (rclk),
1782 
1783        .q      (m5stg_of_mask),
1784 
1785        .se     (se),
1786        .si     (),
1787        .so     ()
1788);
1789
1790
1791///////////////////////////////////////////////////////////////////////////////
1792//
1793//      Multiply sign and exceptions.
1794//
1795//      Multiply stage 5.
1796//
1797///////////////////////////////////////////////////////////////////////////////
1798
1799dffe_s #(1) i_mul_sign_out (
1800        .din    (m5stg_sign),
1801        .en     (m6stg_step),
1802        .clk    (rclk),
1803
1804        .q      (mul_sign_out),
1805
1806        .se     (se),
1807        .si     (),
1808        .so     ()
1809);
1810
1811dffe_s #(1) i_mul_nv_out (
1812        .din    (m5stg_nv),
1813        .en     (m6stg_step),
1814        .clk    (rclk),
1815
1816        .q      (mul_nv_out),
1817
1818        .se     (se),
1819        .si     (),
1820        .so     ()
1821);
1822
1823assign m5stg_in_of= ((!m5stg_exp[12])
1824                        && m5stg_fmuld
1825                        && (m5stg_exp[11] || (&m5stg_exp[10:0]))
1826                        && m5stg_of_mask)
1827                || ((!m5stg_exp[12])
1828                        && m5stg_fmuls
1829                        && ((|m5stg_exp[11:8]) || (&m5stg_exp[7:0]))
1830                        && m5stg_of_mask);
1831
1832assign mul_of_out_tmp1_in= ((!m5stg_exp[12])
1833                        && m5stg_fmuld
1834                        && (&m5stg_exp[10:1])
1835                        && m5stg_rndup
1836                        && m5stg_of_mask)
1837                || ((!m5stg_exp[12])
1838                        && m5stg_fmuls
1839                        && (&m5stg_exp[7:1])
1840                        && m5stg_rndup
1841                        && m5stg_of_mask);
1842
1843dffe_s #(1) i_mul_of_out_tmp1 (
1844        .din    (mul_of_out_tmp1_in),
1845        .en     (m6stg_step),
1846        .clk    (rclk),
1847
1848        .q      (mul_of_out_tmp1),
1849
1850        .se     (se),
1851        .si     (),
1852        .so     ()
1853);
1854
1855dffe_s #(1) i_mul_of_out_tmp2 (
1856        .din    (m5stg_in_of),
1857        .en     (m6stg_step),
1858        .clk    (rclk),
1859
1860        .q      (mul_of_out_tmp2),
1861
1862        .se     (se),
1863        .si     (),
1864        .so     ()
1865);
1866
1867dffe_s #(1) i_mul_of_out_cout (
1868        .din    (m5stg_fracadd_cout),
1869        .en     (m6stg_step),
1870        .clk    (rclk),
1871
1872        .q      (mul_of_out_cout),
1873
1874        .se     (se),
1875        .si     (),
1876        .so     ()
1877);
1878
1879assign mul_of_out= mul_of_out_tmp2
1880                || (mul_of_out_tmp1 && mul_of_out_cout);
1881
1882assign mul_uf_out_in= (m5stg_exp[12] || (!(|m5stg_exp[11:0])))
1883                && m5stg_frac_neq_0;
1884
1885dffe_s #(1) i_mul_uf_out (
1886        .din    (mul_uf_out_in),
1887        .en     (m6stg_step),
1888        .clk    (rclk),
1889 
1890        .q      (mul_uf_out),
1891 
1892        .se     (se),
1893        .si     (),
1894        .so     ()
1895);
1896
1897assign mul_nx_out_in= (m5stg_fmuld && m5stg_frac_dbl_nx)
1898                || (m5stg_fmuls && m5stg_frac_sng_nx);
1899
1900dffe_s #(1) i_mul_nx_out (
1901        .din    (mul_nx_out_in),
1902        .en     (m6stg_step),
1903        .clk    (rclk),
1904
1905        .q      (mul_nx_out),
1906
1907        .se     (se),
1908        .si     (),
1909        .so     ()
1910);
1911
1912
1913///////////////////////////////////////////////////////////////////////////////
1914//
1915//      Multiply exception output.
1916//
1917///////////////////////////////////////////////////////////////////////////////
1918
1919// Austin update
1920// Overflow is always accompanied by inexact.
1921// Previously this was handled within the FFU.
1922
1923// assign mul_exc_out[4:0]= {mul_nv_out, mul_of_out, mul_uf_out, 1'b0, mul_nx_out};
1924
1925assign mul_exc_out[4:0] =
1926  {mul_nv_out,
1927   mul_of_out,
1928   mul_uf_out,
1929   1'b0,
1930   (mul_nx_out || mul_of_out)};  // Overflow is always accompanied by inexact
1931
1932
1933///////////////////////////////////////////////////////////////////////////////
1934//
1935//      Multiply pipeline control logic.
1936//
1937///////////////////////////////////////////////////////////////////////////////
1938 
1939///////////////////////////////////////////////////////////////////////////////
1940//
1941//      Select lines- multiply normalization and special input injection.
1942//
1943//      Multiply stage 1.
1944//
1945///////////////////////////////////////////////////////////////////////////////
1946
1947assign m2stg_frac1_dbl_norm= m1stg_norm_dbl_in1
1948                && ((!(m1stg_infnan_dbl_in1 || m1stg_infnan_dbl_in2))
1949                        || (m1stg_snan_dbl_in1 && (!m1stg_snan_dbl_in2))
1950                        || (m1stg_qnan_dbl_in1 && (!m1stg_nan_dbl_in2)));
1951
1952assign m2stg_frac1_dbl_dnrm= m1stg_denorm_dbl_in1
1953                && (!(m1stg_infnan_dbl_in1 || m1stg_infnan_dbl_in2));
1954
1955assign m2stg_frac1_sng_norm= m1stg_norm_sng_in1
1956                && ((!(m1stg_infnan_sng_in1 || m1stg_infnan_sng_in2))
1957                        || (m1stg_snan_sng_in1 && (!m1stg_snan_sng_in2))
1958                        || (m1stg_qnan_sng_in1 && (!m1stg_nan_sng_in2)));
1959
1960assign m2stg_frac1_sng_dnrm= m1stg_denorm_sng_in1
1961                && (!(m1stg_infnan_sng_in1 || m1stg_infnan_sng_in2));
1962
1963assign m2stg_frac1_inf= (m1stg_inf_in && (!m1stg_nan_in1) && (!m1stg_nan_in2))
1964                || m1stg_snan_in2
1965                || (m1stg_qnan_in2 && (!m1stg_snan_in1));
1966
1967assign m2stg_frac2_dbl_norm= m1stg_norm_dbl_in2
1968                && ((!(m1stg_infnan_dbl_in1 || m1stg_infnan_dbl_in2))
1969                        || m1stg_snan_dbl_in2
1970                        || (m1stg_qnan_dbl_in2 && (!m1stg_snan_dbl_in1)));
1971
1972assign m2stg_frac2_dbl_dnrm= m1stg_denorm_dbl_in2
1973                && (!(m1stg_infnan_dbl_in1 || m1stg_infnan_dbl_in2));
1974
1975assign m2stg_frac2_sng_norm= m1stg_norm_sng_in2
1976                && ((!(m1stg_infnan_sng_in1 || m1stg_infnan_sng_in2))
1977                        || m1stg_snan_sng_in2
1978                        || (m1stg_qnan_sng_in2 && (!m1stg_snan_sng_in1)));
1979
1980assign m2stg_frac2_sng_dnrm= m1stg_denorm_sng_in2
1981                && (!(m1stg_infnan_sng_in1 || m1stg_infnan_sng_in2));
1982
1983assign m2stg_frac2_inf= (m1stg_inf_in && (!m1stg_nan_in1) && (!m1stg_nan_in2))
1984                || (m1stg_snan_in1 && (!m1stg_snan_in2))
1985                || (m1stg_qnan_in1 && (!m1stg_nan_in2));
1986
1987assign m1stg_inf_zero_in= (m1stg_inf_in1 && m1stg_zero_in2)
1988                || (m1stg_zero_in1 && m1stg_inf_in2);
1989
1990assign m1stg_inf_zero_in_dbl= ((m1stg_inf_in1 && m1stg_zero_in2)
1991                        || (m1stg_zero_in1 && m1stg_inf_in2))
1992                && m1stg_fmul_dbl_dst;
1993
1994
1995///////////////////////////////////////////////////////////////////////////////
1996//
1997//      Select lines and control logic- multiply leading 0 counts.
1998//
1999//      Multiply stage 1.
2000//
2001///////////////////////////////////////////////////////////////////////////////
2002
2003assign m2stg_ld0_1_in[5:0]= ({6{(m1stg_denorm_in1 && (!m1stg_infnan_in))}}
2004                & m1stg_ld0_1[5:0]);
2005
2006dffe_s #(6) i_m2stg_ld0_1 (
2007        .din    (m2stg_ld0_1_in[5:0]),
2008        .en     (m6stg_step),
2009        .clk    (rclk),
2010
2011        .q      (m2stg_ld0_1[5:0]),
2012
2013        .se     (se),
2014        .si     (),
2015        .so     ()
2016);
2017
2018assign m2stg_ld0_2_in[5:0]= ({6{(m1stg_denorm_in2 && (!m1stg_infnan_in))}}
2019                & m1stg_ld0_2[5:0]);
2020
2021dffe_s #(6) i_m2stg_ld0_2 (
2022        .din    (m2stg_ld0_2_in[5:0]),
2023        .en     (m6stg_step),
2024        .clk    (rclk),
2025 
2026        .q      (m2stg_ld0_2[5:0]),
2027
2028        .se     (se),
2029        .si     (),
2030        .so     ()
2031);
2032
2033
2034///////////////////////////////////////////////////////////////////////////////
2035//
2036//      Select lines- multiply exponent adder.
2037//
2038//      Multiply stage 1.
2039//
2040///////////////////////////////////////////////////////////////////////////////
2041
2042assign m2stg_exp_expadd= (!m1stg_infnan_in) && (!m1stg_zero_in);
2043
2044assign m2stg_exp_0bff= m1stg_fmuld && m1stg_infnan_in;
2045
2046assign m2stg_exp_017f= m1stg_fmuls && m1stg_infnan_in;
2047
2048assign m2stg_exp_04ff= m1stg_fsmuld && m1stg_infnan_in;
2049 
2050assign m2stg_exp_zero= m1stg_zero_in && (!m1stg_infnan_in);
2051
2052
2053///////////////////////////////////////////////////////////////////////////////
2054//
2055//      Total the leading 0's.
2056//
2057//      Multiply stage 2.
2058//
2059///////////////////////////////////////////////////////////////////////////////
2060
2061assign m2stg_ld0[6:0]= {1'b0, m2stg_ld0_1[5:0]}
2062                        + {1'b0, m2stg_ld0_2[5:0]};
2063
2064assign m2stg_ld0_inv[6:0]= (~m2stg_ld0[6:0]);
2065
2066dffe_s #(7) i_m3astg_ld0_inv (
2067        .din    (m2stg_ld0_inv[6:0]),
2068        .en     (m6stg_step),
2069        .clk    (rclk),
2070
2071        .q      (m3astg_ld0_inv[6:0]),
2072
2073        .se     (se),
2074        .si     (),
2075        .so     ()
2076);
2077
2078
2079///////////////////////////////////////////////////////////////////////////////
2080//
2081//      Leading 0's.
2082//
2083//      Multiply stage 3a.
2084//
2085///////////////////////////////////////////////////////////////////////////////
2086
2087dffe_s #(7) i_m3bstg_ld0_inv (
2088        .din    (m3astg_ld0_inv[6:0]),
2089        .en     (m6stg_step),
2090        .clk    (rclk),
2091
2092        .q      (m3bstg_ld0_inv[6:0]),
2093 
2094        .se     (se),
2095        .si     (),
2096        .so     ()
2097);
2098
2099
2100///////////////////////////////////////////////////////////////////////////////
2101//
2102//      Post-normalization/denormalization shift count and direction.
2103//
2104//      Multiply stage 3.
2105//
2106///////////////////////////////////////////////////////////////////////////////
2107
2108dffe_s #(1) i_m4stg_expadd_eq_0 (
2109        .din    (m3stg_expadd_eq_0),
2110        .en     (m6stg_step),
2111        .clk    (rclk),
2112 
2113        .q      (m4stg_expadd_eq_0),
2114 
2115        .se     (se),
2116        .si     (),
2117        .so     ()
2118);
2119
2120assign m3stg_exp_lte_0= (!(|m3stg_exp[11:0])) || m3stg_exp[12];
2121
2122assign m4stg_right_shift_in= (!m3stg_expadd_lte_0_inv) && m3stg_exp_lte_0;
2123
2124dffe_s #(1) i_m4stg_right_shift (
2125        .din    (m4stg_right_shift_in),
2126        .en     (m6stg_step),
2127        .clk    (rclk),
2128
2129        .q      (m4stg_right_shift),
2130
2131        .se     (se),
2132        .si     (),
2133        .so     ()
2134);
2135
2136assign m3stg_exp_minus1[5:0]= m3stg_exp[5:0]
2137                        + 6'h3f;
2138
2139assign m3stg_exp_inv_plus2[5:0]= (~m3stg_exp[5:0])
2140                        + 6'h02;
2141
2142assign m3stg_exp_lt_neg57= ((!(&m3stg_exp[11:6]))
2143                        || (!(|m3stg_exp[5:3])))
2144                && m3stg_exp[12];
2145
2146assign m4stg_sh_cnt_in[5:0]= ({6{((!m3stg_expadd_lte_0_inv)
2147                                && (!m3stg_exp_lte_0))}}
2148                            & m3stg_exp_minus1[5:0])
2149                | ({6{((!m3stg_expadd_lte_0_inv) && m3stg_exp_lte_0
2150                                && m3stg_exp_lt_neg57)}}
2151                            & 6'h39)
2152                | ({6{((!m3stg_expadd_lte_0_inv) && m3stg_exp_lte_0
2153                                && (!m3stg_exp_lt_neg57))}}
2154                            & m3stg_exp_inv_plus2[5:0])
2155                | ({6{m3stg_expadd_lte_0_inv}}
2156                            & (~m3stg_ld0_inv[5:0]));
2157
2158
2159///////////////////////////////////////////////////////////////////////////////
2160//
2161//      Select lines and control logic- multiply shifts for
2162//              post-normalization/denormalization.
2163//
2164//      Multiply stage 4.
2165//
2166///////////////////////////////////////////////////////////////////////////////
2167
2168assign m4stg_left_shift_step= (!m4stg_right_shift) && m6stg_step;
2169
2170assign m4stg_right_shift_step= m4stg_right_shift && m6stg_step;
2171
2172// Austin update
2173// uarch timing fix
2174// Endpoint: fpu_mul_exp_dp/i_m5stg_exp_pre2_10
2175
2176// assign m4stg_inc_exp= (((!(|m4stg_exp[12:0])) && (!m4stg_right_shift)
2177//                              && m4stg_shl_54)
2178//                      || (m4stg_expadd_eq_0 && m4stg_right_shift
2179//                              && m4stg_frac_105)
2180//                      || ((!m4stg_right_shift) && m4stg_shl_55))
2181//              && m6stg_step;
2182//
2183// assign m4stg_inc_exp_inv= (!m4stg_inc_exp) && m6stg_step;
2184
2185assign m4stg_inc_exp_54  = (!(|m4stg_exp[12:0])) && (!m4stg_right_shift);
2186assign m4stg_inc_exp_55  = !m4stg_right_shift;
2187assign m4stg_inc_exp_105 = m4stg_expadd_eq_0 && m4stg_right_shift && m4stg_frac_105;
2188
2189
2190///////////////////////////////////////////////////////////////////////////////
2191//
2192//      Select lines and control logic- multiply rounding.
2193//
2194//      Multiply stage 5.
2195//
2196///////////////////////////////////////////////////////////////////////////////
2197
2198assign m5stg_rndup= ((((m5stg_rnd_mode[1:0]==2'b10) && (!m5stg_sign)
2199                                        && (m5stg_frac[2:0]!=3'b0))
2200                                || ((m5stg_rnd_mode[1:0]==2'b11) && m5stg_sign
2201                                        && (m5stg_frac[2:0]!=3'b0))
2202                                || ((m5stg_rnd_mode[1:0]==2'b00)
2203                                        && m5stg_frac[2]
2204                                        && ((m5stg_frac[1:0]!=2'b0)
2205                                                || m5stg_frac[3])))
2206                        && m5stg_fmuld)
2207                || ((((m5stg_rnd_mode[1:0]==2'b10) && (!m5stg_sign)
2208                                        && (m5stg_frac[31:0]!=32'b0))
2209                                || ((m5stg_rnd_mode[1:0]==2'b11) && m5stg_sign
2210                                        && (m5stg_frac[31:0]!=32'b0))
2211                                || ((m5stg_rnd_mode[1:0]==2'b00)
2212                                        && m5stg_frac[31]
2213                                        && ((m5stg_frac[30:0]!=31'b0)
2214                                                || m5stg_frac[32])))
2215                        && m5stg_fmuls);
2216
2217assign m5stg_to_0= (m5stg_rnd_mode[1:0]==2'b01)
2218                || ((m5stg_rnd_mode[1:0]==2'b10) && m5stg_sign)
2219                || ((m5stg_rnd_mode[1:0]==2'b11) && (!m5stg_sign));
2220
2221assign m5stg_to_0_inv= (!m5stg_to_0);
2222
2223assign mul_frac_out_fracadd= m5stg_rndup && (!m5stg_in_of);
2224
2225assign mul_frac_out_frac= (!m5stg_rndup) && (!m5stg_in_of);
2226
2227assign mul_exp_out_exp_plus1= m5stg_rndup && (!m5stg_in_of);
2228
2229assign mul_exp_out_exp= (!m5stg_rndup) && (!m5stg_in_of);
2230
2231
2232endmodule
2233
2234
Note: See TracBrowser for help on using the repository browser.