Merge commit 'e4529df944616917ae8462f5102253ff7f983093'
* commit 'e4529df944616917ae8462f5102253ff7f983093': flvdec: K&R formatting cosmetics Conflicts: libavformat/flvdec.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
		
						commit
						ae48547a52
					
				| @ -61,7 +61,11 @@ static int flv_probe(AVProbeData *p) | ||||
|     const uint8_t *d; | ||||
| 
 | ||||
|     d = p->buf; | ||||
|     if (d[0] == 'F' && d[1] == 'L' && d[2] == 'V' && d[3] < 5 && d[5]==0 && AV_RB32(d+5)>8) { | ||||
|     if (d[0] == 'F' && | ||||
|         d[1] == 'L' && | ||||
|         d[2] == 'V' && | ||||
|         d[3] < 5 && d[5] == 0 && | ||||
|         AV_RB32(d + 5) > 8) { | ||||
|         return AVPROBE_SCORE_MAX; | ||||
|     } | ||||
|     return 0; | ||||
| @ -81,6 +85,7 @@ static AVStream *create_stream(AVFormatContext *s, int codec_type) | ||||
|     avpriv_set_pts_info(st, 32, 1, 1000); /* 32 bit pts in ms */ | ||||
|     return st; | ||||
| } | ||||
| 
 | ||||
| static int flv_same_audio_codec(AVCodecContext *acodec, int flags) | ||||
| { | ||||
|     int bits_per_coded_sample = (flags & FLV_AUDIO_SAMPLESIZE_MASK) ? 16 : 8; | ||||
| @ -96,15 +101,18 @@ static int flv_same_audio_codec(AVCodecContext *acodec, int flags) | ||||
|     switch (flv_codecid) { | ||||
|     // no distinction between S16 and S8 PCM codec flags
 | ||||
|     case FLV_CODECID_PCM: | ||||
|         codec_id = bits_per_coded_sample == 8 ? AV_CODEC_ID_PCM_U8 : | ||||
|         codec_id = bits_per_coded_sample == 8 | ||||
|                    ? AV_CODEC_ID_PCM_U8 | ||||
| #if HAVE_BIGENDIAN | ||||
|                             AV_CODEC_ID_PCM_S16BE; | ||||
|                    : AV_CODEC_ID_PCM_S16BE; | ||||
| #else | ||||
|                             AV_CODEC_ID_PCM_S16LE; | ||||
|                    : AV_CODEC_ID_PCM_S16LE; | ||||
| #endif | ||||
|         return codec_id == acodec->codec_id; | ||||
|     case FLV_CODECID_PCM_LE: | ||||
|         codec_id = bits_per_coded_sample == 8 ? AV_CODEC_ID_PCM_U8 : AV_CODEC_ID_PCM_S16LE; | ||||
|         codec_id = bits_per_coded_sample == 8 | ||||
|                    ? AV_CODEC_ID_PCM_U8 | ||||
|                    : AV_CODEC_ID_PCM_S16LE; | ||||
|         return codec_id == acodec->codec_id; | ||||
|     case FLV_CODECID_AAC: | ||||
|         return acodec->codec_id == AV_CODEC_ID_AAC; | ||||
| @ -129,28 +137,42 @@ static int flv_same_audio_codec(AVCodecContext *acodec, int flags) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static void flv_set_audio_codec(AVFormatContext *s, AVStream *astream, AVCodecContext *acodec, int flv_codecid) { | ||||
| static void flv_set_audio_codec(AVFormatContext *s, AVStream *astream, | ||||
|                                 AVCodecContext *acodec, int flv_codecid) | ||||
| { | ||||
|     switch (flv_codecid) { | ||||
|     // no distinction between S16 and S8 PCM codec flags
 | ||||
|     case FLV_CODECID_PCM: | ||||
|             acodec->codec_id = acodec->bits_per_coded_sample == 8 ? AV_CODEC_ID_PCM_U8 : | ||||
|         acodec->codec_id = acodec->bits_per_coded_sample == 8 | ||||
|                            ? AV_CODEC_ID_PCM_U8 | ||||
| #if HAVE_BIGENDIAN | ||||
|                                 AV_CODEC_ID_PCM_S16BE; | ||||
|                            : AV_CODEC_ID_PCM_S16BE; | ||||
| #else | ||||
|                                 AV_CODEC_ID_PCM_S16LE; | ||||
|                            : AV_CODEC_ID_PCM_S16LE; | ||||
| #endif | ||||
|         break; | ||||
|     case FLV_CODECID_PCM_LE: | ||||
|             acodec->codec_id = acodec->bits_per_coded_sample == 8 ? AV_CODEC_ID_PCM_U8 : AV_CODEC_ID_PCM_S16LE; break; | ||||
|         case FLV_CODECID_AAC  : acodec->codec_id = AV_CODEC_ID_AAC;                                    break; | ||||
|         case FLV_CODECID_ADPCM: acodec->codec_id = AV_CODEC_ID_ADPCM_SWF;                              break; | ||||
|         acodec->codec_id = acodec->bits_per_coded_sample == 8 | ||||
|                            ? AV_CODEC_ID_PCM_U8 | ||||
|                            : AV_CODEC_ID_PCM_S16LE; | ||||
|         break; | ||||
|     case FLV_CODECID_AAC: | ||||
|         acodec->codec_id = AV_CODEC_ID_AAC; | ||||
|         break; | ||||
|     case FLV_CODECID_ADPCM: | ||||
|         acodec->codec_id = AV_CODEC_ID_ADPCM_SWF; | ||||
|         break; | ||||
|     case FLV_CODECID_SPEEX: | ||||
|         acodec->codec_id    = AV_CODEC_ID_SPEEX; | ||||
|         acodec->sample_rate = 16000; | ||||
|         break; | ||||
|         case FLV_CODECID_MP3  : acodec->codec_id = AV_CODEC_ID_MP3      ; astream->need_parsing = AVSTREAM_PARSE_FULL; break; | ||||
|     case FLV_CODECID_MP3: | ||||
|         acodec->codec_id      = AV_CODEC_ID_MP3; | ||||
|         astream->need_parsing = AVSTREAM_PARSE_FULL; | ||||
|         break; | ||||
|     case FLV_CODECID_NELLYMOSER_8KHZ_MONO: | ||||
|             acodec->sample_rate = 8000; //in case metadata does not otherwise declare samplerate
 | ||||
|         // in case metadata does not otherwise declare samplerate
 | ||||
|         acodec->sample_rate = 8000; | ||||
|         acodec->codec_id    = AV_CODEC_ID_NELLYMOSER; | ||||
|         break; | ||||
|     case FLV_CODECID_NELLYMOSER_16KHZ_MONO: | ||||
| @ -169,7 +191,8 @@ static void flv_set_audio_codec(AVFormatContext *s, AVStream *astream, AVCodecCo | ||||
|         acodec->codec_id    = AV_CODEC_ID_PCM_ALAW; | ||||
|         break; | ||||
|     default: | ||||
|             av_log(s, AV_LOG_INFO, "Unsupported audio codec (%x)\n", flv_codecid >> FLV_AUDIO_CODECID_OFFSET); | ||||
|         av_log(s, AV_LOG_INFO, "Unsupported audio codec (%x)\n", | ||||
|                flv_codecid >> FLV_AUDIO_CODECID_OFFSET); | ||||
|         acodec->codec_tag = flv_codecid >> FLV_AUDIO_CODECID_OFFSET; | ||||
|     } | ||||
| } | ||||
| @ -199,14 +222,25 @@ static int flv_same_video_codec(AVCodecContext *vcodec, int flags) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static int flv_set_video_codec(AVFormatContext *s, AVStream *vstream, int flv_codecid, int read) { | ||||
| static int flv_set_video_codec(AVFormatContext *s, AVStream *vstream, | ||||
|                                int flv_codecid, int read) | ||||
| { | ||||
|     AVCodecContext *vcodec = vstream->codec; | ||||
|     switch (flv_codecid) { | ||||
|         case FLV_CODECID_H263  : vcodec->codec_id = AV_CODEC_ID_FLV1   ; break; | ||||
|         case FLV_CODECID_REALH263: vcodec->codec_id = AV_CODEC_ID_H263 ; break; // Really mean it this time
 | ||||
|         case FLV_CODECID_SCREEN: vcodec->codec_id = AV_CODEC_ID_FLASHSV; break; | ||||
|         case FLV_CODECID_SCREEN2: vcodec->codec_id = AV_CODEC_ID_FLASHSV2; break; | ||||
|         case FLV_CODECID_VP6   : vcodec->codec_id = AV_CODEC_ID_VP6F   ; | ||||
|     case FLV_CODECID_H263: | ||||
|         vcodec->codec_id = AV_CODEC_ID_FLV1; | ||||
|         break; | ||||
|     case FLV_CODECID_REALH263: | ||||
|         vcodec->codec_id = AV_CODEC_ID_H263; | ||||
|         break; // Really mean it this time
 | ||||
|     case FLV_CODECID_SCREEN: | ||||
|         vcodec->codec_id = AV_CODEC_ID_FLASHSV; | ||||
|         break; | ||||
|     case FLV_CODECID_SCREEN2: | ||||
|         vcodec->codec_id = AV_CODEC_ID_FLASHSV2; | ||||
|         break; | ||||
|     case FLV_CODECID_VP6: | ||||
|         vcodec->codec_id = AV_CODEC_ID_VP6F; | ||||
|     case FLV_CODECID_VP6A: | ||||
|         if (flv_codecid == FLV_CODECID_VP6A) | ||||
|             vcodec->codec_id = AV_CODEC_ID_VP6A; | ||||
| @ -236,7 +270,8 @@ static int flv_set_video_codec(AVFormatContext *s, AVStream *vstream, int flv_co | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| static int amf_get_string(AVIOContext *ioc, char *buffer, int buffsize) { | ||||
| static int amf_get_string(AVIOContext *ioc, char *buffer, int buffsize) | ||||
| { | ||||
|     int length = avio_rb16(ioc); | ||||
|     if (length >= buffsize) { | ||||
|         avio_skip(ioc, length); | ||||
| @ -250,7 +285,9 @@ static int amf_get_string(AVIOContext *ioc, char *buffer, int buffsize) { | ||||
|     return length; | ||||
| } | ||||
| 
 | ||||
| static int parse_keyframes_index(AVFormatContext *s, AVIOContext *ioc, AVStream *vstream, int64_t max_pos) { | ||||
| static int parse_keyframes_index(AVFormatContext *s, AVIOContext *ioc, | ||||
|                                  AVStream *vstream, int64_t max_pos) | ||||
| { | ||||
|     FLVContext *flv       = s->priv_data; | ||||
|     unsigned int timeslen = 0, fileposlen = 0, i; | ||||
|     char str_val[256]; | ||||
| @ -267,7 +304,8 @@ static int parse_keyframes_index(AVFormatContext *s, AVIOContext *ioc, AVStream | ||||
|     if (s->flags & AVFMT_FLAG_IGNIDX) | ||||
|         return 0; | ||||
| 
 | ||||
|     while (avio_tell(ioc) < max_pos - 2 && amf_get_string(ioc, str_val, sizeof(str_val)) > 0) { | ||||
|     while (avio_tell(ioc) < max_pos - 2 && | ||||
|            amf_get_string(ioc, str_val, sizeof(str_val)) > 0) { | ||||
|         int64_t **current_array; | ||||
|         unsigned int arraylen; | ||||
| 
 | ||||
| @ -282,10 +320,13 @@ static int parse_keyframes_index(AVFormatContext *s, AVIOContext *ioc, AVStream | ||||
|         if       (!strcmp(KEYFRAMES_TIMESTAMP_TAG , str_val) && !times) { | ||||
|             current_array = × | ||||
|             timeslen      = arraylen; | ||||
|         }else if (!strcmp(KEYFRAMES_BYTEOFFSET_TAG, str_val) && !filepositions){ | ||||
|         } else if (!strcmp(KEYFRAMES_BYTEOFFSET_TAG, str_val) && | ||||
|                    !filepositions) { | ||||
|             current_array = &filepositions; | ||||
|             fileposlen    = arraylen; | ||||
|         }else // unexpected metatag inside keyframes, will not use such metadata for indexing
 | ||||
|         } else | ||||
|             // unexpected metatag inside keyframes, will not use such
 | ||||
|             // metadata for indexing
 | ||||
|             break; | ||||
| 
 | ||||
|         if (!(*current_array = av_mallocz(sizeof(**current_array) * arraylen))) { | ||||
| @ -328,7 +369,10 @@ finish: | ||||
|     return ret; | ||||
| } | ||||
| 
 | ||||
| static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vstream, const char *key, int64_t max_pos, int depth) { | ||||
| static int amf_parse_object(AVFormatContext *s, AVStream *astream, | ||||
|                             AVStream *vstream, const char *key, | ||||
|                             int64_t max_pos, int depth) | ||||
| { | ||||
|     AVCodecContext *acodec, *vcodec; | ||||
|     FLVContext *flv = s->priv_data; | ||||
|     AVIOContext *ioc; | ||||
| @ -338,28 +382,32 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
| 
 | ||||
|     num_val  = 0; | ||||
|     ioc      = s->pb; | ||||
| 
 | ||||
|     amf_type = avio_r8(ioc); | ||||
| 
 | ||||
|     switch (amf_type) { | ||||
|     case AMF_DATA_TYPE_NUMBER: | ||||
|             num_val = av_int2double(avio_rb64(ioc)); break; | ||||
|         num_val = av_int2double(avio_rb64(ioc)); | ||||
|         break; | ||||
|     case AMF_DATA_TYPE_BOOL: | ||||
|             num_val = avio_r8(ioc); break; | ||||
|         num_val = avio_r8(ioc); | ||||
|         break; | ||||
|     case AMF_DATA_TYPE_STRING: | ||||
|         if (amf_get_string(ioc, str_val, sizeof(str_val)) < 0) | ||||
|             return -1; | ||||
|         break; | ||||
|     case AMF_DATA_TYPE_OBJECT: | ||||
|             if ((vstream || astream) && ioc->seekable && key && !strcmp(KEYFRAMES_TAG, key) && depth == 1) | ||||
|         if ((vstream || astream) && key && | ||||
|             ioc->seekable && | ||||
|             !strcmp(KEYFRAMES_TAG, key) && depth == 1) | ||||
|             if (parse_keyframes_index(s, ioc, vstream ? vstream : astream, | ||||
|                                       max_pos) < 0) | ||||
|                 av_log(s, AV_LOG_ERROR, "Keyframe index parsing failed\n"); | ||||
| 
 | ||||
|             while (avio_tell(ioc) < max_pos - 2 && amf_get_string(ioc, str_val, sizeof(str_val)) > 0) { | ||||
|                 if (amf_parse_object(s, astream, vstream, str_val, max_pos, depth + 1) < 0) | ||||
|         while (avio_tell(ioc) < max_pos - 2 && | ||||
|                amf_get_string(ioc, str_val, sizeof(str_val)) > 0) | ||||
|             if (amf_parse_object(s, astream, vstream, str_val, max_pos, | ||||
|                                  depth + 1) < 0) | ||||
|                 return -1;     // if we couldn't skip, bomb out.
 | ||||
|             } | ||||
|         if (avio_r8(ioc) != AMF_END_OF_OBJECT) | ||||
|             return -1; | ||||
|         break; | ||||
| @ -369,23 +417,26 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|         break;     // these take up no additional space
 | ||||
|     case AMF_DATA_TYPE_MIXEDARRAY: | ||||
|         avio_skip(ioc, 4);     // skip 32-bit max array index
 | ||||
|             while(avio_tell(ioc) < max_pos - 2 && amf_get_string(ioc, str_val, sizeof(str_val)) > 0) { | ||||
|                 //this is the only case in which we would want a nested parse to not skip over the object
 | ||||
|                 if(amf_parse_object(s, astream, vstream, str_val, max_pos, depth + 1) < 0) | ||||
|         while (avio_tell(ioc) < max_pos - 2 && | ||||
|                amf_get_string(ioc, str_val, sizeof(str_val)) > 0) | ||||
|             // this is the only case in which we would want a nested
 | ||||
|             // parse to not skip over the object
 | ||||
|             if (amf_parse_object(s, astream, vstream, str_val, max_pos, | ||||
|                                  depth + 1) < 0) | ||||
|                 return -1; | ||||
|             } | ||||
|         if (avio_r8(ioc) != AMF_END_OF_OBJECT) | ||||
|             return -1; | ||||
|         break; | ||||
|         case AMF_DATA_TYPE_ARRAY: { | ||||
|     case AMF_DATA_TYPE_ARRAY: | ||||
|     { | ||||
|         unsigned int arraylen, i; | ||||
| 
 | ||||
|         arraylen = avio_rb32(ioc); | ||||
|             for(i = 0; i < arraylen && avio_tell(ioc) < max_pos - 1; i++) { | ||||
|                 if(amf_parse_object(s, NULL, NULL, NULL, max_pos, depth + 1) < 0) | ||||
|         for (i = 0; i < arraylen && avio_tell(ioc) < max_pos - 1; i++) | ||||
|             if (amf_parse_object(s, NULL, NULL, NULL, max_pos, | ||||
|                                  depth + 1) < 0) | ||||
|                 return -1;      // if we couldn't skip, bomb out.
 | ||||
|     } | ||||
|         } | ||||
|     break; | ||||
|     case AMF_DATA_TYPE_DATE: | ||||
|         avio_skip(ioc, 8 + 2);  // timestamp (double) and UTC offset (int16)
 | ||||
| @ -394,16 +445,20 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|         return -1; | ||||
|     } | ||||
| 
 | ||||
|     if(depth == 1 && key) { //only look for metadata values when we are not nested and key != NULL
 | ||||
|     // only look for metadata values when we are not nested and key != NULL
 | ||||
|     if (depth == 1 && key) { | ||||
|         acodec = astream ? astream->codec : NULL; | ||||
|         vcodec = vstream ? vstream->codec : NULL; | ||||
| 
 | ||||
|         if (amf_type == AMF_DATA_TYPE_NUMBER || amf_type == AMF_DATA_TYPE_BOOL) { | ||||
|         if (amf_type == AMF_DATA_TYPE_NUMBER || | ||||
|             amf_type == AMF_DATA_TYPE_BOOL) { | ||||
|             if (!strcmp(key, "duration")) | ||||
|                 s->duration = num_val * AV_TIME_BASE; | ||||
|             else if (!strcmp(key, "videodatarate") && vcodec && 0 <= (int)(num_val * 1024.0)) | ||||
|             else if (!strcmp(key, "videodatarate") && vcodec && | ||||
|                      0 <= (int)(num_val * 1024.0)) | ||||
|                 vcodec->bit_rate = num_val * 1024.0; | ||||
|             else if (!strcmp(key, "audiodatarate") && acodec && 0 <= (int)(num_val * 1024.0)) | ||||
|             else if (!strcmp(key, "audiodatarate") && acodec && | ||||
|                      0 <= (int)(num_val * 1024.0)) | ||||
|                 acodec->bit_rate = num_val * 1024.0; | ||||
|             else if (!strcmp(key, "datastream")) { | ||||
|                 AVStream *st = create_stream(s, AVMEDIA_TYPE_DATA); | ||||
| @ -413,12 +468,10 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|             } else if (flv->trust_metadata) { | ||||
|                 if (!strcmp(key, "videocodecid") && vcodec) { | ||||
|                     flv_set_video_codec(s, vstream, num_val, 0); | ||||
|                 } else | ||||
|                 if (!strcmp(key, "audiocodecid") && acodec) { | ||||
|                 } else if (!strcmp(key, "audiocodecid") && acodec) { | ||||
|                     int id = ((int)num_val) << FLV_AUDIO_CODECID_OFFSET; | ||||
|                     flv_set_audio_codec(s, astream, acodec, id); | ||||
|                 } else | ||||
|                 if (!strcmp(key, "audiosamplerate") && acodec) { | ||||
|                 } else if (!strcmp(key, "audiosamplerate") && acodec) { | ||||
|                     acodec->sample_rate = num_val; | ||||
|                 } else if (!strcmp(key, "audiosamplesize") && acodec) { | ||||
|                     acodec->bits_per_coded_sample = num_val; | ||||
| @ -427,11 +480,9 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|                     acodec->channel_layout = acodec->channels == 2 ? | ||||
|                                              AV_CH_LAYOUT_STEREO : | ||||
|                                              AV_CH_LAYOUT_MONO; | ||||
|                 } else | ||||
|                 if (!strcmp(key, "width") && vcodec) { | ||||
|                 } else if (!strcmp(key, "width") && vcodec) { | ||||
|                     vcodec->width = num_val; | ||||
|                 } else | ||||
|                 if (!strcmp(key, "height") && vcodec) { | ||||
|                 } else if (!strcmp(key, "height") && vcodec) { | ||||
|                     vcodec->height = num_val; | ||||
|                 } | ||||
|             } | ||||
| @ -457,7 +508,8 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|             return 0; | ||||
| 
 | ||||
|         if (amf_type == AMF_DATA_TYPE_BOOL) { | ||||
|             av_strlcpy(str_val, num_val > 0 ? "true" : "false", sizeof(str_val)); | ||||
|             av_strlcpy(str_val, num_val > 0 ? "true" : "false", | ||||
|                        sizeof(str_val)); | ||||
|             av_dict_set(&s->metadata, key, str_val, 0); | ||||
|         } else if (amf_type == AMF_DATA_TYPE_NUMBER) { | ||||
|             snprintf(str_val, sizeof(str_val), "%.f", num_val); | ||||
| @ -469,14 +521,19 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, AVStream *vst | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| static int flv_read_metabody(AVFormatContext *s, int64_t next_pos) { | ||||
| static int flv_read_metabody(AVFormatContext *s, int64_t next_pos) | ||||
| { | ||||
|     AMFDataType type; | ||||
|     AVStream *stream, *astream, *vstream, *dstream; | ||||
|     AVIOContext *ioc; | ||||
|     int i; | ||||
|     char buffer[11]; //only needs to hold the string "onMetaData". Anything longer is something we don't want.
 | ||||
|     // only needs to hold the string "onMetaData".
 | ||||
|     // Anything longer is something we don't want.
 | ||||
|     char buffer[11]; | ||||
| 
 | ||||
|     vstream = astream = dstream = NULL; | ||||
|     astream = NULL; | ||||
|     vstream = NULL; | ||||
|     dstream = NULL; | ||||
|     ioc     = s->pb; | ||||
| 
 | ||||
|     // first object needs to be "onMetaData" string
 | ||||
| @ -491,12 +548,16 @@ static int flv_read_metabody(AVFormatContext *s, int64_t next_pos) { | ||||
|     if (strcmp(buffer, "onMetaData")) | ||||
|         return -1; | ||||
| 
 | ||||
|     //find the streams now so that amf_parse_object doesn't need to do the lookup every time it is called.
 | ||||
|     // find the streams now so that amf_parse_object doesn't need to do
 | ||||
|     // the lookup every time it is called.
 | ||||
|     for (i = 0; i < s->nb_streams; i++) { | ||||
|         stream = s->streams[i]; | ||||
|         if(stream->codec->codec_type == AVMEDIA_TYPE_VIDEO) vstream = stream; | ||||
|         else if(stream->codec->codec_type == AVMEDIA_TYPE_AUDIO) astream = stream; | ||||
|         else if(stream->codec->codec_type == AVMEDIA_TYPE_DATA) dstream = stream; | ||||
|         if (stream->codec->codec_type == AVMEDIA_TYPE_VIDEO) | ||||
|             vstream = stream; | ||||
|         else if (stream->codec->codec_type == AVMEDIA_TYPE_AUDIO) | ||||
|             astream = stream; | ||||
|         else if (stream->codec->codec_type == AVMEDIA_TYPE_DATA) | ||||
|             dstream = stream; | ||||
|     } | ||||
| 
 | ||||
|     // parse the second object (we want a mixed array)
 | ||||
| @ -516,19 +577,19 @@ static int flv_read_header(AVFormatContext *s) | ||||
|     /* FIXME: better fix needed */ | ||||
|     if (!flags) { | ||||
|         flags = FLV_HEADER_FLAG_HASVIDEO | FLV_HEADER_FLAG_HASAUDIO; | ||||
|         av_log(s, AV_LOG_WARNING, "Broken FLV file, which says no streams present, this might fail\n"); | ||||
|         av_log(s, AV_LOG_WARNING, | ||||
|                "Broken FLV file, which says no streams present, " | ||||
|                "this might fail\n"); | ||||
|     } | ||||
| 
 | ||||
|     s->ctx_flags |= AVFMTCTX_NOHEADER; | ||||
| 
 | ||||
|     if(flags & FLV_HEADER_FLAG_HASVIDEO){ | ||||
|     if (flags & FLV_HEADER_FLAG_HASVIDEO) | ||||
|         if (!create_stream(s, AVMEDIA_TYPE_VIDEO)) | ||||
|             return AVERROR(ENOMEM); | ||||
|     } | ||||
|     if(flags & FLV_HEADER_FLAG_HASAUDIO){ | ||||
|     if (flags & FLV_HEADER_FLAG_HASAUDIO) | ||||
|         if (!create_stream(s, AVMEDIA_TYPE_AUDIO)) | ||||
|             return AVERROR(ENOMEM); | ||||
|     } | ||||
|     // Flag doesn't indicate whether or not there is script-data present. Must
 | ||||
|     // create that stream if it's encountered.
 | ||||
| 
 | ||||
| @ -565,7 +626,8 @@ static int flv_queue_extradata(FLVContext *flv, AVIOContext *pb, int stream, | ||||
|                                int size) | ||||
| { | ||||
|     av_free(flv->new_extradata[stream]); | ||||
|     flv->new_extradata[stream] = av_mallocz(size + FF_INPUT_BUFFER_PADDING_SIZE); | ||||
|     flv->new_extradata[stream] = av_mallocz(size + | ||||
|                                             FF_INPUT_BUFFER_PADDING_SIZE); | ||||
|     if (!flv->new_extradata[stream]) | ||||
|         return AVERROR(ENOMEM); | ||||
|     flv->new_extradata_size[stream] = size; | ||||
| @ -576,20 +638,19 @@ static int flv_queue_extradata(FLVContext *flv, AVIOContext *pb, int stream, | ||||
| static void clear_index_entries(AVFormatContext *s, int64_t pos) | ||||
| { | ||||
|     int i, j, out; | ||||
|     av_log(s, AV_LOG_WARNING, "Found invalid index entries, clearing the index.\n"); | ||||
|     av_log(s, AV_LOG_WARNING, | ||||
|            "Found invalid index entries, clearing the index.\n"); | ||||
|     for (i = 0; i < s->nb_streams; i++) { | ||||
|         AVStream *st = s->streams[i]; | ||||
|         /* Remove all index entries that point to >= pos */ | ||||
|         out = 0; | ||||
|         for (j = 0; j < st->nb_index_entries; j++) { | ||||
|         for (j = 0; j < st->nb_index_entries; j++) | ||||
|             if (st->index_entries[j].pos < pos) | ||||
|                 st->index_entries[out++] = st->index_entries[j]; | ||||
|         } | ||||
|         st->nb_index_entries = out; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static int flv_data_packet(AVFormatContext *s, AVPacket *pkt, | ||||
|                            int64_t dts, int64_t next) | ||||
| { | ||||
| @ -644,6 +705,7 @@ static int flv_data_packet(AVFormatContext *s, AVPacket *pkt, | ||||
|     pkt->flags       |= AV_PKT_FLAG_KEY; | ||||
| 
 | ||||
|     avio_seek(s->pb, next + 4, SEEK_SET); | ||||
| 
 | ||||
| out: | ||||
|     return ret; | ||||
| } | ||||
| @ -659,7 +721,8 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) | ||||
|     int av_uninit(sample_rate); | ||||
|     AVStream *st    = NULL; | ||||
| 
 | ||||
|  for(;;avio_skip(s->pb, 4)){ /* pkt size is repeated at end. skip it */ | ||||
|     /* pkt size is repeated at end. skip it */ | ||||
|     for (;; avio_skip(s->pb, 4)) { | ||||
|         pos  = avio_tell(s->pb); | ||||
|         type = avio_r8(s->pb); | ||||
|         size = avio_rb24(s->pb); | ||||
| @ -712,7 +775,9 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) | ||||
|                 avio_seek(s->pb, meta_pos, SEEK_SET); | ||||
|             } | ||||
|         } else { | ||||
|         av_log(s, AV_LOG_DEBUG, "skipping flv packet: type %d, size %d, flags %d\n", type, size, flags); | ||||
|             av_log(s, AV_LOG_DEBUG, | ||||
|                    "skipping flv packet: type %d, size %d, flags %d\n", | ||||
|                    type, size, flags); | ||||
| skip: | ||||
|             avio_seek(s->pb, next, SEEK_SET); | ||||
|             continue; | ||||
| @ -727,15 +792,12 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) | ||||
|             st = s->streams[i]; | ||||
|             if (stream_type == FLV_STREAM_TYPE_AUDIO) { | ||||
|                 if (st->codec->codec_type == AVMEDIA_TYPE_AUDIO && | ||||
|                 (s->audio_codec_id || flv_same_audio_codec(st->codec, flags))) { | ||||
|                     (s->audio_codec_id || flv_same_audio_codec(st->codec, flags))) | ||||
|                     break; | ||||
|             } | ||||
|         } else | ||||
|         if (stream_type == FLV_STREAM_TYPE_VIDEO) { | ||||
|             } else if (stream_type == FLV_STREAM_TYPE_VIDEO) { | ||||
|                 if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO && | ||||
|                 (s->video_codec_id || flv_same_video_codec(st->codec, flags))) { | ||||
|                     (s->video_codec_id || flv_same_video_codec(st->codec, flags))) | ||||
|                     break; | ||||
|             } | ||||
|             } else if (stream_type == FLV_STREAM_TYPE_DATA) { | ||||
|                 if (st->codec->codec_type == AVMEDIA_TYPE_DATA) | ||||
|                     break; | ||||
| @ -744,8 +806,7 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) | ||||
|         if (i == s->nb_streams) { | ||||
|             static const enum AVMediaType stream_types[] = {AVMEDIA_TYPE_VIDEO, AVMEDIA_TYPE_AUDIO, AVMEDIA_TYPE_DATA}; | ||||
|             av_log(s, AV_LOG_WARNING, "Stream discovered after head already parsed\n"); | ||||
|         st = create_stream(s, | ||||
|                            stream_types[stream_type]); | ||||
|             st = create_stream(s, stream_types[stream_type]); | ||||
|             if (!st) | ||||
|                 return AVERROR(ENOMEM); | ||||
| 
 | ||||
| @ -763,7 +824,8 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) | ||||
|         break; | ||||
|     } | ||||
| 
 | ||||
|     // if not streamed and no duration from metadata then seek to end to find the duration from the timestamps
 | ||||
|     // if not streamed and no duration from metadata then seek to end to find
 | ||||
|     // the duration from the timestamps
 | ||||
|     if (s->pb->seekable && (!s->duration || s->duration == AV_NOPTS_VALUE) && !flv->searched_for_end) { | ||||
|         int size; | ||||
|         const int64_t pos   = avio_tell(s->pb); | ||||
| @ -790,19 +852,25 @@ retry_duration: | ||||
|     if (stream_type == FLV_STREAM_TYPE_AUDIO) { | ||||
|         int bits_per_coded_sample; | ||||
|         channels = (flags & FLV_AUDIO_CHANNEL_MASK) == FLV_STEREO ? 2 : 1; | ||||
|         sample_rate = (44100 << ((flags & FLV_AUDIO_SAMPLERATE_MASK) >> FLV_AUDIO_SAMPLERATE_OFFSET) >> 3); | ||||
|         sample_rate = 44100 << ((flags & FLV_AUDIO_SAMPLERATE_MASK) >> | ||||
|                                 FLV_AUDIO_SAMPLERATE_OFFSET) >> 3; | ||||
|         bits_per_coded_sample = (flags & FLV_AUDIO_SAMPLESIZE_MASK) ? 16 : 8; | ||||
|         if(!st->codec->channels || !st->codec->sample_rate || !st->codec->bits_per_coded_sample) { | ||||
|         if (!st->codec->channels || !st->codec->sample_rate || | ||||
|             !st->codec->bits_per_coded_sample) { | ||||
|             st->codec->channels              = channels; | ||||
|             st->codec->channel_layout        = channels == 1 ? AV_CH_LAYOUT_MONO : | ||||
|                                                                AV_CH_LAYOUT_STEREO; | ||||
|             st->codec->channel_layout        = channels == 1 | ||||
|                                                ? AV_CH_LAYOUT_MONO | ||||
|                                                : AV_CH_LAYOUT_STEREO; | ||||
|             st->codec->sample_rate           = sample_rate; | ||||
|             st->codec->bits_per_coded_sample = bits_per_coded_sample; | ||||
|         } | ||||
|         if (!st->codec->codec_id) { | ||||
|             flv_set_audio_codec(s, st, st->codec, flags & FLV_AUDIO_CODECID_MASK); | ||||
|             flv->last_sample_rate = sample_rate = st->codec->sample_rate; | ||||
|             flv->last_channels    = channels    = st->codec->channels; | ||||
|             flv_set_audio_codec(s, st, st->codec, | ||||
|                                 flags & FLV_AUDIO_CODECID_MASK); | ||||
|             flv->last_sample_rate = | ||||
|             sample_rate           = st->codec->sample_rate; | ||||
|             flv->last_channels    = | ||||
|             channels              = st->codec->channels; | ||||
|         } else { | ||||
|             AVCodecContext ctx; | ||||
|             ctx.sample_rate = sample_rate; | ||||
| @ -819,11 +887,13 @@ retry_duration: | ||||
|         int type = avio_r8(s->pb); | ||||
|         size--; | ||||
|         if (st->codec->codec_id == AV_CODEC_ID_H264 || st->codec->codec_id == AV_CODEC_ID_MPEG4) { | ||||
|             int32_t cts = (avio_rb24(s->pb)+0xff800000)^0xff800000; // sign extension
 | ||||
|             // sign extension
 | ||||
|             int32_t cts = (avio_rb24(s->pb) + 0xff800000) ^ 0xff800000; | ||||
|             pts = dts + cts; | ||||
|             if (cts < 0) { // dts are wrong
 | ||||
|                 flv->wrong_dts = 1; | ||||
|                 av_log(s, AV_LOG_WARNING, "negative cts, previous timestamps might be wrong\n"); | ||||
|                 av_log(s, AV_LOG_WARNING, | ||||
|                        "negative cts, previous timestamps might be wrong\n"); | ||||
|             } | ||||
|             if (flv->wrong_dts) | ||||
|                 dts = AV_NOPTS_VALUE; | ||||
| @ -879,7 +949,8 @@ retry_duration: | ||||
|             flv->new_extradata_size[stream_type] = 0; | ||||
|         } | ||||
|     } | ||||
|     if (stream_type == FLV_STREAM_TYPE_AUDIO && (sample_rate != flv->last_sample_rate || | ||||
|     if (stream_type == FLV_STREAM_TYPE_AUDIO && | ||||
|                     (sample_rate != flv->last_sample_rate || | ||||
|                      channels    != flv->last_channels)) { | ||||
|         flv->last_sample_rate = sample_rate; | ||||
|         flv->last_channels    = channels; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user