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

Subversion Repositories dma_ahb

[/] [dma_ahb/] [trunk/] [src/] [dma_ahb64/] [dma_ahb64_core0_ch_outs.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:01 2011
5
//--
6
//-- Source file: dma_ch_outs.v
7
//---------------------------------------------------------
8
 
9
 
10
 
11
module dma_ahb64_core0_ch_outs(clk,reset,cmd,clr,outs_max,outs,outs_empty,stall,timeout);
12
 
13
   input                    clk;
14
   input             reset;
15
 
16
   input             cmd;
17
   input             clr;
18
   input [`OUT_BITS-1:0]    outs_max;
19
   output [`OUT_BITS-1:0]   outs;
20
   output             outs_empty;
21
   output             stall;
22
   output             timeout;
23
 
24
 
25
   reg [`OUT_BITS-1:0]         outs;
26
   wire [`OUT_BITS-1:0]     outs_pre;
27
   reg                 stall;
28
   reg [`TIMEOUT_BITS-1:0]  counter;
29
 
30
 
31
 
32
   assign             outs_empty = outs == 'd0;
33
 
34
   assign             outs_pre = outs + cmd - clr;
35
 
36
   always @(posedge clk or posedge reset)
37
     if (reset)
38
       outs <= #1 'd0;
39
     else if (cmd | clr)
40
       outs <= #1 outs_pre;
41
 
42
 
43
   always @(posedge clk or posedge reset)
44
     if (reset)
45
       stall <= #1 1'b0;
46
     else if (|outs_max)
47
       stall <= #1 outs >= outs_max;
48
 
49
 
50
 
51
   assign             timeout = (counter == 'd0);
52
 
53
   always @(posedge clk or posedge reset)
54
     if (reset)
55
       counter <= #1 {`TIMEOUT_BITS{1'b1}};
56
     else if (clr)
57
       counter <= #1 {`TIMEOUT_BITS{1'b1}};
58
     else if (|outs)
59
       counter <= #1 counter - 1'b1;
60
 
61
 
62
endmodule
63
 
64
 
65
 
66
 
67
 
68
 
69
 
70
 
71
 
72
 
73
 

powered by: WebSVN 2.1.0

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