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

Subversion Repositories mpeg2fpga

[/] [mpeg2fpga/] [trunk/] [rtl/] [mpeg2/] [vbuf.v] - Blame information for rev 2

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 kdv
/*
2
 * vbuf.v
3
 *
4
 * Copyright (c) 2007 Koen De Vleeschauwer.
5
 *
6
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
7
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
8
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
9
 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
10
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
11
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
12
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
13
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
14
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
15
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
16
 * SUCH DAMAGE.
17
 */
18
 
19
/*
20
 * vbuf - Video Buffer
21
 * Decoder input buffer.
22
 * vbuf_write writes incoming mpeg2 stream to a circular buffer in memory.
23
 * getbits_fifo reads the incoming mpeg2 stream from a circular buffer in memory.
24
 */
25
 
26
`include "timescale.v"
27
 
28
`undef DEBUG
29
//`define DEBUG 1
30
 
31
/*
32
 Converter from byte-parallel to 64-bits parallel
33
 */
34
 
35
module vbuf_write (
36
  clk, clk_en, rst,
37
  vid_in, vid_in_wr_en,
38
  vid_out, vid_out_wr_en
39
  );
40
 
41
  input              clk;
42
  input              clk_en;
43
  input              rst;                      // synchronous active low reset
44
 
45
  input         [7:0]vid_in;
46
  input              vid_in_wr_en;
47
 
48
  output reg   [63:0]vid_out;
49
  output reg         vid_out_wr_en;
50
 
51
  reg           [7:0]loop;
52
 
53
  always @(posedge clk)
54
    if (~rst) vid_out <= 64'b0;
55
    else if (clk_en && vid_in_wr_en) vid_out <= {vid_out[55:0], vid_in};
56
    else vid_out <= vid_out;
57
 
58
  always @(posedge clk)
59
    if (~rst) loop <= 8'b0;
60
    else if (clk_en && vid_in_wr_en) loop <= {loop[6:0], &(~loop[6:0])};
61
    else loop <= loop;
62
 
63
  always @(posedge clk)
64
    if (~rst) vid_out_wr_en <= 1'b0;
65
    else if (clk_en && vid_in_wr_en) vid_out_wr_en <= loop[6];
66
    else if (clk_en) vid_out_wr_en <= 1'b0;
67
    else vid_out_wr_en <= vid_out_wr_en;
68
 
69
`ifdef DEBUG
70
  always @(posedge clk)
71
    $strobe("%m\tvid_in: %h vid_in_wr_en: %d vid_out: %h vid_out_wr_en: %d loop: %8b",
72
                 vid_in, vid_in_wr_en, vid_out, vid_out_wr_en, loop);
73
`endif
74
 
75
endmodule
76
/* not truncated */

powered by: WebSVN 2.1.0

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