LCOV - code coverage report
Current view: top level - media/libtheora/lib - internal.c (source / functions) Hit Total Coverage
Test: output.info Lines: 0 58 0.0 %
Date: 2017-07-14 16:53:18 Functions: 0 11 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /********************************************************************
       2             :  *                                                                  *
       3             :  * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
       4             :  * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
       5             :  * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
       6             :  * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
       7             :  *                                                                  *
       8             :  * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
       9             :  * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
      10             :  *                                                                  *
      11             :  ********************************************************************
      12             : 
      13             :   function:
      14             :     last mod: $Id: internal.c 17506 2010-10-13 02:52:41Z tterribe $
      15             : 
      16             :  ********************************************************************/
      17             : 
      18             : #include <stdlib.h>
      19             : #include <limits.h>
      20             : #include <string.h>
      21             : #include "internal.h"
      22             : 
      23             : 
      24             : 
      25             : /*A map from the index in the zig zag scan to the coefficient number in a
      26             :    block.
      27             :   All zig zag indices beyond 63 are sent to coefficient 64, so that zero runs
      28             :    past the end of a block in bogus streams get mapped to a known location.*/
      29             : const unsigned char OC_FZIG_ZAG[128]={
      30             :    0, 1, 8,16, 9, 2, 3,10,
      31             :   17,24,32,25,18,11, 4, 5,
      32             :   12,19,26,33,40,48,41,34,
      33             :   27,20,13, 6, 7,14,21,28,
      34             :   35,42,49,56,57,50,43,36,
      35             :   29,22,15,23,30,37,44,51,
      36             :   58,59,52,45,38,31,39,46,
      37             :   53,60,61,54,47,55,62,63,
      38             :   64,64,64,64,64,64,64,64,
      39             :   64,64,64,64,64,64,64,64,
      40             :   64,64,64,64,64,64,64,64,
      41             :   64,64,64,64,64,64,64,64,
      42             :   64,64,64,64,64,64,64,64,
      43             :   64,64,64,64,64,64,64,64,
      44             :   64,64,64,64,64,64,64,64,
      45             :   64,64,64,64,64,64,64,64
      46             : };
      47             : 
      48             : /*A map from the coefficient number in a block to its index in the zig zag
      49             :    scan.*/
      50             : const unsigned char OC_IZIG_ZAG[64]={
      51             :    0, 1, 5, 6,14,15,27,28,
      52             :    2, 4, 7,13,16,26,29,42,
      53             :    3, 8,12,17,25,30,41,43,
      54             :    9,11,18,24,31,40,44,53,
      55             :   10,19,23,32,39,45,52,54,
      56             :   20,22,33,38,46,51,55,60,
      57             :   21,34,37,47,50,56,59,61,
      58             :   35,36,48,49,57,58,62,63
      59             : };
      60             : 
      61             : /*A map from physical macro block ordering to bitstream macro block
      62             :    ordering within a super block.*/
      63             : const unsigned char OC_MB_MAP[2][2]={{0,3},{1,2}};
      64             : 
      65             : /*A list of the indices in the oc_mb.map array that can be valid for each of
      66             :    the various chroma decimation types.*/
      67             : const unsigned char OC_MB_MAP_IDXS[TH_PF_NFORMATS][12]={
      68             :   {0,1,2,3,4,8},
      69             :   {0,1,2,3,4,5,8,9},
      70             :   {0,1,2,3,4,6,8,10},
      71             :   {0,1,2,3,4,5,6,7,8,9,10,11}
      72             : };
      73             : 
      74             : /*The number of indices in the oc_mb.map array that can be valid for each of
      75             :    the various chroma decimation types.*/
      76             : const unsigned char OC_MB_MAP_NIDXS[TH_PF_NFORMATS]={6,8,8,12};
      77             : 
      78             : /*The number of extra bits that are coded with each of the DCT tokens.
      79             :   Each DCT token has some fixed number of additional bits (possibly 0) stored
      80             :    after the token itself, containing, for example, coefficient magnitude,
      81             :    sign bits, etc.*/
      82             : const unsigned char OC_DCT_TOKEN_EXTRA_BITS[TH_NDCT_TOKENS]={
      83             :   0,0,0,2,3,4,12,3,6,
      84             :   0,0,0,0,
      85             :   1,1,1,1,2,3,4,5,6,10,
      86             :   1,1,1,1,1,3,4,
      87             :   2,3
      88             : };
      89             : 
      90             : 
      91             : 
      92           0 : int oc_ilog(unsigned _v){
      93             :   int ret;
      94           0 :   for(ret=0;_v;ret++)_v>>=1;
      95           0 :   return ret;
      96             : }
      97             : 
      98             : 
      99             : 
     100           0 : void *oc_aligned_malloc(size_t _sz,size_t _align){
     101             :   unsigned char *p;
     102           0 :   if(_align-1>UCHAR_MAX||(_align&_align-1)||_sz>~(size_t)0-_align)return NULL;
     103           0 :   p=(unsigned char *)_ogg_malloc(_sz+_align);
     104           0 :   if(p!=NULL){
     105             :     int offs;
     106           0 :     offs=((p-(unsigned char *)0)-1&_align-1);
     107           0 :     p[offs]=offs;
     108           0 :     p+=offs+1;
     109             :   }
     110           0 :   return p;
     111             : }
     112             : 
     113           0 : void oc_aligned_free(void *_ptr){
     114             :   unsigned char *p;
     115           0 :   p=(unsigned char *)_ptr;
     116           0 :   if(p!=NULL){
     117             :     int offs;
     118           0 :     offs=*--p;
     119           0 :     _ogg_free(p-offs);
     120             :   }
     121           0 : }
     122             : 
     123             : 
     124           0 : void **oc_malloc_2d(size_t _height,size_t _width,size_t _sz){
     125             :   size_t  rowsz;
     126             :   size_t  colsz;
     127             :   size_t  datsz;
     128             :   char   *ret;
     129           0 :   colsz=_height*sizeof(void *);
     130           0 :   rowsz=_sz*_width;
     131           0 :   datsz=rowsz*_height;
     132             :   /*Alloc array and row pointers.*/
     133           0 :   ret=(char *)_ogg_malloc(datsz+colsz);
     134           0 :   if(ret==NULL)return NULL;
     135             :   /*Initialize the array.*/
     136           0 :   if(ret!=NULL){
     137             :     size_t   i;
     138             :     void   **p;
     139             :     char    *datptr;
     140           0 :     p=(void **)ret;
     141           0 :     i=_height;
     142           0 :     for(datptr=ret+colsz;i-->0;p++,datptr+=rowsz)*p=(void *)datptr;
     143             :   }
     144           0 :   return (void **)ret;
     145             : }
     146             : 
     147           0 : void **oc_calloc_2d(size_t _height,size_t _width,size_t _sz){
     148             :   size_t  colsz;
     149             :   size_t  rowsz;
     150             :   size_t  datsz;
     151             :   char   *ret;
     152           0 :   colsz=_height*sizeof(void *);
     153           0 :   rowsz=_sz*_width;
     154           0 :   datsz=rowsz*_height;
     155             :   /*Alloc array and row pointers.*/
     156           0 :   ret=(char *)_ogg_calloc(datsz+colsz,1);
     157           0 :   if(ret==NULL)return NULL;
     158             :   /*Initialize the array.*/
     159           0 :   if(ret!=NULL){
     160             :     size_t   i;
     161             :     void   **p;
     162             :     char    *datptr;
     163           0 :     p=(void **)ret;
     164           0 :     i=_height;
     165           0 :     for(datptr=ret+colsz;i-->0;p++,datptr+=rowsz)*p=(void *)datptr;
     166             :   }
     167           0 :   return (void **)ret;
     168             : }
     169             : 
     170           0 : void oc_free_2d(void *_ptr){
     171           0 :   _ogg_free(_ptr);
     172           0 : }
     173             : 
     174             : /*Fills in a Y'CbCr buffer with a pointer to the image data in the first
     175             :    buffer, but with the opposite vertical orientation.
     176             :   _dst: The destination buffer.
     177             :         This can be the same as _src.
     178             :   _src: The source buffer.*/
     179           0 : void oc_ycbcr_buffer_flip(th_ycbcr_buffer _dst,
     180             :  const th_ycbcr_buffer _src){
     181             :   int pli;
     182           0 :   for(pli=0;pli<3;pli++){
     183           0 :     _dst[pli].width=_src[pli].width;
     184           0 :     _dst[pli].height=_src[pli].height;
     185           0 :     _dst[pli].stride=-_src[pli].stride;
     186           0 :     _dst[pli].data=_src[pli].data
     187           0 :      +(1-_dst[pli].height)*(ptrdiff_t)_dst[pli].stride;
     188             :   }
     189           0 : }
     190             : 
     191           0 : const char *th_version_string(void){
     192           0 :   return OC_VENDOR_STRING;
     193             : }
     194             : 
     195           0 : ogg_uint32_t th_version_number(void){
     196           0 :   return (TH_VERSION_MAJOR<<16)+(TH_VERSION_MINOR<<8)+TH_VERSION_SUB;
     197             : }
     198             : 
     199             : /*Determines the packet type.
     200             :   Note that this correctly interprets a 0-byte packet as a video data packet.
     201             :   Return: 1 for a header packet, 0 for a data packet.*/
     202           0 : int th_packet_isheader(ogg_packet *_op){
     203           0 :   return _op->bytes>0?_op->packet[0]>>7:0;
     204             : }
     205             : 
     206             : /*Determines the frame type of a video data packet.
     207             :   Note that this correctly interprets a 0-byte packet as a delta frame.
     208             :   Return: 1 for a key frame, 0 for a delta frame, and -1 for a header
     209             :            packet.*/
     210           0 : int th_packet_iskeyframe(ogg_packet *_op){
     211           0 :   return _op->bytes<=0?0:_op->packet[0]&0x80?-1:!(_op->packet[0]&0x40);
     212             : }

Generated by: LCOV version 1.13