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

Subversion Repositories mpeg2fpga

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

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 kdv
/*
2
 * pixel_queue.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
 * pixel_queue - Pixel output queue
21
 */
22
 
23
`include "timescale.v"
24
 
25
module pixel_queue(
26
  clk_in, clk_in_en,
27
  rst,
28
  y_in, u_in, v_in, osd_in, position_in, pixel_wr_en, pixel_wr_almost_full, pixel_wr_full, pixel_wr_overflow,
29
  clk_out, clk_out_en,
30
  y_out, u_out, v_out, osd_out, position_out, pixel_rd_en, pixel_rd_empty, pixel_rd_valid, pixel_rd_underflow
31
  );
32
 
33
  input              clk_in;                   // write clock
34
  input              clk_in_en;                // write clock enable
35
 
36
  input              rst;                      // synchronous active low reset
37
 
38
  input         [7:0]y_in;
39
  input         [7:0]u_in;
40
  input         [7:0]v_in;
41
  input         [7:0]osd_in;
42
  input         [2:0]position_in;
43
  input              pixel_wr_en;
44
  output             pixel_wr_almost_full;
45
  output             pixel_wr_full;
46
  output             pixel_wr_overflow;
47
 
48
  input              clk_out;                  // read clock
49
  input              clk_out_en;               // read clock enable
50
 
51
  output        [7:0]y_out;
52
  output        [7:0]u_out;
53
  output        [7:0]v_out;
54
  output        [7:0]osd_out;
55
  output        [2:0]position_out;
56
  input              pixel_rd_en;
57
  output             pixel_rd_empty;
58
  output             pixel_rd_valid;
59
  output             pixel_rd_underflow;
60
 
61
`include "fifo_size.v"
62
 
63
  fifo_dc
64
    #(.addr_width(PIXEL_DEPTH),
65
    .dta_width(9'd35),
66
    .prog_thresh(PIXEL_THRESHOLD),
67
    .FIFO_XILINX(1))
68
    pixel_fifo (
69
    .rst(rst),
70
    .wr_clk(clk_in),
71
    .din({y_in, u_in, v_in, osd_in, position_in}),
72
    .wr_en(pixel_wr_en && clk_in_en),
73
    .wr_ack(),
74
    .full(pixel_wr_full),
75
    .overflow(pixel_wr_overflow),
76
    .rd_clk(clk_out),
77
    .dout({y_out, u_out, v_out, osd_out, position_out}),
78
    .rd_en(pixel_rd_en && clk_out_en),
79
    .valid(pixel_rd_valid),
80
    .empty(pixel_rd_empty),
81
    .underflow(pixel_rd_underflow),
82
    .prog_full(pixel_wr_almost_full),
83
    .prog_empty()
84
    );
85
 
86
endmodule
87
/* not truncated */

powered by: WebSVN 2.1.0

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