2010-05-18 11:58:33 -04:00
|
|
|
/*
|
2010-09-09 08:16:39 -04:00
|
|
|
* Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
2010-06-18 12:39:21 -04:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
2010-06-04 16:19:40 -04:00
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
2010-06-18 12:39:21 -04:00
|
|
|
* in the file PATENTS. All contributing project authors may
|
2010-06-04 16:19:40 -04:00
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2010-05-18 11:58:33 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2010-08-13 14:50:51 -04:00
|
|
|
#include "segmentation.h"
|
2010-05-18 11:58:33 -04:00
|
|
|
#include "vpx_mem/vpx_mem.h"
|
|
|
|
|
2010-08-11 11:02:31 -04:00
|
|
|
void vp8_update_gf_useage_maps(VP8_COMP *cpi, VP8_COMMON *cm, MACROBLOCK *x)
|
2010-05-18 11:58:33 -04:00
|
|
|
{
|
|
|
|
int mb_row, mb_col;
|
|
|
|
|
|
|
|
MODE_INFO *this_mb_mode_info = cm->mi;
|
|
|
|
|
2010-08-11 11:02:31 -04:00
|
|
|
x->gf_active_ptr = (signed char *)cpi->gf_active_flags;
|
2010-05-18 11:58:33 -04:00
|
|
|
|
|
|
|
if ((cm->frame_type == KEY_FRAME) || (cm->refresh_golden_frame))
|
|
|
|
{
|
2012-05-21 14:30:56 -07:00
|
|
|
/* Reset Gf useage monitors */
|
2010-08-11 11:02:31 -04:00
|
|
|
vpx_memset(cpi->gf_active_flags, 1, (cm->mb_rows * cm->mb_cols));
|
|
|
|
cpi->gf_active_count = cm->mb_rows * cm->mb_cols;
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2012-05-21 14:30:56 -07:00
|
|
|
/* for each macroblock row in image */
|
2010-05-18 11:58:33 -04:00
|
|
|
for (mb_row = 0; mb_row < cm->mb_rows; mb_row++)
|
|
|
|
{
|
2012-05-21 14:30:56 -07:00
|
|
|
/* for each macroblock col in image */
|
2010-05-18 11:58:33 -04:00
|
|
|
for (mb_col = 0; mb_col < cm->mb_cols; mb_col++)
|
|
|
|
{
|
|
|
|
|
2012-05-21 14:30:56 -07:00
|
|
|
/* If using golden then set GF active flag if not already set.
|
|
|
|
* If using last frame 0,0 mode then leave flag as it is
|
|
|
|
* else if using non 0,0 motion or intra modes then clear
|
|
|
|
* flag if it is currently set
|
|
|
|
*/
|
2010-05-18 11:58:33 -04:00
|
|
|
if ((this_mb_mode_info->mbmi.ref_frame == GOLDEN_FRAME) || (this_mb_mode_info->mbmi.ref_frame == ALTREF_FRAME))
|
|
|
|
{
|
2010-08-11 11:02:31 -04:00
|
|
|
if (*(x->gf_active_ptr) == 0)
|
2010-05-18 11:58:33 -04:00
|
|
|
{
|
2010-08-11 11:02:31 -04:00
|
|
|
*(x->gf_active_ptr) = 1;
|
|
|
|
cpi->gf_active_count ++;
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
}
|
2010-08-11 11:02:31 -04:00
|
|
|
else if ((this_mb_mode_info->mbmi.mode != ZEROMV) && *(x->gf_active_ptr))
|
2010-05-18 11:58:33 -04:00
|
|
|
{
|
2010-08-11 11:02:31 -04:00
|
|
|
*(x->gf_active_ptr) = 0;
|
|
|
|
cpi->gf_active_count--;
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
|
2012-05-21 14:30:56 -07:00
|
|
|
x->gf_active_ptr++; /* Step onto next entry */
|
|
|
|
this_mb_mode_info++; /* skip to next mb */
|
2010-05-18 11:58:33 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-05-21 14:30:56 -07:00
|
|
|
/* this is to account for the border */
|
2010-05-18 11:58:33 -04:00
|
|
|
this_mb_mode_info++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|