annotate ffmpeg/libavcodec/arm/vp56_arith.h @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents 6840f77b83aa
children
rev   line source
yading@10 1 /*
yading@10 2 * Copyright (C) 2010 Mans Rullgard <mans@mansr.com>
yading@10 3 *
yading@10 4 * This file is part of FFmpeg.
yading@10 5 *
yading@10 6 * FFmpeg is free software; you can redistribute it and/or
yading@10 7 * modify it under the terms of the GNU Lesser General Public
yading@10 8 * License as published by the Free Software Foundation; either
yading@10 9 * version 2.1 of the License, or (at your option) any later version.
yading@10 10 *
yading@10 11 * FFmpeg is distributed in the hope that it will be useful,
yading@10 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 14 * Lesser General Public License for more details.
yading@10 15 *
yading@10 16 * You should have received a copy of the GNU Lesser General Public
yading@10 17 * License along with FFmpeg; if not, write to the Free Software
yading@10 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 19 */
yading@10 20
yading@10 21 #ifndef AVCODEC_ARM_VP56_ARITH_H
yading@10 22 #define AVCODEC_ARM_VP56_ARITH_H
yading@10 23
yading@10 24 #if CONFIG_THUMB
yading@10 25 # define A(x)
yading@10 26 # define T(x) x
yading@10 27 #else
yading@10 28 # define A(x) x
yading@10 29 # define T(x)
yading@10 30 #endif
yading@10 31
yading@10 32 #if CONFIG_THUMB || defined __clang__
yading@10 33 # define L(x)
yading@10 34 # define U(x) x
yading@10 35 #else
yading@10 36 # define L(x) x
yading@10 37 # define U(x)
yading@10 38 #endif
yading@10 39
yading@10 40 #if HAVE_ARMV6_INLINE
yading@10 41
yading@10 42 #define vp56_rac_get_prob vp56_rac_get_prob_armv6
yading@10 43 static inline int vp56_rac_get_prob_armv6(VP56RangeCoder *c, int pr)
yading@10 44 {
yading@10 45 unsigned shift = ff_vp56_norm_shift[c->high];
yading@10 46 unsigned code_word = c->code_word << shift;
yading@10 47 unsigned high = c->high << shift;
yading@10 48 unsigned bit;
yading@10 49
yading@10 50 __asm__ ("adds %3, %3, %0 \n"
yading@10 51 "itt cs \n"
yading@10 52 "cmpcs %7, %4 \n"
yading@10 53 L("ldrcsh %2, [%4], #2 \n")
yading@10 54 U("ldrhcs %2, [%4], #2 \n")
yading@10 55 "rsb %0, %6, #256 \n"
yading@10 56 "smlabb %0, %5, %6, %0 \n"
yading@10 57 T("itttt cs \n")
yading@10 58 "rev16cs %2, %2 \n"
yading@10 59 T("lslcs %2, %2, %3 \n")
yading@10 60 T("orrcs %1, %1, %2 \n")
yading@10 61 A("orrcs %1, %1, %2, lsl %3 \n")
yading@10 62 "subcs %3, %3, #16 \n"
yading@10 63 "lsr %0, %0, #8 \n"
yading@10 64 "cmp %1, %0, lsl #16 \n"
yading@10 65 "ittte ge \n"
yading@10 66 "subge %1, %1, %0, lsl #16 \n"
yading@10 67 "subge %0, %5, %0 \n"
yading@10 68 "movge %2, #1 \n"
yading@10 69 "movlt %2, #0 \n"
yading@10 70 : "=&r"(c->high), "=&r"(c->code_word), "=&r"(bit),
yading@10 71 "+&r"(c->bits), "+&r"(c->buffer)
yading@10 72 : "r"(high), "r"(pr), "r"(c->end - 1),
yading@10 73 "0"(shift), "1"(code_word)
yading@10 74 : "cc");
yading@10 75
yading@10 76 return bit;
yading@10 77 }
yading@10 78
yading@10 79 #define vp56_rac_get_prob_branchy vp56_rac_get_prob_branchy_armv6
yading@10 80 static inline int vp56_rac_get_prob_branchy_armv6(VP56RangeCoder *c, int pr)
yading@10 81 {
yading@10 82 unsigned shift = ff_vp56_norm_shift[c->high];
yading@10 83 unsigned code_word = c->code_word << shift;
yading@10 84 unsigned high = c->high << shift;
yading@10 85 unsigned low;
yading@10 86 unsigned tmp;
yading@10 87
yading@10 88 __asm__ ("adds %3, %3, %0 \n"
yading@10 89 "itt cs \n"
yading@10 90 "cmpcs %7, %4 \n"
yading@10 91 L("ldrcsh %2, [%4], #2 \n")
yading@10 92 U("ldrhcs %2, [%4], #2 \n")
yading@10 93 "rsb %0, %6, #256 \n"
yading@10 94 "smlabb %0, %5, %6, %0 \n"
yading@10 95 T("itttt cs \n")
yading@10 96 "rev16cs %2, %2 \n"
yading@10 97 T("lslcs %2, %2, %3 \n")
yading@10 98 T("orrcs %1, %1, %2 \n")
yading@10 99 A("orrcs %1, %1, %2, lsl %3 \n")
yading@10 100 "subcs %3, %3, #16 \n"
yading@10 101 "lsr %0, %0, #8 \n"
yading@10 102 "lsl %2, %0, #16 \n"
yading@10 103 : "=&r"(low), "+&r"(code_word), "=&r"(tmp),
yading@10 104 "+&r"(c->bits), "+&r"(c->buffer)
yading@10 105 : "r"(high), "r"(pr), "r"(c->end - 1), "0"(shift)
yading@10 106 : "cc");
yading@10 107
yading@10 108 if (code_word >= tmp) {
yading@10 109 c->high = high - low;
yading@10 110 c->code_word = code_word - tmp;
yading@10 111 return 1;
yading@10 112 }
yading@10 113
yading@10 114 c->high = low;
yading@10 115 c->code_word = code_word;
yading@10 116 return 0;
yading@10 117 }
yading@10 118
yading@10 119 #endif
yading@10 120
yading@10 121 #endif /* AVCODEC_ARM_VP56_ARITH_H */