/****************************************************************************** * * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ***************************************************************************** * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore */ /** ******************************************************************************* * @file * ih264e_me.h * * @brief * * * @author * Ittiam * * @par List of Functions: * - * * @remarks * None * ******************************************************************************* */ #ifndef _IME_STRUCTS_H_ #define _IME_STRUCTS_H_ /** * Motion vector */ typedef struct { /** * Horizontal Motion Vector */ WORD16 i2_mvx; /** * Vertical Motion Vector */ WORD16 i2_mvy; } ime_mv_t; /** ************************************************************************** * @brief mb_part_ctxt * * Structure that would hold the information for individual MB partitions * gathered during the full pel ME stage ************************************************************************** */ typedef struct { /** * best mvs */ ime_mv_t s_mv_curr; /** * mv predictor */ ime_mv_t s_mv_pred; /** * SAD associated with the MB partition */ WORD32 i4_mb_distortion; /** * cost for the MB partition */ WORD32 i4_mb_cost; /** * Search position for least cost among the list of candidates */ WORD32 i4_srch_pos_idx; /** * Search position for least cost among the list of candidates */ UWORD32 u4_exit; /* * Buffer corresponding to best half pel cost */ UWORD8 *pu1_best_hpel_buf; } mb_part_ctxt; /** ************************************************************************** * @brief me_ctxt_t * * Structure encapsulating the parameters used in the motion estimation * context ************************************************************************** */ typedef struct { /** * Ref pointer to current MB luma for each ref list */ UWORD8 *apu1_ref_buf_luma[MAX_NUM_REFLIST]; /** * Src pointer to current MB luma */ UWORD8 *pu1_src_buf_luma; /** * source stride * (strides for luma and chroma are the same) */ WORD32 i4_src_strd; /** * recon stride * (strides for luma and chroma are the same) */ WORD32 i4_rec_strd; /** * Offset for half pel x plane from the pic buf */ UWORD32 u4_half_x_offset; /** * Offset for half pel y plane from half x plane */ UWORD32 u4_half_y_offset; /** * Offset for half pel xy plane from half y plane */ UWORD32 u4_half_xy_offset; /** * Search range in the X, Y axis in terms of pixels */ WORD32 ai2_srch_boundaries[2]; /** * Search range in the north direction in terms of pixels */ WORD32 i4_srch_range_n; /** * Search range in the south direction in terms of pixels */ WORD32 i4_srch_range_s; /** * Search range in the east direction in terms of pixels */ WORD32 i4_srch_range_e; /** * Search range in the west direction in terms of pixels */ WORD32 i4_srch_range_w; /** * left mb motion vector */ ime_mv_t s_left_mv; /** * top left mb motion vector */ ime_mv_t s_top_left_mv; /** * Number of valid candidates for the Initial search position */ UWORD32 u4_num_candidates[MAX_NUM_REFLIST + 1]; /** * Motion vector predictors derived from neighboring * blocks for each of the six block partitions */ ime_mv_t as_mv_init_search[MAX_NUM_REFLIST + 1][6]; /** * mv bits */ UWORD8 *pu1_mv_bits; /** * lambda (lagrange multiplier for cost computation) */ UWORD32 u4_lambda_motion; /** * enabled fast sad computation */ UWORD32 u4_enable_fast_sad; /* * Enable SKIP block prediction based on SATQD */ UWORD32 u4_enable_stat_sad; /* * Minimum distortion to search for * */ WORD32 i4_min_sad; /* * Signal that minimum sad has been reached in ME * */ UWORD32 u4_min_sad_reached; /** * Flag to enable/disbale half pel motion estimation */ UWORD32 u4_enable_hpel; /** * Diamond search Iteration Max Cnt */ UWORD32 u4_num_layers; /** * encoder me speed */ UWORD32 u4_me_speed_preset; UWORD32 u4_left_is_intra; UWORD32 u4_left_is_skip; /* skip_type can be PREDL0, PREDL1 or BIPRED */ WORD32 i4_skip_type; /* Biasing given for skip prediction */ WORD32 i4_skip_bias[2]; /** * Structure to store the MB partition info * We need 1(L0)+1(L1)+1(bi) */ mb_part_ctxt as_mb_part[MAX_NUM_REFLIST + 1]; /* * Threshold to compare the sad with */ UWORD16 *pu2_sad_thrsh; /** * fn ptrs for compute sad routines */ ime_compute_sad_ft *pf_ime_compute_sad_16x16[2]; ime_compute_sad_ft *pf_ime_compute_sad_16x8; ime_compute_sad4_diamond *pf_ime_compute_sad4_diamond; ime_compute_sad3_diamond *pf_ime_compute_sad3_diamond; ime_compute_sad2_diamond *pf_ime_compute_sad2_diamond; ime_sub_pel_compute_sad_16x16_ft *pf_ime_sub_pel_compute_sad_16x16; /* * Function poitners for SATQD */ ime_compute_sad_stat *pf_ime_compute_sad_stat_luma_16x16; /** * Qp */ UWORD8 u1_mb_qp; /* * Buffers for holding subpel and bipred temp buffers */ UWORD8 *apu1_subpel_buffs[SUBPEL_BUFF_CNT]; WORD32 u4_subpel_buf_strd; /* * Buffers to store the best halfpel plane* */ UWORD8 *pu1_hpel_buf; } me_ctxt_t; #endif // _IME_STRUCTS_H_