zoukankan      html  css  js  c++  java
  • HD,3G视频数据中行号的插入方法---Verilog代码实现

    HD,3G视频数据中行号的插入方法---Verilog代码实现

    行号的生成:

    `timescale 1ns / 1ps
    //////////////////////////////////////////////////////////////////////////////////
    // Company: 
    // Engineer: chensimin
    // 
    // Create Date: 2019/01/14 16:57:42
    // Design Name: 
    // Module Name: line_num_pro
    // Project Name: 
    // Target Devices: 
    // Tool Versions: 
    // Description: 
    // 
    // Dependencies: 
    // 
    // Revision:
    // Revision 0.01 - File Created
    // Additional Comments:
    // 
    //////////////////////////////////////////////////////////////////////////////////
    
    
    module line_num_pro (
    
        input   wire             clk,
        input   wire             rst,
        input   wire             eav,
        input   wire   [9:0]     vid_in,
    
        output  wire   [10:0]    ln
    
        );
    
    //-----------------------------------------------------------------
    
    assign v = vid_in[7];
    
    //-----------------------------------------------------------------
    
    reg   last_v; 
    
    always @(posedge clk or posedge rst)
    begin
        if(rst)
            last_v <= 1'b0;
        else if(eav)
            last_v <= v;
    end
    
    //-----------------------------------------------------------------
    
    wire   ln_load; 
    
    assign ln_load = last_v & ~v;
    
    //-----------------------------------------------------------------
    
    assign ln_tc = ln_counter == 1125;
    
    //-----------------------------------------------------------------
    
    reg     [10:0]    ln_counter; 
    
    always @(posedge clk or posedge rst)
    begin
        if(rst)
            ln_counter <= 11'd1;
        
        else if (eav)
        begin
            if(ln_load)
                ln_counter <= 11'd42;
            else if(ln_tc)
                ln_counter <= 11'd1;
            else 
                ln_counter <= ln_counter + 1'b1;
        end
    end
    
    assign ln = ln_counter;
    
    
    
    //-----------------------------------------------------------------
    
    // ila_13 U576 (
    //     .clk(clk), // input wire clk
    
    //     .probe0(vid_in), // input wire [9:0]  probe0  
    //     .probe1(eav), // input wire [0:0]  probe1 
    //     .probe2(v), // input wire [0:0]  probe2 
    //     .probe3(last_v), // input wire [0:0]  probe3 
    //     .probe4(ln_load), // input wire [0:0]  probe4 
    //     .probe5(ln_tc), // input wire [0:0]  probe5 
    //     .probe6(ln_counter), // input wire [10:0]  probe6 
    //     .probe7(ln) // input wire [10:0]  probe7
    // );
    
    
    endmodule

    行号的插入:

    `timescale 1ns / 1ps
    //////////////////////////////////////////////////////////////////////////////////
    // Company: 
    // Engineer: chensimin
    // 
    // Create Date: 2019/01/15 17:06:40
    // Design Name: 
    // Module Name: line_num_insert
    // Project Name: 
    // Target Devices: 
    // Tool Versions: 
    // Description: 
    // 
    // Dependencies: 
    // 
    // Revision:
    // Revision 0.01 - File Created
    // Additional Comments:
    // 
    //////////////////////////////////////////////////////////////////////////////////
    
    
    module line_num_insert(
    
        input    wire              insert_ln,
        input    wire              ln_word0,
        input    wire              ln_word1,
        input    wire   [9:0]      c_in,
        input    wire   [9:0]      y_in,
        input    wire   [10:0]     ln,   
    
        output   reg   [9:0]      c_out,
        output   reg   [9:0]      y_out
        
        );
    
    
    //-----------------------------------------------------------------------------
    
    always @ (ln or insert_ln or c_in or ln_word0 or ln_word1)
        if (insert_ln & ln_word0)
            c_out <= {~ln[6], ln[6:0], 2'b00};
        else if (insert_ln & ln_word1)
            c_out <= {4'b1000, ln[10:7], 2'b00};
        else
            c_out <= c_in;
    
    //---------------------------------------------------------------------------
    
    always @ (ln or insert_ln or y_in or ln_word0 or ln_word1)
        if (insert_ln & ln_word0)
            y_out <= {~ln[6], ln[6:0], 2'b00};
        else if (insert_ln & ln_word1)
            y_out <= {4'b1000, ln[10:7], 2'b00};
        else
            y_out <= y_in;
    
    //---------------------------------------------------------------------------
    
    
    endmodule

    生成ln_word0, ln_word1的脉冲指示信号:

    reg ln_word0;
    
    
    always @(posedge hdmi_clk or posedge rst)
    begin
        if(rst)
            ln_word0 <= 1'b0;
    
        else if(eav)
            ln_word0 <= 1'b1;
    
        else 
            ln_word0 <= 1'b0;
    end
    
    //-------------------------------------------------------------------------------------------------------------------------
    
    reg ln_word1;
    
    always @(posedge hdmi_clk or posedge rst)
    begin
        if(rst)
            ln_word1 <= 1'b0;
    
        else if(ln_word0)
            ln_word1 <= 1'b1;
    
        else 
            ln_word1 <= 1'b0;
    end
  • 相关阅读:
    用友U8远程接入客户端提示启动客户端错误
    oracle 10g 错误 ORA-01653 的解决过程
    用友 凭证引入 如何删除引入的外部凭证
    Delphi实现程序只运行一次并激活已打开的程序
    Delphi Raize的日期控件RzDateTimeEdit星期几不能正确显示的问题
    U8 提示“操作员没有查询权限或视图权限”
    数据库图片存储也读取
    Delph最简单i获取外网IP
    cxgrid 单元格合并
    cocos2d 中使用 pickerView 简单的老虎机应用
  • 原文地址:https://www.cnblogs.com/chensimin1990/p/10277433.html
Copyright © 2011-2022 走看看