151 lines
3.7 KiB
ArmAsm
151 lines
3.7 KiB
ArmAsm
@/******************************************************************************
|
|
@ *
|
|
@ * Copyright (C) 2018 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
|
|
@*/
|
|
|
|
|
|
.text
|
|
.p2align 2
|
|
.global ixheaacd_radix4bfly
|
|
.type ixheaacd_radix4bfly, %function
|
|
|
|
ixheaacd_radix4bfly:
|
|
|
|
STMFD sp!, {r4-r12, r14}
|
|
|
|
SUB sp, sp, #16
|
|
|
|
MOV r6, #6
|
|
MUL r7, r6, r3
|
|
MOV r4, r3
|
|
STR r7, [sp]
|
|
|
|
|
|
|
|
MOV r3, r3, lsl #1
|
|
|
|
STR r2, [sp, #8]
|
|
STR r4, [sp, #12]
|
|
|
|
|
|
ADD r2, r1, r3, lsl #2
|
|
ADD r0, r0, #8
|
|
|
|
|
|
RADIX4_OUTLOOP:
|
|
RADIX4_INLOOP:
|
|
|
|
|
|
LDR r6, [r1]
|
|
LDR r7, [r2]
|
|
LDR r8, [r2, r3, lsl #2]
|
|
LDR r9, [r2, r3, lsl #3]
|
|
|
|
ADD r10, r6, r8
|
|
SUB r11, r6, r8
|
|
ADD r12, r7, r9
|
|
SUB r14, r7, r9
|
|
|
|
ADD r6, r10, r12
|
|
SUB r7, r10, r12
|
|
STR r6, [r1], #4
|
|
|
|
LDR r8, [r1]
|
|
LDR r6, [r2, #4]!
|
|
LDR r9, [r2, r3, lsl #2]!
|
|
LDR r10, [r2, r3, lsl #2]!
|
|
|
|
ADD r12, r8, r9
|
|
SUB r8, r8, r9
|
|
ADD r9, r6, r10
|
|
SUB r6, r6, r10
|
|
|
|
ADD r10, r12, r9
|
|
STR r10, [r1], #4
|
|
SUB r12, r12, r9
|
|
|
|
ADD r9, r11, r6
|
|
SUB r10, r11, r6
|
|
ADD r11, r8, r14
|
|
LDR r5, [r0], #-4
|
|
SUB r6, r8, r14
|
|
|
|
SMULWB r14, r10, r5
|
|
SMULWT r8, r11, r5
|
|
|
|
SUBS r4, r4, #1
|
|
SUB r8, r8, r14
|
|
MOV r8, r8, lsl #1
|
|
STR r8, [r2], #-4
|
|
|
|
SMULWT r14, r10, r5
|
|
SMLAWB r8, r11, r5, r14
|
|
LDR r11, [r0], #-4
|
|
MOV r8, r8, lsl #1
|
|
STR r8, [r2], -r3, lsl #2
|
|
|
|
SMULWT r10, r7, r11
|
|
SMLAWB r8, r12, r11, r10
|
|
|
|
LDR r14, [r0], #20
|
|
MOV r5, r8, lsl #1
|
|
|
|
SMULWB r10, r7, r11
|
|
SMULWT r8, r12, r11
|
|
|
|
STR r5, [r2], #4
|
|
SUB r7, r8, r10
|
|
MOV r7, r7, lsl #1
|
|
|
|
SMULWB r11, r9, r14
|
|
SMULWT r12, r6, r14
|
|
|
|
STR r7, [r2], -r3, lsl #2
|
|
SUB r12, r12, r11
|
|
MOV r12, r12, lsl #1
|
|
|
|
SMULWT r10, r9, r14
|
|
SMLAWB r7, r6, r14, r10
|
|
|
|
STR r12, [r2], #-4
|
|
MOV r7, r7, lsl #1
|
|
STR r7, [r2], #8
|
|
|
|
|
|
BNE RADIX4_INLOOP
|
|
|
|
LDR r8, [sp]
|
|
LDR r4, [sp, #12]
|
|
LDR r6, [sp, #8]
|
|
|
|
|
|
SUB r0, r0, r8, lsl #1
|
|
ADD r1, r1, r8, lsl #2
|
|
ADD r2, r2, r8, lsl #2
|
|
|
|
SUBS r6, r6, #1
|
|
STR r6, [sp, #8]
|
|
BNE RADIX4_OUTLOOP
|
|
|
|
|
|
|
|
ADD sp, sp, #16
|
|
LDMFD sp!, {r4-r12, r15}
|
|
|
|
|