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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? h.264

?? H.264編碼解碼器源碼(c語言版本)
?? 264
?? 第 1 頁 / 共 5 頁
字號(hào):

/*!
 ***********************************************************************
 *  \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"


//-------- start new Buffer code -----------------------------
static void insert_picture_in_dpb(FrameStore* fs, StorablePicture* p);
static void output_one_frame_from_dpb();
static int  is_used_for_reference(FrameStore* fs);
static void get_smallest_poc(int *poc,int * pos);
static int  remove_unused_frame_from_dpb();
static int  is_short_term_reference(FrameStore* fs);
static int  is_long_term_reference(FrameStore* fs);

DecodedPictureBuffer dpb;

StorablePicture **listX[6];

extern StorablePicture *dec_picture;

int listXsize[6];

/*!
 ************************************************************************
 * \brief
 *    Print out list of pictures in DPB. Used for debug purposes.
 ************************************************************************
 */
void dump_dpb()
{
  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)
      printf("T: poc=%d  ", dpb.fs[i]->top_field->poc);
    if (dpb.fs[i]->is_used & 2)
      printf("B: poc=%d  ", dpb.fs[i]->bottom_field->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  ");
    if (dpb.fs[i]->is_output) printf ("out  ");
    printf ("\n");
  }
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer an initialize with sane values.
 *
 * \param inp
 *    Input Parameters
 *
 ************************************************************************
 */
void init_dpb(struct inp_par *inp)
{
  unsigned i,j;

  dpb.size      = inp->dpb_size;
  dpb.used_size = 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(dpb.size * 2 + 1, 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<(2*dpb.size)+1; i++)
    {
      listX[j][i] = NULL;
    }
    listXsize[j]=0;
  }

  dpb.last_output_poc = INT_MIN;
}


/*!
 ************************************************************************
 * \brief
 *    Free memory for decoded picture buffer.
 ************************************************************************
 */
void free_dpb()
{
  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;
    }
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer frame stores an initialize with sane values.
 *
 * \return
 *    the allocated FrameStore structure
 ************************************************************************
 */
FrameStore* alloc_frame_store()
{
  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_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");

  get_mem2D (&(s->imgY), size_y, size_x);
  get_mem3D (&(s->imgUV), 2, size_y_cr, size_x_cr );

  s->mb_field = calloc (img->PicSizeInMbs, sizeof(int));

  get_mem3Dint (&(s->ref_idx), 2, size_x / BLOCK_SIZE, size_y / BLOCK_SIZE);
  get_mem3Dint (&(s->ref_pic_id), 2, size_x / BLOCK_SIZE, size_y / BLOCK_SIZE);
  get_mem4Dint (&(s->mv), 2, size_x / BLOCK_SIZE, size_y / BLOCK_SIZE,2 );

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

  s->pic_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->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->mb_adaptive_frame_field_flag  = 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)
  {
    free_mem3Dint (p->ref_idx, 2);
    free_mem3Dint (p->ref_pic_id, 2);
    free_mem4Dint (p->mv, 2, p->size_x / BLOCK_SIZE);

    if (p->moving_block)
    {
      free_mem2D (p->moving_block);
      p->moving_block=NULL;
    }
    
    if (p->imgY)
    {
      free_mem2D (p->imgY);
      p->imgY=NULL;
    }
    if (p->imgUV)
    {
      free_mem3D (p->imgUV, 2);
      p->imgUV=NULL;
    }
    
    free(p->mb_field);

    free(p);
  }
}

/*!
 ************************************************************************
 * \brief
 *    mark FrameStore unused for reference
 *
 ************************************************************************
 */
static void unmark_for_reference(FrameStore* fs)
{

  if (fs->is_used & 1)
  {
    fs->top_field->used_for_reference = 0;
  }
  if (fs->is_used & 2)
  {
    fs->bottom_field->used_for_reference = 0;
  }
  if (fs->is_used == 3)
  {
    fs->frame->used_for_reference = 0;
  }

  fs->is_reference = 0;
}


/*!
 ************************************************************************
 * \brief
 *    mark FrameStore unused for reference and reset long term flags
 *
 ************************************************************************
 */
static void unmark_for_long_term_reference(FrameStore* fs)
{

  if (fs->is_used & 1)
  {
    fs->top_field->used_for_reference = 0;
    fs->top_field->is_long_term = 0;
  }
  if (fs->is_used & 2)
  {
    fs->bottom_field->used_for_reference = 0;
    fs->bottom_field->is_long_term = 0;
  }
  if (fs->is_used == 3)
  {
    fs->frame->used_for_reference = 0;
    fs->frame->is_long_term = 0;
  }

  fs->is_reference = 0;
  fs->is_long_term = 0;
}


/*!
 ************************************************************************
 * \brief
 *    compares two stored pictures by picture number for qsort in descending order
 *
 ************************************************************************
 */
static int compare_pic_by_pic_num_desc( const void *arg1, const void *arg2 )
{
  if ( (*(StorablePicture**)arg1)->pic_num < (*(StorablePicture**)arg2)->pic_num)
    return 1;
  if ( (*(StorablePicture**)arg1)->pic_num > (*(StorablePicture**)arg2)->pic_num)
    return -1;
  else
    return 0;
}

/*!
 ************************************************************************
 * \brief
 *    compares two stored pictures by picture number for qsort in descending order
 *
 ************************************************************************
 */
static int compare_pic_by_lt_pic_num_asc( const void *arg1, const void *arg2 )
{
  if ( (*(StorablePicture**)arg1)->long_term_pic_num < (*(StorablePicture**)arg2)->long_term_pic_num)
    return -1;
  if ( (*(StorablePicture**)arg1)->long_term_pic_num > (*(StorablePicture**)arg2)->long_term_pic_num)
    return 1;
  else
    return 0;
}

/*!
 ************************************************************************
 * \brief
 *    compares two frame stores by pic_num for qsort in descending order
 *
 ************************************************************************
 */
static int compare_fs_by_frame_num_desc( const void *arg1, const void *arg2 )
{
  if ( (*(FrameStore**)arg1)->frame_num_wrap < (*(FrameStore**)arg2)->frame_num_wrap)
    return 1;
  if ( (*(FrameStore**)arg1)->frame_num_wrap > (*(FrameStore**)arg2)->frame_num_wrap)
    return -1;
  else
    return 0;
}


/*!
 ************************************************************************
 * \brief
 *    compares two frame stores by lt_pic_num for qsort in descending order
 *
 ************************************************************************
 */
static int compare_fs_by_lt_pic_idx_asc( const void *arg1, const void *arg2 )
{
  if ( (*(FrameStore**)arg1)->long_term_frame_idx < (*(FrameStore**)arg2)->long_term_frame_idx)
    return -1;
  if ( (*(FrameStore**)arg1)->long_term_frame_idx > (*(FrameStore**)arg2)->long_term_frame_idx)
    return 1;
  else
    return 0;
}


/*!
 ************************************************************************

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区性视频| 五月天一区二区| 欧美激情一区二区三区蜜桃视频| 欧美xxxx老人做受| 亚洲精品一线二线三线无人区| 欧美v日韩v国产v| 日韩欧美在线一区二区三区| 日韩区在线观看| 久久蜜桃香蕉精品一区二区三区| 久久婷婷久久一区二区三区| 久久婷婷久久一区二区三区| 欧美激情一区二区三区不卡| 一区视频在线播放| 有坂深雪av一区二区精品| 亚洲一区二区3| 天天色综合天天| 麻豆精品久久久| 国产一区二区三区四区五区入口| 国产精品乡下勾搭老头1| 欧美日韩久久久| 在线播放视频一区| 精品欧美乱码久久久久久1区2区| 国产日韩欧美制服另类| 亚洲日本va午夜在线影院| 亚洲福利视频一区二区| 另类小说视频一区二区| 国产不卡在线播放| 色欧美乱欧美15图片| 欧美精品一级二级三级| www久久精品| 亚洲免费在线观看| 天堂成人免费av电影一区| 国产真实精品久久二三区| 99久久99久久精品免费看蜜桃| 91精品办公室少妇高潮对白| 欧美一区二区视频在线观看2022| 精品欧美一区二区久久| 成人欧美一区二区三区| 日韩av在线免费观看不卡| 国产成人在线视频免费播放| 色悠久久久久综合欧美99| 日韩午夜av电影| 亚洲婷婷综合久久一本伊一区| 丝袜美腿高跟呻吟高潮一区| 成人一区二区三区视频在线观看| 在线观看欧美日本| 精品国产91乱码一区二区三区| 亚洲视频一区在线| 免费成人你懂的| 色综合一个色综合| 久久嫩草精品久久久精品一| 亚洲精品中文字幕在线观看| 精品一区二区成人精品| 在线观看国产精品网站| 久久久www成人免费毛片麻豆| 亚洲国产精品久久一线不卡| 国产精品1区2区3区| 777午夜精品免费视频| 国产日本亚洲高清| 日韩综合小视频| 色综合久久久久| 久久久久久亚洲综合影院红桃 | 国产精品网站在线| 丝袜美腿成人在线| 97久久精品人人澡人人爽| 精品处破学生在线二十三| 亚洲成人自拍偷拍| 不卡欧美aaaaa| 26uuu精品一区二区 | 在线观看免费一区| 欧美国产一区在线| 日本不卡一区二区三区高清视频| 99精品视频在线免费观看| 久久色中文字幕| 麻豆成人免费电影| 欧美性感一区二区三区| 日韩综合一区二区| 欧美亚洲国产怡红院影院| 国产欧美一区二区精品仙草咪| 美女视频一区二区三区| 欧美日韩国产a| 亚洲一区二区精品视频| 色香蕉成人二区免费| 国产精品美女久久久久久久久久久| 麻豆精品蜜桃视频网站| 91精品国产综合久久精品| 五月婷婷激情综合| 欧美日韩一区视频| 亚洲国产精品综合小说图片区| 94-欧美-setu| 国产精品传媒视频| 国产成人av电影在线| 国产亚洲污的网站| 国产一区在线不卡| 久久久亚洲综合| 国产精品正在播放| 久久久精品日韩欧美| 国产精品亚洲а∨天堂免在线| 精品国产一区二区亚洲人成毛片| 日韩av一级电影| 日韩一区二区影院| 久久精品国产第一区二区三区| 欧美一级理论片| 久久激五月天综合精品| 精品日韩一区二区三区| 久草精品在线观看| 久久久久久久国产精品影院| 精品一区二区三区免费播放| 久久婷婷一区二区三区| 国产成人在线观看免费网站| 亚洲国产成人自拍| 91性感美女视频| 亚洲欧美乱综合| 欧美日韩情趣电影| 男人的天堂亚洲一区| 久久夜色精品国产噜噜av| 国产v综合v亚洲欧| 亚洲日本在线观看| 欧美日韩国产一级| 蜜臀a∨国产成人精品| 久久久精品日韩欧美| 成人av电影在线播放| 亚洲综合丝袜美腿| 91精品国产综合久久久久久久久久| 久久成人久久爱| 国产片一区二区| 91久久香蕉国产日韩欧美9色| 亚洲大片一区二区三区| 欧美成人欧美edvon| 国产成人啪免费观看软件| 亚洲日本在线观看| 91精品国产入口| 成人涩涩免费视频| 亚洲黄色小视频| 欧美一区二区三区视频免费播放 | 成人精品小蝌蚪| 一区二区免费视频| 日韩欧美第一区| 成人免费福利片| 亚洲成人av一区二区三区| 久久久欧美精品sm网站| 久久色视频免费观看| a亚洲天堂av| 午夜精品福利一区二区蜜股av| 精品国产一二三区| 91免费国产视频网站| 老司机精品视频线观看86| 中文字幕人成不卡一区| 欧美一区二区视频在线观看2020| 岛国精品在线观看| 午夜国产不卡在线观看视频| 国产校园另类小说区| 欧美日韩精品高清| 豆国产96在线|亚洲| 婷婷国产在线综合| 中文字幕高清一区| 日韩欧美一区二区不卡| 91蜜桃免费观看视频| 国内外成人在线| 午夜精品久久久久| 国产精品久久久久久久久久久免费看 | 中文字幕中文字幕在线一区| 91精品国产综合久久精品麻豆| 99久久久精品免费观看国产蜜| 久久不见久久见免费视频1| 亚洲欧美激情在线| 国产偷国产偷精品高清尤物 | 一区二区免费视频| 国产精品污网站| 久久综合国产精品| 欧美日韩国产精品自在自线| 99综合电影在线视频| 精品无人码麻豆乱码1区2区| 亚洲二区视频在线| 中文字幕一区二区5566日韩| 精品美女一区二区| 欧美高清视频不卡网| 日本二三区不卡| av不卡在线播放| 国产精品白丝jk黑袜喷水| 青青草一区二区三区| 亚洲一二三级电影| 亚洲欧美日韩国产综合| 国产精品毛片无遮挡高清| 精品免费日韩av| 日韩一区二区三区精品视频| 欧美日韩综合不卡| 色综合av在线| 91浏览器打开| 成人av午夜电影| 成人在线视频一区二区| 国产在线视频精品一区| 精品无人码麻豆乱码1区2区| 免费观看91视频大全| 奇米精品一区二区三区在线观看一 | 亚洲三级在线看| 亚洲欧美在线视频观看| 国产精品你懂的在线欣赏| 中文字幕欧美区| 国产精品三级av在线播放|