]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Corrections of errors in aac_ac3_parser
authorbwolowiec <bwolowiec@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 7 Apr 2008 20:54:08 +0000 (20:54 +0000)
committerbwolowiec <bwolowiec@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 7 Apr 2008 20:54:08 +0000 (20:54 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@12759 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavcodec/aac_ac3_parser.c
libavcodec/aac_ac3_parser.h
libavcodec/aac_parser.c
libavcodec/ac3_parser.c

index e920b7f88c272cf0241bf505b1d3596d7853b15a..a1284f75182e17c01dc8b6c0c2e294d9d61e30c9 100644 (file)
@@ -44,13 +44,19 @@ int ff_aac_ac3_parse(AVCodecParserContext *s1,
                 if((len=s->sync(s->state, s, &s->need_next_header, &s->new_frame_start)))
                     break;
             }
-            i-= s->header_size;
+            i-= s->header_size -1;
             if(len>0){
                 s->remaining_size = len + i;
 
                 if(pc->index+i > 0 && s->new_frame_start){
                     s->remaining_size -= i; // remaining_size=len
 output_frame:
+                    if(!s->frame_in_buffer && 0){
+                        s->frame_in_buffer=1;
+                        buf+=i;
+                        buf_size-=i;
+                        continue;
+                    }
                     ff_combine_frame(pc, i, &buf, &buf_size);
                     *poutbuf = buf;
                     *poutbuf_size = buf_size;
@@ -72,6 +78,7 @@ output_frame:
 
                     return i;
                 }
+                s->frame_in_buffer=1;
             }else{
                 break;
             }
index d5b78f7bc4a3d55b31f6a3ec8e0bc398414df9ab..2049dc7097f273d5e693009c0f8dd7ed4c38ae17 100644 (file)
@@ -43,6 +43,7 @@ typedef struct AACAC3ParseContext {
 
     int need_next_header;
     int new_frame_start;
+    int frame_in_buffer;
 } AACAC3ParseContext;
 
 int ff_aac_ac3_parse(AVCodecParserContext *s1,
index ddf82819be5f1c96e0fe705470c596643b9d84c4..9fbef864a10b4c802c06ab9177139f5137070bdf 100644 (file)
@@ -34,7 +34,7 @@ static int aac_sync(uint64_t state, AACAC3ParseContext *hdr_info,
     int size, rdb, ch, sr;
     uint64_t tmp = be2me_64(state);
 
-    init_get_bits(&bits, (uint8_t *)&tmp, AAC_HEADER_SIZE * 8);
+    init_get_bits(&bits, ((uint8_t *)&tmp)+8-AAC_HEADER_SIZE, AAC_HEADER_SIZE * 8);
 
     if(get_bits(&bits, 12) != 0xfff)
         return 0;
index 57cd87f10df6d03909fa8186c6bd13adeb183393..a1d57e4c6e66c5573b1fe1407e5717cb50d8eae8 100644 (file)
@@ -130,7 +130,7 @@ static int ac3_sync(uint64_t state, AACAC3ParseContext *hdr_info,
     uint64_t tmp = be2me_64(state);
     AC3HeaderInfo hdr;
 
-    err = ff_ac3_parse_header((uint8_t *)&tmp, &hdr);
+    err = ff_ac3_parse_header(((uint8_t *)&tmp)+8-AC3_HEADER_SIZE, &hdr);
 
     if(err < 0)
         return 0;