当前位置: 首页 > backend >正文

ARINC818_FILE

module ARINC818_FILE(
    input clk,
    input rst_n,
    input [31:0] container_cnt,    // 容器计数
    input [15:0] advb_frame_cnt,   // advb帧计数
    input advb_frame_last,          // ADVB最后一帧
    input [15:0] img_width,         // 图像宽度
    input [15:0] img_high,          // 图像高度

    output reg [31:0] sofi,        // 首帧起始定界符
    output reg [31:0] sofn,        // 非首帧起始定界符
    output reg [31:0] eofn,        // 非最后帧结束定界符
    output reg [31:0] eoft,        // 最后帧结束定界符
    output reg [31:0] advb_idle,   // advb帧间隙字符

    output reg [31:0] frame_words0_r_ctl,
    output reg [31:0] frame_words0_dst_id,
    output reg [31:0] frame_words1_cs_ctl,
    output reg [31:0] frame_words1_src_id,
    output reg [31:0] frame_words2_type,
    output reg [31:0] frame_words2_f_ctl,
    output reg [31:0] frame_words3_seq_id,
    output reg [31:0] frame_words3_df_ctl,
    output reg [31:0] frame_words3_seq_cnt,
    output reg [31:0] frame_words4_OX_RX_ID,
    output reg [31:0] frame_words5_parameter,
    output reg [31:0] container_words0_cnt,
    output reg [31:0] container_words1_id,
    output reg [31:0] container_words2_time,
    output reg [31:0] container_words3_time,
    output reg [31:0] container_words4_fps,
    output reg [31:0] container_words4_rate
);

    // K28.5, D21.5, D22.2编码示例(ARINC 818协议定义的字符编码)
    localparam [7:0] K28_5 = 8'hBC; // 示例码,真实协议确认
    localparam [7:0] D21_5 = 8'h95;
    localparam [7:0] D22_2 = 8'hB5;
    localparam [31:0] SOFI_VAL = {K28_5, D21_5, D22_2, D22_2};
    localparam [31:0] SOFN_VAL = {K28_5, D21_5, D21_5, D22_2};
    localparam [31:0] EOFN_VAL = {K28_5, D22_2, D21_5, D21_5};
    localparam [31:0] EOFT_VAL = {K28_5, D22_2, D22_2, D21_5};
    localparam [31:0] ADVB_IDLE_VAL = 32'hBC95_B5B5;  // 休止符

    // 初始化和状态更新
    always @(posedge clk or negedge rst_n) begin
        if (!rst_n) begin
            sofi <= SOFI_VAL;
            sofn <= SOFN_VAL;
            eofn <= EOFN_VAL;
            eoft <= EOFT_VAL;
            advb_idle <= ADVB_IDLE_VAL;

            // 这里frame_words*和container_words*初始化为0或默认值
            frame_words0_r_ctl <= 32'd0;
            frame_words0_dst_id <= 32'd0;
            frame_words1_cs_ctl <= 32'd0;
            frame_words1_src_id <= 32'd0;
            frame_words2_type <= 32'd0;
            frame_words2_f_ctl <= 32'd0;
            frame_words3_seq_id <= 32'd0;
            frame_words3_df_ctl <= 32'd0;
            frame_words3_seq_cnt <= 32'd0;
            frame_words4_OX_RX_ID <= 32'd0;
            frame_words5_parameter <= 32'd0;
            container_words0_cnt <= 32'd0;
            container_words1_id <= 32'd0;
            container_words2_time <= 32'd0;
            container_words3_time <= 32'd0;
            container_words4_fps <= 32'd0;
            container_words4_rate <= 32'd0;
        end else begin
            // 根据advb_frame_last控制使用SOFI或SOFN
            sofi <= advb_frame_last ? SOFI_VAL : sofi;
            sofn <= (!advb_frame_last) ? SOFN_VAL : sofn;
            eofn <= (!advb_frame_last) ? EOFN_VAL : eofn;
            eoft <= advb_frame_last ? EOFT_VAL : eoft;

            // 赋值frame_words,示例根据计数器简单赋值,可根据协议详细填写
            frame_words0_r_ctl <= {16'd0, advb_frame_cnt};      // 示例:下16位为帧计数
            frame_words0_dst_id <= 32'h0000_0001;              // 目的ID示例
            frame_words1_cs_ctl <= 32'h0000_0000;               // 控制字段示例
            frame_words1_src_id <= 32'h0000_0002;               // 源ID示例
            frame_words2_type <= 32'h0000_0001;                 // 帧类型示例
            frame_words2_f_ctl <= 32'h0000_0000;                // 帧控制示例
            frame_words3_seq_id <= 32'h0000_0000;                // 序列ID示例
            frame_words3_df_ctl <= 32'h0000_0000;                // DF控制示例
            frame_words3_seq_cnt <= {16'd0, advb_frame_cnt};    // 序列计数示例
            frame_words4_OX_RX_ID <= 32'h0000_0000;             // OX/RX示例
            frame_words5_parameter <= {img_width, img_high};     // 图片分辨率打包示例

            // 容器相关信息直接赋值
            container_words0_cnt <= container_cnt;
            container_words1_id <= 32'h0000_0001;              // 容器ID示例
            container_words2_time <= 32'd0;                      // 时间戳示例
            container_words3_time <= 32'd0;                      // 时间戳示例
            container_words4_fps <= 32'd60;                      // 帧率示例
            container_words4_rate <= 32'd1000;                   // 码率示例
        end
    end

endmodule
 

http://www.xdnf.cn/news/9004.html

相关文章:

  • jquery基础知识
  • 批量转存夸克网盘内容并分享实操教程
  • charAt()
  • ArkUI:鸿蒙应用响应式与组件化开发指南(一)
  • RuoYi前后端分离框架集成UEditorPlus富文本编辑器
  • C++ list基础概念、list初始化、list赋值操作、list大小操作、list数据插入
  • Debian系统安装Python详细教程及常见问题解答
  • 菜鸟之路Day34一一Mybatis-基础操作
  • 基于深度学习的情绪识别检测系统【完整版】
  • 什么是时空学习(Spatiotemporal Learning)
  • 大语言模型 20 - MCP 在客户端中使用 Cursor Cline 中配置 MCP 服务
  • 如何安全配置数据库(MySQL/PostgreSQL/MongoDB)
  • QT5.15 MacOS 打包指南
  • ai作诗平台:AnKo引领未来诗歌创作新时代!
  • CC工具箱使用指南:【计算线要素的插值点数据】
  • 华为OD机试真题——新学校选址(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • 《软件工程》第 5 章 - 需求分析模型的表示
  • Android开机向导定制(1)开机向导加载流程
  • 小土堆pytorch--损失函数与反向传播
  • Godot的RichTextLabel富文本标签,鼠标拖拽滚动,方向键滚动,底部吸附,自动滚动
  • 微信小程序进阶第2篇__事件类型_冒泡_非冒泡
  • 【QT】TXT文件的基础操作
  • 运行打印Hello World启动了多少线程?
  • Python线程同步:保障多线程程序的稳定性与正确性
  • 加速科技荣登2025杭州准独角兽榜单
  • ChatGPT 如何工作——提示工程、对话记忆与上下文管理解析
  • 临床试验中的独立数据监查委员会
  • hadoop纠删码基本原理
  • 【Fifty Project - D31】
  • 【ArcGIS】ArcGIS AI 助手----复现