annotate arm/asm.S @ 12530:63edd10ad4bc libavcodec tip

Try to fix crashes introduced by r25218 r25218 made assumptions about the existence of past reference frames that weren't necessarily true.
author darkshikari
date Tue, 28 Sep 2010 09:06:22 +0000
parents 036603a63c51
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8068
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
1 /*
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
2 * Copyright (c) 2008 Mans Rullgard <mans@mansr.com>
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
3 *
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
4 * This file is part of FFmpeg.
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
5 *
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
10 *
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
14 * Lesser General Public License for more details.
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
15 *
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
19 */
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
20
8507
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
21 #include "config.h"
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
22
9991
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
23 #ifdef __ELF__
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
24 # define ELF
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
25 #else
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
26 # define ELF @
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
27 #endif
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
28
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
29 .macro require8 val=1
9991
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
30 ELF .eabi_attribute 24, \val
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
31 .endm
8068
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
32
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
33 .macro preserve8 val=1
9991
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
34 ELF .eabi_attribute 25, \val
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
35 .endm
8068
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
36
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
37 .macro function name, export=0
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
38 .macro endfunc
11456
c16e47ff9a49 Only use .size in ARM assembly when targeting ELF
mstorsjo
parents: 11443
diff changeset
39 ELF .size \name, . - \name
11443
361a5fcb4393 ARM: set size of asm functions in object files
mru
parents: 10384
diff changeset
40 .endfunc
361a5fcb4393 ARM: set size of asm functions in object files
mru
parents: 10384
diff changeset
41 .purgem endfunc
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
42 .endm
12105
d6e87496883b ARM: set section to .text in 'function' macro
mru
parents: 12015
diff changeset
43 .text
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
44 .if \export
10346
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
45 .global EXTERN_ASM\name
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
46 EXTERN_ASM\name:
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
47 .endif
9991
c50957bfd553 ARM: cleaner selection of ELF-spefic assembler directives
mru
parents: 9989
diff changeset
48 ELF .type \name, %function
8068
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
49 .func \name
923c713c0c48 ARM: add some assembler convenience macros
mru
parents:
diff changeset
50 \name:
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
51 .endm
8507
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
52
12015
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
53 .macro mov32 rd, val
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
54 #if HAVE_ARMV6T2
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
55 movw \rd, #(\val) & 0xffff
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
56 .if (\val) >> 16
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
57 movt \rd, #(\val) >> 16
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
58 .endif
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
59 #else
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
60 ldr \rd, =\val
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
61 #endif
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
62 .endm
b9bbf46b3623 ARM: add mov32 macro
mru
parents: 12014
diff changeset
63
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
64 .macro movrel rd, val
12504
036603a63c51 ARM: disable movw/movt for relocated values on Apple platforms
mru
parents: 12105
diff changeset
65 #if HAVE_ARMV6T2 && !CONFIG_PIC && !defined(__APPLE__)
8507
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
66 movw \rd, #:lower16:\val
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
67 movt \rd, #:upper16:\val
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
68 #else
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
69 ldr \rd, =\val
779a9c93bf61 ARM: work around linker bug with movw/movt relocations in shared libs
mru
parents: 8359
diff changeset
70 #endif
12014
e21223172ca8 ARM: (mostly) whitespace cosmetics
mru
parents: 11456
diff changeset
71 .endm
9968
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
72
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
73 #if HAVE_VFP_ARGS
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
74 .eabi_attribute 28, 1
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
75 # define VFP
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
76 # define NOVFP @
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
77 #else
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
78 # define VFP @
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
79 # define NOVFP
93c52263ff74 ARM: check for VFP register arguments
mru
parents: 8590
diff changeset
80 #endif
10346
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
81
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
82 #define GLUE(a, b) a ## b
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
83 #define JOIN(a, b) GLUE(a, b)
f12b7ea2df2a ARM: apply extern symbol prefix where needed
mru
parents: 10182
diff changeset
84 #define X(s) JOIN(EXTERN_ASM, s)