cec76a36d6
Address calculations moved from encodemb_arm.c file to neon optimized assembly function to save cycles in function calls. - vp8_subtract_b_neon_func replaced with vp8_subtract_b_neon that contains all needed address calculations - unnecessary file encodemb_arm.c removed - consistent with ARMv6 optimized version Change-Id: I6cbc1a2670b56c2077f59995fcf8f70786b4990b
106 lines
4.5 KiB
C
106 lines
4.5 KiB
C
/*
|
|
* Copyright (c) 2011 The WebM project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
|
|
#include "vpx_ports/config.h"
|
|
#include <stddef.h>
|
|
|
|
#include "block.h"
|
|
#include "vp8/common/blockd.h"
|
|
#include "onyx_int.h"
|
|
#include "treewriter.h"
|
|
#include "tokenize.h"
|
|
|
|
#define ct_assert(name,cond) \
|
|
static void assert_##name(void) UNUSED;\
|
|
static void assert_##name(void) {switch(0){case 0:case !!(cond):;}}
|
|
|
|
#define DEFINE(sym, val) int sym = val;
|
|
|
|
/*
|
|
#define BLANK() asm volatile("\n->" : : )
|
|
*/
|
|
|
|
/*
|
|
* int main(void)
|
|
* {
|
|
*/
|
|
|
|
//regular quantize
|
|
DEFINE(vp8_block_coeff, offsetof(BLOCK, coeff));
|
|
DEFINE(vp8_block_zbin, offsetof(BLOCK, zbin));
|
|
DEFINE(vp8_block_round, offsetof(BLOCK, round));
|
|
DEFINE(vp8_block_quant, offsetof(BLOCK, quant));
|
|
DEFINE(vp8_block_quant_fast, offsetof(BLOCK, quant_fast));
|
|
DEFINE(vp8_block_zbin_extra, offsetof(BLOCK, zbin_extra));
|
|
DEFINE(vp8_block_zrun_zbin_boost, offsetof(BLOCK, zrun_zbin_boost));
|
|
DEFINE(vp8_block_quant_shift, offsetof(BLOCK, quant_shift));
|
|
|
|
DEFINE(vp8_blockd_qcoeff, offsetof(BLOCKD, qcoeff));
|
|
DEFINE(vp8_blockd_dequant, offsetof(BLOCKD, dequant));
|
|
DEFINE(vp8_blockd_dqcoeff, offsetof(BLOCKD, dqcoeff));
|
|
DEFINE(vp8_blockd_eob, offsetof(BLOCKD, eob));
|
|
|
|
// subtract
|
|
DEFINE(vp8_block_base_src, offsetof(BLOCK, base_src));
|
|
DEFINE(vp8_block_src, offsetof(BLOCK, src));
|
|
DEFINE(vp8_block_src_diff, offsetof(BLOCK, src_diff));
|
|
DEFINE(vp8_block_src_stride, offsetof(BLOCK, src_stride));
|
|
|
|
DEFINE(vp8_blockd_predictor, offsetof(BLOCKD, predictor));
|
|
|
|
//pack tokens
|
|
DEFINE(vp8_writer_lowvalue, offsetof(vp8_writer, lowvalue));
|
|
DEFINE(vp8_writer_range, offsetof(vp8_writer, range));
|
|
DEFINE(vp8_writer_value, offsetof(vp8_writer, value));
|
|
DEFINE(vp8_writer_count, offsetof(vp8_writer, count));
|
|
DEFINE(vp8_writer_pos, offsetof(vp8_writer, pos));
|
|
DEFINE(vp8_writer_buffer, offsetof(vp8_writer, buffer));
|
|
|
|
DEFINE(tokenextra_token, offsetof(TOKENEXTRA, Token));
|
|
DEFINE(tokenextra_extra, offsetof(TOKENEXTRA, Extra));
|
|
DEFINE(tokenextra_context_tree, offsetof(TOKENEXTRA, context_tree));
|
|
DEFINE(tokenextra_skip_eob_node, offsetof(TOKENEXTRA, skip_eob_node));
|
|
DEFINE(TOKENEXTRA_SZ, sizeof(TOKENEXTRA));
|
|
|
|
DEFINE(vp8_extra_bit_struct_sz, sizeof(vp8_extra_bit_struct));
|
|
|
|
DEFINE(vp8_token_value, offsetof(vp8_token, value));
|
|
DEFINE(vp8_token_len, offsetof(vp8_token, Len));
|
|
|
|
DEFINE(vp8_extra_bit_struct_tree, offsetof(vp8_extra_bit_struct, tree));
|
|
DEFINE(vp8_extra_bit_struct_prob, offsetof(vp8_extra_bit_struct, prob));
|
|
DEFINE(vp8_extra_bit_struct_len, offsetof(vp8_extra_bit_struct, Len));
|
|
DEFINE(vp8_extra_bit_struct_base_val, offsetof(vp8_extra_bit_struct, base_val));
|
|
|
|
DEFINE(vp8_comp_tplist, offsetof(VP8_COMP, tplist));
|
|
DEFINE(vp8_comp_common, offsetof(VP8_COMP, common));
|
|
DEFINE(vp8_comp_bc2, offsetof(VP8_COMP, bc2));
|
|
|
|
DEFINE(tokenlist_start, offsetof(TOKENLIST, start));
|
|
DEFINE(tokenlist_stop, offsetof(TOKENLIST, stop));
|
|
DEFINE(TOKENLIST_SZ, sizeof(TOKENLIST));
|
|
|
|
DEFINE(vp8_common_mb_rows, offsetof(VP8_COMMON, mb_rows));
|
|
|
|
// These two sizes are used in vp8cx_pack_tokens. They are hard coded
|
|
// so if the size changes this will have to be adjusted.
|
|
#if HAVE_ARMV5TE
|
|
ct_assert(TOKENEXTRA_SZ, sizeof(TOKENEXTRA) == 8)
|
|
ct_assert(vp8_extra_bit_struct_sz, sizeof(vp8_extra_bit_struct) == 16)
|
|
#endif
|
|
|
|
//add asserts for any offset that is not supported by assembly code
|
|
//add asserts for any size that is not supported by assembly code
|
|
/*
|
|
* return 0;
|
|
* }
|
|
*/
|