Commit 621450e7 authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '48183b3a'

* commit '48183b3a':
  rtpdec_h264: Generalize parse_sprop_parameter_sets
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents 9b41bf5c 48183b3a
...@@ -93,7 +93,7 @@ static void parse_profile_level_id(AVFormatContext *s, ...@@ -93,7 +93,7 @@ static void parse_profile_level_id(AVFormatContext *s,
} }
static int parse_sprop_parameter_sets(AVFormatContext *s, static int parse_sprop_parameter_sets(AVFormatContext *s,
AVCodecContext *codec, uint8_t **data_ptr, int *size_ptr,
const char *value) const char *value)
{ {
char base64packet[1024]; char base64packet[1024];
...@@ -115,31 +115,28 @@ static int parse_sprop_parameter_sets(AVFormatContext *s, ...@@ -115,31 +115,28 @@ static int parse_sprop_parameter_sets(AVFormatContext *s,
packet_size = av_base64_decode(decoded_packet, base64packet, packet_size = av_base64_decode(decoded_packet, base64packet,
sizeof(decoded_packet)); sizeof(decoded_packet));
if (packet_size > 0) { if (packet_size > 0) {
uint8_t *dest = av_realloc(codec->extradata, uint8_t *dest = av_realloc(*data_ptr,
packet_size + sizeof(start_sequence) + packet_size + sizeof(start_sequence) +
codec->extradata_size + *size_ptr +
FF_INPUT_BUFFER_PADDING_SIZE); FF_INPUT_BUFFER_PADDING_SIZE);
if (!dest) { if (!dest) {
av_log(s, AV_LOG_ERROR, av_log(s, AV_LOG_ERROR,
"Unable to allocate memory for extradata!\n"); "Unable to allocate memory for extradata!\n");
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
} }
codec->extradata = dest; *data_ptr = dest;
memcpy(dest + codec->extradata_size, start_sequence, memcpy(dest + *size_ptr, start_sequence,
sizeof(start_sequence)); sizeof(start_sequence));
memcpy(dest + codec->extradata_size + sizeof(start_sequence), memcpy(dest + *size_ptr + sizeof(start_sequence),
decoded_packet, packet_size); decoded_packet, packet_size);
memset(dest + codec->extradata_size + sizeof(start_sequence) + memset(dest + *size_ptr + sizeof(start_sequence) +
packet_size, 0, FF_INPUT_BUFFER_PADDING_SIZE); packet_size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
codec->extradata_size += sizeof(start_sequence) + packet_size; *size_ptr += sizeof(start_sequence) + packet_size;
} }
} }
av_log(s, AV_LOG_DEBUG, "Extradata set to %p (size: %d)\n",
codec->extradata, codec->extradata_size);
return 0; return 0;
} }
...@@ -167,9 +164,14 @@ static int sdp_parse_fmtp_config_h264(AVFormatContext *s, ...@@ -167,9 +164,14 @@ static int sdp_parse_fmtp_config_h264(AVFormatContext *s,
if (strlen(value) == 6) if (strlen(value) == 6)
parse_profile_level_id(s, h264_data, value); parse_profile_level_id(s, h264_data, value);
} else if (!strcmp(attr, "sprop-parameter-sets")) { } else if (!strcmp(attr, "sprop-parameter-sets")) {
int ret;
codec->extradata_size = 0; codec->extradata_size = 0;
av_freep(&codec->extradata); av_freep(&codec->extradata);
return parse_sprop_parameter_sets(s, codec, value); ret = parse_sprop_parameter_sets(s, &codec->extradata,
&codec->extradata_size, value);
av_log(s, AV_LOG_DEBUG, "Extradata set to %p (size: %d)\n",
codec->extradata, codec->extradata_size);
return ret;
} }
return 0; return 0;
} }
......
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