mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 15:08:48 +00:00
h26xparse: bypass check for length_size_minus_one
fix playback fail, when some file with length_size_minus_one == 2 According to the spec 2 cannot be a valid value, so that stream has a bad config record. but breaking the decoding because of that, perhaps is too much. and ffmpeg seem not check this Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7358>
This commit is contained in:
parent
85b4fbf40b
commit
86c6a43a7c
3 changed files with 5 additions and 7 deletions
|
@ -3781,8 +3781,6 @@ gst_h264_parser_parse_decoder_config_record (GstH264NalParser * nalparser,
|
|||
if (ret->length_size_minus_one == 2) {
|
||||
/* "length_size_minus_one + 1" should be 1, 2, or 4 */
|
||||
GST_WARNING ("Wrong nal-length-size");
|
||||
result = GST_H264_PARSER_ERROR;
|
||||
goto error;
|
||||
}
|
||||
|
||||
/* reserved 3bits */
|
||||
|
|
|
@ -5093,8 +5093,6 @@ gst_h265_parser_parse_decoder_config_record (GstH265Parser * parser,
|
|||
if (ret->length_size_minus_one == 2) {
|
||||
/* "length_size_minus_one + 1" should be 1, 2, or 4 */
|
||||
GST_WARNING ("Wrong nal-length-size");
|
||||
result = GST_H265_PARSER_ERROR;
|
||||
goto error;
|
||||
}
|
||||
|
||||
READ_CONFIG_UINT8 (num_of_arrays, 8);
|
||||
|
|
|
@ -845,12 +845,14 @@ GST_START_TEST (test_h264_decoder_config_record)
|
|||
assert_equals_int (ret, GST_H264_PARSER_ERROR);
|
||||
fail_unless (config == NULL);
|
||||
|
||||
/* wrong length size, return error with null config data */
|
||||
/* wrong length size, since we still try to use it. so return ok */
|
||||
ret = gst_h264_parser_parse_decoder_config_record (parser,
|
||||
h264_wrong_length_size_codec_data,
|
||||
sizeof (h264_wrong_length_size_codec_data), &config);
|
||||
assert_equals_int (ret, GST_H264_PARSER_ERROR);
|
||||
fail_unless (config == NULL);
|
||||
assert_equals_int (ret, GST_H264_PARSER_OK);
|
||||
fail_unless (config != NULL);
|
||||
assert_equals_int (config->length_size_minus_one, 2);
|
||||
g_clear_pointer (&config, gst_h264_decoder_config_record_free);
|
||||
|
||||
gst_h264_nal_parser_free (parser);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue