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

Subversion Repositories dma_ahb

[/] [dma_ahb/] [trunk/] [src/] [dma_ahb64/] [dma_ahb64_core0_channels_mux.v] - Blame information for rev 2

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 eyalhoc
//---------------------------------------------------------
2
//-- File generated by RobustVerilog parser
3
//-- Version: 1.0
4
//-- Invoked Fri Mar 25 23:33:00 2011
5
//--
6
//-- Source file: dma_core_channels_mux.v
7
//---------------------------------------------------------
8
 
9
 
10
 
11
module dma_ahb64_core0_channels_mux(ch_fifo_rd_valid,fifo_rd_valid,ch_fifo_rdata,fifo_rdata,ch_periph_rx_clr,periph_rx_clr,ch_periph_tx_clr,periph_tx_clr,ch_rd_page_cross,ch_wr_page_cross,rd_page_cross,wr_page_cross,timeout_aw,timeout_w,timeout_ar,timeout_num_aw,timeout_num_w,timeout_num_ar,wdt_timeout,wdt_ch_num,ch_timeout_aw,ch_timeout_w,ch_timeout_ar,ch_wdt_timeout,joint_in_prog,joint_not_in_prog,joint_mux_in_prog,ch_joint_in_prog,ch_joint_not_in_prog,ch_joint_mux_in_prog,wr_cmd_pending,ch_wr_cmd_pending,rd_ch_num,rd_cmd_num,load_req_in_prog,rd_line_cmd,rd_go_next_line,rd_burst_start,rd_burst_addr,rd_burst_size,rd_tokens,rd_cmd_port,rd_periph_delay,rd_clr_valid,rd_cmd_split,rd_cmd_line,rd_clr_stall,ch_load_req_in_prog,ch_rd_line_cmd,ch_rd_go_next_line,ch_rd_burst_start,ch_rd_burst_addr,ch_rd_burst_size,ch_rd_tokens,ch_rd_port_num,ch_rd_periph_delay,ch_rd_clr_valid,ch_rd_cmd_split,ch_rd_cmd_line,ch_rd_clr_stall,load_wr_num,load_wr,ch_load_wr,ch_fifo_wr_num,rd_transfer_num,rd_clr_line_num,rd_transfer,rd_clr_line,fifo_wr,ch_rd_transfer,ch_rd_clr_line,ch_fifo_wr,rd_ch_num_resp,rd_slverr,rd_decerr,rd_clr,rd_clr_load,ch_rd_slverr,ch_rd_decerr,ch_rd_clr,ch_rd_clr_load,wr_ch_num,wr_cmd_num,wr_last_cmd,wr_line_cmd,wr_go_next_line,wr_burst_start,wr_burst_addr,wr_burst_size,wr_tokens,wr_cmd_port,wr_periph_delay,wr_clr_valid,wr_cmd_split,wr_clr_stall,ch_wr_last_cmd,ch_wr_line_cmd,ch_wr_go_next_line,ch_wr_burst_start,ch_wr_burst_addr,ch_wr_burst_size,ch_wr_tokens,ch_wr_port_num,ch_wr_periph_delay,ch_wr_clr_valid,ch_wr_cmd_split,ch_wr_clr_stall,ch_fifo_rd_num,wr_transfer_num,wr_clr_line_num,wr_transfer,wr_clr_line,fifo_rd,ch_fifo_wr_ready,ch_wr_transfer,ch_wr_clr_line,ch_fifo_rd,fifo_wr_ready,wr_ch_num_resp,wr_slverr,wr_decerr,wr_clr,wr_clr_last,ch_wr_slverr,ch_wr_decerr,ch_wr_clr_last,ch_wr_clr);
12
 
13
   //data
14
   input [7:0]               ch_fifo_rd_valid;
15
   output               fifo_rd_valid;
16
   input [8*64-1:0]    ch_fifo_rdata;
17
   output [64-1:0]     fifo_rdata;
18
 
19
   //periph
20
   input [8*31-1:0]           ch_periph_rx_clr;
21
   output [30:0]           periph_rx_clr;
22
   input [8*31-1:0]           ch_periph_tx_clr;
23
   output [30:0]           periph_tx_clr;
24
 
25
   output [7:0]           ch_rd_page_cross;
26
   output [7:0]           ch_wr_page_cross;
27
   input               rd_page_cross;
28
   input               wr_page_cross;
29
 
30
   //axim timeout
31
   input               timeout_aw;
32
   input               timeout_w;
33
   input               timeout_ar;
34
   input [2:0]               timeout_num_aw;
35
   input [2:0]               timeout_num_w;
36
   input [2:0]               timeout_num_ar;
37
   input               wdt_timeout;
38
   input [2:0]               wdt_ch_num;
39
 
40
   output [7:0]           ch_timeout_aw;
41
   output [7:0]           ch_timeout_w;
42
   output [7:0]           ch_timeout_ar;
43
   output [7:0]           ch_wdt_timeout;
44
 
45
   output               joint_in_prog;
46
   output               joint_not_in_prog;
47
   output               joint_mux_in_prog;
48
   input [7:0]               ch_joint_in_prog;
49
   input [7:0]               ch_joint_not_in_prog;
50
   input [7:0]               ch_joint_mux_in_prog;
51
 
52
   input               wr_cmd_pending;
53
   output [7:0]           ch_wr_cmd_pending;
54
 
55
   //rd cmd
56
   input [2:0]               rd_ch_num;
57
   input [2:0]               rd_cmd_num;
58
 
59
   output               load_req_in_prog;
60
   output               rd_line_cmd;
61
   output               rd_go_next_line;
62
   input               rd_burst_start;
63
   output [32-1:0]     rd_burst_addr;
64
   output [8-1:0]    rd_burst_size;
65
   output [`TOKEN_BITS-1:0]   rd_tokens;
66
   output               rd_cmd_port;
67
   output [`DELAY_BITS-1:0]   rd_periph_delay;
68
   output               rd_clr_valid;
69
   input               rd_cmd_split;
70
   input               rd_cmd_line;
71
   output               rd_clr_stall;
72
 
73
   input [7:0]               ch_load_req_in_prog;
74
   input [7:0]               ch_rd_line_cmd;
75
   input [7:0]               ch_rd_go_next_line;
76
   output [7:0]           ch_rd_burst_start;
77
   input [8*32-1:0]    ch_rd_burst_addr;
78
   input [8*8-1:0]   ch_rd_burst_size;
79
   input [8*`TOKEN_BITS-1:0]  ch_rd_tokens;
80
   input [7:0]               ch_rd_port_num;
81
   input [8*`DELAY_BITS-1:0]  ch_rd_periph_delay;
82
   input [7:0]               ch_rd_clr_valid;
83
   output [7:0]           ch_rd_cmd_split;
84
   output [7:0]           ch_rd_cmd_line;
85
   input [7:0]               ch_rd_clr_stall;
86
 
87
   //rd data - load cmd
88
   input [2:0]               load_wr_num;
89
 
90
   input               load_wr;
91
 
92
   output [7:0]           ch_load_wr;
93
 
94
   //rd data
95
   input [2:0]               ch_fifo_wr_num;
96
   input [2:0]               rd_transfer_num;
97
   input [2:0]               rd_clr_line_num;
98
 
99
   input               rd_transfer;
100
   input               rd_clr_line;
101
   input               fifo_wr;
102
 
103
   output [7:0]           ch_rd_transfer;
104
   output [7:0]           ch_rd_clr_line;
105
   output [7:0]           ch_fifo_wr;
106
 
107
   //rd resp
108
   input [2:0]               rd_ch_num_resp;
109
 
110
   input               rd_slverr;
111
   input               rd_decerr;
112
   input               rd_clr;
113
   input               rd_clr_load;
114
 
115
   output [7:0]           ch_rd_slverr;
116
   output [7:0]           ch_rd_decerr;
117
   output [7:0]           ch_rd_clr;
118
   output [7:0]           ch_rd_clr_load;
119
 
120
   //wr cmd
121
   input [2:0]               wr_ch_num;
122
   input [2:0]               wr_cmd_num;
123
 
124
   output               wr_last_cmd;
125
   output               wr_line_cmd;
126
   output               wr_go_next_line;
127
   input               wr_burst_start;
128
   output [32-1:0]     wr_burst_addr;
129
   output [8-1:0]    wr_burst_size;
130
   output [`TOKEN_BITS-1:0]   wr_tokens;
131
   output               wr_cmd_port;
132
   output [`DELAY_BITS-1:0]   wr_periph_delay;
133
   output               wr_clr_valid;
134
   input               wr_cmd_split;
135
   output               wr_clr_stall;
136
 
137
   input [7:0]               ch_wr_last_cmd;
138
   input [7:0]               ch_wr_line_cmd;
139
   input [7:0]               ch_wr_go_next_line;
140
   output [7:0]           ch_wr_burst_start;
141
   input [8*32-1:0]    ch_wr_burst_addr;
142
   input [8*8-1:0]   ch_wr_burst_size;
143
   input [8*`TOKEN_BITS-1:0]  ch_wr_tokens;
144
   input [7:0]               ch_wr_port_num;
145
   input [8*`DELAY_BITS-1:0]  ch_wr_periph_delay;
146
   input [7:0]               ch_wr_clr_valid;
147
   output [7:0]           ch_wr_cmd_split;
148
   input [7:0]               ch_wr_clr_stall;
149
 
150
   //wr data
151
   input [2:0]               ch_fifo_rd_num;
152
   input [2:0]               wr_transfer_num;
153
   input [2:0]               wr_clr_line_num;
154
 
155
   input               wr_transfer;
156
   input               wr_clr_line;
157
   input               fifo_rd;
158
   input [7:0]               ch_fifo_wr_ready;
159
 
160
   output [7:0]           ch_wr_transfer;
161
   output [7:0]           ch_wr_clr_line;
162
   output [7:0]           ch_fifo_rd;
163
   output               fifo_wr_ready;
164
 
165
   //wr resp
166
   input [2:0]               wr_ch_num_resp;
167
 
168
   input               wr_slverr;
169
   input               wr_decerr;
170
   input               wr_clr;
171
   input               wr_clr_last;
172
 
173
   output [7:0]           ch_wr_slverr;
174
   output [7:0]           ch_wr_decerr;
175
   output [7:0]           ch_wr_clr_last;
176
   output [7:0]           ch_wr_clr;
177
 
178
 
179
 
180
 
181
   prgen_or8 #(1)
182
   mux_2(.ch_x(ch_fifo_rd_valid),
183
     .x(fifo_rd_valid)
184
     );
185
 
186
   prgen_or8 #(64)
187
   mux_3(.ch_x(ch_fifo_rdata),
188
     .x(fifo_rdata)
189
     );
190
 
191
   prgen_or8 #(31)
192
   mux_4(.ch_x(ch_periph_rx_clr),
193
     .x(periph_rx_clr)
194
     );
195
 
196
   prgen_or8 #(31)
197
   mux_5(.ch_x(ch_periph_tx_clr),
198
     .x(periph_tx_clr)
199
     );
200
 
201
   prgen_mux8 #(`DELAY_BITS)
202
   mux_30(.sel(rd_ch_num),
203
      .ch_x(ch_rd_periph_delay),
204
      .x(rd_periph_delay)
205
      );
206
 
207
   prgen_mux8 #(`DELAY_BITS)
208
   mux_51(.sel(wr_ch_num),
209
      .ch_x(ch_wr_periph_delay),
210
      .x(wr_periph_delay)
211
      );
212
 
213
 
214
   prgen_demux8 #(1)
215
   mux_6(.sel(timeout_num_aw),
216
     .x(timeout_aw),
217
     .ch_x(ch_timeout_aw)
218
     );
219
 
220
   prgen_demux8 #(1)
221
   mux_7(.sel(timeout_num_w),
222
     .x(timeout_w),
223
     .ch_x(ch_timeout_w)
224
     );
225
 
226
   prgen_demux8 #(1)
227
   mux_8(.sel(timeout_num_ar),
228
     .x(timeout_ar),
229
     .ch_x(ch_timeout_ar)
230
     );
231
 
232
   prgen_demux8 #(1)
233
   mux_9(.sel(wdt_ch_num),
234
     .x(wdt_timeout),
235
     .ch_x(ch_wdt_timeout)
236
     );
237
 
238
   prgen_or8 #(1)
239
   mux_55(.ch_x(ch_joint_in_prog),
240
      .x(joint_in_prog)
241
      );
242
 
243
   prgen_or8 #(1)
244
   mux_56(.ch_x(ch_joint_not_in_prog),
245
      .x(joint_not_in_prog)
246
      );
247
 
248
   prgen_or8 #(1)
249
   mux_57(.ch_x(ch_joint_mux_in_prog),
250
      .x(joint_mux_in_prog)
251
      );
252
 
253
   prgen_demux8 #(1)
254
   mux_60(.sel(wr_ch_num),
255
      .x(wr_cmd_pending),
256
      .ch_x(ch_wr_cmd_pending)
257
      );
258
 
259
 
260
   prgen_demux8 #(1)
261
   mux_11(.sel(rd_ch_num),
262
      .x(rd_burst_start),
263
      .ch_x(ch_rd_burst_start)
264
      );
265
 
266
   prgen_demux8 #(1)
267
   mux_13(.sel(load_wr_num),
268
      .x(load_wr),
269
      .ch_x(ch_load_wr)
270
      );
271
 
272
   assign               ch_rd_clr_line  = 'd0;
273
   assign               ch_rd_cmd_line  = 'd0;
274
   assign               rd_line_cmd     = 'd0;
275
   assign               rd_go_next_line = 'd0;
276
   assign               rd_clr_stall    = 'd0;
277
   assign               wr_clr_stall    = 'd0;
278
   assign               ch_wr_clr_line  = 'd0;
279
   assign               wr_line_cmd     = 'd0;
280
   assign               wr_go_next_line = 'd0;
281
 
282
   prgen_mux8 #(1)
283
   mux_33(.sel(rd_ch_num),
284
      .ch_x(ch_rd_clr_valid),
285
      .x(rd_clr_valid)
286
      );
287
 
288
   prgen_mux8 #(1)
289
   mux_53(.sel(wr_ch_num),
290
      .ch_x(ch_wr_clr_valid),
291
      .x(wr_clr_valid)
292
      );
293
 
294
   prgen_demux8 #(1)
295
   mux_15(.sel(rd_transfer_num),
296
      .x(rd_transfer),
297
      .ch_x(ch_rd_transfer)
298
      );
299
 
300
   prgen_demux8 #(1)
301
   mux_16(.sel(rd_ch_num_resp),
302
      .x(rd_slverr),
303
      .ch_x(ch_rd_slverr)
304
      );
305
 
306
   assign               ch_rd_decerr     = 'd0;
307
   assign               ch_wr_decerr     = 'd0;
308
   assign               ch_rd_cmd_split  = 'd0;
309
   assign               ch_wr_cmd_split  = 'd0;
310
   assign               ch_rd_page_cross = 'd0;
311
   assign               ch_wr_page_cross = 'd0;
312
 
313
 
314
   prgen_demux8 #(1)
315
   mux_18(.sel(rd_ch_num_resp),
316
      .x(rd_clr),
317
      .ch_x(ch_rd_clr)
318
      );
319
 
320
   prgen_demux8 #(1)
321
   mux_19(.sel(rd_ch_num_resp),
322
      .x(rd_clr_load),
323
      .ch_x(ch_rd_clr_load)
324
      );
325
 
326
   prgen_demux8 #(1)
327
   mux_21(.sel(ch_fifo_rd_num),
328
      .x(fifo_rd),
329
      .ch_x(ch_fifo_rd)
330
      );
331
 
332
   prgen_mux8 #(1)
333
   mux_23(.sel(rd_ch_num),
334
      .ch_x(ch_load_req_in_prog),
335
      .x(load_req_in_prog)
336
      );
337
 
338
   prgen_mux8 #(32)
339
   mux_26(.sel(rd_ch_num),
340
      .ch_x(ch_rd_burst_addr),
341
      .x(rd_burst_addr)
342
      );
343
 
344
   prgen_mux8 #(8)
345
   mux_27(.sel(rd_ch_num),
346
      .ch_x(ch_rd_burst_size),
347
      .x(rd_burst_size)
348
      );
349
 
350
   prgen_mux8 #(`TOKEN_BITS)
351
   mux_28(.sel(rd_ch_num),
352
      .ch_x(ch_rd_tokens),
353
      .x(rd_tokens)
354
      );
355
 
356
   prgen_mux8 #(`TOKEN_BITS)
357
   mux_49(.sel(wr_ch_num),
358
      .ch_x(ch_wr_tokens),
359
      .x(wr_tokens)
360
      );
361
 
362
   assign               rd_cmd_port = 'd0;
363
   assign               wr_cmd_port = 'd0;
364
 
365
 
366
   prgen_mux8 #(1)
367
   mux_31(.sel(ch_fifo_rd_num),
368
      .ch_x(ch_fifo_wr_ready),
369
      .x(fifo_wr_ready)
370
      );
371
 
372
   prgen_demux8 #(1)
373
   mux_34(.sel(wr_ch_num),
374
      .x(wr_burst_start),
375
      .ch_x(ch_wr_burst_start)
376
      );
377
 
378
   prgen_demux8 #(1)
379
   mux_37(.sel(wr_transfer_num),
380
      .x(wr_transfer),
381
      .ch_x(ch_wr_transfer)
382
      );
383
 
384
   prgen_demux8 #(1)
385
   mux_38(.sel(wr_ch_num_resp),
386
      .x(wr_slverr),
387
      .ch_x(ch_wr_slverr)
388
      );
389
 
390
   prgen_demux8 #(1)
391
   mux_40(.sel(wr_ch_num_resp),
392
      .x(wr_clr),
393
      .ch_x(ch_wr_clr)
394
      );
395
 
396
   prgen_demux8 #(1)
397
   mux_41(.sel(wr_ch_num_resp),
398
      .x(wr_clr_last),
399
      .ch_x(ch_wr_clr_last)
400
      );
401
 
402
   prgen_demux8 #(1)
403
   mux_43(.sel(ch_fifo_wr_num),
404
      .x(fifo_wr),
405
      .ch_x(ch_fifo_wr)
406
      );
407
 
408
   prgen_mux8 #(1)
409
   mux_44(.sel(wr_ch_num),
410
      .ch_x(ch_wr_last_cmd),
411
      .x(wr_last_cmd)
412
      );
413
 
414
   prgen_mux8 #(32)
415
   mux_47(.sel(wr_ch_num),
416
      .ch_x(ch_wr_burst_addr),
417
      .x(wr_burst_addr)
418
      );
419
 
420
   prgen_mux8 #(8)
421
   mux_48(.sel(wr_ch_num),
422
      .ch_x(ch_wr_burst_size),
423
      .x(wr_burst_size)
424
      );
425
 
426
 
427
 
428
endmodule
429
 
430
 
431
 

powered by: WebSVN 2.1.0

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