source: XOpenSparcT1/trunk/T1-CPU/ffu/sparc_ffu.v @ 6

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

versione iniziale opensparc

RevLine 
[6]1// ========== Copyright Header Begin ==========================================
2//
3// OpenSPARC T1 Processor File: sparc_ffu.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//  Module Name: sparc_ffu
24//  Description: This is the top level for the floating point frontend unit (ffu).
25//  It instantiates the control (ffu_ctl), datapath (ffu_dp), and register file
26//                      (frf).
27*/
28
29`include "iop.h"
30`define FPRET_CMP    69
31`define FPRET_CC_HI  68
32`define FPRET_CC_LO  67
33`define FPRET_EXC_HI 76
34`define FPRET_EXC_LO 72
35
36
37module sparc_ffu (/*AUTOARG*/
38   // Outputs
39   so, ffu_tlu_trap_ue, ffu_tlu_trap_other, ffu_tlu_trap_ieee754, 
40   ffu_tlu_ill_inst_m, ffu_tlu_fpu_tid, ffu_tlu_fpu_cmplt, 
41   ffu_lsu_kill_fst_w, ffu_lsu_fpop_rq_vld, ffu_lsu_blk_st_va_e, 
42   ffu_lsu_blk_st_e, ffu_ifu_tid_w2, ffu_ifu_stallreq, 
43   ffu_ifu_inj_ack, ffu_ifu_fst_ce_w, ffu_ifu_fpop_done_w2, 
44   ffu_ifu_err_synd_w2, ffu_ifu_err_reg_w2, ffu_ifu_ecc_ue_w2, 
45   ffu_ifu_ecc_ce_w2, ffu_ifu_cc_w2, ffu_ifu_cc_vld_w2, ffu_lsu_data, 
46   short_so0, ffu_exu_rsr_data_m, 
47   // Inputs
48   si, sehold, se, rclk, lsu_ffu_stb_full3, lsu_ffu_stb_full2, 
49   lsu_ffu_stb_full1, lsu_ffu_stb_full0, lsu_ffu_ld_vld, 
50   lsu_ffu_ld_data, lsu_ffu_flush_pipe_w, lsu_ffu_blk_asi_e, 
51   lsu_ffu_bld_cnt_w, lsu_ffu_ack, ifu_tlu_sraddr_d, 
52   ifu_tlu_inst_vld_w, ifu_tlu_flush_w, ifu_tlu_flsh_inst_e, 
53   ifu_lsu_ld_inst_e, ifu_ffu_visop_d, ifu_ffu_tid_d, 
54   ifu_ffu_stfsr_d, ifu_ffu_quad_op_e, ifu_ffu_mvcnd_m, 
55   ifu_ffu_ldxfsr_d, ifu_ffu_ldst_single_d, ifu_ffu_ldfsr_d, 
56   ifu_ffu_inj_frferr, ifu_ffu_fst_d, ifu_ffu_frs2_d, ifu_ffu_frs1_d, 
57   ifu_ffu_frd_d, ifu_ffu_fpopcode_d, ifu_ffu_fpop2_d, 
58   ifu_ffu_fpop1_d, ifu_ffu_fld_d, ifu_ffu_fcc_num_d, 
59   ifu_exu_nceen_e, ifu_exu_ecc_mask, ifu_exu_disable_ce_e, grst_l, 
60   exu_ffu_wsr_inst_e, exu_ffu_ist_e, exu_ffu_gsr_scale_m, 
61   exu_ffu_gsr_rnd_m, exu_ffu_gsr_mask_m, exu_ffu_gsr_align_m, 
62   cpx_vld, cpx_req, cpx_fpu_data, cpx_fpexc, cpx_fcmp, cpx_fccval, 
63   arst_l, mux_drive_disable, mem_write_disable, short_si0,
64//sotheas,8/17/04: eco 6529
65   lsu_ffu_st_dtlb_perr_g
66//////////////////////////////////
67   ) ;
68
69   output [80:0]        ffu_lsu_data;           // From dp of sparc_ffu_dp.v, ...
70   output               short_so0;
71
72   input                mux_drive_disable;
73   input                mem_write_disable;
74   input                short_si0;
75   /*AUTOINPUT*/
76   // Beginning of automatic inputs (from unused autoinst inputs)
77   input                arst_l;                 // To ctl of sparc_ffu_ctl.v
78   input [1:0]          cpx_fccval;             // To ctl of sparc_ffu_ctl.v
79   input                cpx_fcmp;               // To ctl of sparc_ffu_ctl.v
80   input [4:0]          cpx_fpexc;              // To ctl of sparc_ffu_ctl.v
81   input [63:0]         cpx_fpu_data;           // To dp of sparc_ffu_dp.v
82   input [3:0]          cpx_req;                // To ctl of sparc_ffu_ctl.v
83   input                cpx_vld;                // To ctl of sparc_ffu_ctl.v
84   input [2:0]          exu_ffu_gsr_align_m;    // To ctl of sparc_ffu_ctl.v
85   input [31:0]         exu_ffu_gsr_mask_m;     // To ctl of sparc_ffu_ctl.v
86   input [2:0]          exu_ffu_gsr_rnd_m;      // To ctl of sparc_ffu_ctl.v
87   input [4:0]          exu_ffu_gsr_scale_m;    // To ctl of sparc_ffu_ctl.v
88   input                exu_ffu_ist_e;          // To ctl of sparc_ffu_ctl.v
89   input                exu_ffu_wsr_inst_e;     // To ctl of sparc_ffu_ctl.v
90   input                grst_l;                 // To ctl of sparc_ffu_ctl.v
91   input                ifu_exu_disable_ce_e;   // To ctl of sparc_ffu_ctl.v
92   input [6:0]          ifu_exu_ecc_mask;       // To ctl of sparc_ffu_ctl.v
93   input                ifu_exu_nceen_e;        // To ctl of sparc_ffu_ctl.v
94   input [1:0]          ifu_ffu_fcc_num_d;      // To ctl of sparc_ffu_ctl.v
95   input                ifu_ffu_fld_d;          // To ctl of sparc_ffu_ctl.v
96   input                ifu_ffu_fpop1_d;        // To ctl of sparc_ffu_ctl.v
97   input                ifu_ffu_fpop2_d;        // To ctl of sparc_ffu_ctl.v
98   input [8:0]          ifu_ffu_fpopcode_d;     // To ctl of sparc_ffu_ctl.v
99   input [4:0]          ifu_ffu_frd_d;          // To ctl of sparc_ffu_ctl.v
100   input [4:0]          ifu_ffu_frs1_d;         // To ctl of sparc_ffu_ctl.v
101   input [4:0]          ifu_ffu_frs2_d;         // To ctl of sparc_ffu_ctl.v
102   input                ifu_ffu_fst_d;          // To ctl of sparc_ffu_ctl.v
103   input                ifu_ffu_inj_frferr;     // To ctl of sparc_ffu_ctl.v
104   input                ifu_ffu_ldfsr_d;        // To ctl of sparc_ffu_ctl.v
105   input                ifu_ffu_ldst_single_d;  // To ctl of sparc_ffu_ctl.v
106   input                ifu_ffu_ldxfsr_d;       // To ctl of sparc_ffu_ctl.v
107   input                ifu_ffu_mvcnd_m;        // To ctl of sparc_ffu_ctl.v
108   input                ifu_ffu_quad_op_e;      // To ctl of sparc_ffu_ctl.v
109   input                ifu_ffu_stfsr_d;        // To ctl of sparc_ffu_ctl.v
110   input [1:0]          ifu_ffu_tid_d;          // To ctl of sparc_ffu_ctl.v
111   input                ifu_ffu_visop_d;        // To ctl of sparc_ffu_ctl.v
112   input                ifu_lsu_ld_inst_e;      // To ctl of sparc_ffu_ctl.v
113   input                ifu_tlu_flsh_inst_e;    // To ctl of sparc_ffu_ctl.v
114   input                ifu_tlu_flush_w;        // To ctl of sparc_ffu_ctl.v
115   input                ifu_tlu_inst_vld_w;     // To ctl of sparc_ffu_ctl.v
116   input [6:0]          ifu_tlu_sraddr_d;       // To ctl of sparc_ffu_ctl.v
117   input                lsu_ffu_ack;            // To ctl of sparc_ffu_ctl.v
118   input [2:0]          lsu_ffu_bld_cnt_w;      // To ctl of sparc_ffu_ctl.v
119   input                lsu_ffu_blk_asi_e;      // To ctl of sparc_ffu_ctl.v
120   input                lsu_ffu_flush_pipe_w;   // To ctl of sparc_ffu_ctl.v
121   input [63:0]         lsu_ffu_ld_data;        // To dp of sparc_ffu_dp.v
122   input                lsu_ffu_ld_vld;         // To ctl of sparc_ffu_ctl.v
123   input                lsu_ffu_stb_full0;      // To ctl of sparc_ffu_ctl.v
124   input                lsu_ffu_stb_full1;      // To ctl of sparc_ffu_ctl.v
125   input                lsu_ffu_stb_full2;      // To ctl of sparc_ffu_ctl.v
126   input                lsu_ffu_stb_full3;      // To ctl of sparc_ffu_ctl.v
127   input                lsu_ffu_st_dtlb_perr_g; // sotheas,8/17/04: fixed eco 6529, signal to sparc_ffu_ctl.v
128   input                rclk;                   // To frf of bw_r_frf.v, ...
129   input                se;                     // To frf of bw_r_frf.v, ...
130   input                sehold;                 // To frf of bw_r_frf.v
131   input                si;                     // To dp of sparc_ffu_dp.v
132   // End of automatics
133   /*AUTOOUTPUT*/
134   // Beginning of automatic outputs (from unused autoinst outputs)
135   output [3:0]         ffu_ifu_cc_vld_w2;      // From ctl of sparc_ffu_ctl.v
136   output [7:0]         ffu_ifu_cc_w2;          // From ctl of sparc_ffu_ctl.v
137   output               ffu_ifu_ecc_ce_w2;      // From ctl of sparc_ffu_ctl.v
138   output               ffu_ifu_ecc_ue_w2;      // From ctl of sparc_ffu_ctl.v
139   output [5:0]         ffu_ifu_err_reg_w2;     // From ctl of sparc_ffu_ctl.v
140   output [13:0]        ffu_ifu_err_synd_w2;    // From ctl of sparc_ffu_ctl.v
141   output               ffu_ifu_fpop_done_w2;   // From ctl of sparc_ffu_ctl.v
142   output               ffu_ifu_fst_ce_w;       // From ctl of sparc_ffu_ctl.v
143   output               ffu_ifu_inj_ack;        // From ctl of sparc_ffu_ctl.v
144   output               ffu_ifu_stallreq;       // From ctl of sparc_ffu_ctl.v
145   output [1:0]         ffu_ifu_tid_w2;         // From ctl of sparc_ffu_ctl.v
146   output               ffu_lsu_blk_st_e;       // From ctl of sparc_ffu_ctl.v
147   output [5:3]         ffu_lsu_blk_st_va_e;    // From ctl of sparc_ffu_ctl.v
148   output               ffu_lsu_fpop_rq_vld;    // From ctl of sparc_ffu_ctl.v
149   output               ffu_lsu_kill_fst_w;     // From ctl of sparc_ffu_ctl.v
150   output               ffu_tlu_fpu_cmplt;      // From ctl of sparc_ffu_ctl.v
151   output [1:0]         ffu_tlu_fpu_tid;        // From ctl of sparc_ffu_ctl.v
152   output               ffu_tlu_ill_inst_m;     // From ctl of sparc_ffu_ctl.v
153   output               ffu_tlu_trap_ieee754;   // From ctl of sparc_ffu_ctl.v
154   output               ffu_tlu_trap_other;     // From ctl of sparc_ffu_ctl.v
155   output               ffu_tlu_trap_ue;        // From ctl of sparc_ffu_ctl.v
156   output               so;                     // From dp of sparc_ffu_dp.v
157   // End of automatics
158   /*AUTOWIRE*/
159   // Beginning of automatic wires (for undeclared instantiated-module outputs)
160   wire                 ctl_dp_ecc_sel_frf;     // From ctl of sparc_ffu_ctl.v
161   wire [9:0]           ctl_dp_exc_w2;          // From ctl of sparc_ffu_ctl.v
162   wire [7:0]           ctl_dp_fcc_w2;          // From ctl of sparc_ffu_ctl.v
163   wire                 ctl_dp_flip_fpu;        // From ctl of sparc_ffu_ctl.v
164   wire                 ctl_dp_flip_lsu;        // From ctl of sparc_ffu_ctl.v
165   wire [3:0]           ctl_dp_fp_thr;          // From ctl of sparc_ffu_ctl.v
166   wire [3:0]           ctl_dp_fsr_sel_fpu;     // From ctl of sparc_ffu_ctl.v
167   wire [3:0]           ctl_dp_fsr_sel_ld;      // From ctl of sparc_ffu_ctl.v
168   wire [3:0]           ctl_dp_fsr_sel_old;     // From ctl of sparc_ffu_ctl.v
169   wire [2:0]           ctl_dp_ftt_w2;          // From ctl of sparc_ffu_ctl.v
170   wire [3:0]           ctl_dp_gsr_wsr_w2;      // From ctl of sparc_ffu_ctl.v
171   wire                 ctl_dp_new_rs1;         // From ctl of sparc_ffu_ctl.v
172   wire                 ctl_dp_noflip_fpu;      // From ctl of sparc_ffu_ctl.v
173   wire                 ctl_dp_noflip_lsu;      // From ctl of sparc_ffu_ctl.v
174   wire                 ctl_dp_noshift64_frf;   // From ctl of sparc_ffu_ctl.v
175   wire                 ctl_dp_output_sel_frf;  // From ctl of sparc_ffu_ctl.v
176   wire                 ctl_dp_output_sel_fsr;  // From ctl of sparc_ffu_ctl.v
177   wire                 ctl_dp_output_sel_rs1;  // From ctl of sparc_ffu_ctl.v
178   wire                 ctl_dp_output_sel_rs2;  // From ctl of sparc_ffu_ctl.v
179   wire                 ctl_dp_rd_ecc;          // From ctl of sparc_ffu_ctl.v
180   wire                 ctl_dp_rs2_frf_read;    // From ctl of sparc_ffu_ctl.v
181   wire                 ctl_dp_rs2_keep_data;   // From ctl of sparc_ffu_ctl.v
182   wire                 ctl_dp_rs2_sel_fpu_lsu; // From ctl of sparc_ffu_ctl.v
183   wire                 ctl_dp_rs2_sel_vis;     // From ctl of sparc_ffu_ctl.v
184   wire                 ctl_dp_rst_l;           // From ctl of sparc_ffu_ctl.v
185   wire                 ctl_dp_shift_frf_left;  // From ctl of sparc_ffu_ctl.v
186   wire                 ctl_dp_shift_frf_right; // From ctl of sparc_ffu_ctl.v
187   wire [1:0]           ctl_dp_sign;            // From ctl of sparc_ffu_ctl.v
188   wire [3:0]           ctl_dp_thr_e;           // From ctl of sparc_ffu_ctl.v
189   wire [36:0]          ctl_dp_wsr_data_w2;     // From ctl of sparc_ffu_ctl.v
190   wire                 ctl_dp_zero_low32_frf;  // From ctl of sparc_ffu_ctl.v
191   wire [6:0]           ctl_frf_addr;           // From ctl of sparc_ffu_ctl.v
192   wire                 ctl_frf_ren;            // From ctl of sparc_ffu_ctl.v
193   wire [1:0]           ctl_frf_wen;            // From ctl of sparc_ffu_ctl.v
194   wire                 ctl_vis_add32;          // From ctl of sparc_ffu_ctl.v
195   wire                 ctl_vis_align0;         // From ctl of sparc_ffu_ctl.v
196   wire                 ctl_vis_align2;         // From ctl of sparc_ffu_ctl.v
197   wire                 ctl_vis_align4;         // From ctl of sparc_ffu_ctl.v
198   wire                 ctl_vis_align6;         // From ctl of sparc_ffu_ctl.v
199   wire                 ctl_vis_align_odd;      // From ctl of sparc_ffu_ctl.v
200   wire                 ctl_vis_cin;            // From ctl of sparc_ffu_ctl.v
201   wire                 ctl_vis_log_constant;   // From ctl of sparc_ffu_ctl.v
202   wire                 ctl_vis_log_invert_rs1; // From ctl of sparc_ffu_ctl.v
203   wire                 ctl_vis_log_invert_rs2; // From ctl of sparc_ffu_ctl.v
204   wire                 ctl_vis_log_pass_const; // From ctl of sparc_ffu_ctl.v
205   wire                 ctl_vis_log_pass_rs1;   // From ctl of sparc_ffu_ctl.v
206   wire                 ctl_vis_log_pass_rs2;   // From ctl of sparc_ffu_ctl.v
207   wire                 ctl_vis_log_sel_nand;   // From ctl of sparc_ffu_ctl.v
208   wire                 ctl_vis_log_sel_nor;    // From ctl of sparc_ffu_ctl.v
209   wire                 ctl_vis_log_sel_pass;   // From ctl of sparc_ffu_ctl.v
210   wire                 ctl_vis_log_sel_xor;    // From ctl of sparc_ffu_ctl.v
211   wire                 ctl_vis_sel_add;        // From ctl of sparc_ffu_ctl.v
212   wire                 ctl_vis_sel_align;      // From ctl of sparc_ffu_ctl.v
213   wire                 ctl_vis_sel_log;        // From ctl of sparc_ffu_ctl.v
214   wire                 ctl_vis_subtract;       // From ctl of sparc_ffu_ctl.v
215   wire [4:0]           dp_ctl_fsr_aexc;        // From dp of sparc_ffu_dp.v
216   wire [4:0]           dp_ctl_fsr_cexc;        // From dp of sparc_ffu_dp.v
217   wire [7:0]           dp_ctl_fsr_fcc;         // From dp of sparc_ffu_dp.v
218   wire [1:0]           dp_ctl_fsr_rnd;         // From dp of sparc_ffu_dp.v
219   wire [4:0]           dp_ctl_fsr_tem;         // From dp of sparc_ffu_dp.v
220   wire [31:0]          dp_ctl_gsr_mask_e;      // From dp of sparc_ffu_dp.v
221   wire [4:0]           dp_ctl_gsr_scale_e;     // From dp of sparc_ffu_dp.v
222   wire [7:0]           dp_ctl_ld_fcc;          // From dp of sparc_ffu_dp.v
223   wire [1:0]           dp_ctl_rs2_sign;        // From dp of sparc_ffu_dp.v
224   wire [6:0]           dp_ctl_synd_out_high;   // From dp of sparc_ffu_dp.v
225   wire [6:0]           dp_ctl_synd_out_low;    // From dp of sparc_ffu_dp.v
226   wire [63:0]          dp_vis_rs1_data;        // From dp of sparc_ffu_dp.v
227   wire [63:0]          dp_vis_rs2_data;        // From dp of sparc_ffu_dp.v
228   wire [77:0]          frf_dp_data;            // From frf of bw_r_frf.v
229   wire [63:0]          vis_dp_rd_data;         // From vis of sparc_ffu_vis.v
230   // End of automatics
231   wire [77:0]          dp_frf_data;
232   
233   output [63:0]        ffu_exu_rsr_data_m;
234   wire [31:0]          ffu_exu_rsr_data_hi_m;
235   wire [2:0]          ffu_exu_rsr_data_mid_m;
236   wire [7:0]          ffu_exu_rsr_data_lo_m;
237
238   wire                short_scan_1;
239   
240   assign              ffu_exu_rsr_data_m[63:0] = {ffu_exu_rsr_data_hi_m[31:0], 4'b0, 
241                                                   ffu_exu_rsr_data_mid_m[2:0], 17'b0,
242                                                   ffu_exu_rsr_data_lo_m[7:0]};
243
244   bw_r_frf frf(
245                .si(short_si0),
246                .so(short_scan_1),
247                .dp_frf_data            (dp_frf_data[77:0]),
248                .rst_tri_en             (mem_write_disable),
249                /*AUTOINST*/
250                // Outputs
251                .frf_dp_data            (frf_dp_data[77:0]),
252                // Inputs
253                .rclk                   (rclk),
254                .se                     (se),
255                .sehold                 (sehold),
256                .ctl_frf_wen            (ctl_frf_wen[1:0]),
257                .ctl_frf_ren            (ctl_frf_ren),
258                .ctl_frf_addr           (ctl_frf_addr[6:0]));
259
260   sparc_ffu_dp dp(
261                   .dp_frf_data         ({dp_frf_data[70:39],dp_frf_data[31:0]}),
262                   /*AUTOINST*/
263                   // Outputs
264                   .so                  (so),
265                   .ffu_lsu_data        (ffu_lsu_data[63:0]),
266                   .dp_vis_rs1_data     (dp_vis_rs1_data[63:0]),
267                   .dp_vis_rs2_data     (dp_vis_rs2_data[63:0]),
268                   .dp_ctl_rs2_sign     (dp_ctl_rs2_sign[1:0]),
269                   .dp_ctl_fsr_fcc      (dp_ctl_fsr_fcc[7:0]),
270                   .dp_ctl_fsr_rnd      (dp_ctl_fsr_rnd[1:0]),
271                   .dp_ctl_fsr_tem      (dp_ctl_fsr_tem[4:0]),
272                   .dp_ctl_fsr_aexc     (dp_ctl_fsr_aexc[4:0]),
273                   .dp_ctl_fsr_cexc     (dp_ctl_fsr_cexc[4:0]),
274                   .dp_ctl_ld_fcc       (dp_ctl_ld_fcc[7:0]),
275                   .dp_ctl_gsr_mask_e   (dp_ctl_gsr_mask_e[31:0]),
276                   .dp_ctl_gsr_scale_e  (dp_ctl_gsr_scale_e[4:0]),
277                   .dp_ctl_synd_out_low (dp_ctl_synd_out_low[6:0]),
278                   .dp_ctl_synd_out_high(dp_ctl_synd_out_high[6:0]),
279                   // Inputs
280                   .rclk                (rclk),
281                   .se                  (se),
282                   .si                  (si),
283                   .ctl_dp_rst_l        (ctl_dp_rst_l),
284                   .frf_dp_data         (frf_dp_data[77:0]),
285                   .cpx_fpu_data        (cpx_fpu_data[63:0]),
286                   .lsu_ffu_ld_data     (lsu_ffu_ld_data[63:0]),
287                   .vis_dp_rd_data      (vis_dp_rd_data[63:0]),
288                   .ctl_dp_wsr_data_w2  (ctl_dp_wsr_data_w2[36:0]),
289                   .ctl_dp_sign         (ctl_dp_sign[1:0]),
290                   .ctl_dp_exc_w2       (ctl_dp_exc_w2[9:0]),
291                   .ctl_dp_fcc_w2       (ctl_dp_fcc_w2[7:0]),
292                   .ctl_dp_ftt_w2       (ctl_dp_ftt_w2[2:0]),
293                   .ctl_dp_noshift64_frf(ctl_dp_noshift64_frf),
294                   .ctl_dp_shift_frf_right(ctl_dp_shift_frf_right),
295                   .ctl_dp_shift_frf_left(ctl_dp_shift_frf_left),
296                   .ctl_dp_zero_low32_frf(ctl_dp_zero_low32_frf),
297                   .ctl_dp_output_sel_rs1(ctl_dp_output_sel_rs1),
298                   .ctl_dp_output_sel_rs2(ctl_dp_output_sel_rs2),
299                   .ctl_dp_output_sel_frf(ctl_dp_output_sel_frf),
300                   .ctl_dp_output_sel_fsr(ctl_dp_output_sel_fsr),
301                   .ctl_dp_noflip_lsu   (ctl_dp_noflip_lsu),
302                   .ctl_dp_flip_lsu     (ctl_dp_flip_lsu),
303                   .ctl_dp_noflip_fpu   (ctl_dp_noflip_fpu),
304                   .ctl_dp_flip_fpu     (ctl_dp_flip_fpu),
305                   .ctl_dp_rs2_frf_read (ctl_dp_rs2_frf_read),
306                   .ctl_dp_rs2_sel_vis  (ctl_dp_rs2_sel_vis),
307                   .ctl_dp_rs2_sel_fpu_lsu(ctl_dp_rs2_sel_fpu_lsu),
308                   .ctl_dp_rs2_keep_data(ctl_dp_rs2_keep_data),
309                   .ctl_dp_rd_ecc       (ctl_dp_rd_ecc),
310                   .ctl_dp_fp_thr       (ctl_dp_fp_thr[3:0]),
311                   .ctl_dp_fsr_sel_old  (ctl_dp_fsr_sel_old[3:0]),
312                   .ctl_dp_fsr_sel_ld   (ctl_dp_fsr_sel_ld[3:0]),
313                   .ctl_dp_fsr_sel_fpu  (ctl_dp_fsr_sel_fpu[3:0]),
314                   .ctl_dp_gsr_wsr_w2   (ctl_dp_gsr_wsr_w2[3:0]),
315                   .ctl_dp_thr_e        (ctl_dp_thr_e[3:0]),
316                   .ctl_dp_new_rs1      (ctl_dp_new_rs1),
317                   .ctl_dp_ecc_sel_frf  (ctl_dp_ecc_sel_frf));
318
319   sparc_ffu_ctl ctl(
320                     .si(short_scan_1),
321                     .so                (short_so0),
322                     .ffu_exu_rsr_data_hi_m(ffu_exu_rsr_data_hi_m[31:0]),
323                     .ffu_exu_rsr_data_lo_m(ffu_exu_rsr_data_lo_m[7:0]),
324                     .ffu_exu_rsr_data_mid_m(ffu_exu_rsr_data_mid_m[2:0]),
325                     .ctl_frf_write_synd({dp_frf_data[77:71],dp_frf_data[38:32]}),
326                     .rst_tri_en        (mux_drive_disable),
327                     /*AUTOINST*/
328                     // Outputs
329                     .ctl_dp_gsr_wsr_w2 (ctl_dp_gsr_wsr_w2[3:0]),
330                     .ctl_dp_thr_e      (ctl_dp_thr_e[3:0]),
331                     .ctl_dp_wsr_data_w2(ctl_dp_wsr_data_w2[36:0]),
332                     .ctl_vis_add32     (ctl_vis_add32),
333                     .ctl_vis_align0    (ctl_vis_align0),
334                     .ctl_vis_align2    (ctl_vis_align2),
335                     .ctl_vis_align4    (ctl_vis_align4),
336                     .ctl_vis_align6    (ctl_vis_align6),
337                     .ctl_vis_align_odd (ctl_vis_align_odd),
338                     .ctl_vis_cin       (ctl_vis_cin),
339                     .ctl_vis_log_constant(ctl_vis_log_constant),
340                     .ctl_vis_log_invert_rs1(ctl_vis_log_invert_rs1),
341                     .ctl_vis_log_invert_rs2(ctl_vis_log_invert_rs2),
342                     .ctl_vis_log_pass_const(ctl_vis_log_pass_const),
343                     .ctl_vis_log_pass_rs1(ctl_vis_log_pass_rs1),
344                     .ctl_vis_log_pass_rs2(ctl_vis_log_pass_rs2),
345                     .ctl_vis_log_sel_nand(ctl_vis_log_sel_nand),
346                     .ctl_vis_log_sel_nor(ctl_vis_log_sel_nor),
347                     .ctl_vis_log_sel_pass(ctl_vis_log_sel_pass),
348                     .ctl_vis_log_sel_xor(ctl_vis_log_sel_xor),
349                     .ctl_vis_sel_add   (ctl_vis_sel_add),
350                     .ctl_vis_sel_align (ctl_vis_sel_align),
351                     .ctl_vis_sel_log   (ctl_vis_sel_log),
352                     .ctl_vis_subtract  (ctl_vis_subtract),
353                     .ctl_dp_rst_l      (ctl_dp_rst_l),
354                     .ffu_ifu_fpop_done_w2(ffu_ifu_fpop_done_w2),
355                     .ffu_ifu_cc_vld_w2 (ffu_ifu_cc_vld_w2[3:0]),
356                     .ffu_ifu_cc_w2     (ffu_ifu_cc_w2[7:0]),
357                     .ffu_ifu_tid_w2    (ffu_ifu_tid_w2[1:0]),
358                     .ffu_ifu_stallreq  (ffu_ifu_stallreq),
359                     .ffu_ifu_ecc_ce_w2 (ffu_ifu_ecc_ce_w2),
360                     .ffu_ifu_ecc_ue_w2 (ffu_ifu_ecc_ue_w2),
361                     .ffu_ifu_err_reg_w2(ffu_ifu_err_reg_w2[5:0]),
362                     .ffu_ifu_err_synd_w2(ffu_ifu_err_synd_w2[13:0]),
363                     .ffu_ifu_fst_ce_w  (ffu_ifu_fst_ce_w),
364                     .ffu_lsu_kill_fst_w(ffu_lsu_kill_fst_w),
365                     .ffu_ifu_inj_ack   (ffu_ifu_inj_ack),
366                     .ffu_lsu_data      (ffu_lsu_data[80:64]),
367                     .ffu_lsu_fpop_rq_vld(ffu_lsu_fpop_rq_vld),
368                     .ffu_lsu_blk_st_va_e(ffu_lsu_blk_st_va_e[5:3]),
369                     .ffu_lsu_blk_st_e  (ffu_lsu_blk_st_e),
370                     .ffu_tlu_trap_ieee754(ffu_tlu_trap_ieee754),
371                     .ffu_tlu_trap_other(ffu_tlu_trap_other),
372                     .ffu_tlu_trap_ue   (ffu_tlu_trap_ue),
373                     .ffu_tlu_ill_inst_m(ffu_tlu_ill_inst_m),
374                     .ffu_tlu_fpu_tid   (ffu_tlu_fpu_tid[1:0]),
375                     .ffu_tlu_fpu_cmplt (ffu_tlu_fpu_cmplt),
376                     .ctl_frf_ren       (ctl_frf_ren),
377                     .ctl_frf_wen       (ctl_frf_wen[1:0]),
378                     .ctl_frf_addr      (ctl_frf_addr[6:0]),
379                     .ctl_dp_fp_thr     (ctl_dp_fp_thr[3:0]),
380                     .ctl_dp_fcc_w2     (ctl_dp_fcc_w2[7:0]),
381                     .ctl_dp_ftt_w2     (ctl_dp_ftt_w2[2:0]),
382                     .ctl_dp_exc_w2     (ctl_dp_exc_w2[9:0]),
383                     .ctl_dp_ecc_sel_frf(ctl_dp_ecc_sel_frf),
384                     .ctl_dp_output_sel_rs1(ctl_dp_output_sel_rs1),
385                     .ctl_dp_output_sel_rs2(ctl_dp_output_sel_rs2),
386                     .ctl_dp_output_sel_frf(ctl_dp_output_sel_frf),
387                     .ctl_dp_output_sel_fsr(ctl_dp_output_sel_fsr),
388                     .ctl_dp_rs2_frf_read(ctl_dp_rs2_frf_read),
389                     .ctl_dp_rs2_sel_vis(ctl_dp_rs2_sel_vis),
390                     .ctl_dp_rs2_sel_fpu_lsu(ctl_dp_rs2_sel_fpu_lsu),
391                     .ctl_dp_rs2_keep_data(ctl_dp_rs2_keep_data),
392                     .ctl_dp_rd_ecc     (ctl_dp_rd_ecc),
393                     .ctl_dp_fsr_sel_ld (ctl_dp_fsr_sel_ld[3:0]),
394                     .ctl_dp_fsr_sel_fpu(ctl_dp_fsr_sel_fpu[3:0]),
395                     .ctl_dp_fsr_sel_old(ctl_dp_fsr_sel_old[3:0]),
396                     .ctl_dp_noshift64_frf(ctl_dp_noshift64_frf),
397                     .ctl_dp_shift_frf_right(ctl_dp_shift_frf_right),
398                     .ctl_dp_shift_frf_left(ctl_dp_shift_frf_left),
399                     .ctl_dp_zero_low32_frf(ctl_dp_zero_low32_frf),
400                     .ctl_dp_new_rs1    (ctl_dp_new_rs1),
401                     .ctl_dp_sign       (ctl_dp_sign[1:0]),
402                     .ctl_dp_flip_fpu   (ctl_dp_flip_fpu),
403                     .ctl_dp_flip_lsu   (ctl_dp_flip_lsu),
404                     .ctl_dp_noflip_fpu (ctl_dp_noflip_fpu),
405                     .ctl_dp_noflip_lsu (ctl_dp_noflip_lsu),
406                     // Inputs
407                     .dp_ctl_gsr_mask_e (dp_ctl_gsr_mask_e[31:0]),
408                     .dp_ctl_gsr_scale_e(dp_ctl_gsr_scale_e[4:0]),
409                     .exu_ffu_gsr_align_m(exu_ffu_gsr_align_m[2:0]),
410                     .exu_ffu_gsr_mask_m(exu_ffu_gsr_mask_m[31:0]),
411                     .exu_ffu_gsr_rnd_m (exu_ffu_gsr_rnd_m[2:0]),
412                     .exu_ffu_gsr_scale_m(exu_ffu_gsr_scale_m[4:0]),
413                     .exu_ffu_wsr_inst_e(exu_ffu_wsr_inst_e),
414                     .ifu_tlu_sraddr_d  (ifu_tlu_sraddr_d[6:0]),
415                     .lsu_ffu_st_dtlb_perr_g  (lsu_ffu_st_dtlb_perr_g), //sotheas,8/17/04: fixed eco 6529
416                     .rclk              (rclk),
417                     .se                (se),
418                     .grst_l            (grst_l),
419                     .arst_l            (arst_l),
420                     .dp_ctl_rs2_sign   (dp_ctl_rs2_sign[1:0]),
421                     .cpx_vld           (cpx_vld),
422                     .cpx_fcmp          (cpx_fcmp),
423                     .cpx_req           (cpx_req[3:0]),
424                     .cpx_fccval        (cpx_fccval[1:0]),
425                     .cpx_fpexc         (cpx_fpexc[4:0]),
426                     .dp_ctl_fsr_fcc    (dp_ctl_fsr_fcc[7:0]),
427                     .dp_ctl_fsr_rnd    (dp_ctl_fsr_rnd[1:0]),
428                     .dp_ctl_fsr_tem    (dp_ctl_fsr_tem[4:0]),
429                     .dp_ctl_fsr_aexc   (dp_ctl_fsr_aexc[4:0]),
430                     .dp_ctl_fsr_cexc   (dp_ctl_fsr_cexc[4:0]),
431                     .dp_ctl_synd_out_low(dp_ctl_synd_out_low[6:0]),
432                     .dp_ctl_synd_out_high(dp_ctl_synd_out_high[6:0]),
433                     .ifu_ffu_fpop1_d   (ifu_ffu_fpop1_d),
434                     .ifu_ffu_fpop2_d   (ifu_ffu_fpop2_d),
435                     .ifu_ffu_visop_d   (ifu_ffu_visop_d),
436                     .ifu_ffu_fpopcode_d(ifu_ffu_fpopcode_d[8:0]),
437                     .ifu_ffu_frs1_d    (ifu_ffu_frs1_d[4:0]),
438                     .ifu_ffu_frs2_d    (ifu_ffu_frs2_d[4:0]),
439                     .ifu_ffu_frd_d     (ifu_ffu_frd_d[4:0]),
440                     .ifu_ffu_fld_d     (ifu_ffu_fld_d),
441                     .ifu_ffu_fst_d     (ifu_ffu_fst_d),
442                     .ifu_ffu_ldst_single_d(ifu_ffu_ldst_single_d),
443                     .ifu_ffu_tid_d     (ifu_ffu_tid_d[1:0]),
444                     .ifu_ffu_fcc_num_d (ifu_ffu_fcc_num_d[1:0]),
445                     .ifu_ffu_mvcnd_m   (ifu_ffu_mvcnd_m),
446                     .ifu_ffu_inj_frferr(ifu_ffu_inj_frferr),
447                     .ifu_exu_ecc_mask  (ifu_exu_ecc_mask[6:0]),
448                     .ifu_ffu_ldfsr_d   (ifu_ffu_ldfsr_d),
449                     .ifu_ffu_ldxfsr_d  (ifu_ffu_ldxfsr_d),
450                     .ifu_ffu_stfsr_d   (ifu_ffu_stfsr_d),
451                     .ifu_ffu_quad_op_e (ifu_ffu_quad_op_e),
452                     .ifu_tlu_inst_vld_w(ifu_tlu_inst_vld_w),
453                     .lsu_ffu_flush_pipe_w(lsu_ffu_flush_pipe_w),
454                     .ifu_tlu_flush_w   (ifu_tlu_flush_w),
455                     .lsu_ffu_ack       (lsu_ffu_ack),
456                     .lsu_ffu_ld_vld    (lsu_ffu_ld_vld),
457                     .lsu_ffu_bld_cnt_w (lsu_ffu_bld_cnt_w[2:0]),
458                     .dp_ctl_ld_fcc     (dp_ctl_ld_fcc[7:0]),
459                     .ifu_exu_nceen_e   (ifu_exu_nceen_e),
460                     .ifu_exu_disable_ce_e(ifu_exu_disable_ce_e),
461                     .lsu_ffu_blk_asi_e (lsu_ffu_blk_asi_e),
462                     .exu_ffu_ist_e     (exu_ffu_ist_e),
463                     .ifu_tlu_flsh_inst_e(ifu_tlu_flsh_inst_e),
464                     .ifu_lsu_ld_inst_e (ifu_lsu_ld_inst_e),
465                     .lsu_ffu_stb_full0 (lsu_ffu_stb_full0),
466                     .lsu_ffu_stb_full1 (lsu_ffu_stb_full1),
467                     .lsu_ffu_stb_full2 (lsu_ffu_stb_full2),
468                     .lsu_ffu_stb_full3 (lsu_ffu_stb_full3));
469
470   sparc_ffu_vis vis(/*AUTOINST*/
471                     // Outputs
472                     .vis_dp_rd_data    (vis_dp_rd_data[63:0]),
473                     // Inputs
474                     .dp_vis_rs1_data   (dp_vis_rs1_data[63:0]),
475                     .dp_vis_rs2_data   (dp_vis_rs2_data[63:0]),
476                     .ctl_vis_sel_add   (ctl_vis_sel_add),
477                     .ctl_vis_sel_log   (ctl_vis_sel_log),
478                     .ctl_vis_sel_align (ctl_vis_sel_align),
479                     .ctl_vis_add32     (ctl_vis_add32),
480                     .ctl_vis_subtract  (ctl_vis_subtract),
481                     .ctl_vis_cin       (ctl_vis_cin),
482                     .ctl_vis_align0    (ctl_vis_align0),
483                     .ctl_vis_align2    (ctl_vis_align2),
484                     .ctl_vis_align4    (ctl_vis_align4),
485                     .ctl_vis_align6    (ctl_vis_align6),
486                     .ctl_vis_align_odd (ctl_vis_align_odd),
487                     .ctl_vis_log_sel_pass(ctl_vis_log_sel_pass),
488                     .ctl_vis_log_sel_nand(ctl_vis_log_sel_nand),
489                     .ctl_vis_log_sel_nor(ctl_vis_log_sel_nor),
490                     .ctl_vis_log_sel_xor(ctl_vis_log_sel_xor),
491                     .ctl_vis_log_invert_rs1(ctl_vis_log_invert_rs1),
492                     .ctl_vis_log_invert_rs2(ctl_vis_log_invert_rs2),
493                     .ctl_vis_log_constant(ctl_vis_log_constant),
494                     .ctl_vis_log_pass_const(ctl_vis_log_pass_const),
495                     .ctl_vis_log_pass_rs1(ctl_vis_log_pass_rs1),
496                     .ctl_vis_log_pass_rs2(ctl_vis_log_pass_rs2));
497endmodule // sparc_ffu
498// Local Variables:
499// verilog-library-directories:("." "../../../srams/rtl")
500// End:
501
Note: See TracBrowser for help on using the repository browser.