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

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

?? mbuffer.c

?? jm_frext22.ZIP的壓縮文件,主要用于嵌入式系統(tǒng)圖象的編解碼的開發(fā).
?? 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"
#include "header.h"

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);
void gen_field_ref_ids(StorablePicture *p);

DecodedPictureBuffer dpb;

StorablePicture **listX[6];

ColocatedParams *Co_located = NULL;

extern StorablePicture *dec_picture;

int listXsize[6];

#define MAX_LIST_SIZE 33

/*!
 ************************************************************************
 * \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 (%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()
{
  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:
    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
 *    Allocate memory for decoded picture buffer and initialize with sane values.
 *
 ************************************************************************
 */
void init_dpb()
{
  unsigned i,j;

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

  dpb.size      = getDpbSize();
  dpb.num_ref_frames = active_sps->num_ref_frames;

  if (0==dpb.size)
  {
    printf("warning: DPB size of zero frames at specified level / frame size. Decoding may fail.\n");
  }
//  dpb.size      = input->dpb_size;
  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()
{
  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()
{
  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");

  if (structure!=FRAME)
  {
    size_y    /= 2;
    size_y_cr /= 2; 
  }

  s->PicSizeInMbs                  = (size_x*size_y)/256;

  get_mem2Dpel (&(s->imgY), size_y, size_x);
  get_mem3Dpel (&(s->imgUV), 2, size_y_cr, size_x_cr);

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

  get_mem2Dint (&(s->slice_id), size_x / MB_BLOCK_SIZE, size_y / MB_BLOCK_SIZE);

  get_mem3Dint (&(s->ref_idx), 2, size_x / BLOCK_SIZE, size_y / BLOCK_SIZE);
  get_mem3Dint64 (&(s->ref_pic_id), 6, size_x / BLOCK_SIZE, size_y / BLOCK_SIZE);
  get_mem3Dint64 (&(s->ref_id), 6, 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);
  get_mem2D (&(s->field_frame), size_x / BLOCK_SIZE, size_y / 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->max_slice_id = 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->dec_ref_pic_marking_buffer = 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)
  {
    free_mem2Dint   (p->slice_id);
    free_mem3Dint   (p->ref_idx, 2);
    free_mem3Dint64 (p->ref_pic_id, 6);
    free_mem3Dint64 (p->ref_id, 6);
    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->field_frame)
    {
      free_mem2D (p->field_frame);
      p->field_frame=NULL;
    }

    
    if (p->imgY)
    {
      free_mem2Dpel (p->imgY);
      p->imgY=NULL;
    }
    if (p->imgUV)
    {
      free_mem3Dpel (p->imgUV, 2);
      p->imgUV=NULL;
    }
    
    free(p->mb_field);

    free(p);
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
激情五月播播久久久精品| 亚洲成人激情av| 久久亚洲精品国产精品紫薇 | 欧美猛男gaygay网站| 91在线丨porny丨国产| 国产成人精品免费一区二区| 激情综合五月婷婷| 国产精品资源网| 国产乱子伦一区二区三区国色天香| 久久国产精品一区二区| 蜜桃av噜噜一区| 国产高清亚洲一区| 粉嫩高潮美女一区二区三区| 国产精品99久| 99re8在线精品视频免费播放| 91国产福利在线| 欧美日韩三级一区| 久久久99久久| 综合久久久久久| 蜜桃传媒麻豆第一区在线观看| 国产精品自在欧美一区| 成人午夜视频在线观看| 欧美日韩精品免费观看视频| 欧美成人官网二区| 一区二区三区国产精品| 国产一区在线不卡| 欧美日韩精品一二三区| 综合欧美一区二区三区| 久久成人综合网| 欧美日韩免费在线视频| 国产丝袜欧美中文另类| 日本欧美一区二区三区乱码| 99久久精品免费精品国产| 日韩精品中文字幕一区二区三区| 中文字幕一区二区三| 国产精品亚洲第一区在线暖暖韩国| 欧美三日本三级三级在线播放| 综合色中文字幕| 91老司机福利 在线| 亚洲国产高清不卡| 色婷婷久久久综合中文字幕| 久久久蜜臀国产一区二区| 日韩国产高清在线| 久久精品亚洲国产奇米99| 国产精品香蕉一区二区三区| 亚洲日本va在线观看| 色天天综合色天天久久| 亚洲一区欧美一区| 一本一道久久a久久精品综合蜜臀| 国产女人aaa级久久久级| 不卡的av电影在线观看| 国产精品毛片久久久久久| 欧美日韩综合色| 国产激情91久久精品导航| 亚洲日韩欧美一区二区在线| 91在线视频网址| 日本91福利区| 国产精品进线69影院| 日韩一区二区免费视频| 国产成人精品一区二区三区四区| 中文字幕一区二区在线观看| 欧美日韩一级二级| 奇米影视一区二区三区小说| 国产精品网站导航| 色呦呦日韩精品| 欧美a一区二区| 亚洲日本在线看| 国产精品天天摸av网| 色欧美日韩亚洲| 成人美女在线观看| 久久99精品国产麻豆婷婷洗澡| 洋洋成人永久网站入口| 337p粉嫩大胆色噜噜噜噜亚洲| 99久久久久免费精品国产| 粉嫩高潮美女一区二区三区| 精品在线免费视频| 亚洲一区成人在线| 亚洲黄色片在线观看| 国产精品久久久久久户外露出 | 久久这里只精品最新地址| 91精品国产综合久久久久久久久久 | 日韩国产欧美视频| 久久久精品欧美丰满| 欧美不卡在线视频| 欧美三电影在线| 在线观看日韩国产| 成人三级伦理片| 国产在线不卡一区| 精品系列免费在线观看| 久久国产精品免费| 奇米色一区二区三区四区| 亚洲一区二区三区爽爽爽爽爽| 久久久国产精品午夜一区ai换脸| 精品国产欧美一区二区| 欧美va在线播放| 久久久蜜桃精品| 国产性天天综合网| 中文字幕日韩av资源站| 国产免费观看久久| 中文字幕一区视频| 久久精工是国产品牌吗| 三级精品在线观看| 韩国欧美国产1区| 成人伦理片在线| 97久久人人超碰| 欧美日韩免费观看一区二区三区| 一本久道久久综合中文字幕 | 久久亚洲免费视频| 中文字幕一区二区三区在线观看 | 精品久久久久99| **性色生活片久久毛片| 日韩国产精品久久久| 成人永久aaa| 777奇米四色成人影色区| 欧美在线不卡一区| 欧美电影免费观看高清完整版在| 最新不卡av在线| 国产成人激情av| 精品视频免费看| 亚洲男女一区二区三区| 成人福利视频网站| 国产精品久久久久永久免费观看 | 欧美一区二区私人影院日本| 欧美高清视频不卡网| 久久精品人人做| av在线不卡观看免费观看| 国产一区二区调教| 国产在线国偷精品产拍免费yy | 欧美激情一区二区| av在线这里只有精品| 一区二区三区高清不卡| 欧美成人艳星乳罩| 一本大道久久a久久综合婷婷| 综合久久综合久久| 欧美亚洲综合网| 亚洲韩国一区二区三区| 欧美色中文字幕| 午夜精品成人在线视频| 欧美一区二区三区免费| 精品一区二区三区免费| 国产亚洲va综合人人澡精品 | 欧美三级电影在线看| 日韩和欧美一区二区| 精品电影一区二区| 成人午夜av影视| 亚洲 欧美综合在线网络| 26uuu成人网一区二区三区| 丁香婷婷综合网| 亚洲精品成人悠悠色影视| 日韩欧美国产1| 色老汉一区二区三区| 奇米在线7777在线精品| 亚洲欧美aⅴ...| 欧美大片一区二区| 成人av网址在线观看| 亚洲成年人网站在线观看| 国产日本亚洲高清| 91.com在线观看| 97aⅴ精品视频一二三区| 美女脱光内衣内裤视频久久网站| 亚洲国产精品久久不卡毛片| 久久精品亚洲精品国产欧美kt∨| 8x8x8国产精品| 欧美午夜电影网| av色综合久久天堂av综合| 国产精品一区二区无线| 亚洲国产视频一区| 亚洲美女区一区| 欧美国产国产综合| 国产午夜久久久久| 欧美变态tickle挠乳网站| 欧美色欧美亚洲另类二区| 大美女一区二区三区| 国产精品99久| av午夜一区麻豆| 91片在线免费观看| 色域天天综合网| 91捆绑美女网站| 一本色道久久综合亚洲精品按摩| 国产福利精品一区二区| 国产精品66部| 成年人网站91| 91小视频在线| 欧美区视频在线观看| 日韩美女一区二区三区| 国产精品入口麻豆九色| 一区二区三区不卡视频在线观看| 日韩激情视频在线观看| 国产精品一区二区男女羞羞无遮挡| 国产美女在线观看一区| 91精品国产综合久久福利| 久久综合九色综合97婷婷| 日韩一区在线免费观看| 天堂蜜桃91精品| 亚洲人成伊人成综合网小说| 中文字幕不卡在线| 一区二区三区四区在线免费观看| 亚洲婷婷国产精品电影人久久| 亚洲视频在线一区| 亚洲第一搞黄网站|