Home | History | Annotate | Download | only in src
      1 /*--------------------------------------------------------------------------
      2 Copyright (c) 2010 - 2013, The Linux Foundation. All rights reserved.
      3 
      4 Redistribution and use in source and binary forms, with or without
      5 modification, are permitted provided that the following conditions are met:
      6     * Redistributions of source code must retain the above copyright
      7       notice, this list of conditions and the following disclaimer.
      8     * Redistributions in binary form must reproduce the above copyright
      9       notice, this list of conditions and the following disclaimer in the
     10       documentation and/or other materials provided with the distribution.
     11     * Neither the name of The Linux Foundation nor
     12       the names of its contributors may be used to endorse or promote
     13       products derived from this software without specific prior written
     14       permission.
     15 
     16 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
     17 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     18 IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
     19 NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
     20 CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
     21 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
     22 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
     23 OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     24 WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
     25 OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
     26 ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     27 --------------------------------------------------------------------------*/
     28 #include "mp4_utils.h"
     29 //#include "omx_vdec.h"
     30 # include <stdio.h>
     31 #ifdef _ANDROID_
     32 extern "C" {
     33 #include<utils/Log.h>
     34 }
     35 #endif//_ANDROID_
     36 
     37 #undef DEBUG_PRINT_LOW
     38 #undef DEBUG_PRINT_HIGH
     39 #undef DEBUG_PRINT_ERROR
     40 
     41 #define DEBUG_PRINT_LOW ALOGV
     42 #define DEBUG_PRINT_HIGH ALOGV
     43 #define DEBUG_PRINT_ERROR ALOGE
     44 
     45 MP4_Utils::MP4_Utils()
     46 {
     47     m_SrcWidth = 0;
     48     m_SrcHeight = 0;
     49     vop_time_resolution = 0;
     50     vop_time_found = false;
     51 
     52 }
     53 MP4_Utils::~MP4_Utils()
     54 {
     55 }
     56 
     57 uint32 MP4_Utils::read_bit_field(posInfoType * posPtr, uint32 size)
     58 {
     59     uint8 *bits = &posPtr->bytePtr[0];
     60     uint32 bitBuf =
     61         (bits[0] << 24) | (bits[1] << 16) | (bits[2] << 8) | bits[3];
     62 
     63     uint32 value = (bitBuf >> (32 - posPtr->bitPos - size)) & MASK(size);
     64 
     65     /* Update the offset in preparation for next field    */
     66     posPtr->bitPos += size;
     67 
     68     while (posPtr->bitPos >= 8) {
     69         posPtr->bitPos -= 8;
     70         posPtr->bytePtr++;
     71     }
     72 
     73     return value;
     74 }
     75     static uint8 *find_code
     76 (uint8 * bytePtr, uint32 size, uint32 codeMask, uint32 referenceCode)
     77 {
     78     uint32 code = 0xFFFFFFFF;
     79 
     80     for (uint32 i = 0; i < size; i++) {
     81         code <<= 8;
     82         code |= *bytePtr++;
     83 
     84         if ((code & codeMask) == referenceCode) {
     85             return bytePtr;
     86         }
     87     }
     88 
     89     DEBUG_PRINT_LOW("Unable to find code 0x%x\n", referenceCode);
     90     return NULL;
     91 }
     92 bool MP4_Utils::parseHeader(mp4StreamType * psBits)
     93 {
     94     uint32 profile_and_level_indication = 0;
     95     uint8 VerID = 1; /* default value */
     96     long hxw = 0;
     97 
     98     m_posInfo.bitPos = 0;
     99     m_posInfo.bytePtr = psBits->data;
    100     m_dataBeginPtr = psBits->data;
    101 
    102     m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,4,
    103             MASK(32),VOP_START_CODE);
    104 
    105     if (m_posInfo.bytePtr) {
    106         return false;
    107     }
    108 
    109     m_posInfo.bitPos = 0;
    110     m_posInfo.bytePtr = psBits->data;
    111     m_dataBeginPtr = psBits->data;
    112     m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,4,
    113             MASK(32),GOV_START_CODE);
    114 
    115     if (m_posInfo.bytePtr) {
    116         return false;
    117     }
    118 
    119     m_posInfo.bitPos = 0;
    120     m_posInfo.bytePtr = psBits->data;
    121     m_dataBeginPtr = psBits->data;
    122     /* parsing Visual Object Seqence(VOS) header */
    123     m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,
    124             psBits->numBytes,
    125             MASK(32),
    126             VISUAL_OBJECT_SEQUENCE_START_CODE);
    127 
    128     if ( m_posInfo.bytePtr == NULL ) {
    129         m_posInfo.bitPos  = 0;
    130         m_posInfo.bytePtr = psBits->data;
    131     } else {
    132         uint32 profile_and_level_indication = read_bit_field (&m_posInfo, 8);
    133     }
    134 
    135     /* parsing Visual Object(VO) header*/
    136     /* note: for now, we skip over the user_data */
    137     m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,psBits->numBytes,
    138             MASK(32),VISUAL_OBJECT_START_CODE);
    139 
    140     if (m_posInfo.bytePtr == NULL) {
    141         m_posInfo.bitPos = 0;
    142         m_posInfo.bytePtr = psBits->data;
    143     } else {
    144         uint32 is_visual_object_identifier = read_bit_field (&m_posInfo, 1);
    145 
    146         if ( is_visual_object_identifier ) {
    147             /* visual_object_verid*/
    148             read_bit_field (&m_posInfo, 4);
    149             /* visual_object_priority*/
    150             read_bit_field (&m_posInfo, 3);
    151         }
    152 
    153         /* visual_object_type*/
    154         uint32 visual_object_type = read_bit_field (&m_posInfo, 4);
    155 
    156         if ( visual_object_type != VISUAL_OBJECT_TYPE_VIDEO_ID ) {
    157             return false;
    158         }
    159 
    160         /* skipping video_signal_type params*/
    161         /*parsing Video Object header*/
    162         m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,psBits->numBytes,
    163                 VIDEO_OBJECT_START_CODE_MASK,VIDEO_OBJECT_START_CODE);
    164 
    165         if ( m_posInfo.bytePtr == NULL ) {
    166             return false;
    167         }
    168     }
    169 
    170     /* parsing Video Object Layer(VOL) header */
    171     m_posInfo.bitPos = 0;
    172     m_posInfo.bytePtr = find_code(m_posInfo.bytePtr,
    173             psBits->numBytes,
    174             VIDEO_OBJECT_LAYER_START_CODE_MASK,
    175             VIDEO_OBJECT_LAYER_START_CODE);
    176 
    177     if ( m_posInfo.bytePtr == NULL ) {
    178         m_posInfo.bitPos = 0;
    179         m_posInfo.bytePtr = psBits->data;
    180     }
    181 
    182     // 1 -> random accessible VOL
    183     read_bit_field(&m_posInfo, 1);
    184 
    185     uint32 video_object_type_indication = read_bit_field (&m_posInfo, 8);
    186 
    187     if ( (video_object_type_indication != SIMPLE_OBJECT_TYPE) &&
    188             (video_object_type_indication != SIMPLE_SCALABLE_OBJECT_TYPE) &&
    189             (video_object_type_indication != CORE_OBJECT_TYPE) &&
    190             (video_object_type_indication != ADVANCED_SIMPLE) &&
    191             (video_object_type_indication != RESERVED_OBJECT_TYPE) &&
    192             (video_object_type_indication != MAIN_OBJECT_TYPE)) {
    193         return false;
    194     }
    195 
    196     /* is_object_layer_identifier*/
    197     uint32 is_object_layer_identifier = read_bit_field (&m_posInfo, 1);
    198 
    199     if (is_object_layer_identifier) {
    200         uint32 video_object_layer_verid = read_bit_field (&m_posInfo, 4);
    201         uint32 video_object_layer_priority = read_bit_field (&m_posInfo, 3);
    202         VerID = (unsigned char)video_object_layer_verid;
    203     }
    204 
    205     /* aspect_ratio_info*/
    206     uint32 aspect_ratio_info = read_bit_field (&m_posInfo, 4);
    207 
    208     if ( aspect_ratio_info == EXTENDED_PAR ) {
    209         /* par_width*/
    210         read_bit_field (&m_posInfo, 8);
    211         /* par_height*/
    212         read_bit_field (&m_posInfo, 8);
    213     }
    214 
    215     /* vol_control_parameters */
    216     uint32 vol_control_parameters = read_bit_field (&m_posInfo, 1);
    217 
    218     if ( vol_control_parameters ) {
    219         /* chroma_format*/
    220         uint32 chroma_format = read_bit_field (&m_posInfo, 2);
    221 
    222         if ( chroma_format != 1 ) {
    223             return false;
    224         }
    225 
    226         /* low_delay*/
    227         uint32 low_delay = read_bit_field (&m_posInfo, 1);
    228         /* vbv_parameters (annex D)*/
    229         uint32 vbv_parameters = read_bit_field (&m_posInfo, 1);
    230 
    231         if ( vbv_parameters ) {
    232             /* first_half_bitrate*/
    233             uint32 first_half_bitrate = read_bit_field (&m_posInfo, 15);
    234             uint32 marker_bit = read_bit_field (&m_posInfo, 1);
    235 
    236             if ( marker_bit != 1) {
    237                 return false;
    238             }
    239 
    240             /* latter_half_bitrate*/
    241             uint32 latter_half_bitrate = read_bit_field (&m_posInfo, 15);
    242             marker_bit = read_bit_field (&m_posInfo, 1);
    243 
    244             if ( marker_bit != 1) {
    245                 return false;
    246             }
    247 
    248             uint32 VBVPeakBitRate = (first_half_bitrate << 15) + latter_half_bitrate;
    249             /* first_half_vbv_buffer_size*/
    250             uint32 first_half_vbv_buffer_size = read_bit_field (&m_posInfo, 15);
    251             marker_bit = read_bit_field (&m_posInfo, 1);
    252 
    253             if ( marker_bit != 1) {
    254                 return false;
    255             }
    256 
    257             /* latter_half_vbv_buffer_size*/
    258             uint32 latter_half_vbv_buffer_size = read_bit_field (&m_posInfo, 3);
    259             uint32 VBVBufferSize = (first_half_vbv_buffer_size << 3) + latter_half_vbv_buffer_size;
    260             /* first_half_vbv_occupancy*/
    261             uint32 first_half_vbv_occupancy = read_bit_field (&m_posInfo, 11);
    262             marker_bit = read_bit_field (&m_posInfo, 1);
    263 
    264             if ( marker_bit != 1) {
    265                 return false;
    266             }
    267 
    268             /* latter_half_vbv_occupancy*/
    269             uint32 latter_half_vbv_occupancy = read_bit_field (&m_posInfo, 15);
    270             marker_bit = read_bit_field (&m_posInfo, 1);
    271 
    272             if ( marker_bit != 1) {
    273                 return false;
    274             }
    275         }/* vbv_parameters*/
    276     }/*vol_control_parameters*/
    277 
    278     /* video_object_layer_shape*/
    279     uint32 video_object_layer_shape = read_bit_field (&m_posInfo, 2);
    280     uint8 VOLShape = (unsigned char)video_object_layer_shape;
    281 
    282     if ( VOLShape != MPEG4_SHAPE_RECTANGULAR ) {
    283         return false;
    284     }
    285 
    286     /* marker_bit*/
    287     uint32 marker_bit = read_bit_field (&m_posInfo, 1);
    288 
    289     if ( marker_bit != 1 ) {
    290         return false;
    291     }
    292 
    293     /* vop_time_increment_resolution*/
    294     uint32 vop_time_increment_resolution = read_bit_field (&m_posInfo, 16);
    295     vop_time_resolution = vop_time_increment_resolution;
    296     vop_time_found = true;
    297     return true;
    298 }
    299 
    300 bool MP4_Utils::is_notcodec_vop(unsigned char *pbuffer, unsigned int len)
    301 {
    302     unsigned int index = 4,vop_bits=0;
    303     unsigned int temp = vop_time_resolution - 1;
    304     unsigned char vop_type=0,modulo_bit=0,not_coded=0;
    305 
    306     if (!vop_time_found || !pbuffer || len < 5) {
    307         return false;
    308     }
    309 
    310     if ((pbuffer[0] == 0) && (pbuffer[1] == 0) && (pbuffer[2] == 1) && (pbuffer[3] == 0xB6)) {
    311         while (temp) {
    312             vop_bits++;
    313             temp >>= 1;
    314         }
    315 
    316         vop_type = (pbuffer[index] & 0xc0) >> 6;
    317         unsigned bits_parsed = 2;
    318 
    319         do {
    320             modulo_bit = pbuffer[index]  & (1 << (7-bits_parsed));
    321             bits_parsed++;
    322             index += bits_parsed/8;
    323             bits_parsed = bits_parsed %8;
    324 
    325             if (index >= len) {
    326                 return false;
    327             }
    328         } while (modulo_bit);
    329 
    330         bits_parsed++; //skip marker bit
    331         bits_parsed += vop_bits + 1;//Vop bit & Marker bits
    332         index += bits_parsed/8;
    333 
    334         if (index >= len) {
    335             return false;
    336         }
    337 
    338         bits_parsed = bits_parsed % 8;
    339         not_coded = pbuffer[index] & (1 << (7 - bits_parsed));
    340 
    341         if (!not_coded) {
    342             return true;
    343         }
    344     }
    345 
    346     return false;
    347 }
    348