]> cvs.zerfleddert.de Git - raggedstone/blame - ethernet/source/pci/pci_wb_slave_unit.v
EDK project
[raggedstone] / ethernet / source / pci / pci_wb_slave_unit.v
CommitLineData
40a1f26c 1//////////////////////////////////////////////////////////////////////
2//// ////
3//// File name "wb_slave_unit.v" ////
4//// ////
5//// This file is part of the "PCI bridge" project ////
6//// http://www.opencores.org/cores/pci/ ////
7//// ////
8//// Author(s): ////
9//// - Miha Dolenc (mihad@opencores.org) ////
10//// ////
11//// All additional information is avaliable in the README ////
12//// file. ////
13//// ////
14//// ////
15//////////////////////////////////////////////////////////////////////
16//// ////
17//// Copyright (C) 2001 Miha Dolenc, mihad@opencores.org ////
18//// ////
19//// This source file may be used and distributed without ////
20//// restriction provided that this copyright statement is not ////
21//// removed from the file and that any derivative work contains ////
22//// the original copyright notice and the associated disclaimer. ////
23//// ////
24//// This source file is free software; you can redistribute it ////
25//// and/or modify it under the terms of the GNU Lesser General ////
26//// Public License as published by the Free Software Foundation; ////
27//// either version 2.1 of the License, or (at your option) any ////
28//// later version. ////
29//// ////
30//// This source is distributed in the hope that it will be ////
31//// useful, but WITHOUT ANY WARRANTY; without even the implied ////
32//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR ////
33//// PURPOSE. See the GNU Lesser General Public License for more ////
34//// details. ////
35//// ////
36//// You should have received a copy of the GNU Lesser General ////
37//// Public License along with this source; if not, download it ////
38//// from http://www.opencores.org/lgpl.shtml ////
39//// ////
40//////////////////////////////////////////////////////////////////////
41//
42// CVS Revision History
43//
44// $Log: pci_wb_slave_unit.v,v $
45// Revision 1.1 2007-03-20 17:50:56 sithglan
46// add shit
47//
48// Revision 1.4 2006/07/04 13:16:19 mihad
49// Write burst performance patch applied.
50// Not tested. Everything should be backwards
51// compatible, since functional code is ifdefed.
52//
53// Revision 1.3 2004/01/24 11:54:18 mihad
54// Update! SPOCI Implemented!
55//
56// Revision 1.2 2003/10/17 09:11:52 markom
57// mbist signals updated according to newest convention
58//
59// Revision 1.1 2003/01/27 16:49:31 mihad
60// Changed module and file names. Updated scripts accordingly. FIFO synchronizations changed.
61//
62// Revision 1.8 2002/10/18 03:36:37 tadejm
63// Changed wrong signal name mbist_sen into mbist_ctrl_i.
64//
65// Revision 1.7 2002/10/17 22:49:22 tadejm
66// Changed BIST signals for RAMs.
67//
68// Revision 1.6 2002/10/11 10:09:01 mihad
69// Added additional testcase and changed rst name in BIST to trst
70//
71// Revision 1.5 2002/10/08 17:17:06 mihad
72// Added BIST signals for RAMs.
73//
74// Revision 1.4 2002/09/25 15:53:52 mihad
75// Removed all logic from asynchronous reset network
76//
77// Revision 1.3 2002/02/01 15:25:13 mihad
78// Repaired a few bugs, updated specification, added test bench files and design document
79//
80// Revision 1.2 2001/10/05 08:14:30 mihad
81// Updated all files with inclusion of timescale file for simulation purposes.
82//
83// Revision 1.1.1.1 2001/10/02 15:33:46 mihad
84// New project directory structure
85//
86//
87
88// Module instantiates and connects other modules lower in hierarcy
89// Wishbone slave unit consists of modules that together form datapath
90// between external WISHBONE masters and external PCI targets
91`include "pci_constants.v"
92
93// synopsys translate_off
94`include "timescale.v"
95// synopsys translate_on
96
97module pci_wb_slave_unit
98(
99 reset_in,
100 wb_clock_in,
101 pci_clock_in,
102 ADDR_I,
103 SDATA_I,
104 SDATA_O,
105 CYC_I,
106 STB_I,
107 WE_I,
108 SEL_I,
109 ACK_O,
110 RTY_O,
111 ERR_O,
112 CAB_I,
113 wbu_map_in,
114 wbu_pref_en_in,
115 wbu_mrl_en_in,
116 wbu_pci_drcomp_pending_in,
117 wbu_conf_data_in,
118 wbu_pciw_empty_in,
119 wbu_bar0_in,
120 wbu_bar1_in,
121 wbu_bar2_in,
122 wbu_bar3_in,
123 wbu_bar4_in,
124 wbu_bar5_in,
125 wbu_am0_in,
126 wbu_am1_in,
127 wbu_am2_in,
128 wbu_am3_in,
129 wbu_am4_in,
130 wbu_am5_in,
131 wbu_ta0_in,
132 wbu_ta1_in,
133 wbu_ta2_in,
134 wbu_ta3_in,
135 wbu_ta4_in,
136 wbu_ta5_in,
137 wbu_at_en_in,
138 wbu_ccyc_addr_in ,
139 wbu_master_enable_in,
140 wb_init_complete_in,
141 wbu_cache_line_size_not_zero,
142 wbu_cache_line_size_in,
143 wbu_pciif_gnt_in,
144 wbu_pciif_frame_in,
145 wbu_pciif_irdy_in,
146 wbu_pciif_trdy_in,
147 wbu_pciif_trdy_reg_in,
148 wbu_pciif_stop_in,
149 wbu_pciif_stop_reg_in,
150 wbu_pciif_devsel_in,
151 wbu_pciif_devsel_reg_in,
152 wbu_pciif_ad_reg_in,
153 wbu_pciif_req_out,
154 wbu_pciif_frame_out,
155 wbu_pciif_frame_en_out,
156 wbu_pciif_frame_en_in,
157 wbu_pciif_frame_out_in,
158 wbu_pciif_frame_load_out,
159 wbu_pciif_irdy_out,
160 wbu_pciif_irdy_en_out,
161 wbu_pciif_ad_out,
162 wbu_pciif_ad_en_out,
163 wbu_pciif_cbe_out,
164 wbu_pciif_cbe_en_out,
165 wbu_err_addr_out,
166 wbu_err_bc_out,
167 wbu_err_signal_out,
168 wbu_err_source_out,
169 wbu_err_rty_exp_out,
170 wbu_tabort_rec_out,
171 wbu_mabort_rec_out,
172 wbu_conf_offset_out,
173 wbu_conf_renable_out,
174 wbu_conf_wenable_out,
175 wbu_conf_be_out,
176 wbu_conf_data_out,
177 wbu_del_read_comp_pending_out,
178 wbu_wbw_fifo_empty_out,
179 wbu_latency_tim_val_in,
180 wbu_ad_load_out,
181 wbu_ad_load_on_transfer_out
182
183`ifdef PCI_BIST
184 ,
185 // debug chain signals
186 mbist_si_i, // bist scan serial in
187 mbist_so_o, // bist scan serial out
188 mbist_ctrl_i // bist chain shift control
189`endif
190);
191
192input reset_in,
193 wb_clock_in,
194 pci_clock_in ;
195
196input [31:0] ADDR_I ;
197input [31:0] SDATA_I ;
198output [31:0] SDATA_O ;
199input CYC_I ;
200input STB_I ;
201input WE_I ;
202input [3:0] SEL_I ;
203output ACK_O ;
204output RTY_O ;
205output ERR_O ;
206input CAB_I ;
207
208input [5:0] wbu_map_in ;
209input [5:0] wbu_pref_en_in ;
210input [5:0] wbu_mrl_en_in ;
211
212input wbu_pci_drcomp_pending_in ;
213
214input [31:0] wbu_conf_data_in ;
215
216input wbu_pciw_empty_in ;
217
218input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar0_in ;
219input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar1_in ;
220input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar2_in ;
221input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar3_in ;
222input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar4_in ;
223input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_bar5_in ;
224input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am0_in ;
225input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am1_in ;
226input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am2_in ;
227input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am3_in ;
228input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am4_in ;
229input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_am5_in ;
230input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta0_in ;
231input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta1_in ;
232input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta2_in ;
233input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta3_in ;
234input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta4_in ;
235input [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] wbu_ta5_in ;
236input [5:0] wbu_at_en_in ;
237
238input [23:0] wbu_ccyc_addr_in ;
239
240input wbu_master_enable_in ;
241input wb_init_complete_in ;
242
243input wbu_cache_line_size_not_zero ;
244input [7:0] wbu_cache_line_size_in ;
245
246input wbu_pciif_gnt_in ;
247input wbu_pciif_frame_in ;
248input wbu_pciif_frame_en_in ;
249input wbu_pciif_irdy_in ;
250input wbu_pciif_trdy_in;
251input wbu_pciif_trdy_reg_in;
252input wbu_pciif_stop_in ;
253input wbu_pciif_stop_reg_in ;
254input wbu_pciif_devsel_in ;
255input wbu_pciif_devsel_reg_in ;
256input [31:0] wbu_pciif_ad_reg_in ;
257
258output wbu_pciif_req_out ;
259output wbu_pciif_frame_out ;
260output wbu_pciif_frame_en_out ;
261input wbu_pciif_frame_out_in ;
262output wbu_pciif_frame_load_out ;
263output wbu_pciif_irdy_out ;
264output wbu_pciif_irdy_en_out ;
265output [31:0] wbu_pciif_ad_out ;
266output wbu_pciif_ad_en_out ;
267output [3:0] wbu_pciif_cbe_out ;
268output wbu_pciif_cbe_en_out ;
269
270output [31:0] wbu_err_addr_out ;
271output [3:0] wbu_err_bc_out ;
272output wbu_err_signal_out ;
273output wbu_err_source_out ;
274output wbu_err_rty_exp_out ;
275output wbu_tabort_rec_out ;
276output wbu_mabort_rec_out ;
277
278output [11:0] wbu_conf_offset_out ;
279output wbu_conf_renable_out ;
280output wbu_conf_wenable_out ;
281output [3:0] wbu_conf_be_out ;
282output [31:0] wbu_conf_data_out ;
283
284output wbu_del_read_comp_pending_out ;
285output wbu_wbw_fifo_empty_out ;
286
287input [7:0] wbu_latency_tim_val_in ;
288
289output wbu_ad_load_out ;
290output wbu_ad_load_on_transfer_out ;
291
292`ifdef PCI_BIST
293/*-----------------------------------------------------
294BIST debug chain port signals
295-----------------------------------------------------*/
296input mbist_si_i; // bist scan serial in
297output mbist_so_o; // bist scan serial out
298input [`PCI_MBIST_CTRL_WIDTH - 1:0] mbist_ctrl_i; // bist chain shift control
299`endif
300
301// pci master interface outputs
302wire [31:0] pcim_if_address_out ;
303wire [3:0] pcim_if_bc_out ;
304wire [31:0] pcim_if_data_out ;
305wire [3:0] pcim_if_be_out ;
306wire pcim_if_req_out ;
307wire pcim_if_rdy_out ;
308wire pcim_if_last_out ;
309wire pcim_if_wbw_renable_out ;
310wire pcim_if_wbr_wenable_out ;
311wire [31:0] pcim_if_wbr_data_out ;
312wire [3:0] pcim_if_wbr_be_out ;
313wire [3:0] pcim_if_wbr_control_out ;
314wire pcim_if_del_complete_out ;
315wire pcim_if_del_error_out ;
316wire pcim_if_del_rty_exp_out ;
317wire [31:0] pcim_if_err_addr_out ;
318wire [3:0] pcim_if_err_bc_out ;
319wire pcim_if_err_signal_out ;
320wire pcim_if_err_source_out ;
321wire pcim_if_err_rty_exp_out ;
322wire pcim_if_tabort_out ;
323wire pcim_if_mabort_out ;
324wire [31:0] pcim_if_next_data_out ;
325wire [3:0] pcim_if_next_be_out ;
326wire pcim_if_next_last_out ;
327wire pcim_if_posted_write_not_present_out ;
328
329
330
331wire pcim_sm_req_out ;
332wire pcim_sm_frame_out ;
333wire pcim_sm_frame_en_out ;
334wire pcim_sm_irdy_out ;
335wire pcim_sm_irdy_en_out ;
336wire [31:0] pcim_sm_ad_out ;
337wire pcim_sm_ad_en_out ;
338wire [3:0] pcim_sm_cbe_out ;
339wire pcim_sm_cbe_en_out ;
340wire pcim_sm_ad_load_out ;
341wire pcim_sm_ad_load_on_transfer_out ;
342
343wire pcim_sm_wait_out ;
344wire pcim_sm_wtransfer_out ;
345wire pcim_sm_rtransfer_out ;
346wire pcim_sm_retry_out ;
347wire pcim_sm_rerror_out ;
348wire pcim_sm_first_out ;
349wire pcim_sm_mabort_out ;
350wire pcim_sm_frame_load_out ;
351
352assign wbu_pciif_frame_load_out = pcim_sm_frame_load_out ;
353
354assign wbu_err_addr_out = pcim_if_err_addr_out ;
355assign wbu_err_bc_out = pcim_if_err_bc_out ;
356assign wbu_err_signal_out = pcim_if_err_signal_out ;
357assign wbu_err_source_out = pcim_if_err_source_out ;
358assign wbu_err_rty_exp_out = pcim_if_err_rty_exp_out ;
359assign wbu_tabort_rec_out = pcim_if_tabort_out ;
360assign wbu_mabort_rec_out = pcim_if_mabort_out ;
361
362assign wbu_wbw_fifo_empty_out = pcim_if_posted_write_not_present_out ;
363
364// pci master state machine outputs
365// pci interface signals
366assign wbu_pciif_req_out = pcim_sm_req_out ;
367assign wbu_pciif_frame_out = pcim_sm_frame_out ;
368assign wbu_pciif_frame_en_out = pcim_sm_frame_en_out ;
369assign wbu_pciif_irdy_out = pcim_sm_irdy_out ;
370assign wbu_pciif_irdy_en_out = pcim_sm_irdy_en_out ;
371assign wbu_pciif_ad_out = pcim_sm_ad_out ;
372assign wbu_pciif_ad_en_out = pcim_sm_ad_en_out ;
373assign wbu_pciif_cbe_out = pcim_sm_cbe_out ;
374assign wbu_pciif_cbe_en_out = pcim_sm_cbe_en_out ;
375assign wbu_ad_load_out = pcim_sm_ad_load_out ;
376assign wbu_ad_load_on_transfer_out = pcim_sm_ad_load_on_transfer_out ;
377
378// signals to internal of the core
379wire [31:0] pcim_sm_data_out ;
380
381// wishbone slave state machine outputs
382wire [3:0] wbs_sm_del_bc_out ;
383wire wbs_sm_del_req_out ;
384wire wbs_sm_del_done_out ;
385wire wbs_sm_del_burst_out ;
386wire wbs_sm_del_write_out ;
387wire [11:0] wbs_sm_conf_offset_out ;
388wire wbs_sm_conf_renable_out ;
389wire wbs_sm_conf_wenable_out ;
390wire [3:0] wbs_sm_conf_be_out ;
391wire [31:0] wbs_sm_conf_data_out ;
392wire [31:0] wbs_sm_data_out ;
393wire [3:0] wbs_sm_cbe_out ;
394wire wbs_sm_wbw_wenable_out ;
395wire [3:0] wbs_sm_wbw_control_out ;
396wire wbs_sm_wbr_renable_out ;
397wire wbs_sm_wbr_flush_out ;
398wire wbs_sm_del_in_progress_out ;
399wire [31:0] wbs_sm_sdata_out ;
400wire wbs_sm_ack_out ;
401wire wbs_sm_rty_out ;
402wire wbs_sm_err_out ;
403wire wbs_sm_sample_address_out ;
404
405assign wbu_conf_offset_out = wbs_sm_conf_offset_out ;
406assign wbu_conf_renable_out = wbs_sm_conf_renable_out ;
407assign wbu_conf_wenable_out = wbs_sm_conf_wenable_out ;
408assign wbu_conf_be_out = ~wbs_sm_conf_be_out ;
409assign wbu_conf_data_out = wbs_sm_conf_data_out ;
410
411assign SDATA_O = wbs_sm_sdata_out ;
412assign ACK_O = wbs_sm_ack_out ;
413assign RTY_O = wbs_sm_rty_out ;
414assign ERR_O = wbs_sm_err_out ;
415
416
417// wbw_wbr fifo outputs
418
419// wbw_fifo_outputs:
420wire [31:0] fifos_wbw_addr_data_out ;
421wire [3:0] fifos_wbw_cbe_out ;
422wire [3:0] fifos_wbw_control_out ;
423wire fifos_wbw_almost_full_out ;
424wire fifos_wbw_full_out ;
425wire fifos_wbw_half_full_out; //Robert, burst issue
426wire fifos_wbw_empty_out ;
427wire fifos_wbw_transaction_ready_out ;
428
429// wbr_fifo_outputs
430wire [31:0] fifos_wbr_data_out ;
431wire [3:0] fifos_wbr_be_out ;
432wire [3:0] fifos_wbr_control_out ;
433wire fifos_wbr_empty_out ;
434
435// address multiplexer outputs
436wire [5:0] amux_hit_out ;
437wire [31:0] amux_address_out ;
438
439// delayed transaction logic outputs
440wire [31:0] del_sync_addr_out ;
441wire [3:0] del_sync_be_out ;
442wire del_sync_we_out ;
443wire del_sync_comp_req_pending_out ;
444wire del_sync_comp_comp_pending_out ;
445wire del_sync_req_req_pending_out ;
446wire del_sync_req_comp_pending_out ;
447wire [3:0] del_sync_bc_out ;
448wire del_sync_status_out ;
449wire del_sync_comp_flush_out ;
450wire del_sync_burst_out ;
451
452assign wbu_del_read_comp_pending_out = del_sync_comp_comp_pending_out ;
453
454// delayed write storage output
455wire [31:0] del_write_data_out ;
456
457// config. cycle address decoder output
458wire [31:0] ccyc_addr_out ;
459
460
461// WISHBONE slave interface inputs
462wire [4:0] wbs_sm_hit_in = amux_hit_out[5:1] ;
463wire wbs_sm_conf_hit_in = amux_hit_out[0] ;
464wire [4:0] wbs_sm_map_in = wbu_map_in[5:1] ;
465wire [4:0] wbs_sm_pref_en_in = wbu_pref_en_in[5:1] ;
466wire [4:0] wbs_sm_mrl_en_in = wbu_mrl_en_in[5:1] ;
467wire [31:0] wbs_sm_addr_in = amux_address_out ;
468wire [3:0] wbs_sm_del_bc_in = del_sync_bc_out ;
469wire wbs_sm_del_req_pending_in = del_sync_req_req_pending_out ;
470wire wbs_sm_wb_del_comp_pending_in = del_sync_req_comp_pending_out ;
471wire wbs_sm_pci_drcomp_pending_in = wbu_pci_drcomp_pending_in ;
472wire wbs_sm_del_write_in = del_sync_we_out ;
473wire wbs_sm_del_error_in = del_sync_status_out ;
474wire [31:0] wbs_sm_del_addr_in = del_sync_addr_out ;
475wire [3:0] wbs_sm_del_be_in = del_sync_be_out ;
476wire [31:0] wbs_sm_conf_data_in = wbu_conf_data_in ;
477wire wbs_sm_wbw_almost_full_in = fifos_wbw_almost_full_out ;
478wire wbs_sm_wbw_full_in = fifos_wbw_full_out ;
479wire wbs_sm_wbw_half_full_in = fifos_wbw_half_full_out; ////Robert, burst issue
480wire [3:0] wbs_sm_wbr_be_in = fifos_wbr_be_out ;
481wire [31:0] wbs_sm_wbr_data_in = fifos_wbr_data_out ;
482wire [3:0] wbs_sm_wbr_control_in = fifos_wbr_control_out ;
483wire wbs_sm_wbr_empty_in = fifos_wbr_empty_out ;
484wire wbs_sm_pciw_empty_in = wbu_pciw_empty_in ;
485wire wbs_sm_lock_in = ~wbu_master_enable_in ;
486wire wbs_sm_cache_line_size_not_zero = wbu_cache_line_size_not_zero ;
487wire wbs_sm_cyc_in = CYC_I ;
488wire wbs_sm_stb_in = STB_I ;
489wire wbs_sm_we_in = WE_I ;
490wire [3:0] wbs_sm_sel_in = SEL_I ;
491wire [31:0] wbs_sm_sdata_in = SDATA_I ;
492wire wbs_sm_cab_in = CAB_I ;
493wire [31:0] wbs_sm_ccyc_addr_in = ccyc_addr_out ;
494wire wbs_sm_init_complete_in = wb_init_complete_in ;
495
496// WISHBONE slave interface instantiation
497pci_wb_slave wishbone_slave(
498 .wb_clock_in (wb_clock_in) ,
499 .reset_in (reset_in) ,
500 .wb_hit_in (wbs_sm_hit_in) ,
501 .wb_conf_hit_in (wbs_sm_conf_hit_in) ,
502 .wb_map_in (wbs_sm_map_in) ,
503 .wb_pref_en_in (wbs_sm_pref_en_in) ,
504 .wb_mrl_en_in (wbs_sm_mrl_en_in) ,
505 .wb_addr_in (wbs_sm_addr_in),
506 .del_bc_in (wbs_sm_del_bc_in),
507 .wb_del_req_pending_in (wbs_sm_del_req_pending_in),
508 .wb_del_comp_pending_in (wbs_sm_wb_del_comp_pending_in),
509 .pci_drcomp_pending_in (wbs_sm_pci_drcomp_pending_in),
510 .del_bc_out (wbs_sm_del_bc_out),
511 .del_req_out (wbs_sm_del_req_out),
512 .del_done_out (wbs_sm_del_done_out),
513 .del_burst_out (wbs_sm_del_burst_out),
514 .del_write_out (wbs_sm_del_write_out),
515 .del_write_in (wbs_sm_del_write_in),
516 .del_error_in (wbs_sm_del_error_in),
517 .wb_del_addr_in (wbs_sm_del_addr_in),
518 .wb_del_be_in (wbs_sm_del_be_in),
519 .wb_conf_offset_out (wbs_sm_conf_offset_out),
520 .wb_conf_renable_out (wbs_sm_conf_renable_out),
521 .wb_conf_wenable_out (wbs_sm_conf_wenable_out),
522 .wb_conf_be_out (wbs_sm_conf_be_out),
523 .wb_conf_data_in (wbs_sm_conf_data_in),
524 .wb_conf_data_out (wbs_sm_conf_data_out),
525 .wb_data_out (wbs_sm_data_out),
526 .wb_cbe_out (wbs_sm_cbe_out),
527 .wbw_fifo_wenable_out (wbs_sm_wbw_wenable_out),
528 .wbw_fifo_control_out (wbs_sm_wbw_control_out),
529 .wbw_fifo_almost_full_in (wbs_sm_wbw_almost_full_in),
530 .wbw_fifo_full_in (wbs_sm_wbw_full_in),
531 .wbw_fifo_half_full_in (wbs_sm_wbw_half_full_in), ////Robert, burst issue
532 .wbr_fifo_renable_out (wbs_sm_wbr_renable_out),
533 .wbr_fifo_be_in (wbs_sm_wbr_be_in),
534 .wbr_fifo_data_in (wbs_sm_wbr_data_in),
535 .wbr_fifo_control_in (wbs_sm_wbr_control_in),
536 .wbr_fifo_flush_out (wbs_sm_wbr_flush_out),
537 .wbr_fifo_empty_in (wbs_sm_wbr_empty_in),
538 .pciw_fifo_empty_in (wbs_sm_pciw_empty_in),
539 .wbs_lock_in (wbs_sm_lock_in),
540 .init_complete_in (wbs_sm_init_complete_in),
541 .cache_line_size_not_zero (wbs_sm_cache_line_size_not_zero),
542 .del_in_progress_out (wbs_sm_del_in_progress_out),
543 .ccyc_addr_in (wbs_sm_ccyc_addr_in),
544 .sample_address_out (wbs_sm_sample_address_out),
545 .CYC_I (wbs_sm_cyc_in),
546 .STB_I (wbs_sm_stb_in),
547 .WE_I (wbs_sm_we_in),
548 .SEL_I (wbs_sm_sel_in),
549 .SDATA_I (wbs_sm_sdata_in),
550 .SDATA_O (wbs_sm_sdata_out),
551 .ACK_O (wbs_sm_ack_out),
552 .RTY_O (wbs_sm_rty_out),
553 .ERR_O (wbs_sm_err_out),
554 .CAB_I (wbs_sm_cab_in)
555 );
556
557// wbw_wbr_fifos inputs
558// WBW_FIFO inputs
559wire fifos_wbw_wenable_in = wbs_sm_wbw_wenable_out;
560wire [31:0] fifos_wbw_addr_data_in = wbs_sm_data_out ;
561wire [3:0] fifos_wbw_cbe_in = wbs_sm_cbe_out ;
562wire [3:0] fifos_wbw_control_in = wbs_sm_wbw_control_out ;
563wire fifos_wbw_renable_in = pcim_if_wbw_renable_out ;
564
565//wire fifos_wbw_flush_in = 1'b0 ; flush for write fifo not used
566
567// WBR_FIFO inputs
568wire fifos_wbr_wenable_in = pcim_if_wbr_wenable_out ;
569wire [31:0] fifos_wbr_data_in = pcim_if_wbr_data_out ;
570wire [3:0] fifos_wbr_be_in = pcim_if_wbr_be_out ;
571wire [3:0] fifos_wbr_control_in = pcim_if_wbr_control_out ;
572wire fifos_wbr_renable_in = wbs_sm_wbr_renable_out ;
573wire fifos_wbr_flush_in = wbs_sm_wbr_flush_out || del_sync_comp_flush_out ;
574
575// WBW_FIFO and WBR_FIFO instantiation
576pci_wbw_wbr_fifos fifos
577(
578 .wb_clock_in (wb_clock_in),
579 .pci_clock_in (pci_clock_in),
580 .reset_in (reset_in),
581 .wbw_wenable_in (fifos_wbw_wenable_in),
582 .wbw_addr_data_in (fifos_wbw_addr_data_in),
583 .wbw_cbe_in (fifos_wbw_cbe_in),
584 .wbw_control_in (fifos_wbw_control_in),
585 .wbw_renable_in (fifos_wbw_renable_in),
586 .wbw_addr_data_out (fifos_wbw_addr_data_out),
587 .wbw_cbe_out (fifos_wbw_cbe_out),
588 .wbw_control_out (fifos_wbw_control_out),
589// .wbw_flush_in (fifos_wbw_flush_in), // flush for write fifo not used
590 .wbw_almost_full_out (fifos_wbw_almost_full_out),
591 .wbw_full_out (fifos_wbw_full_out),
592 .wbw_empty_out (fifos_wbw_empty_out),
593 .wbw_transaction_ready_out (fifos_wbw_transaction_ready_out),
594 .wbw_half_full_out (fifos_wbw_half_full_out),////Robert, burst issue
595 .wbr_wenable_in (fifos_wbr_wenable_in),
596 .wbr_data_in (fifos_wbr_data_in),
597 .wbr_be_in (fifos_wbr_be_in),
598 .wbr_control_in (fifos_wbr_control_in),
599 .wbr_renable_in (fifos_wbr_renable_in),
600 .wbr_data_out (fifos_wbr_data_out),
601 .wbr_be_out (fifos_wbr_be_out),
602 .wbr_control_out (fifos_wbr_control_out),
603 .wbr_flush_in (fifos_wbr_flush_in),
604 .wbr_empty_out (fifos_wbr_empty_out)
605
606`ifdef PCI_BIST
607 ,
608 .mbist_si_i (mbist_si_i),
609 .mbist_so_o (mbist_so_o),
610 .mbist_ctrl_i (mbist_ctrl_i)
611`endif
612) ;
613
614wire [31:0] amux_addr_in = ADDR_I ;
615wire amux_sample_address_in = wbs_sm_sample_address_out ;
616
617wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar0_in = wbu_bar0_in ;
618wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar1_in = wbu_bar1_in ;
619wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar2_in = wbu_bar2_in ;
620wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar3_in = wbu_bar3_in ;
621wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar4_in = wbu_bar4_in ;
622wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_bar5_in = wbu_bar5_in ;
623wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am0_in = wbu_am0_in ;
624wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am1_in = wbu_am1_in ;
625wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am2_in = wbu_am2_in ;
626wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am3_in = wbu_am3_in ;
627wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am4_in = wbu_am4_in ;
628wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_am5_in = wbu_am5_in ;
629wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta0_in = wbu_ta0_in ;
630wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta1_in = wbu_ta1_in ;
631wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta2_in = wbu_ta2_in ;
632wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta3_in = wbu_ta3_in ;
633wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta4_in = wbu_ta4_in ;
634wire [(`WB_NUM_OF_DEC_ADDR_LINES - 1):0] amux_ta5_in = wbu_ta5_in ;
635wire [5:0] amux_at_en_in = wbu_at_en_in ;
636
637pci_wb_addr_mux wb_addr_dec
638(
639 `ifdef REGISTER_WBS_OUTPUTS
640 .clk_in (wb_clock_in),
641 .reset_in (reset_in),
642 .sample_address_in (amux_sample_address_in),
643 `endif
644 .address_in (amux_addr_in),
645 .bar0_in (amux_bar0_in),
646 .bar1_in (amux_bar1_in),
647 .bar2_in (amux_bar2_in),
648 .bar3_in (amux_bar3_in),
649 .bar4_in (amux_bar4_in),
650 .bar5_in (amux_bar5_in),
651 .am0_in (amux_am0_in),
652 .am1_in (amux_am1_in),
653 .am2_in (amux_am2_in),
654 .am3_in (amux_am3_in),
655 .am4_in (amux_am4_in),
656 .am5_in (amux_am5_in),
657 .ta0_in (amux_ta0_in),
658 .ta1_in (amux_ta1_in),
659 .ta2_in (amux_ta2_in),
660 .ta3_in (amux_ta3_in),
661 .ta4_in (amux_ta4_in),
662 .ta5_in (amux_ta5_in),
663 .at_en_in (amux_at_en_in),
664 .hit_out (amux_hit_out),
665 .address_out (amux_address_out)
666);
667
668// delayed transaction logic inputs
669wire del_sync_req_in = wbs_sm_del_req_out ;
670wire del_sync_comp_in = pcim_if_del_complete_out ;
671wire del_sync_done_in = wbs_sm_del_done_out ;
672wire del_sync_in_progress_in = wbs_sm_del_in_progress_out ;
673wire [31:0] del_sync_addr_in = wbs_sm_data_out ;
674wire [3:0] del_sync_be_in = wbs_sm_conf_be_out ;
675wire del_sync_we_in = wbs_sm_del_write_out ;
676wire [3:0] del_sync_bc_in = wbs_sm_del_bc_out ;
677wire del_sync_status_in = pcim_if_del_error_out ;
678wire del_sync_burst_in = wbs_sm_del_burst_out ;
679wire del_sync_retry_expired_in = pcim_if_del_rty_exp_out ;
680
681// delayed transaction logic instantiation
682pci_delayed_sync del_sync (
683 .reset_in (reset_in),
684 .req_clk_in (wb_clock_in),
685 .comp_clk_in (pci_clock_in),
686 .req_in (del_sync_req_in),
687 .comp_in (del_sync_comp_in),
688 .done_in (del_sync_done_in),
689 .in_progress_in (del_sync_in_progress_in),
690 .comp_req_pending_out (del_sync_comp_req_pending_out),
691 .comp_comp_pending_out(del_sync_comp_comp_pending_out),
692 .req_req_pending_out (del_sync_req_req_pending_out),
693 .req_comp_pending_out (del_sync_req_comp_pending_out),
694 .addr_in (del_sync_addr_in),
695 .be_in (del_sync_be_in),
696 .addr_out (del_sync_addr_out),
697 .be_out (del_sync_be_out),
698 .we_in (del_sync_we_in),
699 .we_out (del_sync_we_out),
700 .bc_in (del_sync_bc_in),
701 .bc_out (del_sync_bc_out),
702 .status_in (del_sync_status_in),
703 .status_out (del_sync_status_out),
704 .comp_flush_out (del_sync_comp_flush_out),
705 .burst_in (del_sync_burst_in),
706 .burst_out (del_sync_burst_out),
707 .retry_expired_in (del_sync_retry_expired_in)
708 );
709
710// delayed write storage inputs
711wire del_write_we_in = wbs_sm_del_req_out && wbs_sm_del_write_out ;
712wire [31:0] del_write_data_in = wbs_sm_conf_data_out ;
713
714pci_delayed_write_reg delayed_write_data
715(
716 .reset_in (reset_in),
717 .req_clk_in (wb_clock_in),
718 .comp_wdata_out (del_write_data_out),
719 .req_we_in (del_write_we_in),
720 .req_wdata_in (del_write_data_in)
721);
722
723`ifdef HOST
724 // configuration cycle address decoder input
725 wire [31:0] ccyc_addr_in = {8'h00, wbu_ccyc_addr_in} ;
726
727 pci_conf_cyc_addr_dec ccyc_addr_dec
728 (
729 .ccyc_addr_in (ccyc_addr_in),
730 .ccyc_addr_out (ccyc_addr_out)
731 ) ;
732`else
733`ifdef GUEST
734 assign ccyc_addr_out = 32'h0000_0000 ;
735`endif
736`endif
737
738// pci master interface inputs
739wire [31:0] pcim_if_wbw_addr_data_in = fifos_wbw_addr_data_out ;
740wire [3:0] pcim_if_wbw_cbe_in = fifos_wbw_cbe_out ;
741wire [3:0] pcim_if_wbw_control_in = fifos_wbw_control_out ;
742wire pcim_if_wbw_empty_in = fifos_wbw_empty_out ;
743wire pcim_if_wbw_transaction_ready_in = fifos_wbw_transaction_ready_out ;
744wire [31:0] pcim_if_data_in = pcim_sm_data_out ;
745wire [31:0] pcim_if_del_wdata_in = del_write_data_out ;
746wire pcim_if_del_req_in = del_sync_comp_req_pending_out ;
747wire [31:0] pcim_if_del_addr_in = del_sync_addr_out ;
748wire [3:0] pcim_if_del_bc_in = del_sync_bc_out ;
749wire [3:0] pcim_if_del_be_in = del_sync_be_out ;
750wire pcim_if_del_burst_in = del_sync_burst_out ;
751wire pcim_if_del_we_in = del_sync_we_out ;
752wire [7:0] pcim_if_cache_line_size_in = wbu_cache_line_size_in ;
753wire pcim_if_wait_in = pcim_sm_wait_out ;
754wire pcim_if_wtransfer_in = pcim_sm_wtransfer_out ;
755wire pcim_if_rtransfer_in = pcim_sm_rtransfer_out ;
756wire pcim_if_retry_in = pcim_sm_retry_out ;
757wire pcim_if_rerror_in = pcim_sm_rerror_out ;
758wire pcim_if_first_in = pcim_sm_first_out ;
759wire pcim_if_mabort_in = pcim_sm_mabort_out ;
760
761pci_master32_sm_if pci_initiator_if
762(
763 .clk_in (pci_clock_in),
764 .reset_in (reset_in),
765 .address_out (pcim_if_address_out),
766 .bc_out (pcim_if_bc_out),
767 .data_out (pcim_if_data_out),
768 .data_in (pcim_if_data_in),
769 .be_out (pcim_if_be_out),
770 .req_out (pcim_if_req_out),
771 .rdy_out (pcim_if_rdy_out),
772 .last_out (pcim_if_last_out),
773 .wbw_renable_out (pcim_if_wbw_renable_out),
774 .wbw_fifo_addr_data_in (pcim_if_wbw_addr_data_in),
775 .wbw_fifo_cbe_in (pcim_if_wbw_cbe_in),
776 .wbw_fifo_control_in (pcim_if_wbw_control_in),
777 .wbw_fifo_empty_in (pcim_if_wbw_empty_in),
778 .wbw_fifo_transaction_ready_in (pcim_if_wbw_transaction_ready_in),
779 .wbr_fifo_wenable_out (pcim_if_wbr_wenable_out),
780 .wbr_fifo_data_out (pcim_if_wbr_data_out),
781 .wbr_fifo_be_out (pcim_if_wbr_be_out),
782 .wbr_fifo_control_out (pcim_if_wbr_control_out),
783 .del_wdata_in (pcim_if_del_wdata_in),
784 .del_complete_out (pcim_if_del_complete_out),
785 .del_req_in (pcim_if_del_req_in),
786 .del_addr_in (pcim_if_del_addr_in),
787 .del_bc_in (pcim_if_del_bc_in),
788 .del_be_in (pcim_if_del_be_in),
789 .del_burst_in (pcim_if_del_burst_in),
790 .del_error_out (pcim_if_del_error_out),
791 .del_rty_exp_out (pcim_if_del_rty_exp_out),
792 .del_we_in (pcim_if_del_we_in),
793 .err_addr_out (pcim_if_err_addr_out),
794 .err_bc_out (pcim_if_err_bc_out),
795 .err_signal_out (pcim_if_err_signal_out),
796 .err_source_out (pcim_if_err_source_out),
797 .err_rty_exp_out (pcim_if_err_rty_exp_out),
798 .cache_line_size_in (pcim_if_cache_line_size_in),
799 .mabort_received_out (pcim_if_mabort_out),
800 .tabort_received_out (pcim_if_tabort_out),
801 .next_data_out (pcim_if_next_data_out),
802 .next_be_out (pcim_if_next_be_out),
803 .next_last_out (pcim_if_next_last_out),
804 .wait_in (pcim_if_wait_in),
805 .wtransfer_in (pcim_if_wtransfer_in),
806 .rtransfer_in (pcim_if_rtransfer_in),
807 .retry_in (pcim_if_retry_in),
808 .rerror_in (pcim_if_rerror_in),
809 .first_in (pcim_if_first_in),
810 .mabort_in (pcim_if_mabort_in),
811 .posted_write_not_present_out (pcim_if_posted_write_not_present_out)
812);
813
814// pci master state machine inputs
815wire pcim_sm_gnt_in = wbu_pciif_gnt_in ;
816wire pcim_sm_frame_in = wbu_pciif_frame_in ;
817wire pcim_sm_irdy_in = wbu_pciif_irdy_in ;
818wire pcim_sm_trdy_in = wbu_pciif_trdy_in;
819wire pcim_sm_stop_in = wbu_pciif_stop_in ;
820wire pcim_sm_devsel_in = wbu_pciif_devsel_in ;
821wire [31:0] pcim_sm_ad_reg_in = wbu_pciif_ad_reg_in ;
822wire [31:0] pcim_sm_address_in = pcim_if_address_out ;
823wire [3:0] pcim_sm_bc_in = pcim_if_bc_out ;
824wire [31:0] pcim_sm_data_in = pcim_if_data_out ;
825wire [3:0] pcim_sm_be_in = pcim_if_be_out ;
826wire pcim_sm_req_in = pcim_if_req_out ;
827wire pcim_sm_rdy_in = pcim_if_rdy_out ;
828wire pcim_sm_last_in = pcim_if_last_out ;
829wire [7:0] pcim_sm_latency_tim_val_in = wbu_latency_tim_val_in ;
830wire [31:0] pcim_sm_next_data_in = pcim_if_next_data_out ;
831wire [3:0] pcim_sm_next_be_in = pcim_if_next_be_out ;
832wire pcim_sm_next_last_in = pcim_if_next_last_out ;
833wire pcim_sm_trdy_reg_in = wbu_pciif_trdy_reg_in ;
834wire pcim_sm_stop_reg_in = wbu_pciif_stop_reg_in ;
835wire pcim_sm_devsel_reg_in = wbu_pciif_devsel_reg_in ;
836wire pcim_sm_frame_en_in = wbu_pciif_frame_en_in ;
837wire pcim_sm_frame_out_in = wbu_pciif_frame_out_in ;
838
839pci_master32_sm pci_initiator_sm
840(
841 .clk_in (pci_clock_in),
842 .reset_in (reset_in),
843 .pci_req_out (pcim_sm_req_out),
844 .pci_gnt_in (pcim_sm_gnt_in),
845 .pci_frame_in (pcim_sm_frame_in),
846 .pci_frame_out (pcim_sm_frame_out),
847 .pci_frame_en_out (pcim_sm_frame_en_out),
848 .pci_frame_out_in (pcim_sm_frame_out_in),
849 .pci_frame_load_out (pcim_sm_frame_load_out),
850 .pci_frame_en_in (pcim_sm_frame_en_in),
851 .pci_irdy_in (pcim_sm_irdy_in),
852 .pci_irdy_out (pcim_sm_irdy_out),
853 .pci_irdy_en_out (pcim_sm_irdy_en_out),
854 .pci_trdy_in (pcim_sm_trdy_in),
855 .pci_trdy_reg_in (pcim_sm_trdy_reg_in),
856 .pci_stop_in (pcim_sm_stop_in),
857 .pci_stop_reg_in (pcim_sm_stop_reg_in),
858 .pci_devsel_in (pcim_sm_devsel_in),
859 .pci_devsel_reg_in (pcim_sm_devsel_reg_in),
860 .pci_ad_reg_in (pcim_sm_ad_reg_in),
861 .pci_ad_out (pcim_sm_ad_out),
862 .pci_ad_en_out (pcim_sm_ad_en_out),
863 .pci_cbe_out (pcim_sm_cbe_out),
864 .pci_cbe_en_out (pcim_sm_cbe_en_out),
865 .address_in (pcim_sm_address_in),
866 .bc_in (pcim_sm_bc_in),
867 .data_in (pcim_sm_data_in),
868 .data_out (pcim_sm_data_out),
869 .be_in (pcim_sm_be_in),
870 .req_in (pcim_sm_req_in),
871 .rdy_in (pcim_sm_rdy_in),
872 .last_in (pcim_sm_last_in),
873 .latency_tim_val_in (pcim_sm_latency_tim_val_in),
874 .next_data_in (pcim_sm_next_data_in),
875 .next_be_in (pcim_sm_next_be_in),
876 .next_last_in (pcim_sm_next_last_in),
877 .ad_load_out (pcim_sm_ad_load_out),
878 .ad_load_on_transfer_out (pcim_sm_ad_load_on_transfer_out),
879 .wait_out (pcim_sm_wait_out),
880 .wtransfer_out (pcim_sm_wtransfer_out),
881 .rtransfer_out (pcim_sm_rtransfer_out),
882 .retry_out (pcim_sm_retry_out),
883 .rerror_out (pcim_sm_rerror_out),
884 .first_out (pcim_sm_first_out),
885 .mabort_out (pcim_sm_mabort_out)
886) ;
887
888endmodule
Impressum, Datenschutz