mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 02:15:31 +00:00
Revert "libs: encoder: add api gst_vaapi_encoder_add/del_roi"
This reverts commit 7a6f690340
.
https://bugzilla.gnome.org/show_bug.cgi?id=768248
This commit is contained in:
parent
35226dba88
commit
d3110713b8
3 changed files with 0 additions and 123 deletions
|
@ -1323,9 +1323,6 @@ gst_vaapi_encoder_finalize (GstVaapiEncoder * encoder)
|
||||||
|
|
||||||
klass->finalize (encoder);
|
klass->finalize (encoder);
|
||||||
|
|
||||||
if (encoder->roi_regions)
|
|
||||||
g_list_free_full (encoder->roi_regions, g_free);
|
|
||||||
|
|
||||||
gst_vaapi_object_replace (&encoder->context, NULL);
|
gst_vaapi_object_replace (&encoder->context, NULL);
|
||||||
gst_vaapi_display_replace (&encoder->display, NULL);
|
gst_vaapi_display_replace (&encoder->display, NULL);
|
||||||
encoder->va_display = NULL;
|
encoder->va_display = NULL;
|
||||||
|
@ -1566,111 +1563,6 @@ gst_vaapi_encoder_ensure_max_num_ref_frames (GstVaapiEncoder * encoder,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_vaapi_encoder_add_roi:
|
|
||||||
* @encoder: a #GstVaapiEncoder
|
|
||||||
* @roi: (transfer none): a #GstVaapiROI
|
|
||||||
*
|
|
||||||
* Adds a roi region provided by user.
|
|
||||||
*
|
|
||||||
* This can be called on running a pipeline,
|
|
||||||
* Since vaapi encoder set roi regions at every frame encoding.
|
|
||||||
* Note that if it exceeds number of supported roi in driver,
|
|
||||||
* this will return FALSE.
|
|
||||||
*
|
|
||||||
* Return value: a #gboolean
|
|
||||||
*/
|
|
||||||
gboolean
|
|
||||||
gst_vaapi_encoder_add_roi (GstVaapiEncoder * encoder, GstVaapiROI * roi)
|
|
||||||
{
|
|
||||||
GstVaapiContextInfo *const cip = &encoder->context_info;
|
|
||||||
const GstVaapiConfigInfoEncoder *const config = &cip->config.encoder;
|
|
||||||
GstVaapiROI *region = NULL;
|
|
||||||
GList *walk;
|
|
||||||
|
|
||||||
g_return_val_if_fail (roi != NULL, FALSE);
|
|
||||||
|
|
||||||
if (!config->roi_capability)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (encoder->roi_regions &&
|
|
||||||
g_list_length (encoder->roi_regions) > config->roi_num_supported)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
walk = encoder->roi_regions;
|
|
||||||
while (walk) {
|
|
||||||
GstVaapiROI *region_ptr = (GstVaapiROI *) walk->data;
|
|
||||||
if (region_ptr->rect.x == roi->rect.x &&
|
|
||||||
region_ptr->rect.y == roi->rect.y &&
|
|
||||||
region_ptr->rect.width == roi->rect.width &&
|
|
||||||
region_ptr->rect.height == roi->rect.height) {
|
|
||||||
/* Duplicated region */
|
|
||||||
goto end;
|
|
||||||
}
|
|
||||||
walk = walk->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
region = g_malloc0 (sizeof (GstVaapiROI));
|
|
||||||
if (G_UNLIKELY (!region))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
region->rect.x = roi->rect.x;
|
|
||||||
region->rect.y = roi->rect.y;
|
|
||||||
region->rect.width = roi->rect.width;
|
|
||||||
region->rect.height = roi->rect.height;
|
|
||||||
|
|
||||||
encoder->roi_regions = g_list_append (encoder->roi_regions, region);
|
|
||||||
|
|
||||||
end:
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gst_vaapi_encoder_del_roi:
|
|
||||||
* @encoder: a #GstVaapiEncoder
|
|
||||||
* @roi: (transfer none): a #GstVaapiROI
|
|
||||||
*
|
|
||||||
* Deletes a roi region provided by user.
|
|
||||||
*
|
|
||||||
* This can be called on running a pipeline,
|
|
||||||
* Since vaapi encoder set roi regions at every frame encoding.
|
|
||||||
*
|
|
||||||
* Return value: a #gboolean
|
|
||||||
*/
|
|
||||||
gboolean
|
|
||||||
gst_vaapi_encoder_del_roi (GstVaapiEncoder * encoder, GstVaapiROI * roi)
|
|
||||||
{
|
|
||||||
GstVaapiContextInfo *const cip = &encoder->context_info;
|
|
||||||
const GstVaapiConfigInfoEncoder *const config = &cip->config.encoder;
|
|
||||||
GList *walk;
|
|
||||||
gboolean ret = FALSE;
|
|
||||||
|
|
||||||
g_return_val_if_fail (roi != NULL, FALSE);
|
|
||||||
|
|
||||||
if (!config->roi_capability)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (encoder->roi_regions && g_list_length (encoder->roi_regions) == 0)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
walk = encoder->roi_regions;
|
|
||||||
while (walk) {
|
|
||||||
GstVaapiROI *region = (GstVaapiROI *) walk->data;
|
|
||||||
if (region->rect.x == roi->rect.x &&
|
|
||||||
region->rect.y == roi->rect.y &&
|
|
||||||
region->rect.width == roi->rect.width &&
|
|
||||||
region->rect.height == roi->rect.height) {
|
|
||||||
encoder->roi_regions = g_list_remove (encoder->roi_regions, region);
|
|
||||||
g_free (region);
|
|
||||||
ret = TRUE;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
walk = walk->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Returns a GType for the #GstVaapiEncoderTune set */
|
/** Returns a GType for the #GstVaapiEncoderTune set */
|
||||||
GType
|
GType
|
||||||
gst_vaapi_encoder_tune_get_type (void)
|
gst_vaapi_encoder_tune_get_type (void)
|
||||||
|
|
|
@ -140,11 +140,6 @@ typedef struct {
|
||||||
GParamSpec *const pspec;
|
GParamSpec *const pspec;
|
||||||
} GstVaapiEncoderPropInfo;
|
} GstVaapiEncoderPropInfo;
|
||||||
|
|
||||||
typedef struct _GstVaapiROI {
|
|
||||||
gint roi_value;
|
|
||||||
GstVaapiRectangle rect;
|
|
||||||
} GstVaapiROI;
|
|
||||||
|
|
||||||
GType
|
GType
|
||||||
gst_vaapi_encoder_tune_get_type (void) G_GNUC_CONST;
|
gst_vaapi_encoder_tune_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
|
@ -206,13 +201,6 @@ gst_vaapi_encoder_flush (GstVaapiEncoder * encoder);
|
||||||
GArray *
|
GArray *
|
||||||
gst_vaapi_encoder_get_surface_formats (GstVaapiEncoder * encoder,
|
gst_vaapi_encoder_get_surface_formats (GstVaapiEncoder * encoder,
|
||||||
GstVaapiProfile profile);
|
GstVaapiProfile profile);
|
||||||
|
|
||||||
gboolean
|
|
||||||
gst_vaapi_encoder_add_roi (GstVaapiEncoder * encoder, GstVaapiROI * roi);
|
|
||||||
|
|
||||||
gboolean
|
|
||||||
gst_vaapi_encoder_del_roi (GstVaapiEncoder * encoder, GstVaapiROI * roi);
|
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* GST_VAAPI_ENCODER_H */
|
#endif /* GST_VAAPI_ENCODER_H */
|
||||||
|
|
|
@ -283,9 +283,6 @@ struct _GstVaapiEncoder
|
||||||
guint got_packed_headers:1;
|
guint got_packed_headers:1;
|
||||||
guint got_rate_control_mask:1;
|
guint got_rate_control_mask:1;
|
||||||
|
|
||||||
/* Region of Interest */
|
|
||||||
GList *roi_regions;
|
|
||||||
|
|
||||||
/* miscellaneous buffer parameters */
|
/* miscellaneous buffer parameters */
|
||||||
VAEncMiscParameterRateControl va_ratecontrol;
|
VAEncMiscParameterRateControl va_ratecontrol;
|
||||||
VAEncMiscParameterFrameRate va_framerate;
|
VAEncMiscParameterFrameRate va_framerate;
|
||||||
|
|
Loading…
Reference in a new issue