matroskadec: fix lace vs block duration.
Fixes Ticket1270 Thanks-to: Moritz Bunkus Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
		
							parent
							
								
									dbf25b70ea
								
							
						
					
					
						commit
						ee475e272e
					
				@ -1886,8 +1886,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
 | 
				
			|||||||
    if (st->discard >= AVDISCARD_ALL)
 | 
					    if (st->discard >= AVDISCARD_ALL)
 | 
				
			||||||
        return res;
 | 
					        return res;
 | 
				
			||||||
    av_assert1(duration != AV_NOPTS_VALUE);
 | 
					    av_assert1(duration != AV_NOPTS_VALUE);
 | 
				
			||||||
    if (!duration)
 | 
					 | 
				
			||||||
        duration = track->default_duration / matroska->time_scale;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    block_time = AV_RB16(data);
 | 
					    block_time = AV_RB16(data);
 | 
				
			||||||
    data += 2;
 | 
					    data += 2;
 | 
				
			||||||
@ -1904,7 +1902,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
 | 
				
			|||||||
            is_keyframe = 0;  /* overlapping subtitles are not key frame */
 | 
					            is_keyframe = 0;  /* overlapping subtitles are not key frame */
 | 
				
			||||||
        if (is_keyframe)
 | 
					        if (is_keyframe)
 | 
				
			||||||
            av_add_index_entry(st, cluster_pos, timecode, 0,0,AVINDEX_KEYFRAME);
 | 
					            av_add_index_entry(st, cluster_pos, timecode, 0,0,AVINDEX_KEYFRAME);
 | 
				
			||||||
        track->end_timecode = FFMAX(track->end_timecode, timecode+duration);
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (matroska->skip_to_keyframe && track->type != MATROSKA_TRACK_TYPE_SUBTITLE) {
 | 
					    if (matroska->skip_to_keyframe && track->type != MATROSKA_TRACK_TYPE_SUBTITLE) {
 | 
				
			||||||
@ -1995,7 +1992,15 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (res == 0) {
 | 
					    if (res == 0) {
 | 
				
			||||||
 | 
					        if (!duration)
 | 
				
			||||||
 | 
					            duration = track->default_duration * laces / matroska->time_scale;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (cluster_time != (uint64_t)-1 && (block_time >= 0 || cluster_time >= -block_time))
 | 
				
			||||||
 | 
					            track->end_timecode = FFMAX(track->end_timecode, timecode+duration);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for (n = 0; n < laces; n++) {
 | 
					        for (n = 0; n < laces; n++) {
 | 
				
			||||||
 | 
					            int64_t lace_duration = duration*(n+1) / laces - duration*n / laces;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if (lace_size[n] > size) {
 | 
					            if (lace_size[n] > size) {
 | 
				
			||||||
                av_log(matroska->ctx, AV_LOG_ERROR, "Invalid packet size\n");
 | 
					                av_log(matroska->ctx, AV_LOG_ERROR, "Invalid packet size\n");
 | 
				
			||||||
                break;
 | 
					                break;
 | 
				
			||||||
@ -2101,12 +2106,12 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
 | 
				
			|||||||
                    pkt->pts = timecode;
 | 
					                    pkt->pts = timecode;
 | 
				
			||||||
                pkt->pos = pos;
 | 
					                pkt->pos = pos;
 | 
				
			||||||
                if (st->codec->codec_id == AV_CODEC_ID_TEXT)
 | 
					                if (st->codec->codec_id == AV_CODEC_ID_TEXT)
 | 
				
			||||||
                    pkt->convergence_duration = duration;
 | 
					                    pkt->convergence_duration = lace_duration;
 | 
				
			||||||
                else if (track->type != MATROSKA_TRACK_TYPE_SUBTITLE)
 | 
					                else if (track->type != MATROSKA_TRACK_TYPE_SUBTITLE)
 | 
				
			||||||
                    pkt->duration = duration;
 | 
					                    pkt->duration = lace_duration;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                if (st->codec->codec_id == AV_CODEC_ID_SSA)
 | 
					                if (st->codec->codec_id == AV_CODEC_ID_SSA)
 | 
				
			||||||
                    matroska_fix_ass_packet(matroska, pkt, duration);
 | 
					                    matroska_fix_ass_packet(matroska, pkt, lace_duration);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                if (matroska->prev_pkt &&
 | 
					                if (matroska->prev_pkt &&
 | 
				
			||||||
                    timecode != AV_NOPTS_VALUE &&
 | 
					                    timecode != AV_NOPTS_VALUE &&
 | 
				
			||||||
@ -2121,7 +2126,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
 | 
				
			|||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if (timecode != AV_NOPTS_VALUE)
 | 
					            if (timecode != AV_NOPTS_VALUE)
 | 
				
			||||||
                timecode = duration ? timecode + duration : AV_NOPTS_VALUE;
 | 
					                timecode = lace_duration ? timecode + lace_duration : AV_NOPTS_VALUE;
 | 
				
			||||||
            data += lace_size[n];
 | 
					            data += lace_size[n];
 | 
				
			||||||
            size -= lace_size[n];
 | 
					            size -= lace_size[n];
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user