alloccommon.c 4.79 KB
Newer Older
John Koleszar's avatar
John Koleszar committed
1
/*
2
 *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
John Koleszar's avatar
John Koleszar committed
3
 *
4
 *  Use of this source code is governed by a BSD-style license
5 6
 *  that can be found in the LICENSE file in the root of the source
 *  tree. An additional intellectual property rights grant can be found
7
 *  in the file PATENTS.  All contributing project authors may
8
 *  be found in the AUTHORS file in the root of the source tree.
John Koleszar's avatar
John Koleszar committed
9 10 11
 */


12
#include "vpx_ports/config.h"
John Koleszar's avatar
John Koleszar committed
13 14 15 16 17 18 19 20 21 22 23 24 25
#include "blockd.h"
#include "vpx_mem/vpx_mem.h"
#include "onyxc_int.h"
#include "findnearmv.h"
#include "entropymode.h"
#include "systemdependent.h"


extern  void vp8_init_scan_order_mask();

void vp8_update_mode_info_border(MODE_INFO *mi, int rows, int cols)
{
    int i;
26
    vpx_memset(mi - cols - 2, 0, sizeof(MODE_INFO) * (cols + 1));
John Koleszar's avatar
John Koleszar committed
27 28 29 30 31 32

    for (i = 0; i < rows; i++)
    {
        vpx_memset(&mi[i*cols-1], 0, sizeof(MODE_INFO));
    }
}
33

John Koleszar's avatar
John Koleszar committed
34 35
void vp8_de_alloc_frame_buffers(VP8_COMMON *oci)
{
36 37 38 39 40
    int i;

    for (i = 0; i < NUM_YV12_BUFFERS; i++)
        vp8_yv12_de_alloc_frame_buffer(&oci->yv12_fb[i]);

John Koleszar's avatar
John Koleszar committed
41 42 43
    vp8_yv12_de_alloc_frame_buffer(&oci->temp_scale_frame);
    vp8_yv12_de_alloc_frame_buffer(&oci->post_proc_buffer);

44
    vpx_free(oci->above_context);
John Koleszar's avatar
John Koleszar committed
45 46
    vpx_free(oci->mip);

47
    oci->above_context = 0;
John Koleszar's avatar
John Koleszar committed
48 49 50 51 52 53
    oci->mip = 0;

}

int vp8_alloc_frame_buffers(VP8_COMMON *oci, int width, int height)
{
54 55
    int i;

John Koleszar's avatar
John Koleszar committed
56 57
    vp8_de_alloc_frame_buffers(oci);

58
    /* our internal buffers are always multiples of 16 */
John Koleszar's avatar
John Koleszar committed
59 60 61 62 63 64 65
    if ((width & 0xf) != 0)
        width += 16 - (width & 0xf);

    if ((height & 0xf) != 0)
        height += 16 - (height & 0xf);


66
    for (i = 0; i < NUM_YV12_BUFFERS; i++)
John Koleszar's avatar
John Koleszar committed
67
    {
68
      oci->fb_idx_ref_cnt[0] = 0;
John Koleszar's avatar
John Koleszar committed
69

70 71 72
      if (vp8_yv12_alloc_frame_buffer(&oci->yv12_fb[i],  width, height, VP8BORDERINPIXELS) < 0)
        {
            vp8_de_alloc_frame_buffers(oci);
John Koleszar's avatar
John Koleszar committed
73
            return 1;
74
        }
John Koleszar's avatar
John Koleszar committed
75 76
    }

77 78 79 80
    oci->new_fb_idx = 0;
    oci->lst_fb_idx = 1;
    oci->gld_fb_idx = 2;
    oci->alt_fb_idx = 3;
John Koleszar's avatar
John Koleszar committed
81

82 83 84 85
    oci->fb_idx_ref_cnt[0] = 1;
    oci->fb_idx_ref_cnt[1] = 1;
    oci->fb_idx_ref_cnt[2] = 1;
    oci->fb_idx_ref_cnt[3] = 1;
John Koleszar's avatar
John Koleszar committed
86

87
    if (vp8_yv12_alloc_frame_buffer(&oci->temp_scale_frame,   width, 16, VP8BORDERINPIXELS) < 0)
John Koleszar's avatar
John Koleszar committed
88 89
    {
        vp8_de_alloc_frame_buffers(oci);
John Koleszar's avatar
John Koleszar committed
90
        return 1;
John Koleszar's avatar
John Koleszar committed
91 92 93 94 95
    }

    if (vp8_yv12_alloc_frame_buffer(&oci->post_proc_buffer, width, height, VP8BORDERINPIXELS) < 0)
    {
        vp8_de_alloc_frame_buffers(oci);
John Koleszar's avatar
John Koleszar committed
96
        return 1;
John Koleszar's avatar
John Koleszar committed
97 98 99 100 101 102 103 104 105 106 107
    }

    oci->mb_rows = height >> 4;
    oci->mb_cols = width >> 4;
    oci->MBs = oci->mb_rows * oci->mb_cols;
    oci->mode_info_stride = oci->mb_cols + 1;
    oci->mip = vpx_calloc((oci->mb_cols + 1) * (oci->mb_rows + 1), sizeof(MODE_INFO));

    if (!oci->mip)
    {
        vp8_de_alloc_frame_buffers(oci);
John Koleszar's avatar
John Koleszar committed
108
        return 1;
John Koleszar's avatar
John Koleszar committed
109 110 111 112 113
    }

    oci->mi = oci->mip + oci->mode_info_stride + 1;


114
    oci->above_context = vpx_calloc(sizeof(ENTROPY_CONTEXT_PLANES) * oci->mb_cols, 1);
John Koleszar's avatar
John Koleszar committed
115

116
    if (!oci->above_context)
John Koleszar's avatar
John Koleszar committed
117 118
    {
        vp8_de_alloc_frame_buffers(oci);
John Koleszar's avatar
John Koleszar committed
119
        return 1;
John Koleszar's avatar
John Koleszar committed
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154
    }

    vp8_update_mode_info_border(oci->mi, oci->mb_rows, oci->mb_cols);

    return 0;
}
void vp8_setup_version(VP8_COMMON *cm)
{
    switch (cm->version)
    {
    case 0:
        cm->no_lpf = 0;
        cm->simpler_lpf = 0;
        cm->use_bilinear_mc_filter = 0;
        cm->full_pixel = 0;
        break;
    case 1:
        cm->no_lpf = 0;
        cm->simpler_lpf = 1;
        cm->use_bilinear_mc_filter = 1;
        cm->full_pixel = 0;
        break;
    case 2:
        cm->no_lpf = 1;
        cm->simpler_lpf = 0;
        cm->use_bilinear_mc_filter = 1;
        cm->full_pixel = 0;
        break;
    case 3:
        cm->no_lpf = 1;
        cm->simpler_lpf = 1;
        cm->use_bilinear_mc_filter = 1;
        cm->full_pixel = 1;
        break;
    default:
155
        /*4,5,6,7 are reserved for future use*/
John Koleszar's avatar
John Koleszar committed
156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
        cm->no_lpf = 0;
        cm->simpler_lpf = 0;
        cm->use_bilinear_mc_filter = 0;
        cm->full_pixel = 0;
        break;
    }
}
void vp8_create_common(VP8_COMMON *oci)
{
    vp8_machine_specific_config(oci);
    vp8_default_coef_probs(oci);
    vp8_init_mbmode_probs(oci);
    vp8_default_bmode_probs(oci->fc.bmode_prob);

    oci->mb_no_coeff_skip = 1;
    oci->no_lpf = 0;
    oci->simpler_lpf = 0;
    oci->use_bilinear_mc_filter = 0;
    oci->full_pixel = 0;
    oci->multi_token_partition = ONE_PARTITION;
    oci->clr_type = REG_YUV;
    oci->clamp_type = RECON_CLAMP_REQUIRED;

179
    /* Initialise reference frame sign bias structure to defaults */
John Koleszar's avatar
John Koleszar committed
180 181
    vpx_memset(oci->ref_frame_sign_bias, 0, sizeof(oci->ref_frame_sign_bias));

182
    /* Default disable buffer to buffer copying */
John Koleszar's avatar
John Koleszar committed
183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200
    oci->copy_buffer_to_gf = 0;
    oci->copy_buffer_to_arf = 0;
}

void vp8_remove_common(VP8_COMMON *oci)
{
    vp8_de_alloc_frame_buffers(oci);
}

void vp8_initialize_common()
{
    vp8_coef_tree_initialize();

    vp8_entropy_mode_init();

    vp8_init_scan_order_mask();

}