summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Eugen Hoyos <cehoyos@ag.or.at>2015-09-12 19:00:02 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2015-09-12 19:00:02 +0200
commite3e55758dcf6e7801e9402df2cb734c19d0ea314 (patch)
tree1a89ea0487955ca015b7890f2dbd9781710d675e
parenta84613b4c2a514bafa7e1d4b87f5fdf47ea85914 (diff)
lavf/img2dec: Improve jpeg auto-detection.
Fixes ticket #4841.
-rw-r--r--libavformat/img2dec.c26
1 files changed, 20 insertions, 6 deletions
diff --git a/libavformat/img2dec.c b/libavformat/img2dec.c
index cf848ce05e..70f0b09f18 100644
--- a/libavformat/img2dec.c
+++ b/libavformat/img2dec.c
@@ -660,18 +660,14 @@ static int j2k_probe(AVProbeData *p)
static int jpeg_probe(AVProbeData *p)
{
const uint8_t *b = p->buf;
- int i, state = 0xD8, exif_size = 0;
+ int i, state = 0xD8;
if (AV_RB16(b) != 0xFFD8 ||
AV_RB32(b) == 0xFFD8FFF7)
return 0;
b += 2;
- if (AV_RB16(b) == 0xFFE1 && AV_RB32(b + 4) == AV_RB32("Exif")) {
- exif_size = AV_RB16(b + 2) + 2;
- b += exif_size;
- }
- for (i = 0; i + exif_size < p->buf_size - 2; i++) {
+ for (i = 0; i < p->buf_size - 3; i++) {
int c;
if (b[i] != 0xFF)
continue;
@@ -700,6 +696,24 @@ static int jpeg_probe(AVProbeData *p)
return 0;
state = 0xD9;
break;
+ case 0xE0:
+ case 0xE1:
+ case 0xE2:
+ case 0xE3:
+ case 0xE4:
+ case 0xE5:
+ case 0xE6:
+ case 0xE7:
+ case 0xE8:
+ case 0xE9:
+ case 0xEA:
+ case 0xEB:
+ case 0xEC:
+ case 0xED:
+ case 0xEE:
+ case 0xEF:
+ i += AV_RB16(&b[i + 2]) + 1;
+ break;
default:
if ( (c >= 0x02 && c <= 0xBF)
|| c == 0xC8)