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

Subversion Repositories dma_ahb

[/] [dma_ahb/] [trunk/] [src/] [dma_ahb32/] [dma_ahb32_core0_ch_fifo_ctrl.v] - Blame information for rev 4

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 4 eyalhoc
/////////////////////////////////////////////////////////////////////
2
////                                                             ////
3
////  Author: Eyal Hochberg                                      ////
4
////          eyal@provartec.com                                 ////
5
////                                                             ////
6
////  Downloaded from: http://www.opencores.org                  ////
7
/////////////////////////////////////////////////////////////////////
8
////                                                             ////
9
//// Copyright (C) 2010 Provartec LTD                            ////
10
//// www.provartec.com                                           ////
11
//// info@provartec.com                                          ////
12
////                                                             ////
13
//// This source file may be used and distributed without        ////
14
//// restriction provided that this copyright statement is not   ////
15
//// removed from the file and that any derivative work contains ////
16
//// the original copyright notice and the associated disclaimer.////
17
////                                                             ////
18
//// This source file is free software; you can redistribute it  ////
19
//// and/or modify it under the terms of the GNU Lesser General  ////
20
//// Public License as published by the Free Software Foundation.////
21
////                                                             ////
22
//// This source is distributed in the hope that it will be      ////
23
//// useful, but WITHOUT ANY WARRANTY; without even the implied  ////
24
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR     ////
25
//// PURPOSE.  See the GNU Lesser General Public License for more////
26
//// details. http://www.gnu.org/licenses/lgpl.html              ////
27
////                                                             ////
28
/////////////////////////////////////////////////////////////////////
29 2 eyalhoc
//---------------------------------------------------------
30
//-- File generated by RobustVerilog parser
31
//-- Version: 1.0
32
//-- Invoked Fri Mar 25 23:31:25 2011
33
//--
34
//-- Source file: dma_ch_fifo_ctrl.v
35
//---------------------------------------------------------
36
 
37
 
38
 
39
module dma_ahb32_core0_ch_fifo_ctrl (clk,reset,end_swap,joint_in_prog,wr_outstanding,ch_update,fifo_wr,fifo_wdata,fifo_wsize,wr_align,rd_incr,fifo_rd,fifo_rsize,rd_align,wr_incr,wr_single,wr_burst_size,rd_clr_line,wr_clr_line,wr_next_size,fifo_rd_valid,fifo_rdata,fifo_wr_ready,fifo_overflow,fifo_underflow);
40
 
41
   input               clk;
42
   input               reset;
43
 
44
   input [1:0]               end_swap;
45
 
46
   input               joint_in_prog;
47
   input               wr_outstanding;
48
   input               ch_update;
49
 
50
   input               fifo_wr;
51
   input [32-1:0]      fifo_wdata;
52
   input [3-1:0]      fifo_wsize;
53
   input [2-1:0]      wr_align;
54
   input               rd_incr;
55
 
56
   input               fifo_rd;
57
   input [3-1:0]      fifo_rsize;
58
   input [2-1:0]      rd_align;
59
   input               wr_incr;
60
   input               wr_single;
61
   input [7-1:0]     wr_burst_size;
62
 
63
   input               rd_clr_line;
64
   input               wr_clr_line;
65
   input [3-1:0]      wr_next_size;
66
 
67
   output               fifo_rd_valid;
68
   output [32-1:0]     fifo_rdata;
69
   output               fifo_wr_ready;
70
   output               fifo_overflow;
71
   output               fifo_underflow;
72
 
73
 
74
 
75
   //outputs of wr slicer
76
   wire               slice_wr;
77
   wire               slice_wr_fifo;
78
   wire [5-1:0]       slice_wr_ptr;
79
   wire [4-1:0]       slice_bsel;
80
   wire [32-1:0]       slice_wdata;
81
   wire [3-1:0]       slice_wsize;
82
 
83
   //outputs of rd slicer
84
   wire               slice_rd;
85
   wire [32-1:0]       slice_rdata;
86
   wire [3-1:0]       slice_rsize;
87
   wire [5-1:0]       slice_rd_ptr;
88
   wire               slice_rd_valid;
89
 
90
   //outputs of fifo ptr
91
   wire [5-1:0]       rd_ptr;
92
   wire [5-1:0]       wr_ptr;
93
   wire [3-1:0]       rd_line_remain;
94
   wire               joint_delay;
95
   wire               fifo_wr_ready;
96
   wire               fifo_overflow;
97
   wire               fifo_underflow;
98
 
99
   //outputs of fifo
100
   wire [32-1:0]       DOUT;
101
 
102
   wire               fifo_wr_d;
103
   reg [32-1:0]           fifo_wdata_d;
104
   wire               fifo_wr_valid;
105
   wire [32-1:0]       fifo_wdata_valid;
106
 
107
 
108
   prgen_delay #(1) delay_fifo_wr (.clk(clk), .reset(reset), .din(fifo_wr), .dout(fifo_wr_d));
109
 
110
   always @(posedge clk or posedge reset)
111
     if (reset)
112
       fifo_wdata_d <= #1 {32{1'b0}};
113
     else if (fifo_wr)
114
       fifo_wdata_d <= #1 fifo_wdata;
115
 
116
   assign               fifo_wr_valid    = joint_delay ? fifo_wr_d : fifo_wr;
117
   assign               fifo_wdata_valid = joint_delay ? fifo_wdata_d : fifo_wdata;
118
 
119
 
120
 
121
   assign               fifo_rdata    = slice_rdata & {32{slice_rd_valid}};
122
   assign               fifo_rd_valid = slice_rd_valid;
123
 
124
 
125
   dma_ahb32_core0_ch_wr_slicer
126
   dma_ahb32_ch_wr_slicer (
127
            .clk(clk),
128
            .reset(reset),
129
            .ch_update(ch_update),
130
            .rd_clr_line(rd_clr_line),
131
            .fifo_wr(fifo_wr_valid),
132
            .fifo_wdata(fifo_wdata_valid),
133
            .fifo_wsize(fifo_wsize),
134
            .wr_align(wr_align),
135
            .wr_ptr(wr_ptr),
136
            .rd_incr(rd_incr),
137
            .end_swap(end_swap),
138
            .slice_wr(slice_wr),
139
            .slice_wr_fifo(slice_wr_fifo),
140
            .slice_wr_ptr(slice_wr_ptr),
141
            .slice_bsel(slice_bsel),
142
            .slice_wdata(slice_wdata),
143
            .slice_wsize(slice_wsize)
144
            );
145
 
146
 
147
   dma_ahb32_core0_ch_rd_slicer
148
   dma_ahb32_ch_rd_slicer (
149
            .clk(clk),
150
            .reset(reset),
151
            .fifo_rd(fifo_rd),
152
            .fifo_rdata(DOUT),
153
            .fifo_rsize(fifo_rsize),
154
            .rd_align(rd_align),
155
            .rd_ptr(rd_ptr),
156
            .rd_line_remain(rd_line_remain),
157
            .wr_incr(wr_incr),
158
            .wr_single(wr_single),
159
            .slice_rd(slice_rd),
160
            .slice_rdata(slice_rdata),
161
            .slice_rd_valid(slice_rd_valid),
162
            .slice_rsize(slice_rsize),
163
            .slice_rd_ptr(slice_rd_ptr)
164
            );
165
 
166
 
167
   dma_ahb32_core0_ch_fifo_ptr
168
   dma_ahb32_ch_fifo_ptr (
169
               .clk(clk),
170
               .reset(reset),
171
               .joint_in_prog(joint_in_prog),
172
               .wr_outstanding(wr_outstanding),
173
               .ch_update(ch_update),
174
               .fifo_rd(fifo_rd),
175
               .fifo_rsize(fifo_rsize),
176
               .slice_wr(slice_wr),
177
               .slice_wr_fifo(slice_wr_fifo),
178
               .slice_wsize(slice_wsize),
179
               .slice_rd(slice_rd),
180
               .slice_rsize(slice_rsize),
181
               .rd_clr_line(rd_clr_line),
182
               .wr_clr_line(wr_clr_line),
183
               .rd_ptr(rd_ptr),
184
               .wr_ptr(wr_ptr),
185
               .rd_line_remain(rd_line_remain),
186
               .joint_delay(joint_delay),
187
               .wr_next_size(wr_next_size),
188
               .wr_burst_size(wr_burst_size),
189
               .fifo_wr_ready(fifo_wr_ready),
190
               .fifo_overflow(fifo_overflow),
191
               .fifo_underflow(fifo_underflow)
192
               );
193
 
194
 
195
   dma_ahb32_core0_ch_fifo
196
   dma_ahb32_ch_fifo (
197
           .CLK(clk),
198
           .WR(slice_wr_fifo),
199
           .RD(slice_rd),
200
           .WR_ADDR(slice_wr_ptr[5-1:2] ),
201
           .RD_ADDR(slice_rd_ptr[5-1:2]),
202
           .DIN(slice_wdata),
203
           .BSEL(slice_bsel),
204
           .DOUT(DOUT)
205
           );
206
 
207
 
208
endmodule
209
 
210
 
211
 
212
 
213
 
214
 

powered by: WebSVN 2.1.0

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