; ; Copyright (c) 2010 The VP8 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. ; EXPORT |vp8_decode_value_v6| EXPORT |vp8dx_start_decode_v6| EXPORT |vp8dx_stop_decode_v6| EXPORT |vp8dx_decode_bool_v6| ARM REQUIRE8 PRESERVE8 INCLUDE vpx_asm_offsets.asm br RN r0 prob RN r1 bits RN r1 AREA |.text|, CODE, READONLY ; name this block of code ; int z = 0; ; int bit; ; for ( bit=bits-1; bit>=0; bit-- ) ; { ; z |= (vp8dx_decode_bool(br, 0x80)<> 8) mov r12, #1 smlawb r6, r6, prob, r12 mov lr, #0 subs r5, r3, r6, lsl #24 ;cmp r3, r1 movhs lr, #1 movhs r3, r5 subhs r2, r2, r6 movlo r2, r6 cmp r2, #0x80 blt range_less_0x80 ;strd r2, r3, [br, #bool_decoder_range] str r2, [br, #bool_decoder_range] str r3, [br, #bool_decoder_value] mov r0, lr ldmia sp!, {r4 - r6, pc} range_less_0x80 ldr r5, [br, #bool_decoder_pos] ldr r1, [br, #bool_decoder_buffer] ldr r4, [br, #bool_decoder_count] add r1, r1, r5 clz r12, r2 sub r12, r12, #24 subs r4, r4, r12 ldrleb r6, [r1], #1 mov r2, r2, lsl r12 mov r3, r3, lsl r12 addle r4, r4, #8 rsble r12, r4, #8 addle r5, r5, #1 orrle r3, r3, r6, lsl r12 ;strd r2, r3, [br, #bool_decoder_range] ;strd r4, r5, [br, #bool_decoder_count] str r2, [br, #bool_decoder_range] str r3, [br, #bool_decoder_value] str r4, [br, #bool_decoder_count] str r5, [br, #bool_decoder_pos] mov r0, lr ldmia sp!, {r4 - r6, pc} ENDP ; |vp8dx_decode_bool_v6| END