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

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

?? mbuffer.c

?? JM 11.0 KTA 2.1 Source Code
?? 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"
#ifdef ADAPTIVE_FILTER
#include "adaptive_filter.h"
#endif
#ifdef ADAPTIVE_FD_SD_CODING
#include "mbuffer.h"
#endif

#ifdef SWITCHED_FILTERS
#include "switched_filters.h"
#endif  // SWITCHED_FILTERS

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;
#ifdef ADAPTIVE_FILTER
  s->imgY_ups_aif = NULL;
  s->imgY_ups_aif_hor = NULL; //separable aif
  s->p_imgY_ups_aif = NULL;
#ifdef E_DAIF
  s->imgY_11_aif = NULL;
  s->p_imgY_11_aif = NULL;
#endif  // E_DAIF 
#endif  // ADAPTIVE_FILTER

#ifdef SWITCHED_FILTERS
  get_mem2Dpel (&(s->imgY_filt), size_y, size_x);  
  s->imgY_11_filt = malloc ((size_x * size_y) * sizeof (imgpel));
  s->p_imgY_filt = NULL;  
  s->p_imgY_11_filt = NULL;  
#endif  // SWITCHED_FILTERS

  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
*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩电影在线一区| 亚洲蜜臀av乱码久久精品蜜桃| 91视视频在线观看入口直接观看www| 国产剧情av麻豆香蕉精品| 色综合久久九月婷婷色综合| 777xxx欧美| 亚洲黄色av一区| 成人sese在线| 国产精品天美传媒沈樵| 精品一区免费av| 欧美一级午夜免费电影| 亚洲r级在线视频| 欧美人体做爰大胆视频| 亚洲成人精品影院| 欧美亚洲自拍偷拍| 亚洲成av人**亚洲成av**| 国产乱码精品一区二区三区五月婷| 欧美少妇bbb| 丝袜亚洲另类丝袜在线| 8v天堂国产在线一区二区| 图片区小说区区亚洲影院| 色噜噜夜夜夜综合网| 亚洲成人av一区| 欧美一区二区三区四区五区 | 亚洲精品欧美二区三区中文字幕| 99精品国产热久久91蜜凸| 伊人色综合久久天天| 日韩精品一区二区三区在线观看| 国产传媒欧美日韩成人| 亚洲国产日产av| 久久精品夜色噜噜亚洲a∨| 91久久精品一区二区| 国产一区二区三区免费看 | 国产在线一区二区| 综合久久久久综合| 精品久久久久久综合日本欧美| 99精品偷自拍| 成人在线综合网| 国产制服丝袜一区| 日本va欧美va瓶| 午夜精品久久久久久久| 成人免费在线播放视频| 精品国产区一区| 欧美xfplay| 精品国精品国产| 日韩欧美三级在线| 91精品国产综合久久久久久| 91一区一区三区| 成人av在线电影| 99热99精品| www..com久久爱| 99国产精品国产精品久久| 国产成人免费视频网站| 久久不见久久见免费视频1| 日韩综合小视频| 日本不卡的三区四区五区| 免费观看久久久4p| 男女男精品视频| 国内成+人亚洲+欧美+综合在线| 国内精品免费**视频| 久久99精品久久久久久| 极品少妇xxxx精品少妇偷拍 | 午夜精品一区二区三区免费视频 | 92国产精品观看| 色综合天天综合给合国产| 欧美亚洲图片小说| 欧美一级日韩一级| 国产偷国产偷精品高清尤物| 亚洲免费av观看| 另类中文字幕网| 91香蕉视频黄| 91精品麻豆日日躁夜夜躁| 久久久久久久综合日本| 亚洲欧洲精品一区二区三区| 亚洲自拍偷拍九九九| 麻豆成人久久精品二区三区红| 成人av电影在线播放| 欧美日韩精品一区二区三区| 精品国产区一区| 1000部国产精品成人观看| 乱一区二区av| 欧美伊人久久大香线蕉综合69| 精品久久一区二区三区| 亚洲国产精品久久一线不卡| 国产盗摄视频一区二区三区| 欧美一区二区三区免费观看视频| 久久精品视频免费| 久久精品av麻豆的观看方式| 在线观看中文字幕不卡| 国产欧美一区二区精品性| 韩国成人福利片在线播放| 91精品久久久久久久99蜜桃| 亚洲另类中文字| 色屁屁一区二区| 日韩码欧中文字| 成人福利在线看| 亚洲国产成人午夜在线一区| 国产在线视频一区二区三区| 日韩午夜在线观看| 久久精品国产亚洲a| 26uuu国产在线精品一区二区| 亚洲欧洲制服丝袜| 色综合天天性综合| 亚洲精品国产第一综合99久久| 成人午夜免费av| 亚洲视频一区二区在线| 色呦呦国产精品| 亚洲成人av电影| 欧美一区二区三区视频免费 | 99re这里只有精品视频首页| 国产精品国产馆在线真实露脸| 成人精品视频一区二区三区 | 顶级嫩模精品视频在线看| 久久女同互慰一区二区三区| 成人免费视频caoporn| 一区二区三区蜜桃网| 欧美日韩国产综合视频在线观看| 午夜在线成人av| 久久午夜老司机| 日本精品裸体写真集在线观看| 午夜久久久久久久久久一区二区| 欧美tickling挠脚心丨vk| 国产精品123区| 一区二区三区成人| 欧美va在线播放| 97aⅴ精品视频一二三区| 青青草国产精品97视觉盛宴| 亚洲欧洲国产日韩| 精品捆绑美女sm三区| 日本韩国一区二区三区| 狠狠色伊人亚洲综合成人| 天堂一区二区在线| 国产精品久99| 这里只有精品视频在线观看| 99久久精品99国产精品 | 日韩精品欧美成人高清一区二区| xvideos.蜜桃一区二区| 欧美日韩中字一区| 成人白浆超碰人人人人| 3d成人动漫网站| 日韩精品高清不卡| 91福利小视频| 国产美女娇喘av呻吟久久| 午夜不卡av免费| 亚洲一区二区三区精品在线| 国产精品少妇自拍| 国产精品久久久久四虎| 亚洲国产精品av| 国产精品久久久久久久久晋中 | 国产99久久久精品| 日韩高清一区在线| 香蕉成人伊视频在线观看| 亚洲欧美日韩国产综合在线| 国产精品理论在线观看| 国产精品久久久久久久久晋中 | 欧美a级一区二区| 久久机这里只有精品| 久久精品国产亚洲高清剧情介绍| 日韩精品一区第一页| 麻豆视频观看网址久久| 激情综合色综合久久综合| 黑人巨大精品欧美黑白配亚洲| 国产九色sp调教91| www.欧美色图| 欧美电影在哪看比较好| 精品久久久久香蕉网| 亚洲人成7777| 蜜桃久久av一区| 99久久免费视频.com| 欧美视频一区在线观看| 精品噜噜噜噜久久久久久久久试看| 久久精品人人做人人爽97| 一区二区三区在线免费播放| 久久aⅴ国产欧美74aaa| 99久久精品国产导航| 欧美v国产在线一区二区三区| 国产精品免费免费| 男男gaygay亚洲| 欧美综合一区二区| 久久久三级国产网站| 亚洲丰满少妇videoshd| 成人一区二区三区| ww久久中文字幕| 午夜精品aaa| 欧洲精品在线观看| 一区二区欧美国产| 粉嫩av一区二区三区| 538在线一区二区精品国产| 国产精品国产馆在线真实露脸| 国产制服丝袜一区| 欧美一区国产二区| 日韩精品乱码av一区二区| 色综合久久久网| 亚洲欧洲成人精品av97| 成人精品鲁一区一区二区| 久久久美女毛片| 国产91精品精华液一区二区三区| 久久综合久久综合久久| 国内外成人在线视频| 久久久91精品国产一区二区精品|