mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-23 08:46:40 +00:00
nvcodec: Add max-display-delay decoder property
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/1633>
This commit is contained in:
parent
8cf1b7a154
commit
1d4b6299dc
2 changed files with 71 additions and 1 deletions
|
@ -38,6 +38,14 @@
|
|||
GST_DEBUG_CATEGORY_EXTERN (gst_nvdec_debug);
|
||||
#define GST_CAT_DEFAULT gst_nvdec_debug
|
||||
|
||||
#define DEFAULT_MAX_DISPLAY_DELAY -1
|
||||
|
||||
enum
|
||||
{
|
||||
PROP_0,
|
||||
PROP_MAX_DISPLAY_DELAY,
|
||||
};
|
||||
|
||||
#ifdef HAVE_NVCODEC_GST_GL
|
||||
#define SUPPORTED_GL_APIS (GST_GL_API_OPENGL | GST_GL_API_OPENGL3 | GST_GL_API_GLES2)
|
||||
|
||||
|
@ -166,12 +174,48 @@ static gboolean gst_nvdec_ensure_gl_context (GstNvDec * nvdec);
|
|||
#define gst_nvdec_parent_class parent_class
|
||||
G_DEFINE_ABSTRACT_TYPE (GstNvDec, gst_nvdec, GST_TYPE_VIDEO_DECODER);
|
||||
|
||||
static void
|
||||
gst_nv_dec_set_property (GObject * object, guint prop_id, const GValue * value,
|
||||
GParamSpec * pspec)
|
||||
{
|
||||
GstNvDec *nvdec = GST_NVDEC (object);
|
||||
|
||||
switch (prop_id) {
|
||||
case PROP_MAX_DISPLAY_DELAY:
|
||||
nvdec->max_display_delay = g_value_get_int (value);
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
gst_nv_dec_get_property (GObject * object, guint prop_id, GValue * value,
|
||||
GParamSpec * pspec)
|
||||
{
|
||||
GstNvDec *nvdec = GST_NVDEC (object);
|
||||
|
||||
switch (prop_id) {
|
||||
case PROP_MAX_DISPLAY_DELAY:
|
||||
g_value_set_int (value, nvdec->max_display_delay);
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
gst_nvdec_class_init (GstNvDecClass * klass)
|
||||
{
|
||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||
GstVideoDecoderClass *video_decoder_class = GST_VIDEO_DECODER_CLASS (klass);
|
||||
GstElementClass *element_class = GST_ELEMENT_CLASS (klass);
|
||||
|
||||
gobject_class->set_property = gst_nv_dec_set_property;
|
||||
gobject_class->get_property = gst_nv_dec_get_property;
|
||||
|
||||
video_decoder_class->open = GST_DEBUG_FUNCPTR (gst_nvdec_open);
|
||||
video_decoder_class->start = GST_DEBUG_FUNCPTR (gst_nvdec_start);
|
||||
video_decoder_class->stop = GST_DEBUG_FUNCPTR (gst_nvdec_stop);
|
||||
|
@ -189,11 +233,19 @@ gst_nvdec_class_init (GstNvDecClass * klass)
|
|||
|
||||
element_class->set_context = GST_DEBUG_FUNCPTR (gst_nvdec_set_context);
|
||||
gst_type_mark_as_plugin_api (GST_TYPE_NVDEC, 0);
|
||||
|
||||
g_object_class_install_property (gobject_class, PROP_MAX_DISPLAY_DELAY,
|
||||
g_param_spec_int ("max-display-delay", "Max Display Delay",
|
||||
"Improves pipelining of decode with display, 0 means no delay "
|
||||
"(auto = -1)",
|
||||
-1, G_MAXINT, DEFAULT_MAX_DISPLAY_DELAY,
|
||||
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||
}
|
||||
|
||||
static void
|
||||
gst_nvdec_init (GstNvDec * nvdec)
|
||||
{
|
||||
nvdec->max_display_delay = DEFAULT_MAX_DISPLAY_DELAY;
|
||||
gst_video_decoder_set_packetized (GST_VIDEO_DECODER (nvdec), TRUE);
|
||||
gst_video_decoder_set_needs_format (GST_VIDEO_DECODER (nvdec), TRUE);
|
||||
}
|
||||
|
@ -261,6 +313,13 @@ calculate_num_decode_surface (cudaVideoCodec codec, guint width, guint height)
|
|||
return 8;
|
||||
}
|
||||
|
||||
static guint
|
||||
gst_nvdec_get_max_display_delay (GstNvDec * nvdec)
|
||||
{
|
||||
return nvdec->max_display_delay >= 0 ? nvdec->max_display_delay :
|
||||
(nvdec->is_live ? 0 : 4);
|
||||
}
|
||||
|
||||
/* 0: fail, 1: succeeded, > 1: override dpb size of parser
|
||||
* (set by CUVIDPARSERPARAMS::ulMaxNumDecodeSurfaces while creating parser) */
|
||||
static gint CUDAAPI
|
||||
|
@ -931,6 +990,7 @@ gst_nvdec_set_format (GstVideoDecoder * decoder, GstVideoCodecState * state)
|
|||
GstNvDec *nvdec = GST_NVDEC (decoder);
|
||||
GstNvDecClass *klass = GST_NVDEC_GET_CLASS (decoder);
|
||||
CUVIDPARSERPARAMS parser_params = { 0, };
|
||||
GstQuery *query;
|
||||
gboolean ret = TRUE;
|
||||
|
||||
GST_DEBUG_OBJECT (nvdec, "set format");
|
||||
|
@ -943,12 +1003,19 @@ gst_nvdec_set_format (GstVideoDecoder * decoder, GstVideoCodecState * state)
|
|||
if (!maybe_destroy_decoder_and_parser (nvdec))
|
||||
return FALSE;
|
||||
|
||||
/* Check if pipeline is live */
|
||||
nvdec->is_live = FALSE;
|
||||
query = gst_query_new_latency ();
|
||||
if (gst_pad_peer_query (GST_VIDEO_DECODER_SINK_PAD (decoder), query))
|
||||
gst_query_parse_latency (query, &nvdec->is_live, NULL, NULL);
|
||||
gst_query_unref (query);
|
||||
|
||||
parser_params.CodecType = klass->codec_type;
|
||||
/* ulMaxNumDecodeSurfaces will be updated by the return value of
|
||||
* SequenceCallback */
|
||||
parser_params.ulMaxNumDecodeSurfaces = 1;
|
||||
parser_params.ulErrorThreshold = 100;
|
||||
parser_params.ulMaxDisplayDelay = 0;
|
||||
parser_params.ulMaxDisplayDelay = gst_nvdec_get_max_display_delay (nvdec);
|
||||
parser_params.ulClockRate = GST_SECOND;
|
||||
parser_params.pUserData = nvdec;
|
||||
parser_params.pfnSequenceCallback =
|
||||
|
|
|
@ -75,6 +75,9 @@ struct _GstNvDec
|
|||
GstGLContext *other_gl_context;
|
||||
#endif
|
||||
|
||||
gint max_display_delay;
|
||||
gboolean is_live;
|
||||
|
||||
CUvideoparser parser;
|
||||
CUvideodecoder decoder;
|
||||
GstCudaContext *cuda_ctx;
|
||||
|
|
Loading…
Reference in a new issue