qsv: Check 16K resolution support

... and remove duplicated code

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/3310>
This commit is contained in:
Seungha Yang 2022-11-01 22:19:18 +09:00 committed by GStreamer Marge Bot
parent 31c23fb6c0
commit be1771126d
10 changed files with 105 additions and 174 deletions

View file

@ -225343,12 +225343,12 @@
"klass": "Codec/Decoder/Video/Hardware", "klass": "Codec/Decoder/Video/Hardware",
"pad-templates": { "pad-templates": {
"sink": { "sink": {
"caps": "video/x-h264:\n width: [ 16, 4096 ]\n height: [ 16, 4096 ]\n stream-format: { (string)byte-stream, (string)avc, (string)avc3 }\n alignment: au\n profile: { (string)high, (string)progressive-high, (string)constrained-high, (string)main, (string)constrained-baseline, (string)baseline }\n", "caps": "video/x-h264:\n width: [ 1, 4096 ]\n height: [ 1, 4096 ]\n stream-format: { (string)byte-stream, (string)avc, (string)avc3 }\n alignment: au\n profile: { (string)high, (string)progressive-high, (string)constrained-high, (string)main, (string)constrained-baseline, (string)baseline }\n",
"direction": "sink", "direction": "sink",
"presence": "always" "presence": "always"
}, },
"src": { "src": {
"caps": "video/x-raw(memory:D3D11Memory):\n format: NV12\n width: [ 16, 4096 ]\n height: [ 16, 4096 ]\nvideo/x-raw:\n format: NV12\n width: [ 16, 4096 ]\n height: [ 16, 4096 ]\n", "caps": "video/x-raw(memory:D3D11Memory):\n format: NV12\n width: [ 1, 4096 ]\n height: [ 1, 4096 ]\nvideo/x-raw:\n format: NV12\n width: [ 1, 4096 ]\n height: [ 1, 4096 ]\n",
"direction": "src", "direction": "src",
"presence": "always" "presence": "always"
} }
@ -225742,12 +225742,12 @@
"klass": "Codec/Decoder/Video/Hardware", "klass": "Codec/Decoder/Video/Hardware",
"pad-templates": { "pad-templates": {
"sink": { "sink": {
"caps": "video/x-h265:\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\n stream-format: { (string)byte-stream, (string)hev1, (string)hvc1 }\n alignment: au\n profile: { (string)main, (string)main-10 }\n", "caps": "video/x-h265:\n width: [ 1, 16384 ]\n height: [ 1, 16384 ]\n stream-format: { (string)byte-stream, (string)hev1, (string)hvc1 }\n alignment: au\n profile: { (string)main, (string)main-10 }\n",
"direction": "sink", "direction": "sink",
"presence": "always" "presence": "always"
}, },
"src": { "src": {
"caps": "video/x-raw(memory:D3D11Memory):\n format: NV12\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\nvideo/x-raw:\n format: NV12\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\n", "caps": "video/x-raw(memory:D3D11Memory):\n format: NV12\n width: [ 1, 16384 ]\n height: [ 1, 16384 ]\nvideo/x-raw:\n format: NV12\n width: [ 1, 16384 ]\n height: [ 1, 16384 ]\n",
"direction": "src", "direction": "src",
"presence": "always" "presence": "always"
} }
@ -226078,12 +226078,12 @@
"klass": "Codec/Encoder/Video/Hardware", "klass": "Codec/Encoder/Video/Hardware",
"pad-templates": { "pad-templates": {
"sink": { "sink": {
"caps": "video/x-raw(memory:D3D11Memory):\n format: { NV12, BGRA }\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\n\nvideo/x-raw(memory:VAMemory):\n format: { NV12, BGRA }\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\nvideo/x-raw:\n format: { NV12, BGRA }\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\n", "caps": "video/x-raw(memory:D3D11Memory):\n format: { NV12, BGRA }\n width: [ 16, 16384 ]\n height: [ 16, 16384 ]\n\nvideo/x-raw(memory:VAMemory):\n format: { NV12, BGRA }\n width: [ 16, 16384 ]\n height: [ 16, 16384 ]\nvideo/x-raw:\n format: { NV12, BGRA }\n width: [ 16, 16384 ]\n height: [ 16, 16384 ]\n",
"direction": "sink", "direction": "sink",
"presence": "always" "presence": "always"
}, },
"src": { "src": {
"caps": "image/jpeg:\n width: [ 16, 8192 ]\n height: [ 16, 8192 ]\n", "caps": "image/jpeg:\n width: [ 16, 16384 ]\n height: [ 16, 16384 ]\n",
"direction": "src", "direction": "src",
"presence": "always" "presence": "always"
} }

View file

@ -626,24 +626,14 @@ done:
return ret; return ret;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_av1_enc_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_av1_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = {
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
Resolution max_resolution; GstQsvResolution max_resolution;
mfxExtAV1ResolutionParam resolution_param; mfxExtAV1ResolutionParam resolution_param;
mfxExtAV1BitstreamParam bitstream_param; mfxExtAV1BitstreamParam bitstream_param;
mfxExtBuffer *ext_bufs[2]; mfxExtBuffer *ext_bufs[2];
@ -651,7 +641,7 @@ gst_qsv_av1_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GST_DEBUG_CATEGORY_INIT (gst_qsv_av1_enc_debug, "qsvav1enc", 0, "qsvav1enc"); GST_DEBUG_CATEGORY_INIT (gst_qsv_av1_enc_debug, "qsvav1enc", 0, "qsvav1enc");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
memset (&resolution_param, 0, sizeof (mfxExtAV1ResolutionParam)); memset (&resolution_param, 0, sizeof (mfxExtAV1ResolutionParam));
memset (&bitstream_param, 0, sizeof (mfxExtAV1BitstreamParam)); memset (&bitstream_param, 0, sizeof (mfxExtAV1BitstreamParam));
@ -718,22 +708,22 @@ gst_qsv_av1_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->FrameInfo.Shift = 0; mfx->FrameInfo.Shift = 0;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = mfx->FrameInfo.CropW = mfx->FrameInfo.Width = mfx->FrameInfo.CropW =
GST_ROUND_UP_16 (resolutions_to_check[i].width); GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = mfx->FrameInfo.CropH = mfx->FrameInfo.Height = mfx->FrameInfo.CropH =
GST_ROUND_UP_16 (resolutions_to_check[i].height); GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
resolution_param.FrameWidth = resolutions_to_check[i].width; resolution_param.FrameWidth = gst_qsv_resolutions[i].width;
resolution_param.FrameHeight = resolutions_to_check[i].height; resolution_param.FrameHeight = gst_qsv_resolutions[i].height;
bitstream_param.WriteIVFHeaders = MFX_CODINGOPTION_OFF; bitstream_param.WriteIVFHeaders = MFX_CODINGOPTION_OFF;
if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
GST_INFO ("Maximum supported resolution: %dx%d", GST_INFO ("Maximum supported resolution: %dx%d",

View file

@ -50,7 +50,7 @@ GST_DEBUG_CATEGORY_STATIC (gst_qsv_h264_dec_debug);
#define GST_CAT_DEFAULT gst_qsv_h264_dec_debug #define GST_CAT_DEFAULT gst_qsv_h264_dec_debug
#define DOC_SINK_CAPS \ #define DOC_SINK_CAPS \
"video/x-h264, width = (int) [ 16, 4096 ], height = (int) [ 16, 4096 ], " \ "video/x-h264, width = (int) [ 1, 4096 ], height = (int) [ 1, 4096 ], " \
"stream-format = (string) { byte-stream, avc, avc3 }, " \ "stream-format = (string) { byte-stream, avc, avc3 }, " \
"alignment = (string) au, " \ "alignment = (string) au, " \
"profile = (string) { high, progressive-high, constrained-high, main, " \ "profile = (string) { high, progressive-high, constrained-high, main, " \
@ -58,7 +58,7 @@ GST_DEBUG_CATEGORY_STATIC (gst_qsv_h264_dec_debug);
#define DOC_SRC_CAPS_COMM \ #define DOC_SRC_CAPS_COMM \
"format = (string) NV12, " \ "format = (string) NV12, " \
"width = (int) [ 16, 4096 ], height = (int) [ 16, 4096 ]" "width = (int) [ 1, 4096 ], height = (int) [ 1, 4096 ]"
#define DOC_SRC_CAPS \ #define DOC_SRC_CAPS \
"video/x-raw(memory:D3D11Memory), " DOC_SRC_CAPS_COMM "; " \ "video/x-raw(memory:D3D11Memory), " DOC_SRC_CAPS_COMM "; " \
@ -436,29 +436,19 @@ gst_qsv_h264_dec_process_input (GstQsvDecoder * decoder,
return new_buf; return new_buf;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_h264_dec_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_h264_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = { GstQsvResolution max_resolution;
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
Resolution max_resolution;
GST_DEBUG_CATEGORY_INIT (gst_qsv_h264_dec_debug, GST_DEBUG_CATEGORY_INIT (gst_qsv_h264_dec_debug,
"qsvh264dec", 0, "qsvh264dec"); "qsvh264dec", 0, "qsvh264dec");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
param.AsyncDepth = 4; param.AsyncDepth = 4;
param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY; param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY;
@ -478,17 +468,17 @@ gst_qsv_h264_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->CodecProfile = MFX_PROFILE_AVC_MAIN; mfx->CodecProfile = MFX_PROFILE_AVC_MAIN;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[i].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[i].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.CropH = resolutions_to_check[i].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[i].height;
if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
if (max_resolution.width == 0 || max_resolution.height == 0) if (max_resolution.width == 0 || max_resolution.height == 0)
@ -502,8 +492,8 @@ gst_qsv_h264_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
guint resolution = MAX (max_resolution.width, max_resolution.height); guint resolution = MAX (max_resolution.width, max_resolution.height);
std::string src_caps_str = "video/x-raw, format=(string) NV12"; std::string src_caps_str = "video/x-raw, format=(string) NV12";
src_caps_str += ", width=(int) [ 16, " + std::to_string (resolution) + " ]"; src_caps_str += ", width=(int) [ 1, " + std::to_string (resolution) + " ]";
src_caps_str += ", height=(int) [ 16, " + std::to_string (resolution) + " ]"; src_caps_str += ", height=(int) [ 1, " + std::to_string (resolution) + " ]";
GstCaps *src_caps = gst_caps_from_string (src_caps_str.c_str ()); GstCaps *src_caps = gst_caps_from_string (src_caps_str.c_str ());
@ -518,8 +508,8 @@ gst_qsv_h264_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
#endif #endif
std::string sink_caps_str = "video/x-h264"; std::string sink_caps_str = "video/x-h264";
sink_caps_str += ", width=(int) [ 16, " + std::to_string (resolution) + " ]"; sink_caps_str += ", width=(int) [ 1, " + std::to_string (resolution) + " ]";
sink_caps_str += ", height=(int) [ 16, " + std::to_string (resolution) + " ]"; sink_caps_str += ", height=(int) [ 1, " + std::to_string (resolution) + " ]";
sink_caps_str += ", stream-format=(string) { byte-stream, avc, avc3 }"; sink_caps_str += ", stream-format=(string) { byte-stream, avc, avc3 }";
sink_caps_str += ", alignment=(string) au"; sink_caps_str += ", alignment=(string) au";

View file

@ -1842,12 +1842,6 @@ done:
return ret; return ret;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_h264_enc_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_h264_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
@ -1855,19 +1849,15 @@ gst_qsv_h264_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
mfxStatus status; mfxStatus status;
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = {
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
std::vector < mfxU16 > supported_profiles; std::vector < mfxU16 > supported_profiles;
Resolution max_resolution; GstQsvResolution max_resolution;
bool supports_interlaced = false; bool supports_interlaced = false;
GST_DEBUG_CATEGORY_INIT (gst_qsv_h264_enc_debug, GST_DEBUG_CATEGORY_INIT (gst_qsv_h264_enc_debug,
"qsvh264enc", 0, "qsvh264enc"); "qsvh264enc", 0, "qsvh264enc");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
param.AsyncDepth = 4; param.AsyncDepth = 4;
param.IOPattern = MFX_IOPATTERN_IN_VIDEO_MEMORY; param.IOPattern = MFX_IOPATTERN_IN_VIDEO_MEMORY;
@ -1907,17 +1897,17 @@ gst_qsv_h264_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->CodecProfile = supported_profiles[0]; mfx->CodecProfile = supported_profiles[0];
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[i].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[i].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.CropH = resolutions_to_check[i].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[i].height;
if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
GST_INFO ("Maximum supported resolution: %dx%d", GST_INFO ("Maximum supported resolution: %dx%d",

View file

@ -51,13 +51,13 @@ GST_DEBUG_CATEGORY_STATIC (gst_qsv_h265_dec_debug);
#define GST_CAT_DEFAULT gst_qsv_h265_dec_debug #define GST_CAT_DEFAULT gst_qsv_h265_dec_debug
#define DOC_SINK_CAPS \ #define DOC_SINK_CAPS \
"video/x-h265, width = (int) [ 16, 8192 ], height = (int) [ 16, 8192 ], " \ "video/x-h265, width = (int) [ 1, 16384 ], height = (int) [ 1, 16384 ], " \
"stream-format = (string) { byte-stream, hev1, hvc1 }, " \ "stream-format = (string) { byte-stream, hev1, hvc1 }, " \
"alignment = (string) au, profile = (string) { main, main-10 }" "alignment = (string) au, profile = (string) { main, main-10 }"
#define DOC_SRC_CAPS_COMM \ #define DOC_SRC_CAPS_COMM \
"format = (string) NV12, " \ "format = (string) NV12, " \
"width = (int) [ 16, 8192 ], height = (int) [ 16, 8192 ]" "width = (int) [ 1, 16384 ], height = (int) [ 1, 16384 ]"
#define DOC_SRC_CAPS \ #define DOC_SRC_CAPS \
"video/x-raw(memory:D3D11Memory), " DOC_SRC_CAPS_COMM "; " \ "video/x-raw(memory:D3D11Memory), " DOC_SRC_CAPS_COMM "; " \
@ -477,23 +477,13 @@ gst_qsv_h265_dec_process_input (GstQsvDecoder * decoder,
return new_buf; return new_buf;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = { GstQsvResolution max_resolution;
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
Resolution max_resolution;
std::vector < std::string > supported_profiles; std::vector < std::string > supported_profiles;
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
@ -501,7 +491,7 @@ gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
"qsvh265dec", 0, "qsvh265dec"); "qsvh265dec", 0, "qsvh265dec");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
param.AsyncDepth = 4; param.AsyncDepth = 4;
param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY; param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY;
@ -521,17 +511,17 @@ gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->CodecProfile = MFX_PROFILE_HEVC_MAIN; mfx->CodecProfile = MFX_PROFILE_HEVC_MAIN;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[i].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[i].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.CropH = resolutions_to_check[i].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[i].height;
if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
if (max_resolution.width == 0 || max_resolution.height == 0) if (max_resolution.width == 0 || max_resolution.height == 0)
@ -552,10 +542,10 @@ gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->FrameInfo.Shift = 1; mfx->FrameInfo.Shift = 1;
mfx->FrameInfo.PicStruct = MFX_PICSTRUCT_PROGRESSIVE; mfx->FrameInfo.PicStruct = MFX_PICSTRUCT_PROGRESSIVE;
mfx->CodecProfile = MFX_PROFILE_HEVC_MAIN10; mfx->CodecProfile = MFX_PROFILE_HEVC_MAIN10;
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[0].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[0].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[0].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[0].height);
mfx->FrameInfo.CropW = resolutions_to_check[0].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[0].width;
mfx->FrameInfo.CropH = resolutions_to_check[0].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[0].height;
if (MFXVideoDECODE_Query (session, &param, &param) == MFX_ERR_NONE) { if (MFXVideoDECODE_Query (session, &param, &param) == MFX_ERR_NONE) {
supported_profiles.push_back ("main-10"); supported_profiles.push_back ("main-10");
supported_formats.push_back ("P010_10LE"); supported_formats.push_back ("P010_10LE");
@ -566,8 +556,8 @@ gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
guint resolution = MAX (max_resolution.width, max_resolution.height); guint resolution = MAX (max_resolution.width, max_resolution.height);
std::string src_caps_str = "video/x-raw"; std::string src_caps_str = "video/x-raw";
src_caps_str += ", width=(int) [ 16, " + std::to_string (resolution) + " ]"; src_caps_str += ", width=(int) [ 1, " + std::to_string (resolution) + " ]";
src_caps_str += ", height=(int) [ 16, " + std::to_string (resolution) + " ]"; src_caps_str += ", height=(int) [ 1, " + std::to_string (resolution) + " ]";
/* *INDENT-OFF* */ /* *INDENT-OFF* */
if (supported_formats.size () > 1) { if (supported_formats.size () > 1) {
@ -600,8 +590,8 @@ gst_qsv_h265_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
#endif #endif
std::string sink_caps_str = "video/x-h265"; std::string sink_caps_str = "video/x-h265";
sink_caps_str += ", width=(int) [ 16, " + std::to_string (resolution) + " ]"; sink_caps_str += ", width=(int) [ 1, " + std::to_string (resolution) + " ]";
sink_caps_str += ", height=(int) [ 16, " + std::to_string (resolution) + " ]"; sink_caps_str += ", height=(int) [ 1, " + std::to_string (resolution) + " ]";
sink_caps_str += ", stream-format=(string) { byte-stream, hev1, hvc1 }"; sink_caps_str += ", stream-format=(string) { byte-stream, hev1, hvc1 }";
sink_caps_str += ", alignment=(string) au"; sink_caps_str += ", alignment=(string) au";

View file

@ -1424,25 +1424,15 @@ done:
return ret; return ret;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_h265_enc_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_h265_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = {
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
std::vector < mfxU16 > supported_profiles; std::vector < mfxU16 > supported_profiles;
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
Resolution max_resolution; GstQsvResolution max_resolution;
mfxExtContentLightLevelInfo cll; mfxExtContentLightLevelInfo cll;
mfxExtMasteringDisplayColourVolume mdcv; mfxExtMasteringDisplayColourVolume mdcv;
mfxExtBuffer *ext_buffers[2]; mfxExtBuffer *ext_buffers[2];
@ -1452,7 +1442,7 @@ gst_qsv_h265_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
"qsvh265enc", 0, "qsvh265enc"); "qsvh265enc", 0, "qsvh265enc");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
memset (&cll, 0, sizeof (mfxExtContentLightLevelInfo)); memset (&cll, 0, sizeof (mfxExtContentLightLevelInfo));
memset (&mdcv, 0, sizeof (mfxExtMasteringDisplayColourVolume)); memset (&mdcv, 0, sizeof (mfxExtMasteringDisplayColourVolume));
@ -1543,17 +1533,17 @@ gst_qsv_h265_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
param.ExtParam = nullptr; param.ExtParam = nullptr;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[i].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[i].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.CropH = resolutions_to_check[i].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[i].height;
if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
GST_INFO ("Maximum supported resolution: %dx%d", GST_INFO ("Maximum supported resolution: %dx%d",

View file

@ -60,7 +60,7 @@ enum
#define DOC_SINK_CAPS_COMM \ #define DOC_SINK_CAPS_COMM \
"format = (string) { NV12, BGRA }, " \ "format = (string) { NV12, BGRA }, " \
"width = (int) [ 16, 8192 ], height = (int) [ 16, 8192 ]" "width = (int) [ 16, 16384 ], height = (int) [ 16, 16384 ]"
#define DOC_SINK_CAPS \ #define DOC_SINK_CAPS \
"video/x-raw(memory:D3D11Memory), " DOC_SINK_CAPS_COMM "; " \ "video/x-raw(memory:D3D11Memory), " DOC_SINK_CAPS_COMM "; " \
@ -68,7 +68,7 @@ enum
"video/x-raw, " DOC_SINK_CAPS_COMM "video/x-raw, " DOC_SINK_CAPS_COMM
#define DOC_SRC_CAPS \ #define DOC_SRC_CAPS \
"image/jpeg, width = (int) [ 16, 8192 ], height = (int) [ 16, 8192 ]" "image/jpeg, width = (int) [ 16, 16384 ], height = (int) [ 16, 16384 ]"
typedef struct _GstQsvJpegEncClassData typedef struct _GstQsvJpegEncClassData
{ {
@ -359,24 +359,14 @@ gst_qsv_jpeg_enc_check_reconfigure (GstQsvEncoder * encoder, mfxSession session,
return ret; return ret;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_jpeg_enc_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_jpeg_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = {
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
Resolution max_resolution; GstQsvResolution max_resolution;
mfxStatus status; mfxStatus status;
gboolean interlaved = TRUE; gboolean interlaved = TRUE;
@ -384,7 +374,7 @@ gst_qsv_jpeg_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
"qsvjpegenc", 0, "qsvjpegenc"); "qsvjpegenc", 0, "qsvjpegenc");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
param.AsyncDepth = 4; param.AsyncDepth = 4;
param.IOPattern = MFX_IOPATTERN_IN_VIDEO_MEMORY; param.IOPattern = MFX_IOPATTERN_IN_VIDEO_MEMORY;
@ -433,16 +423,16 @@ gst_qsv_jpeg_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->FrameInfo.FourCC = MFX_FOURCC_NV12; mfx->FrameInfo.FourCC = MFX_FOURCC_NV12;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.Width = mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.Height = mfx->FrameInfo.CropH = mfx->FrameInfo.Height = mfx->FrameInfo.CropH =
resolutions_to_check[i].height; gst_qsv_resolutions[i].height;
if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
GST_INFO ("Maximum supported resolution: %dx%d", GST_INFO ("Maximum supported resolution: %dx%d",

View file

@ -64,4 +64,15 @@ gst_qsv_timestamp_from_gst (GstClockTime timestamp)
return gst_util_uint64_scale (timestamp, 90000, GST_SECOND); return gst_util_uint64_scale (timestamp, 90000, GST_SECOND);
} }
typedef struct _GstQsvResolution
{
guint width;
guint height;
} GstQsvResolution;
static const GstQsvResolution gst_qsv_resolutions[] = {
{1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}, {15360, 8640}, {16384, 8640}
};
G_END_DECLS G_END_DECLS

View file

@ -133,23 +133,13 @@ gst_qsv_vp9_dec_init (GstQsvVP9Dec * self)
{ {
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_vp9_dec_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_vp9_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = { GstQsvResolution max_resolution;
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}, {15360, 8640}, {16384, 8640}
};
Resolution max_resolution;
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
gboolean have_profile_2 = FALSE; gboolean have_profile_2 = FALSE;
gboolean have_profile_2_12bits = FALSE; gboolean have_profile_2_12bits = FALSE;
@ -157,7 +147,7 @@ gst_qsv_vp9_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
GST_DEBUG_CATEGORY_INIT (gst_qsv_vp9_dec_debug, "qsvvp9dec", 0, "qsvvp9dec"); GST_DEBUG_CATEGORY_INIT (gst_qsv_vp9_dec_debug, "qsvvp9dec", 0, "qsvvp9dec");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
param.AsyncDepth = 4; param.AsyncDepth = 4;
param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY; param.IOPattern = MFX_IOPATTERN_OUT_VIDEO_MEMORY;
@ -177,17 +167,17 @@ gst_qsv_vp9_dec_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->CodecProfile = MFX_PROFILE_VP9_0; mfx->CodecProfile = MFX_PROFILE_VP9_0;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = GST_ROUND_UP_16 (resolutions_to_check[i].width); mfx->FrameInfo.Width = GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = GST_ROUND_UP_16 (resolutions_to_check[i].height); mfx->FrameInfo.Height = GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
mfx->FrameInfo.CropW = resolutions_to_check[i].width; mfx->FrameInfo.CropW = gst_qsv_resolutions[i].width;
mfx->FrameInfo.CropH = resolutions_to_check[i].height; mfx->FrameInfo.CropH = gst_qsv_resolutions[i].height;
if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoDECODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
if (max_resolution.width == 0 || max_resolution.height == 0) if (max_resolution.width == 0 || max_resolution.height == 0)

View file

@ -835,32 +835,22 @@ done:
return ret; return ret;
} }
typedef struct
{
guint width;
guint height;
} Resolution;
void void
gst_qsv_vp9_enc_register (GstPlugin * plugin, guint rank, guint impl_index, gst_qsv_vp9_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
GstObject * device, mfxSession session) GstObject * device, mfxSession session)
{ {
mfxVideoParam param; mfxVideoParam param;
mfxInfoMFX *mfx; mfxInfoMFX *mfx;
static const Resolution resolutions_to_check[] = {
{1280, 720}, {1920, 1088}, {2560, 1440}, {3840, 2160}, {4096, 2160},
{7680, 4320}, {8192, 4320}
};
std::vector < mfxU16 > supported_profiles; std::vector < mfxU16 > supported_profiles;
std::vector < std::string > supported_formats; std::vector < std::string > supported_formats;
Resolution max_resolution; GstQsvResolution max_resolution;
mfxExtVP9Param vp9_param; mfxExtVP9Param vp9_param;
mfxExtBuffer *ext_bufs[1]; mfxExtBuffer *ext_bufs[1];
GST_DEBUG_CATEGORY_INIT (gst_qsv_vp9_enc_debug, "qsvvp9enc", 0, "qsvvp9enc"); GST_DEBUG_CATEGORY_INIT (gst_qsv_vp9_enc_debug, "qsvvp9enc", 0, "qsvvp9enc");
memset (&param, 0, sizeof (mfxVideoParam)); memset (&param, 0, sizeof (mfxVideoParam));
memset (&max_resolution, 0, sizeof (Resolution)); memset (&max_resolution, 0, sizeof (GstQsvResolution));
ext_bufs[0] = (mfxExtBuffer *) & vp9_param; ext_bufs[0] = (mfxExtBuffer *) & vp9_param;
@ -945,24 +935,24 @@ gst_qsv_vp9_enc_register (GstPlugin * plugin, guint rank, guint impl_index,
mfx->FrameInfo.Shift = 0; mfx->FrameInfo.Shift = 0;
/* Check max-resolution */ /* Check max-resolution */
for (guint i = 0; i < G_N_ELEMENTS (resolutions_to_check); i++) { for (guint i = 0; i < G_N_ELEMENTS (gst_qsv_resolutions); i++) {
mfx->FrameInfo.Width = mfx->FrameInfo.CropW = mfx->FrameInfo.Width = mfx->FrameInfo.CropW =
GST_ROUND_UP_16 (resolutions_to_check[i].width); GST_ROUND_UP_16 (gst_qsv_resolutions[i].width);
mfx->FrameInfo.Height = mfx->FrameInfo.CropH = mfx->FrameInfo.Height = mfx->FrameInfo.CropH =
GST_ROUND_UP_16 (resolutions_to_check[i].height); GST_ROUND_UP_16 (gst_qsv_resolutions[i].height);
gst_qsv_vp9_enc_init_vp9_param (&vp9_param); gst_qsv_vp9_enc_init_vp9_param (&vp9_param);
vp9_param.FrameWidth = resolutions_to_check[i].width; vp9_param.FrameWidth = gst_qsv_resolutions[i].width;
vp9_param.FrameHeight = resolutions_to_check[i].height; vp9_param.FrameHeight = gst_qsv_resolutions[i].height;
vp9_param.WriteIVFHeaders = MFX_CODINGOPTION_OFF; vp9_param.WriteIVFHeaders = MFX_CODINGOPTION_OFF;
if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE) if (MFXVideoENCODE_Query (session, &param, &param) != MFX_ERR_NONE)
break; break;
max_resolution.width = resolutions_to_check[i].width; max_resolution.width = gst_qsv_resolutions[i].width;
max_resolution.height = resolutions_to_check[i].height; max_resolution.height = gst_qsv_resolutions[i].height;
} }
GST_INFO ("Maximum supported resolution: %dx%d", GST_INFO ("Maximum supported resolution: %dx%d",