读取解码视频数据并写入共享内存

读取解码视频数据并写入共享内存的流程图

上图是读取解码视频数据并写入共享内存的流程 框图, rv1126_vdec_thread 线程作用的是读取VDEC解码器的视频数据,并把VDEC的数据传输到共享内存里面 。它要调用RK_MPI_SYS_GetMediaBuffer的API获取每一帧VDEC解码器的数据,并把每一帧的VDEC的视频数据存放到共享内存里面。并且在拷贝的过程中需要用到信号量P/V操作来保证共享内存安全性,这里用的是semop进行P/V操作。

信号量是为了保证数据一致性。和线程锁一样的,保护共享资源,信号量的使用方法,是做P/V操作。

P操作表示的是进入临界点, 一般是写入数据之前; V操作指的是走出临界点,一般是写入数据之后

信号量:

复制代码
/**
 *生成 IPC 键值:
 * key_t sem_key = ftok("/etc/semfile", 65);
 *
 * 创建信号量集合:
 * semid = semget(sem_key, 1, 0666 | IPC_CREAT); //信号量资源为1
 *
 * 初始化信号量:
 * union semun sem_union;
 * sem_union.val = 1;                   // 设置初始值为1
 * semctl(semid, 0, SETVAL, sem_union); // 设置信号量的值
 *
 * 定义信号量操作:
 * sem_p = {0, -1, 0}; // 信号量减1
 * sem_v = {0, 1, 0};  // 信号量加1
 *
 * 使用信号量:
 * semop(semid, &sem_p, 1); // P 操作(等待)
 * //要访问的共享贡献
 * semop(semid, &sem_v, 1); // V 操作(释放)
 */

封装这些接口。

直接就调用这些接口就可以,简单美观,信号量就创建完了


共享内存:

由于此共享内存存放的是YUV视频数据,所以sharememory_size = yuv_size = WIDTH * HEIGHT * 3 /2;

把数据分装好,就直接调用就可以了


rv1126_vdec_thread 线程的具体实现,首先要调用RK_MPI_SYS_GetMediaBuffer 去获取每一帧的VDEC解码视频数据,具体的传参,第一个参数:模块号id, 这里填的是RK_ID_VDEC; 第二个参数:VDEC通道号ID, 这个和创建的ID号保持一致; ****第三个参数:-****1阻塞获取数据

相关推荐
Everbrilliant898 小时前
音视频之H.264的句法和语义
音视频·h.264·h.264句法和语义·h.264句法表·h.264 nal层语义·h.264序列参数集语义·h.264图像参数集语义
硬件学长森哥8 小时前
Android音视频多媒体开源框架基础大全
android·图像处理·音视频
不喝可乐_9 小时前
Node.js 检测视频链接是否可以播放(批量检测)
node.js·音视频
^Rocky11 小时前
uniapp 实现腾讯云音视频通话功能
uni-app·音视频·腾讯云
aqi0012 小时前
FFmpeg开发笔记(六十五)Linux给FFmpeg集成LC3音频的编码器liblc3
ffmpeg·音视频·直播·流媒体
温温top16 小时前
java中合并音频
java·音视频
批量小王子19 小时前
2025-06-13【视频处理】基于视频内容转场进行分割
音视频
Jay Kay1 天前
MemVid:信息存储的未来?创新还是“视频噱头”?
音视频
昨日之日20061 天前
LatentSync V8版 - 音频驱动视频生成数字人说话视频 更新V1.6版模型 支持50系显卡 支持批量 一键整合包下载
人工智能·音视频
知舟不叙2 天前
基于OpenCV实现视频运动目标检测与跟踪
opencv·目标检测·目标跟踪·音视频