瑞芯微 多路视频硬解码 代码

时间: 2023-09-18 20:10:26 浏览: 57
瑞芯微多路视频硬解码通常需要使用相关的SDK和驱动程序来实现。下面提供一个简单的代码示例,演示如何使用RK3399处理器进行H.264视频硬解码: ``` #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include "rockchip/rk_mpi.h" #include "rockchip/rk_type.h" #define IN_FILE "/path/to/input.h264" #define OUT_FILE "/path/to/output.yuv" #define WIDTH 1920 #define HEIGHT 1080 int main(int argc, char **argv) { MPP_RET ret; MPP_CTX mpp_ctx = NULL; MppApi *mpi = NULL; FILE *in_file = NULL, *out_file = NULL; RK_U8 *buf = NULL; MppBuffer pkt_buf = NULL; MppBuffer frm_buf = NULL; MppPacket pkt = NULL; MppFrame frm = NULL; RK_U32 pkt_eos = 0, frm_eos = 0; RK_U32 pkt_size = 0, frm_size = 0; RK_U32 width = WIDTH, height = HEIGHT; RK_U32 hor_stride = 0, ver_stride = 0; // 初始化MPP上下文 ret = mpp_create(&mpp_ctx, &mpi); if (ret != MPP_OK) { printf("mpp_create failed: %d\n", ret); return -1; } // 配置解码参数 MppCodingType type = MPP_VIDEO_CodingAVC; MppFrameFormat fmt = MPP_FMT_YUV420SP; MppPacketCoding pkt_type = MPP_VIDEO_CodingAVC; MppFrameCoding frm_type = MPP_VIDEO_CodingI420; MppEncConfig enc_conf; memset(&enc_conf, 0, sizeof(enc_conf)); enc_conf.coding = type; enc_conf.width = width; enc_conf.height = height; enc_conf.hor_stride = hor_stride; enc_conf.ver_stride = ver_stride; enc_conf.fps_in = 30; enc_conf.fps_out = 30; enc_conf.qp_init = 0; enc_conf.qp_max = 51; enc_conf.qp_min = 0; enc_conf.rc_mode = MPP_ENC_RC_MODE_CBR; enc_conf.bps_target = 1024 * 1024; enc_conf.profile = MPP_PROFILE_AVC_HIGH; enc_conf.level = MPP_LEVEL_UNKNOWN; enc_conf.gop = 30; enc_conf.skip_cnt = 0; enc_conf.max_key_interval = 30; enc_conf.ref_num = 1; enc_conf.i_frame_qp_delta = 0; enc_conf.b_frame_qp_delta = 0; enc_conf.init_vbv_buffer_size = 1024 * 1024; enc_conf.vbv_buffer_size = 1024 * 1024; enc_conf.vbv_buffer_delay = 1000; // 初始化解码器 ret = mpi->control(mpp_ctx, MPP_DEC_SET_OUTPUT_FORMAT, &fmt); if (ret != MPP_OK) { printf("mpi->control MPP_DEC_SET_OUTPUT_FORMAT failed: %d\n", ret); goto end; } ret = mpi->control(mpp_ctx, MPP_DEC_SET_CodingType, &type); if (ret != MPP_OK) { printf("mpi->control MPP_DEC_SET_CodingType failed: %d\n", ret); goto end; } ret = mpi->control(mpp_ctx, MPP_DEC_SET_FRAME_INFO, &enc_conf); if (ret != MPP_OK) { printf("mpi->control MPP_DEC_SET_FRAME_INFO failed: %d\n", ret); goto end; } // 打开输入文件和输出文件 in_file = fopen(IN_FILE, "rb"); out_file = fopen(OUT_FILE, "wb"); if (!in_file || !out_file) { printf("open file failed\n"); goto end; } // 解码循环 while (!pkt_eos || !frm_eos) { if (!pkt_eos) { // 读取输入数据 if (!pkt_buf) { ret = mpi->control(mpp_ctx, MPP_DEC_GET_PKT_BUF, &pkt_buf); if (ret != MPP_OK) { printf("mpi->control MPP_DEC_GET_PKT_BUF failed: %d\n", ret); goto end; } } buf = (RK_U8*)mpp_buffer_get_ptr(pkt_buf); pkt_size = fread(buf, 1, mpp_buffer_get_size(pkt_buf), in_file); if (pkt_size == 0) { pkt_eos = 1; } // 构造输入数据包 ret = mpp_packet_init(&pkt, buf, pkt_size); if (ret != MPP_OK) { printf("mpp_packet_init failed: %d\n", ret); goto end; } mpp_packet_set_length(pkt, pkt_size); mpp_packet_set_pts(pkt, 0); mpp_packet_set_dts(pkt, 0); } if (!frm_eos) { if (!frm_buf) { // 申请输出缓冲区 ret = mpi->control(mpp_ctx, MPP_DEC_GET_FRAME_BUF, &frm_buf); if (ret != MPP_OK) { printf("mpi->control MPP_DEC_GET_FRAME_BUF failed: %d\n", ret); goto end; } } // 解码数据包 ret = mpi->decode_put_packet(mpp_ctx, pkt); if (ret != MPP_OK) { printf("mpi->decode_put_packet failed: %d\n", ret); goto end; } ret = mpi->decode_get_frame(mpp_ctx, &frm); if (ret != MPP_OK) { if (ret == MPP_NOK_ENOMEM) { // 缓冲区不足,继续循环 usleep(1000); continue; } else if (ret == MPP_OK || ret == MPP_ERR_TIMEOUT) { // 解码成功或者超时,继续循环 usleep(1000); continue; } else { printf("mpi->decode_get_frame failed: %d\n", ret); goto end; } } // 将解码后的数据写入输出文件 buf = (RK_U8*)mpp_buffer_get_ptr(frm_buf); frm_size = mpp_frame_get_size(frm); fwrite(buf, 1, frm_size, out_file); } } end: // 释放资源 if (mpi) { mpi->reset(mpp_ctx); mpp_destroy(mpp_ctx); } if (in_file) { fclose(in_file); } if (out_file) { fclose(out_file); } if (pkt_buf) { mpp_buffer_put(pkt_buf); } if (pkt) { mpp_packet_deinit(&pkt); } if (frm_buf) { mpp_buffer_put(frm_buf); } if (frm) { mpp_frame_deinit(&frm); } return 0; } ``` 需要注意的是,这只是一个简单的示例代码,实际使用时需要根据具体的需求和硬件平台进行相应的修改和优化。

相关推荐

最新推荐

recommend-type

瑞芯微px30 linux ubuntu ROS开发从零基础到精通.pdf

瑞芯微px30 linux ubuntu ROS开发从零基础到精通.pdf
recommend-type

瑞芯微Image打包工具使用说明

该工具用于将各项目中使用的旧Image固件重新打包成供统一工具使用的新格式固件.目前支持RK28|RK281X|RKCROWN|RKNANO|RKCAYMAN|RK29|RK30|RK30B|RK31 |RK32|RK292X|RKPANDA|RKSMART
recommend-type

k8s1.16的jenkins部署java项目cicd(cd手动)-kubernetes安装包和详细文档笔记整理

k8s1.16的jenkins部署java项目cicd(cd手动)-kubernetes安装包和详细文档笔记整理
recommend-type

sja1311.x86_64.tar.gz

SQLyong 各个版本,免费下载 SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依