mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 08:38:21 +00:00
msdk: don't cache mfxFrameAllocResponse pointer
Otherwise it is possible that different wrappers share the same mfxFrameAllocResponse pointer, so instead of caching the pointer, we may cache the content of mfxFrameAllocResponse
This commit is contained in:
parent
f840e304f3
commit
e50011c064
3 changed files with 7 additions and 9 deletions
|
@ -69,10 +69,10 @@ gst_msdk_frame_alloc (mfxHDL pthis, mfxFrameAllocRequest * req,
|
||||||
gst_msdk_context_get_cached_alloc_responses_by_request (context, req);
|
gst_msdk_context_get_cached_alloc_responses_by_request (context, req);
|
||||||
if (cached) {
|
if (cached) {
|
||||||
/* check if enough frames were allocated */
|
/* check if enough frames were allocated */
|
||||||
if (req->NumFrameSuggested > cached->response->NumFrameActual)
|
if (req->NumFrameSuggested > cached->response.NumFrameActual)
|
||||||
return MFX_ERR_MEMORY_ALLOC;
|
return MFX_ERR_MEMORY_ALLOC;
|
||||||
|
|
||||||
*resp = *cached->response;
|
*resp = cached->response;
|
||||||
return MFX_ERR_NONE;
|
return MFX_ERR_NONE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -205,8 +205,7 @@ gst_msdk_frame_alloc (mfxHDL pthis, mfxFrameAllocRequest * req,
|
||||||
resp->mids = mids;
|
resp->mids = mids;
|
||||||
resp->NumFrameActual = surfaces_num;
|
resp->NumFrameActual = surfaces_num;
|
||||||
|
|
||||||
msdk_resp->response = resp;
|
msdk_resp->response = *resp;
|
||||||
msdk_resp->mem_ids = mids;
|
|
||||||
msdk_resp->request = *req;
|
msdk_resp->request = *req;
|
||||||
|
|
||||||
gst_msdk_context_add_alloc_response (context, msdk_resp);
|
gst_msdk_context_add_alloc_response (context, msdk_resp);
|
||||||
|
|
|
@ -346,7 +346,7 @@ _find_response (gconstpointer resp, gconstpointer comp_resp)
|
||||||
GstMsdkAllocResponse *cached_resp = (GstMsdkAllocResponse *) resp;
|
GstMsdkAllocResponse *cached_resp = (GstMsdkAllocResponse *) resp;
|
||||||
mfxFrameAllocResponse *_resp = (mfxFrameAllocResponse *) comp_resp;
|
mfxFrameAllocResponse *_resp = (mfxFrameAllocResponse *) comp_resp;
|
||||||
|
|
||||||
return cached_resp ? cached_resp->mem_ids != _resp->mids : -1;
|
return cached_resp ? cached_resp->response.mids != _resp->mids : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
|
@ -400,8 +400,8 @@ create_surfaces (GstMsdkContext * context, GstMsdkAllocResponse * resp)
|
||||||
mfxMemId *mem_id;
|
mfxMemId *mem_id;
|
||||||
mfxFrameSurface1 *surface;
|
mfxFrameSurface1 *surface;
|
||||||
|
|
||||||
for (i = 0; i < resp->response->NumFrameActual; i++) {
|
for (i = 0; i < resp->response.NumFrameActual; i++) {
|
||||||
mem_id = resp->mem_ids[i];
|
mem_id = resp->response.mids[i];
|
||||||
surface = (mfxFrameSurface1 *) g_slice_new0 (mfxFrameSurface1);
|
surface = (mfxFrameSurface1 *) g_slice_new0 (mfxFrameSurface1);
|
||||||
if (!surface) {
|
if (!surface) {
|
||||||
GST_ERROR ("failed to allocate surface");
|
GST_ERROR ("failed to allocate surface");
|
||||||
|
|
|
@ -97,9 +97,8 @@ gint gst_msdk_context_get_fd (GstMsdkContext * context);
|
||||||
typedef struct _GstMsdkAllocResponse GstMsdkAllocResponse;
|
typedef struct _GstMsdkAllocResponse GstMsdkAllocResponse;
|
||||||
|
|
||||||
struct _GstMsdkAllocResponse {
|
struct _GstMsdkAllocResponse {
|
||||||
mfxFrameAllocResponse *response;
|
mfxFrameAllocResponse response;
|
||||||
mfxFrameAllocRequest request;
|
mfxFrameAllocRequest request;
|
||||||
mfxMemId *mem_ids;
|
|
||||||
GList *surfaces_avail;
|
GList *surfaces_avail;
|
||||||
GList *surfaces_used;
|
GList *surfaces_used;
|
||||||
GList *surfaces_locked;
|
GList *surfaces_locked;
|
||||||
|
|
Loading…
Reference in a new issue