d3d12convert: Use new sampler filter update method

... instead of creating new converter

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7550>
This commit is contained in:
Seungha Yang 2024-09-18 23:24:55 +09:00 committed by GStreamer Marge Bot
parent a1029d5b87
commit 62caa76155

View file

@ -143,7 +143,6 @@ struct GstD3D12ConvertPrivate
/* sampling method, configured via property */ /* sampling method, configured via property */
GstD3D12SamplingMethod sampling_method = DEFAULT_SAMPLING_METHOD; GstD3D12SamplingMethod sampling_method = DEFAULT_SAMPLING_METHOD;
GstD3D12SamplingMethod active_sampling_method = DEFAULT_SAMPLING_METHOD;
/* orientation */ /* orientation */
/* method configured via property */ /* method configured via property */
@ -326,8 +325,10 @@ gst_d3d12_convert_set_sampling_method (GstD3D12Convert * self,
"Sampling method %d -> %d", priv->sampling_method, method); "Sampling method %d -> %d", priv->sampling_method, method);
priv->sampling_method = method; priv->sampling_method = method;
if (priv->sampling_method != priv->active_sampling_method) if (priv->ctx && priv->ctx->conv) {
gst_base_transform_reconfigure_src (GST_BASE_TRANSFORM_CAST (self)); g_object_set (priv->ctx->conv, "sampler-filter",
gst_d3d12_sampling_method_to_native (method), nullptr);
}
} }
static void static void
@ -1678,12 +1679,11 @@ gst_d3d12_convert_set_info (GstD3D12BaseFilter * filter,
priv->active_add_borders = priv->add_borders; priv->active_add_borders = priv->add_borders;
priv->active_gamma_mode = priv->gamma_mode; priv->active_gamma_mode = priv->gamma_mode;
priv->active_primaries_mode = priv->primaries_mode; priv->active_primaries_mode = priv->primaries_mode;
priv->active_sampling_method = priv->sampling_method;
GST_DEBUG_OBJECT (self, "method %d, add-borders %d, gamma-mode %d, " GST_DEBUG_OBJECT (self, "method %d, add-borders %d, gamma-mode %d, "
"primaries-mode %d, sampling %d", priv->active_method, "primaries-mode %d, sampling %d", priv->active_method,
priv->active_add_borders, priv->active_gamma_mode, priv->active_add_borders, priv->active_gamma_mode,
priv->active_primaries_mode, priv->active_sampling_method); priv->active_primaries_mode, priv->sampling_method);
if (priv->active_method != GST_VIDEO_ORIENTATION_IDENTITY) if (priv->active_method != GST_VIDEO_ORIENTATION_IDENTITY)
need_flip = TRUE; need_flip = TRUE;
@ -1776,8 +1776,7 @@ gst_d3d12_convert_set_info (GstD3D12BaseFilter * filter,
GST_TYPE_VIDEO_PRIMARIES_MODE, priv->active_primaries_mode, GST_TYPE_VIDEO_PRIMARIES_MODE, priv->active_primaries_mode,
GST_D3D12_CONVERTER_OPT_SAMPLER_FILTER, GST_D3D12_CONVERTER_OPT_SAMPLER_FILTER,
GST_TYPE_D3D12_CONVERTER_SAMPLER_FILTER, GST_TYPE_D3D12_CONVERTER_SAMPLER_FILTER,
gst_d3d12_sampling_method_to_native gst_d3d12_sampling_method_to_native (priv->sampling_method), nullptr);
(priv->active_sampling_method), nullptr);
auto ctx = std::make_unique < ConvertContext > (filter->device); auto ctx = std::make_unique < ConvertContext > (filter->device);
@ -1929,8 +1928,7 @@ gst_d3d12_convert_before_transform (GstBaseTransform * trans,
if (priv->selected_method != priv->active_method || if (priv->selected_method != priv->active_method ||
priv->add_borders != priv->active_add_borders || priv->add_borders != priv->active_add_borders ||
priv->gamma_mode != priv->active_gamma_mode || priv->gamma_mode != priv->active_gamma_mode ||
priv->primaries_mode != priv->active_primaries_mode || priv->primaries_mode != priv->active_primaries_mode) {
priv->sampling_method != priv->active_sampling_method) {
update = TRUE; update = TRUE;
} }
priv->lock.unlock (); priv->lock.unlock ();