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

Subversion Repositories s1_core

[/] [s1_core/] [trunk/] [hdl/] [rtl/] [sparc_core/] [sparc_exu_ecl_eccctl.v] - Blame information for rev 113

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 95 fafa1971
// ========== Copyright Header Begin ==========================================
2
// 
3
// OpenSPARC T1 Processor File: sparc_exu_ecl_eccctl.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 113 albert.wat
`ifdef SIMPLY_RISC_TWEAKS
22
`define SIMPLY_RISC_SCANIN .si(0)
23
`else
24
`define SIMPLY_RISC_SCANIN .si()
25
`endif
26 95 fafa1971
////////////////////////////////////////////////////////////////////////
27
/*
28
//  Module Name: sparc_exu_ecl_eccctl
29
//      Description:  Implements the control logic for ecc checking.
30
//              This includes picking which error to fix (only one fixed per instruction),
31
//              enabling the checks, and signalling the errors.
32
*/
33
 
34
module sparc_exu_ecl_eccctl (/*AUTOARG*/
35
   // Outputs
36
   ue_trap_m, ecl_ecc_sel_rs1_m_l, ecl_ecc_sel_rs2_m_l,
37
   ecl_ecc_sel_rs3_m_l, ecl_ecc_log_rs1_m, ecl_ecc_log_rs2_m,
38
   ecl_ecc_log_rs3_m, ecl_byp_sel_ecc_m, ecl_ecc_rs1_use_rf_e,
39
   ecl_ecc_rs2_use_rf_e, ecl_ecc_rs3_use_rf_e, eccctl_wb_rd_m,
40
   exu_ifu_ecc_ce_m, exu_ifu_ecc_ue_m, exu_ifu_err_reg_m,
41
   ecl_byp_ecc_mask_m_l, exu_ifu_inj_ack, exu_ifu_err_synd_7_m,
42
   // Inputs
43
   clk, se, rst_tri_en, ecc_ecl_rs1_ce, ecc_ecl_rs1_ue,
44
   ecc_ecl_rs2_ce, ecc_ecl_rs2_ue, ecc_ecl_rs3_ce, ecc_ecl_rs3_ue,
45
   ecl_byp_rcc_mux2_sel_rf, ecl_byp_rs2_mux2_sel_rf,
46
   ecl_byp_rs3_mux2_sel_rf, rs1_vld_e, rs2_vld_e, rs3_vld_e,
47
   ifu_exu_rs1_m, ifu_exu_rs2_m, ifu_exu_rs3_m, rml_ecl_cwp_d,
48
   ifu_exu_ecc_mask, ifu_exu_inj_irferr, ifu_exu_disable_ce_e,
49
   wb_eccctl_spec_wen_next, ifu_exu_nceen_e, ifu_exu_inst_vld_e,
50
   rml_ecl_gl_e, cancel_rs3_ecc_e
51
   ) ;
52
   input clk;
53
   input se;
54
   input rst_tri_en;
55
   input       ecc_ecl_rs1_ce;
56
   input       ecc_ecl_rs1_ue;
57
   input       ecc_ecl_rs2_ce;
58
   input       ecc_ecl_rs2_ue;
59
   input       ecc_ecl_rs3_ce;
60
   input       ecc_ecl_rs3_ue;
61
   input       ecl_byp_rcc_mux2_sel_rf;
62
   input       ecl_byp_rs2_mux2_sel_rf;
63
   input       ecl_byp_rs3_mux2_sel_rf;
64
   input       rs1_vld_e;
65
   input       rs2_vld_e;
66
   input       rs3_vld_e;
67
   input [4:0] ifu_exu_rs1_m;
68
   input [4:0] ifu_exu_rs2_m;
69
   input [4:0] ifu_exu_rs3_m;
70
   input [2:0] rml_ecl_cwp_d;
71
   input [7:0] ifu_exu_ecc_mask;
72
   input       ifu_exu_inj_irferr;
73
   input       ifu_exu_disable_ce_e;
74
   input       wb_eccctl_spec_wen_next;
75
   input       ifu_exu_nceen_e;
76
   input       ifu_exu_inst_vld_e;
77
   input [1:0] rml_ecl_gl_e;
78
   input       cancel_rs3_ecc_e;
79
 
80
   output      ue_trap_m;
81
   output      ecl_ecc_sel_rs1_m_l;
82
   output      ecl_ecc_sel_rs2_m_l;
83
   output      ecl_ecc_sel_rs3_m_l;
84
   output      ecl_ecc_log_rs1_m;
85
   output      ecl_ecc_log_rs2_m;
86
   output      ecl_ecc_log_rs3_m;
87
   output      ecl_byp_sel_ecc_m;
88
   output      ecl_ecc_rs1_use_rf_e;
89
   output      ecl_ecc_rs2_use_rf_e;
90
   output      ecl_ecc_rs3_use_rf_e;
91
   output [4:0] eccctl_wb_rd_m;
92
   output       exu_ifu_ecc_ce_m;
93
   output       exu_ifu_ecc_ue_m;
94
   output [7:0] exu_ifu_err_reg_m;
95
   output [7:0] ecl_byp_ecc_mask_m_l;
96
   output       exu_ifu_inj_ack;
97
   output    exu_ifu_err_synd_7_m;
98
 
99
   wire      sel_rs1_e;
100
   wire      sel_rs2_e;
101
   wire      sel_rs3_e;
102
   wire        sel_rs1_m;
103
   wire        sel_rs2_m;
104
   wire        sel_rs3_m;
105
   wire        safe_sel_rs1_m;
106
   wire        safe_sel_rs2_m;
107
   wire        safe_sel_rs3_m;
108
   wire [2:0]  cwp_e;
109
   wire [2:0]  cwp_m;
110
   wire [1:0]  gl_m;
111
   wire        inj_irferr_m;
112
   wire        inj_irferr_w;
113
   wire        detect_ce_e;
114
   wire        detect_ue_e;
115
   wire        flag_ecc_ce_e;
116
   wire        flag_ecc_ue_e;
117
   wire [4:0]  log_rs_m;
118
   wire        rs1_ce_m;
119
   wire        rs1_ue_m;
120
   wire        rs2_ce_m;
121
   wire        rs2_ue_m;
122
   wire        rs3_ue_m;
123
   wire        rs1_sel_rf_e;
124
   wire        rs2_sel_rf_e;
125
   wire        rs3_sel_rf_e;
126
   wire        vld_rs3_ce_e;
127
   wire        vld_rs3_ue_e;
128 113 albert.wat
 
129
`ifdef SIMPLY_RISC_TWEAKS
130
wire nceen_m;
131
`endif
132 95 fafa1971
 
133
   // Store whether rf value was used for ecc checking
134
   assign      ecl_ecc_rs1_use_rf_e = rs1_sel_rf_e & rs1_vld_e & ifu_exu_inst_vld_e;
135
   assign      ecl_ecc_rs2_use_rf_e = rs2_sel_rf_e & rs2_vld_e & ifu_exu_inst_vld_e;
136
   assign      ecl_ecc_rs3_use_rf_e = rs3_sel_rf_e & rs3_vld_e & ifu_exu_inst_vld_e;
137
 
138 113 albert.wat
   dff_s rs1_rf_dff(.din(ecl_byp_rcc_mux2_sel_rf), .clk(clk),
139
                  .q(rs1_sel_rf_e), .se(se), `SIMPLY_RISC_SCANIN, .so());
140
   dff_s rs2_rf_dff(.din(ecl_byp_rs2_mux2_sel_rf), .clk(clk),
141
                  .q(rs2_sel_rf_e), .se(se), `SIMPLY_RISC_SCANIN, .so());
142
   dff_s rs3_rf_dff(.din(ecl_byp_rs3_mux2_sel_rf), .clk(clk),
143
                  .q(rs3_sel_rf_e), .se(se), `SIMPLY_RISC_SCANIN, .so());
144 95 fafa1971
 
145
   assign      vld_rs3_ce_e = ecc_ecl_rs3_ce & ~cancel_rs3_ecc_e;
146
   assign      vld_rs3_ue_e = ecc_ecl_rs3_ue & ~cancel_rs3_ecc_e;
147
   assign    detect_ce_e = (ecc_ecl_rs1_ce | ecc_ecl_rs2_ce | vld_rs3_ce_e);
148
   assign    detect_ue_e = (ecc_ecl_rs1_ue | ecc_ecl_rs2_ue | vld_rs3_ue_e);
149
   // Generate trap signals
150
   assign    flag_ecc_ue_e = (detect_ue_e |
151
                                    detect_ce_e & ifu_exu_disable_ce_e); // convert ce to ue
152
   assign    flag_ecc_ce_e = detect_ce_e & ~ifu_exu_disable_ce_e;
153
 
154
   // Pass along signal to fix errors
155 113 albert.wat
   dff_s byp_sel_ecc_e2m(.din(flag_ecc_ce_e), .clk(clk), .q(ecl_byp_sel_ecc_m),
156
                       .se(se), `SIMPLY_RISC_SCANIN, .so());
157
   dff_s ecc_ue_e2m(.din(flag_ecc_ue_e), .clk(clk), .q(exu_ifu_ecc_ue_m),
158
                  .se(se), `SIMPLY_RISC_SCANIN, .so());
159
   dff_s nceen_e2m(.din(ifu_exu_nceen_e), .clk(clk), .q(nceen_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
160 95 fafa1971
   assign    ue_trap_m = exu_ifu_ecc_ue_m & nceen_m;
161
   // only report ce (and replay) if no ue
162
   assign      exu_ifu_ecc_ce_m = ecl_byp_sel_ecc_m & ~exu_ifu_ecc_ue_m;
163
   // if globals then report %gl.  otherwise log %cwp
164
   assign      exu_ifu_err_reg_m[7:5] = (~log_rs_m[4] & ~log_rs_m[3])? {1'b0,gl_m[1:0]}: cwp_m[2:0];
165
   assign      exu_ifu_err_reg_m[4:0] = log_rs_m[4:0];
166
 
167
   // Control for mux to ecc decoder (just ce)
168
   assign      sel_rs1_e = ecc_ecl_rs1_ce;
169
   assign      sel_rs2_e = ~ecc_ecl_rs1_ce & ecc_ecl_rs2_ce;
170
   assign      sel_rs3_e = ~(ecc_ecl_rs1_ce | ecc_ecl_rs2_ce);
171
 
172 113 albert.wat
   dff_s ecc_sel_rs1_dff(.din(sel_rs1_e), .clk(clk), .q(sel_rs1_m),
173
                       .se(se), `SIMPLY_RISC_SCANIN, .so());
174
   dff_s ecc_sel_rs2_dff(.din(sel_rs2_e), .clk(clk), .q(sel_rs2_m),
175
                       .se(se), `SIMPLY_RISC_SCANIN, .so());
176
   dff_s ecc_sel_rs3_dff(.din(sel_rs3_e), .clk(clk), .q(sel_rs3_m),
177
                       .se(se), `SIMPLY_RISC_SCANIN, .so());
178 95 fafa1971
   // Make selects one hot
179
   assign      safe_sel_rs1_m = sel_rs1_m | rst_tri_en;
180
   assign      safe_sel_rs2_m = sel_rs2_m & ~rst_tri_en;
181
   assign      safe_sel_rs3_m = sel_rs3_m & ~rst_tri_en;
182
   assign      ecl_ecc_sel_rs1_m_l = ~safe_sel_rs1_m;
183
   assign      ecl_ecc_sel_rs2_m_l = ~safe_sel_rs2_m;
184
   assign      ecl_ecc_sel_rs3_m_l = ~safe_sel_rs3_m;
185
 
186
   // Mux to generate the rd for fixed value
187
   mux3ds #(5) ecc_rd_mux(.dout(eccctl_wb_rd_m[4:0]),
188
                          .in0(ifu_exu_rs1_m[4:0]),
189
                          .in1(ifu_exu_rs2_m[4:0]),
190
                          .in2(ifu_exu_rs3_m[4:0]),
191
                          .sel0(safe_sel_rs1_m),
192
                          .sel1(safe_sel_rs2_m),
193
                          .sel2(safe_sel_rs3_m));
194
 
195
   // Control for muxes for logging errors
196
   assign      ecl_ecc_log_rs1_m = rs1_ue_m | (rs1_ce_m & ~rs2_ue_m & ~rs3_ue_m);
197
   assign      ecl_ecc_log_rs2_m = (rs2_ue_m & ~rs1_ue_m) | (rs2_ce_m & ~rs1_ue_m & ~rs1_ce_m & ~rs3_ue_m);
198
   assign      ecl_ecc_log_rs3_m = ~(ecl_ecc_log_rs1_m | ecl_ecc_log_rs2_m);
199
   // Mux to generate the rs for error_logging
200
   mux3ds #(5) ecc_rdlog_mux(.dout(log_rs_m[4:0]),
201
                          .in0(ifu_exu_rs1_m[4:0]),
202
                          .in1(ifu_exu_rs2_m[4:0]),
203
                          .in2(ifu_exu_rs3_m[4:0]),
204
                          .sel0(ecl_ecc_log_rs1_m),
205
                          .sel1(ecl_ecc_log_rs2_m),
206
                          .sel2(ecl_ecc_log_rs3_m));
207
 
208 113 albert.wat
   dff_s #(3) cwp_d2e(.din(rml_ecl_cwp_d[2:0]), .clk(clk), .q(cwp_e[2:0]),
209
                    .se(se), `SIMPLY_RISC_SCANIN, .so());
210
   dff_s #(3) cwp_e2m(.din(cwp_e[2:0]), .clk(clk), .q(cwp_m[2:0]),
211
                    .se(se), `SIMPLY_RISC_SCANIN, .so());
212
   dff_s #(2) gl_e2m(.din(rml_ecl_gl_e[1:0]), .clk(clk), .q(gl_m[1:0]),
213
                   .se(se), `SIMPLY_RISC_SCANIN, .so());
214 95 fafa1971
 
215
   // Syndrome needs to know if it was really a ce or ue
216
   mux3ds ecc_synd7_mux(.dout(exu_ifu_err_synd_7_m),
217
                        .in0(rs1_ce_m),
218
                        .in1(rs2_ce_m),
219
                        .in2(~rs3_ue_m),
220
                        .sel0(ecl_ecc_log_rs1_m),
221
                        .sel1(ecl_ecc_log_rs2_m),
222
                        .sel2(ecl_ecc_log_rs3_m));
223
 
224
 
225
   // signals for injecting errors
226
   // inject error if it is enabled and a write will probably happen
227
   // (don't bother to check kill_w
228
   assign      inj_irferr_m = wb_eccctl_spec_wen_next & ifu_exu_inj_irferr;
229
   assign      ecl_byp_ecc_mask_m_l = ~(ifu_exu_ecc_mask[7:0] & {8{inj_irferr_m}});
230 113 albert.wat
   dff_s inj_irferr_m2w(.din(inj_irferr_m), .clk(clk), .q(inj_irferr_w),
231
                      .se(se), `SIMPLY_RISC_SCANIN, .so());
232 95 fafa1971
   assign      exu_ifu_inj_ack = inj_irferr_w;
233
 
234
   // Pipeline Flops
235 113 albert.wat
   dff_s rs1_ue_e2m(.din(ecc_ecl_rs1_ue), .clk(clk), .q(rs1_ue_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
236
   dff_s rs1_ce_e2m(.din(ecc_ecl_rs1_ce), .clk(clk), .q(rs1_ce_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
237
   dff_s rs2_ue_e2m(.din(ecc_ecl_rs2_ue), .clk(clk), .q(rs2_ue_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
238
   dff_s rs2_ce_e2m(.din(ecc_ecl_rs2_ce), .clk(clk), .q(rs2_ce_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
239
   dff_s rs3_ue_e2m(.din(vld_rs3_ue_e), .clk(clk), .q(rs3_ue_m), .se(se), `SIMPLY_RISC_SCANIN, .so());
240 95 fafa1971
 
241
endmodule // sparc_exu_ecl_eccctl

powered by: WebSVN 2.1.0

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