mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-27 12:11:13 +00:00
msdkvpp: close the current VPP session if this session has been initialized
Otherwise MFXVideoVPP_Init will fail because it is called twice without
a close.
Example pipeline:
gst-launch-1.0 videotestsrc ! msdkvpp ! glimagesink
Sometimes glimagesink emits GST_EVENT_RECONFIGURE event which results
in that MFXVideoVPP_Init is called twice, then get the negotiation
failure below:
0:00:00.093715518 21218 0x558ef56231e0 ERROR msdkvpp
gstmsdkvpp.c:995:gst_msdkvpp_initialize:<msdkvpp0> Init failed
(undefined behavior)
WARNING: from element /GstPipeline:pipeline0/GstMsdkVPP:msdkvpp0: not
negotiated
After applying this commit, the pipeline above may run without
negotiation failure, however NV12 layout in dmabuf mode is selected in
renegotiation, the display image is corrupted due to the NV12 issue which
was mentioned in commit 3f2314a
. Some other fixes are needed to avoid
renegotiation by default
This commit is contained in:
parent
e8d2f58e23
commit
7681566f29
1 changed files with 7 additions and 0 deletions
|
@ -904,6 +904,13 @@ gst_msdkvpp_initialize (GstMsdkVPP * thiz)
|
||||||
GST_OBJECT_LOCK (thiz);
|
GST_OBJECT_LOCK (thiz);
|
||||||
session = gst_msdk_context_get_session (thiz->context);
|
session = gst_msdk_context_get_session (thiz->context);
|
||||||
|
|
||||||
|
/* Close the current session if the session has been initialized,
|
||||||
|
* otherwise the subsequent function call of MFXVideoVPP_Init() will
|
||||||
|
* fail
|
||||||
|
*/
|
||||||
|
if (thiz->initialized)
|
||||||
|
MFXVideoVPP_Close (session);
|
||||||
|
|
||||||
if (thiz->use_video_memory) {
|
if (thiz->use_video_memory) {
|
||||||
gst_msdk_set_frame_allocator (thiz->context);
|
gst_msdk_set_frame_allocator (thiz->context);
|
||||||
thiz->param.IOPattern =
|
thiz->param.IOPattern =
|
||||||
|
|
Loading…
Reference in a new issue