亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mbuffer.c

?? H.264的編碼器
?? C
?? 第 1 頁 / 共 5 頁
字號:

/*!
 ***********************************************************************
 *  \file
 *      mbuffer.c
 *
 *  \brief
 *      Frame buffer functions
 *
 *  \author
 *      Main contributors (see contributors.h for copyright, address and affiliation details)
 *      - Karsten S黨ring                 <suehring@hhi.de>
 *      - Alexis Tourapis                 <alexismt@ieee.org>
 ***********************************************************************
 */

#include <stdlib.h>
#include <assert.h>
#include <limits.h>
#include <string.h>

#include "global.h"
#include "mbuffer.h"
#include "memalloc.h"
#include "output.h"
#include "image.h"

static void insert_picture_in_dpb(FrameStore* fs, StorablePicture* p);
static void output_one_frame_from_dpb(void);
static int  is_used_for_reference(FrameStore* fs);
static void get_smallest_poc(int *poc,int * pos);
static int  remove_unused_frame_from_dpb(void);
static int  is_short_term_reference(FrameStore* fs);
static int  is_long_term_reference(FrameStore* fs);
void gen_field_ref_ids(StorablePicture *p);

DecodedPictureBuffer dpb;

StorablePicture **listX[6];

ColocatedParams *Co_located = NULL;


int listXsize[6];

#define MAX_LIST_SIZE 33

/*!
 ************************************************************************
 * \brief
 *    Print out list of pictures in DPB. Used for debug purposes.
 ************************************************************************
 */
void dump_dpb(void)
{
  unsigned i;

  return;
  
  for (i=0; i<dpb.used_size;i++)
  {
    printf("(");
    printf("fn=%d  ", dpb.fs[i]->frame_num);
    if (dpb.fs[i]->is_used & 1)
    {
      if (dpb.fs[i]->top_field)
        printf("T: poc=%d  ", dpb.fs[i]->top_field->poc);
      else
        printf("T: poc=%d  ", dpb.fs[i]->frame->top_poc);
    }
    if (dpb.fs[i]->is_used & 2)
    {
      if (dpb.fs[i]->bottom_field)
        printf("B: poc=%d  ", dpb.fs[i]->bottom_field->poc);
      else
        printf("B: poc=%d  ", dpb.fs[i]->frame->bottom_poc);
    }
    if (dpb.fs[i]->is_used == 3)
      printf("F: poc=%d  ", dpb.fs[i]->frame->poc);
    printf("G: poc=%d)  ", dpb.fs[i]->poc);
    if (dpb.fs[i]->is_reference) printf ("ref (%d) ", dpb.fs[i]->is_reference);
    if (dpb.fs[i]->is_long_term) printf ("lt_ref (%d) ", dpb.fs[i]->is_reference);
    if (dpb.fs[i]->is_output) printf ("out  ");
    if (dpb.fs[i]->is_used == 3)
    {
      if (dpb.fs[i]->frame->non_existing) printf ("ne  ");
    }
    printf ("\n");
  }
}

/*!
 ************************************************************************
 * \brief
 *    Returns the size of the dpb depending on level and picture size
 *
 *
 ************************************************************************
 */
int getDpbSize(void)
{
  int pic_size = (active_sps->pic_width_in_mbs_minus1 + 1) * (active_sps->pic_height_in_map_units_minus1 + 1) * (active_sps->frame_mbs_only_flag?1:2) * 384;

  int size = 0;

  switch (active_sps->level_idc)
  {
  case 10:
    size = 152064;
    break;
  case 11:
    size = 345600;
    break;
  case 12:
    size = 912384;
    break;
  case 13:
    size = 912384;
    break;
  case 20:
    size = 912384;
    break;
  case 21:
    size = 1824768;
    break;
  case 22:
    size = 3110400;
    break;
  case 30:
    size = 3110400;
    break;
  case 31:
    size = 6912000;
    break;
  case 32:
    size = 7864320;
    break;
  case 40:
    size = 12582912;
    break;
  case 41:
    size = 12582912;
    break;
 case 42:
   if(  (active_sps->profile_idc==FREXT_HP   ) || (active_sps->profile_idc==FREXT_Hi10P)
     || (active_sps->profile_idc==FREXT_Hi422) || (active_sps->profile_idc==FREXT_Hi444))
     size = 13369344;
   else
     size = 12582912;
   break; 
  case 50:
    size = 42393600;
    break;
  case 51:
    size = 70778880;
    break;
  default:
    error ("undefined level", 500);
    break;
  }

  size /= pic_size;
  return min( size, 16);
}

/*!
 ************************************************************************
 * \brief
 *    Check then number of frames marked "used for reference" and break 
 *    if maximum is exceeded
 *
 ************************************************************************
 */
void check_num_ref(void)
{
  if ((int)(dpb.ltref_frames_in_buffer +  dpb.ref_frames_in_buffer ) > (max(1,img->num_ref_frames)))
  {
    error ("Max. number of reference frames exceeded. Invalid stream.", 500);
  }
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer and initialize with sane values.
 *
 ************************************************************************
 */
void init_dpb(void)
{
  unsigned i,j;

  if (dpb.init_done)
  {
    free_dpb();
  }

  dpb.size      = getDpbSize();
  
  if (dpb.size < (unsigned int)input->num_ref_frames)
  {
    error ("DPB size at specified level is smaller than the specified number of reference frames. This is not allowed.\n", 1000);
  }

  dpb.used_size = 0;
  dpb.last_picture = NULL;

  dpb.ref_frames_in_buffer = 0;
  dpb.ltref_frames_in_buffer = 0;
  
  dpb.fs = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs) 
    no_mem_exit("init_dpb: dpb->fs");

  dpb.fs_ref = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs_ref) 
    no_mem_exit("init_dpb: dpb->fs_ref");

  dpb.fs_ltref = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs_ltref) 
    no_mem_exit("init_dpb: dpb->fs_ltref");

  for (i=0; i<dpb.size; i++)
  {
    dpb.fs[i]       = alloc_frame_store();
    dpb.fs_ref[i]   = NULL;
    dpb.fs_ltref[i] = NULL;
  }
  
  for (i=0; i<6; i++)
  {
    listX[i] = calloc(MAX_LIST_SIZE, sizeof (StorablePicture*)); // +1 for reordering
    if (NULL==listX[i]) 
      no_mem_exit("init_dpb: listX[i]");
  }

  for (j=0;j<6;j++)
  {
    for (i=0; i<MAX_LIST_SIZE; i++)
    {
      listX[j][i] = NULL;
    }
    listXsize[j]=0;
  }

  dpb.last_output_poc = INT_MIN;

  img->last_has_mmco_5 = 0;

  dpb.init_done = 1;
}


/*!
 ************************************************************************
 * \brief
 *    Free memory for decoded picture buffer.
 ************************************************************************
 */
void free_dpb(void)
{
  unsigned i;
  if (dpb.fs)
  {
    for (i=0; i<dpb.size; i++)
    {
      free_frame_store(dpb.fs[i]);
    }
    free (dpb.fs);
    dpb.fs=NULL;
  }
  if (dpb.fs_ref)
  {
    free (dpb.fs_ref);
  }
  if (dpb.fs_ltref)
  {
    free (dpb.fs_ltref);
  }
  dpb.last_output_poc = INT_MIN;

  for (i=0; i<6; i++)
    if (listX[i])
    {
      free (listX[i]);
      listX[i] = NULL;
    }

  dpb.init_done = 0;
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer frame stores an initialize with sane values.
 *
 * \return
 *    the allocated FrameStore structure
 ************************************************************************
 */
FrameStore* alloc_frame_store(void)
{
  FrameStore *f;

  f = calloc (1, sizeof(FrameStore));
  if (NULL==f) 
    no_mem_exit("alloc_frame_store: f");

  f->is_used      = 0;
  f->is_reference = 0;
  f->is_long_term = 0;
  f->is_orig_reference = 0;

  f->is_output = 0;

  f->frame        = NULL;;
  f->top_field    = NULL;
  f->bottom_field = NULL;

  return f;
}

/*!
 ************************************************************************
 * \brief
 *    Allocate memory for a stored picture. 
 *
 * \param structure
 *    picture structure
 * \param size_x
 *    horizontal luma size
 * \param size_y
 *    vertical luma size
 * \param size_x_cr
 *    horizontal chroma size
 * \param size_y_cr
 *    vertical chroma size
 *
 * \return
 *    the allocated StorablePicture structure
 ************************************************************************
 */
StorablePicture* alloc_storable_picture(PictureStructure structure, int size_x, int size_y, int size_x_cr, int size_y_cr)
{
  StorablePicture *s;

  //printf ("Allocating (%s) picture (x=%d, y=%d, x_cr=%d, y_cr=%d)\n", (type == FRAME)?"FRAME":(type == TOP_FIELD)?"TOP_FIELD":"BOTTOM_FIELD", size_x, size_y, size_x_cr, size_y_cr);

  s = calloc (1, sizeof(StorablePicture));
  if (NULL==s) 
    no_mem_exit("alloc_storable_picture: s");

  s->imgY_11  = NULL;
  s->imgY_ups = NULL;
  s->imgUV    = NULL;

  if (input->WeightedPrediction || input->WeightedBiprediction || input->GenerateMultiplePPS)
  {
      s->imgY_11_w = NULL;
      s->imgY_ups_w = NULL;
  }

  get_mem2Dpel (&(s->imgY), size_y, size_x);
  if (img->yuv_format != YUV400)
    get_mem3Dpel (&(s->imgUV), 2, size_y_cr, size_x_cr);

  s->mb_field = calloc (img->PicSizeInMbs, sizeof(int));
  if (NULL==s->mb_field) 
    no_mem_exit("alloc_storable_picture: s->mb_field");

  get_mem3D      ((byte****)(&(s->ref_idx)),    2, size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);
  get_mem3Dint64 (&(s->ref_pic_id), 6, size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);
  get_mem3Dint64 (&(s->ref_id),     6, size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);
  get_mem4Dshort (&(s->mv),         2, size_y / BLOCK_SIZE, size_x / BLOCK_SIZE, 2);

  get_mem2D (&(s->moving_block),       size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);
  get_mem2D (&(s->field_frame),        size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);

  s->pic_num=0;
  s->frame_num=0;
  s->long_term_frame_idx=0;
  s->long_term_pic_num=0;
  s->used_for_reference=0;
  s->is_long_term=0;
  s->non_existing=0;
  s->is_output = 0;

  s->structure=structure;

  s->size_x = size_x;
  s->size_y = size_y;
  s->size_x_cr = size_x_cr;
  s->size_y_cr = size_y_cr;
  
  s->top_field    = NULL;
  s->bottom_field = NULL;
  s->frame        = NULL;

  s->coded_frame    = 0;
  s->MbaffFrameFlag = 0;

  return s;
}

/*!
 ************************************************************************
 * \brief
 *    Free frame store memory.
 *
 * \param f
 *    FrameStore to be freed
 *
 ************************************************************************
 */
void free_frame_store(FrameStore* f)
{
  if (f)
  {
    if (f->frame)
    {
      free_storable_picture(f->frame);
      f->frame=NULL;
    }
    if (f->top_field)
    {
      free_storable_picture(f->top_field);
      f->top_field=NULL;
    }
    if (f->bottom_field)
    {
      free_storable_picture(f->bottom_field);
      f->bottom_field=NULL;
    }
    free(f);
  }
}

/*!
 ************************************************************************
 * \brief
 *    Free picture memory.
 *
 * \param p
 *    Picture to be freed
 *
 ************************************************************************
 */
void free_storable_picture(StorablePicture* p)
{
  if (p)
  {
    if (p->ref_idx)
    {
      free_mem3D ((byte***)p->ref_idx, 2);
      p->ref_idx = NULL;
    }
    
    if (p->ref_pic_id)
    {
      free_mem3Dint64 (p->ref_pic_id, 6);
      p->ref_pic_id = NULL;
    }
    if (p->ref_id)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品二区第二页| 国产一区美女在线| 91在线视频网址| 日韩欧美一级二级| 国产精品网站在线| 成人精品鲁一区一区二区| 久久精品在这里| 99久久综合色| 自拍偷拍欧美精品| 欧美在线视频全部完| 亚洲成av人影院在线观看网| 欧美人体做爰大胆视频| 蜜臀av国产精品久久久久| 欧美mv日韩mv国产网站| 国产·精品毛片| 一区二区三区不卡视频| 91精品国产综合久久精品app| 麻豆国产欧美日韩综合精品二区| 久久亚洲综合色一区二区三区 | 色天天综合色天天久久| 亚洲成a人片综合在线| 欧美成人精品福利| 成人黄动漫网站免费app| 亚洲精选视频在线| 日韩一区二区三区视频在线| 国产精品一二三区| 亚洲在线观看免费视频| 日韩精品自拍偷拍| a级精品国产片在线观看| 亚洲第一会所有码转帖| 精品久久久久久无| 99精品久久只有精品| 日韩电影一区二区三区| 国产精品电影一区二区三区| 91精品国产综合久久久久久漫画| 国产aⅴ综合色| 日韩成人免费看| 国产精品理论在线观看| 欧美一区二区三区视频免费| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 蜜桃久久久久久| 欧美国产成人在线| 日本韩国欧美在线| 亚洲欧洲av在线| 欧美一级欧美三级在线观看| a亚洲天堂av| 黄页网站大全一区二区| 一区二区在线观看视频在线观看| 精品免费国产一区二区三区四区| www.亚洲激情.com| 激情另类小说区图片区视频区| 一二三四区精品视频| 亚洲国产精品成人综合| 国产成人三级在线观看| 亚洲v中文字幕| 中文字幕在线免费不卡| 26uuu亚洲综合色欧美| 欧美日韩国产一级| av一区二区不卡| 国产一区二区不卡| 蜜臀av性久久久久蜜臀aⅴ流畅| 一区二区三区四区av| 中文字幕欧美激情| 国产亚洲欧美日韩日本| 日韩欧美国产1| 亚洲一卡二卡三卡四卡五卡| 一区二区三区在线影院| 欧美经典一区二区三区| 日韩欧美国产系列| 91精品国产综合久久福利软件| 欧美日韩在线亚洲一区蜜芽| 91免费精品国自产拍在线不卡| 国产福利电影一区二区三区| 九九九久久久精品| 久久精品国产77777蜜臀| 奇米精品一区二区三区在线观看一| 亚洲欧美另类小说视频| 亚洲伦理在线免费看| 一区二区三区在线高清| 亚洲精品免费视频| 亚洲一级电影视频| 午夜伦欧美伦电影理论片| 香蕉影视欧美成人| 午夜私人影院久久久久| 视频一区二区三区入口| 美女一区二区三区| 久久99久久久欧美国产| 国产在线看一区| 丁香婷婷综合激情五月色| www.爱久久.com| 91视频在线观看| 在线观看日韩毛片| 欧美精三区欧美精三区| 日韩女优毛片在线| 久久久久久久免费视频了| 国产精品拍天天在线| 亚洲毛片av在线| 亚洲成av人影院在线观看网| 美腿丝袜一区二区三区| 91国偷自产一区二区开放时间| 91免费视频网| 欧美伦理影视网| 欧美美女一区二区三区| 精品美女一区二区三区| 国产婷婷精品av在线| 亚洲人成7777| 蜜臀a∨国产成人精品| 国产91色综合久久免费分享| 色94色欧美sute亚洲13| 欧美高清性hdvideosex| 精品国产91九色蝌蚪| 日韩伦理电影网| 亚洲成av人片在线观看无码| 久久成人18免费观看| 99久久99精品久久久久久| 欧美日韩精品欧美日韩精品一综合| 欧美一区二区三区在| 久久亚洲免费视频| 欧美男女性生活在线直播观看| 精品电影一区二区| 亚洲精品国产a| 激情国产一区二区| 色老汉一区二区三区| 91日韩在线专区| 欧美军同video69gay| 久久一区二区三区四区| 亚洲一区二区三区四区不卡| 国产最新精品免费| 欧美探花视频资源| 日本一区二区三级电影在线观看| 天天综合天天综合色| 国产99久久久精品| 欧美一级生活片| 亚洲黄色小视频| 国产一区二区三区香蕉| 欧美日韩免费在线视频| 国产精品大尺度| 美女爽到高潮91| 91香蕉视频在线| 欧美xxx久久| 一个色综合av| 91美女视频网站| 2欧美一区二区三区在线观看视频| 亚洲伊人伊色伊影伊综合网| 国产成人精品亚洲777人妖| 欧美一级生活片| 天堂在线亚洲视频| 91久久精品国产91性色tv| 国产日韩欧美在线一区| 五月婷婷久久丁香| 日本高清无吗v一区| 国产精品欧美久久久久无广告| 蜜臀a∨国产成人精品| 51午夜精品国产| 亚洲电影视频在线| 91国偷自产一区二区开放时间| 国产精品电影一区二区三区| 国产精品88888| 日韩精品中午字幕| 天天综合日日夜夜精品| 91国产精品成人| 亚洲欧美视频在线观看视频| 成人精品一区二区三区中文字幕| 久久夜色精品国产噜噜av| 精东粉嫩av免费一区二区三区| 欧美一级专区免费大片| 久久精品国产第一区二区三区 | 国产999精品久久| 精品噜噜噜噜久久久久久久久试看| 午夜精品福利一区二区三区av| 色8久久精品久久久久久蜜| 一区二区三区国产精品| 在线观看视频91| 午夜久久久影院| 91精品国产福利| 久久成人18免费观看| 精品国偷自产国产一区| 精品午夜一区二区三区在线观看| 精品国产乱码久久久久久浪潮| 狠狠色丁香久久婷婷综合_中| 欧美va天堂va视频va在线| 国产呦萝稀缺另类资源| 久久久精品天堂| av中文字幕在线不卡| 亚洲老妇xxxxxx| 欧美日韩另类一区| 久久精品国产精品青草| 国产欧美日韩中文久久| 成人性生交大片免费看在线播放 | 久久久青草青青国产亚洲免观| 国产精品综合二区| 91精品免费在线| 91精品国产一区二区| 麻豆久久久久久| 国产人伦精品一区二区| 色综合久久99| 亚洲视频精选在线| 欧美日韩精品一区二区天天拍小说| 视频在线观看91| 精品欧美一区二区三区精品久久|