zhengfl

fix #408:Queue丢视频时,不应该丢弃SequenceHeader

@@ -357,52 +357,49 @@ int SrsMessageQueue::dump_packets(SrsConsumer* consumer, bool atc, int tba, int @@ -357,52 +357,49 @@ int SrsMessageQueue::dump_packets(SrsConsumer* consumer, bool atc, int tba, int
357 357
358 void SrsMessageQueue::shrink() 358 void SrsMessageQueue::shrink()
359 { 359 {
360 - int iframe_index = -1; 360 + SrsSharedPtrMessage* video_sh = NULL;
  361 + SrsSharedPtrMessage* audio_sh = NULL;
  362 + int msgs_size = (int)msgs.size();
361 363
362 - // issue the first iframe.  
363 - // skip the first frame, whatever the type of it,  
364 - // for when we shrinked, the first is the iframe,  
365 - // we will directly remove the gop next time.  
366 - for (int i = 1; i < (int)msgs.size(); i++) { 364 + // remove all msg
  365 + // igone the sequence header
  366 + for (int i = 0; i < (int)msgs.size(); i++) {
367 SrsSharedPtrMessage* msg = msgs.at(i); 367 SrsSharedPtrMessage* msg = msgs.at(i);
368 368
369 - if (msg->is_video()) {  
370 - if (SrsFlvCodec::video_is_keyframe(msg->payload, msg->size)) {  
371 - // the max frame index to remove.  
372 - iframe_index = i;  
373 -  
374 - // set the start time, we will remove until this frame.  
375 - av_start_time = msg->timestamp;  
376 -  
377 - break; 369 + if (msg->is_video() && SrsFlvCodec::video_is_sequence_header(msg->payload, msg->size)) {
  370 + srs_freep(video_sh);
  371 + video_sh = msg;
  372 + continue;
378 } 373 }
  374 + else if (msg->is_audio() && SrsFlvCodec::audio_is_sequence_header(msg->payload, msg->size)) {
  375 + srs_freep(audio_sh);
  376 + audio_sh = msg;
  377 + continue;
379 } 378 }
  379 +
  380 + srs_freep(msg);
380 } 381 }
  382 + msgs.clear();
381 383
382 - // no iframe, for audio, clear the queue.  
383 - // it is ok to clear for audio, for the shrink tell us the queue is full.  
384 - // for video, we clear util the I-Frame, for the decoding must start from I-frame,  
385 - // for audio, it's ok to clear any data, also we can clear the whole queue.  
386 - // @see: https://github.com/simple-rtmp-server/srs/issues/134  
387 - if (iframe_index < 0) {  
388 - clear();  
389 - return; 384 + // update av_start_time
  385 + av_start_time = av_end_time;
  386 + //push_back secquence header and update timestamp
  387 + if (video_sh) {
  388 + video_sh->timestamp = av_end_time;
  389 + msgs.push_back(video_sh);
  390 + }
  391 + if (audio_sh) {
  392 + audio_sh->timestamp = av_end_time;
  393 + msgs.push_back(audio_sh);
390 } 394 }
391 395
392 if (_ignore_shrink) { 396 if (_ignore_shrink) {
393 srs_info("shrink the cache queue, size=%d, removed=%d, max=%.2f", 397 srs_info("shrink the cache queue, size=%d, removed=%d, max=%.2f",
394 - (int)msgs.size(), iframe_index, queue_size_ms / 1000.0); 398 + (int)msgs.size(), msgs_size - (int)msgs.size(), queue_size_ms / 1000.0);
395 } else { 399 } else {
396 srs_trace("shrink the cache queue, size=%d, removed=%d, max=%.2f", 400 srs_trace("shrink the cache queue, size=%d, removed=%d, max=%.2f",
397 - (int)msgs.size(), iframe_index, queue_size_ms / 1000.0);  
398 - }  
399 -  
400 - // remove the first gop from the front  
401 - for (int i = 0; i < iframe_index; i++) {  
402 - SrsSharedPtrMessage* msg = msgs.at(i);  
403 - srs_freep(msg); 401 + (int)msgs.size(), msgs_size - (int)msgs.size(), queue_size_ms / 1000.0);
404 } 402 }
405 - msgs.erase(msgs.begin(), msgs.begin() + iframe_index);  
406 } 403 }
407 404
408 void SrsMessageQueue::clear() 405 void SrsMessageQueue::clear()