AC3: fix strict aliasing violation in parser
authorMåns Rullgård <mans@mansr.com>
Wed, 17 Dec 2008 02:30:26 +0000 (02:30 +0000)
committerMåns Rullgård <mans@mansr.com>
Wed, 17 Dec 2008 02:30:26 +0000 (02:30 +0000)
Originally committed as revision 16181 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/ac3_parser.c

index aedcbcd..ccd687a 100644 (file)
@@ -158,11 +158,14 @@ static int ac3_sync(uint64_t state, AACAC3ParseContext *hdr_info,
         int *need_next_header, int *new_frame_start)
 {
     int err;
-    uint64_t tmp = be2me_64(state);
+    union {
+        uint64_t u64;
+        uint8_t  u8[8];
+    } tmp = { be2me_64(state) };
     AC3HeaderInfo hdr;
     GetBitContext gbc;
 
-    init_get_bits(&gbc, ((uint8_t *)&tmp)+8-AC3_HEADER_SIZE, 54);
+    init_get_bits(&gbc, tmp.u8+8-AC3_HEADER_SIZE, 54);
     err = ff_ac3_parse_header(&gbc, &hdr);
 
     if(err < 0)