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

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

上图是读取解码视频数据并写入共享内存的流程 框图, 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阻塞获取数据

相关推荐
开开心心就好1 小时前
整合多家平台资源的免费学习应用
人工智能·vscode·学习·游戏·音视频·语音识别·媒体
DogDaoDao1 小时前
VVC 参考软件 VTM 全面深度解析:架构设计、核心算法与工程实践
音视频·视频编解码·hevc·h266·vvc·vtm·视频压缩
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_13:多媒体嵌入 —— 视频与音频
前端·css·笔记·ui·html·音视频
jinglong.zha20 小时前
AI萌宠短剧实战:从0孵化动物IP,用AI制作爆款短视频
人工智能·ai·音视频·网赚教程·萌宠
大学生小郑1 天前
CMOS 传感器堆叠结构
图像处理·学习·音视频·视频
luoqice1 天前
利用librtmp实现h264和AAC音频的推流
音视频·aac
byte轻骑兵1 天前
蓝牙CAP规范解析:构建多设备协同的通用音频新生态
人工智能·音视频·le audio·低功耗音频·蓝牙通话
大象AI共学1 天前
我让AI写了个网页,它自动变成了视频
人工智能·音视频
Prannt1 天前
星朗智能语音——视频音色替换
ai·音视频·语音识别
时空自由民.2 天前
音视频图片压缩
音视频