Commit a3972541 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

vdpau: automatic ITU-R colour space matrix selection

(same as OpenGL shaders)
parent 07946c4e
...@@ -46,6 +46,22 @@ struct filter_sys_t ...@@ -46,6 +46,22 @@ struct filter_sys_t
picture_t *history[MAX_PAST + 1 + MAX_FUTURE]; picture_t *history[MAX_PAST + 1 + MAX_FUTURE];
}; };
/** Initialize the colour space conversion matrix */
static VdpStatus MixerSetupColors(filter_t *filter, VdpCSCMatrix *restrict csc)
{
filter_sys_t *sys = filter->p_sys;
VdpStatus err;
VdpColorStandard std = (filter->fmt_in.video.i_height > 576)
? VDP_COLOR_STANDARD_ITUR_BT_709
: VDP_COLOR_STANDARD_ITUR_BT_601;
err = vdp_generate_csc_matrix(sys->vdp, NULL, std, csc);
if (err != VDP_STATUS_OK)
msg_Err(filter, "video %s failure: %s", "color space matrix",
vdp_get_error_string(sys->vdp, err));
return err;
}
/** Create VDPAU video mixer */ /** Create VDPAU video mixer */
static VdpVideoMixer MixerCreate(filter_t *filter) static VdpVideoMixer MixerCreate(filter_t *filter)
{ {
...@@ -115,11 +131,20 @@ static VdpVideoMixer MixerCreate(filter_t *filter) ...@@ -115,11 +131,20 @@ static VdpVideoMixer MixerCreate(filter_t *filter)
} }
/* Set initial features and attributes */ /* Set initial features and attributes */
VdpVideoMixerAttribute attrv[1]; VdpVideoMixerAttribute attrv[2];
const void *valv[1]; const void *valv[2];
unsigned attrc = 0; unsigned attrc = 0;
VdpCSCMatrix csc;
featc = 0; featc = 0;
if (MixerSetupColors(filter, &csc) == VDP_STATUS_OK)
{
attrv[attrc] = VDP_VIDEO_MIXER_ATTRIBUTE_CSC_MATRIX;
valv[attrc] = &csc;
attrc++;
}
if (noise > 0.f) if (noise > 0.f)
{ {
featv[featc++] = VDP_VIDEO_MIXER_FEATURE_NOISE_REDUCTION; featv[featc++] = VDP_VIDEO_MIXER_FEATURE_NOISE_REDUCTION;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment