gstreamer/deepstream崩溃记录及分析

简介: gstreamer/deepstream崩溃记录及分析

今天专门测试了一下摄像头的断电问题.这个问题以前一直想做,今天终于下决心.这一套视频使用的gstreamer/deepstream.如前文所说的结束方法,结束代码如下:


gst_element_set_state(pipeline,      GST_STATE_NULL);
gst_object_unref(pipeline);

 如果摄像头已启动完成,再启动程序,这两句是可以正常执行的.


 如果摄像头没加电,启动程序,自然会报错.然后在结束时,gst_element_set_state(pipeline, GST_STATE_NULL)会导致崩溃.分析了一下core,并进行了测试,确定是nvidia的解码器插件(nvdec_h264)在释放时崩溃.也就是说,此时如果gst_element_set_state(nvdec_h264, GST_STATE_NULL),照样引起崩溃.



 怎么办?吾有两个办法:


 先ping一下摄像头,成功了再启动任务.这样就可以彻底避免这个问题.


 加一个探头,收到解码调用时记录一下时间.这样结束时就可以判断一下.


 需要重复的是,即使是正常结束,nvidia的解码器插件(nvdec_h264)大约有100MB的显存没有释放.这个真没办法.


 那么gstreamer是不是就正确结束了呢?应该是的,因为没看到报错.内存是不是正确释放了?这个...一时没有分析.

目录
相关文章
|
3月前
|
Linux
crash工具使用 —— 查看DMI信息
crash工具使用 —— 查看DMI信息
|
SQL 安全 测试技术
【解决方案 二十七】如何安全稳定的Dump线上数据
【解决方案 二十七】如何安全稳定的Dump线上数据
187 0
|
NoSQL Ubuntu
麟系统开发笔记(十):在国产麒麟系统上使用gdb定位崩溃异常方法流程以及测试Demo
本篇就适合代码崩溃的方法,可以定位到代码崩溃原因,测试Demo。
麟系统开发笔记(十):在国产麒麟系统上使用gdb定位崩溃异常方法流程以及测试Demo
J3D在UOS+KIRIN崩溃1:直接原因分析
J3D在UOS+KIRIN崩溃1:直接原因分析
107 0
J3D在UOS+KIRIN崩溃2:深层原因分析
J3D在UOS+KIRIN崩溃2:深层原因分析
72 0
|
网络安全 开发工具
FreeSWITCH线上一次Crashes分析定位过程-ldns库问题
线上一次Crashes分析定位过程-ldns库问题
gstreamer/deepstream崩溃记录及分析
gstreamer/deepstream崩溃记录及分析
412 0
|
Windows
Windbg内核调试之四: Dump文件分析
Dump 文件分析很大程度上就是分析蓝屏产生的原因。这种系统级的错误算是Windows提示错误中比较严重的一种(更严重的还有启动黑屏等硬件或软件兼容性错误等等)。说它是比较严重,是因为毕竟Windows还提供了dump文件给用户分析,至少能比较容易的找到错误的原因。
1647 0

热门文章

最新文章