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

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

?? mbuffer.c

?? the newest JM software by h.264 JVT official reference model.
?? C
?? 第 1 頁 / 共 5 頁
字號:
  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_padded = size_x + 2 * IMG_PAD_SIZE;
  s->size_y_padded = size_y + 2 * IMG_PAD_SIZE;
  s->size_x_pad = size_x + 2 * IMG_PAD_SIZE - 1 - MB_BLOCK_SIZE;
  s->size_y_pad = size_y + 2 * IMG_PAD_SIZE - 1 - MB_BLOCK_SIZE;
  s->size_x_cr = size_x_cr;
  s->size_y_cr = size_y_cr;
  s->size_x_cr_pad = (int) (size_x_cr - 1) + (img_pad_size_uv_x << 1) - (img->mb_cr_size_x);
  s->size_y_cr_pad = (int) (size_y_cr - 1) + (img_pad_size_uv_y << 1) - (img->mb_cr_size_y);

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

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

  init_stats(&s->stats);
  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);
  }
}

void free_pic_motion(PicMotionParams *motion)
{
  if (motion->ref_pic_id)
  {
    free_mem3Dint64 (motion->ref_pic_id);
    motion->ref_pic_id = NULL;
  }
  if (motion->ref_id)
  {
    free_mem3Dint64 (motion->ref_id);
    motion->ref_id = NULL;
  }

  if (motion->mv)
  {
    free_mem4Dshort (motion->mv);
    motion->mv = NULL;
  }

  if (motion->ref_idx)
  {
    free_mem3D ((byte***)motion->ref_idx);
    motion->ref_idx = NULL;
  }

  if (motion->mb_field)
  {
    free(motion->mb_field);
    motion->mb_field=NULL;
  }

  if (motion->field_frame)
  {
    free_mem2D (motion->field_frame);
    motion->field_frame=NULL;
  }
}


/*!
 ************************************************************************
 * \brief
 *    Free picture memory.
 *
 * \param p
 *    Picture to be freed
 *
 ************************************************************************
 */
void free_storable_picture(StorablePicture* p)
{
  int nplane;
  if (p)
  {
    //free_mem3Dmp (p->mv_info);
    free_pic_motion(&p->motion);

    if( IS_INDEPENDENT(params) )
    {
      for( nplane=0; nplane<MAX_PLANE; nplane++ )
      {
        free_pic_motion(&p->JVmotion[nplane]);
      }
    }

    if (p->imgY)
    {      
      free_mem2Dpel (p->imgY);
      p->imgY=NULL;      
    }    

    if( IS_INDEPENDENT(params) )
    {
      if (p->imgY_sub)
      {
        free_mem4Dpel (p->imgY_sub);
        p->imgY_sub=NULL;
      }
      if (p->imgUV_sub)
      {
        free_mem5Dpel (p->imgUV_sub);
        p->imgUV_sub = NULL;
      }

      p->p_curr_img     = NULL;
      p->p_curr_img_sub = NULL;
      p->p_img[0]       = NULL;
      p->p_img[1]       = NULL;
      p->p_img[2]       = NULL;
      p->p_img_sub[0]   = NULL;
      p->p_img_sub[1]   = NULL;
      p->p_img_sub[2]   = NULL;
    }
    else
    {
      if (p->imgY_sub)
      {
        free_mem4Dpel (p->imgY_sub);
        p->imgY_sub=NULL;
      }

      if ( p->imgUV_sub && img->yuv_format != YUV400 && params->ChromaMCBuffer )
      {
        free_mem5Dpel (p->imgUV_sub);
        p->imgUV_sub = NULL;
      }
    }

    if (p->imgUV)
    {
      free_mem3Dpel (p->imgUV);
      p->imgUV=NULL;
    }

    if (p->dec_imgY)
    {
      free_mem3Dpel(p->dec_imgY);
    }
    if (p->dec_imgUV)
    {
      free_mem4Dpel(p->dec_imgUV);
    }
    for (nplane = 0; nplane < 3; nplane++)
    {
      if (p->p_dec_img[nplane])
      {  
        free(p->p_dec_img[nplane]);
        p->p_dec_img[nplane] = NULL;
      }
    }
    if (p->mb_error_map)
    {
      free_mem3D(p->mb_error_map);
    }

    p->mb_error_map = NULL;
    p->dec_imgY   = NULL;
    p->dec_imgUV  = NULL;

    free(p);
    p = NULL;
  }
}

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

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

  fs->is_reference = 0;

  if(fs->frame)
  {
    if (fs->frame->imgY_sub)
    {
      free_mem4Dpel (fs->frame->imgY_sub);
      fs->frame->imgY_sub=NULL;
    }

    if (fs->frame->imgUV_sub)
    {
      free_mem5Dpel (fs->frame->imgUV_sub);
      fs->frame->imgUV_sub = NULL;
    }

    free_pic_motion(&fs->frame->motion);
  }

  if (fs->top_field)
  {
    if (fs->top_field->imgY_sub)
    {
      free_mem4Dpel (fs->top_field->imgY_sub);
      fs->top_field->imgY_sub=NULL;
    }

    if (fs->top_field->imgUV_sub)
    {
      free_mem5Dpel (fs->top_field->imgUV_sub);
      fs->top_field->imgUV_sub = NULL;
    }
    
    free_pic_motion(&fs->top_field->motion);
  }
  if (fs->bottom_field)
  {
    if (fs->bottom_field->imgY_sub)
    {
      free_mem4Dpel (fs->bottom_field->imgY_sub);
      fs->bottom_field->imgY_sub=NULL;
    }
    if (fs->bottom_field->imgUV_sub)
    {
      free_mem5Dpel (fs->bottom_field->imgUV_sub);
      fs->bottom_field->imgUV_sub = NULL;
    }

    free_pic_motion(&fs->bottom_field->motion);
  }
}


/*!
 ************************************************************************
 * \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)
  {
    if (fs->top_field)
    {
      fs->top_field->used_for_reference = 0;
      fs->top_field->is_long_term = 0;
    }
  }
  if (fs->is_used & 2)
  {
    if (fs->bottom_field)
    {
      fs->bottom_field->used_for_reference = 0;
      fs->bottom_field->is_long_term = 0;
    }
  }
  if (fs->is_used == 3)
  {
    if (fs->top_field && fs->bottom_field)
    {
      fs->top_field->used_for_reference = 0;
      fs->top_field->is_long_term = 0;
      fs->bottom_field->used_for_reference = 0;
      fs->bottom_field->is_long_term = 0;
    }
    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;
}


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


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


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


/*!
 ************************************************************************
 * \brief

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美区在线观看| 久久国产精品99久久人人澡| 同产精品九九九| 国产精品99久久久久久似苏梦涵| 在线免费不卡视频| 久久亚洲综合色一区二区三区 | 欧美日韩一区三区| 国产精品视频线看| 狠狠色2019综合网| 91麻豆精品国产91久久久久| 国产精品久99| 国产精华液一区二区三区| 欧美久久一二三四区| 国产精品妹子av| 国产乱子伦视频一区二区三区| 欧美日韩精品福利| 亚洲一区二区不卡免费| 91久久人澡人人添人人爽欧美| 国产女人18毛片水真多成人如厕 | 337p亚洲精品色噜噜噜| 亚洲男人都懂的| 国产日韩欧美激情| 久久99日本精品| 欧美日本精品一区二区三区| 樱花影视一区二区| 91视频xxxx| 一色屋精品亚洲香蕉网站| 国产丶欧美丶日本不卡视频| 久久伊人蜜桃av一区二区| 久久精品国产久精国产爱| 91精品国产综合久久久蜜臀图片| 亚洲bdsm女犯bdsm网站| 欧美酷刑日本凌虐凌虐| 日韩综合小视频| 777午夜精品免费视频| 日日骚欧美日韩| 欧美一区二区三区视频| 久久国产麻豆精品| 欧美精品一区二区三区蜜桃视频| 韩国女主播成人在线观看| 久久久久一区二区三区四区| 国产一区二区在线观看免费| 久久精品夜夜夜夜久久| 成人国产精品免费观看| 一区二区在线观看不卡| 欧美日韩国产bt| 美女在线一区二区| 欧美一区二区精品在线| 狠狠色2019综合网| jlzzjlzz亚洲女人18| 亚洲欧美日韩电影| 7799精品视频| 国产精品1024| 一区二区三区影院| 欧美蜜桃一区二区三区| 狠狠色伊人亚洲综合成人| 中文子幕无线码一区tr| 欧美性大战久久| 九九九久久久精品| 综合色天天鬼久久鬼色| 欧美欧美午夜aⅴ在线观看| 久久国产精品露脸对白| 最近中文字幕一区二区三区| 欧美日韩亚洲综合| 国产成人综合在线| 亚洲在线观看免费视频| 精品动漫一区二区三区在线观看| 成人国产精品免费观看| 人禽交欧美网站| 亚洲色图一区二区| 精品久久久久一区| 欧美影视一区在线| 国产精品77777| 亚洲国产一区二区视频| 欧美国产一区二区| 6080日韩午夜伦伦午夜伦| 成人国产精品免费观看动漫| 日韩二区三区四区| 一本一道综合狠狠老| 午夜视黄欧洲亚洲| 国产精品视频免费| 日韩网站在线看片你懂的| 色菇凉天天综合网| 国产不卡在线播放| 秋霞成人午夜伦在线观看| 亚洲激情在线播放| 国产日产欧美一区| 日韩亚洲欧美成人一区| 日本精品一区二区三区四区的功能| 韩日av一区二区| 免费日韩伦理电影| 香蕉加勒比综合久久| 成人免费视频在线观看| 国产视频一区二区在线| 欧美大片日本大片免费观看| 91国偷自产一区二区开放时间 | 性做久久久久久久免费看| 亚洲欧洲日韩在线| 久久精品一区八戒影视| 欧美刺激午夜性久久久久久久| 欧美日韩一区二区三区在线| 91日韩在线专区| www.视频一区| 波多野结衣在线aⅴ中文字幕不卡| 国产在线精品免费| 激情久久五月天| 久久99精品国产麻豆婷婷| 五月天一区二区三区| 亚洲午夜三级在线| 一区二区三区精品久久久| 最新日韩在线视频| 亚洲天堂网中文字| 中文字幕一区二区三区不卡在线 | 成人免费视频视频在线观看免费 | 中文字幕va一区二区三区| 国产欧美日本一区二区三区| 狠狠色狠狠色综合日日91app| 一区二区三区欧美在线观看| 日韩理论在线观看| 国产精品卡一卡二卡三| 国产精品视频九色porn| 成人免费在线视频| 亚洲欧美福利一区二区| 亚洲男同性恋视频| 亚洲国产精品一区二区www| 亚洲成人一二三| 日韩二区在线观看| 激情偷乱视频一区二区三区| 国产精品一二三四区| 国产成人亚洲综合a∨婷婷图片 | 午夜精品福利视频网站| 午夜精品影院在线观看| 免费观看30秒视频久久| 国产另类ts人妖一区二区| 成人免费av资源| 日本精品视频一区二区| 日韩一级高清毛片| 国产精品久久久久久久久晋中| 亚洲精品国产视频| 蜜臀久久久久久久| 国产麻豆成人精品| 91精品91久久久中77777| 欧美一二三区在线观看| 欧美经典一区二区| 伊人色综合久久天天人手人婷| 奇米色777欧美一区二区| 国产精品99久久久久久久女警 | 99在线精品视频| 欧美日韩一区成人| 精品国精品国产| 亚洲欧美日韩国产手机在线 | 精品国产乱码久久久久久图片| 国产农村妇女毛片精品久久麻豆| 亚洲综合久久av| 国产成人综合亚洲91猫咪| 在线观看网站黄不卡| 精品少妇一区二区| 亚洲综合丁香婷婷六月香| 国产精品综合视频| 欧美日韩中文字幕一区二区| 国产精品系列在线| 日本午夜精品一区二区三区电影| 国产成人免费视频一区| 欧美一区二区三区四区视频 | 国产精品麻豆久久久| 奇米四色…亚洲| 在线观看网站黄不卡| 国产欧美一区在线| 麻豆成人av在线| 欧美亚洲丝袜传媒另类| 国产精品区一区二区三| 麻豆91在线播放| 欧美色图免费看| 中文字幕在线观看一区二区| 久久精品国产精品亚洲红杏 | 奇米888四色在线精品| 色综合咪咪久久| 国产精品国产三级国产普通话三级| 日韩av在线免费观看不卡| 色美美综合视频| 亚洲色图丝袜美腿| 色狠狠av一区二区三区| 欧美日韩另类一区| 中文字幕五月欧美| 国产一区二区三区免费| 欧美精品久久99| 亚洲精品高清在线| 色婷婷综合久久久久中文| 亚洲国产成人午夜在线一区| 国产传媒日韩欧美成人| 久久久无码精品亚洲日韩按摩| 美女一区二区在线观看| 欧美一级黄色录像| 七七婷婷婷婷精品国产| 欧美一区二区精美| 日韩av二区在线播放| 欧美一区二区三区在线视频| 免费欧美日韩国产三级电影| 日韩一区二区电影在线| 免费高清在线一区|