mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
aacdec: Don't count probed ADTS frames if there are false positives
If a portion of the probe buffer seem to resemble ADTS frames, but some data at the end is a mismatch, disregard the whole probing attempt. If it actually is ADTS data, there shouldn't be any mismatches within the sequential frame data. Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
a84c8af042
commit
0412cb67cd
@ -42,8 +42,16 @@ static int adts_aac_probe(AVProbeData *p)
|
|||||||
|
|
||||||
for (frames = 0; buf2 < end; frames++) {
|
for (frames = 0; buf2 < end; frames++) {
|
||||||
uint32_t header = AV_RB16(buf2);
|
uint32_t header = AV_RB16(buf2);
|
||||||
if ((header & 0xFFF6) != 0xFFF0)
|
if ((header & 0xFFF6) != 0xFFF0) {
|
||||||
|
if (buf != buf0) {
|
||||||
|
// Found something that isn't an ADTS header, starting
|
||||||
|
// from a position other than the start of the buffer.
|
||||||
|
// Discard the count we've accumulated so far since it
|
||||||
|
// probably was a false positive.
|
||||||
|
frames = 0;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
fsize = (AV_RB32(buf2 + 3) >> 13) & 0x1FFF;
|
fsize = (AV_RB32(buf2 + 3) >> 13) & 0x1FFF;
|
||||||
if (fsize < 7)
|
if (fsize < 7)
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user