1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * Copyright (c) 2009 Mans Rullgard <mans@mansr.com>
3cabdff1aSopenharmony_ci *
4cabdff1aSopenharmony_ci * This file is part of FFmpeg.
5cabdff1aSopenharmony_ci *
6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
10cabdff1aSopenharmony_ci *
11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14cabdff1aSopenharmony_ci * Lesser General Public License for more details.
15cabdff1aSopenharmony_ci *
16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19cabdff1aSopenharmony_ci */
20cabdff1aSopenharmony_ci
21cabdff1aSopenharmony_ci#include "libavutil/arm/asm.S"
22cabdff1aSopenharmony_ci
23cabdff1aSopenharmony_cifunction ff_pix_norm1_armv6, export=1
24cabdff1aSopenharmony_ci        push            {r4-r6, lr}
25cabdff1aSopenharmony_ci        mov             r12, #16
26cabdff1aSopenharmony_ci        mov             lr,  #0
27cabdff1aSopenharmony_ci1:
28cabdff1aSopenharmony_ci        ldm             r0,  {r2-r5}
29cabdff1aSopenharmony_ci        uxtb16          r6,  r2
30cabdff1aSopenharmony_ci        uxtb16          r2,  r2,  ror #8
31cabdff1aSopenharmony_ci        smlad           lr,  r6,  r6,  lr
32cabdff1aSopenharmony_ci        uxtb16          r6,  r3
33cabdff1aSopenharmony_ci        smlad           lr,  r2,  r2,  lr
34cabdff1aSopenharmony_ci        uxtb16          r3,  r3,  ror #8
35cabdff1aSopenharmony_ci        smlad           lr,  r6,  r6,  lr
36cabdff1aSopenharmony_ci        uxtb16          r6,  r4
37cabdff1aSopenharmony_ci        smlad           lr,  r3,  r3,  lr
38cabdff1aSopenharmony_ci        uxtb16          r4,  r4,  ror #8
39cabdff1aSopenharmony_ci        smlad           lr,  r6,  r6,  lr
40cabdff1aSopenharmony_ci        uxtb16          r6,  r5
41cabdff1aSopenharmony_ci        smlad           lr,  r4,  r4,  lr
42cabdff1aSopenharmony_ci        uxtb16          r5,  r5,  ror #8
43cabdff1aSopenharmony_ci        smlad           lr,  r6,  r6,  lr
44cabdff1aSopenharmony_ci        subs            r12, r12, #1
45cabdff1aSopenharmony_ci        add             r0,  r0,  r1
46cabdff1aSopenharmony_ci        smlad           lr,  r5,  r5,  lr
47cabdff1aSopenharmony_ci        bgt             1b
48cabdff1aSopenharmony_ci
49cabdff1aSopenharmony_ci        mov             r0,  lr
50cabdff1aSopenharmony_ci        pop             {r4-r6, pc}
51cabdff1aSopenharmony_ciendfunc
52cabdff1aSopenharmony_ci
53cabdff1aSopenharmony_cifunction ff_pix_sum_armv6, export=1
54cabdff1aSopenharmony_ci        push            {r4-r7, lr}
55cabdff1aSopenharmony_ci        mov             r12, #16
56cabdff1aSopenharmony_ci        mov             r2,  #0
57cabdff1aSopenharmony_ci        mov             r3,  #0
58cabdff1aSopenharmony_ci        mov             lr,  #0
59cabdff1aSopenharmony_ci        ldr             r4,  [r0]
60cabdff1aSopenharmony_ci1:
61cabdff1aSopenharmony_ci        subs            r12, r12, #1
62cabdff1aSopenharmony_ci        ldr             r5,  [r0, #4]
63cabdff1aSopenharmony_ci        usada8          r2,  r4,  lr,  r2
64cabdff1aSopenharmony_ci        ldr             r6,  [r0, #8]
65cabdff1aSopenharmony_ci        usada8          r3,  r5,  lr,  r3
66cabdff1aSopenharmony_ci        ldr             r7,  [r0, #12]
67cabdff1aSopenharmony_ci        usada8          r2,  r6,  lr,  r2
68cabdff1aSopenharmony_ci        beq             2f
69cabdff1aSopenharmony_ci        ldr_pre         r4,  r0,  r1
70cabdff1aSopenharmony_ci        usada8          r3,  r7,  lr,  r3
71cabdff1aSopenharmony_ci        bgt             1b
72cabdff1aSopenharmony_ci2:
73cabdff1aSopenharmony_ci        usada8          r3,  r7,  lr,  r3
74cabdff1aSopenharmony_ci        add             r0,  r2,  r3
75cabdff1aSopenharmony_ci        pop             {r4-r7, pc}
76cabdff1aSopenharmony_ciendfunc
77