]> git.sesse.net Git - ffmpeg/blob - libavutil/arm/asm.S
Merge commit '8e9cd81d291b1010c625b2766058aadf4affb537'
[ffmpeg] / libavutil / arm / asm.S
1 /*
2  * Copyright (c) 2008 Mans Rullgard <mans@mansr.com>
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20
21 #include "config.h"
22
23 #ifdef __ELF__
24 #   define ELF
25 #else
26 #   define ELF @
27 #endif
28
29 #if CONFIG_THUMB
30 #   define A @
31 #   define T
32 #else
33 #   define A
34 #   define T @
35 #endif
36
37 #if HAVE_AS_FUNC
38 #   define FUNC
39 #else
40 #   define FUNC @
41 #endif
42
43 #if   HAVE_NEON
44         .arch           armv7-a
45 #elif HAVE_ARMV6T2
46         .arch           armv6t2
47 #elif HAVE_ARMV6
48         .arch           armv6
49 #elif HAVE_ARMV5TE
50         .arch           armv5te
51 #endif
52 #if   HAVE_AS_OBJECT_ARCH
53 ELF     .object_arch    armv4
54 #endif
55
56 #if   HAVE_NEON
57         .fpu            neon
58 ELF     .eabi_attribute 10, 0           @ suppress Tag_FP_arch
59 ELF     .eabi_attribute 12, 0           @ suppress Tag_Advanced_SIMD_arch
60 #elif HAVE_VFP
61         .fpu            vfp
62 ELF     .eabi_attribute 10, 0           @ suppress Tag_FP_arch
63 #endif
64
65         .syntax unified
66 T       .thumb
67 ELF     .eabi_attribute 25, 1           @ Tag_ABI_align_preserved
68 ELF     .section .note.GNU-stack,"",%progbits @ Mark stack as non-executable
69
70 .macro  function name, export=0, align=2
71         .set            .Lpic_idx, 0
72         .set            .Lpic_gp, 0
73     .macro endfunc
74       .if .Lpic_idx
75         .align          2
76         .altmacro
77         put_pic         %(.Lpic_idx - 1)
78         .noaltmacro
79       .endif
80       .if .Lpic_gp
81         .unreq          gp
82       .endif
83 ELF     .size   \name, . - \name
84 FUNC    .endfunc
85         .purgem endfunc
86     .endm
87         .text
88         .align          \align
89     .if \export
90         .global EXTERN_ASM\name
91 ELF     .type   EXTERN_ASM\name, %function
92 FUNC    .func   EXTERN_ASM\name
93 EXTERN_ASM\name:
94     .else
95 ELF     .type   \name, %function
96 FUNC    .func   \name
97 \name:
98     .endif
99 .endm
100
101 .macro  const   name, align=2, relocate=0
102     .macro endconst
103 ELF     .size   \name, . - \name
104         .purgem endconst
105     .endm
106 .if HAVE_SECTION_DATA_REL_RO && \relocate
107         .section        .data.rel.ro
108 .else
109         .section        .rodata
110 .endif
111         .align          \align
112 \name:
113 .endm
114
115 #if !HAVE_ARMV6T2_EXTERNAL
116 .macro  movw    rd, val
117         mov     \rd, \val &  255
118         orr     \rd, \val & ~255
119 .endm
120 #endif
121
122 .macro  mov32   rd, val
123 #if HAVE_ARMV6T2_EXTERNAL
124         movw            \rd, #(\val) & 0xffff
125     .if (\val) >> 16
126         movt            \rd, #(\val) >> 16
127     .endif
128 #else
129         ldr             \rd, =\val
130 #endif
131 .endm
132
133 .macro  put_pic         num
134         put_pic_\num
135 .endm
136
137 .macro  do_def_pic      num, val, label
138     .macro put_pic_\num
139       .if \num
140         .altmacro
141         put_pic         %(\num - 1)
142         .noaltmacro
143       .endif
144 \label: .word           \val
145         .purgem         put_pic_\num
146     .endm
147 .endm
148
149 .macro  def_pic         val, label
150         .altmacro
151         do_def_pic      %.Lpic_idx, \val, \label
152         .noaltmacro
153         .set            .Lpic_idx, .Lpic_idx + 1
154 .endm
155
156 .macro  ldpic           rd,  val, indir=0
157         ldr             \rd, .Lpicoff\@
158 .Lpic\@:
159     .if \indir
160 A       ldr             \rd, [pc, \rd]
161 T       add             \rd, pc
162 T       ldr             \rd, [\rd]
163     .else
164         add             \rd, pc
165     .endif
166         def_pic         \val - (.Lpic\@ + (8 >> CONFIG_THUMB)), .Lpicoff\@
167 .endm
168
169 .macro  movrel rd, val
170 #if CONFIG_PIC
171         ldpic           \rd, \val
172 #elif HAVE_ARMV6T2_EXTERNAL && !defined(__APPLE__)
173         movw            \rd, #:lower16:\val
174         movt            \rd, #:upper16:\val
175 #else
176         ldr             \rd, =\val
177 #endif
178 .endm
179
180 .macro  movrelx         rd,  val, gp
181 #if CONFIG_PIC && defined(__ELF__)
182     .ifnb \gp
183       .if .Lpic_gp
184         .unreq          gp
185       .endif
186         gp      .req    \gp
187         ldpic           gp,  _GLOBAL_OFFSET_TABLE_
188     .elseif !.Lpic_gp
189         gp      .req    r12
190         ldpic           gp,  _GLOBAL_OFFSET_TABLE_
191     .endif
192         .set            .Lpic_gp, 1
193         ldr             \rd, .Lpicoff\@
194         ldr             \rd, [gp, \rd]
195         def_pic         \val(GOT), .Lpicoff\@
196 #elif CONFIG_PIC && defined(__APPLE__)
197         ldpic           \rd, .Lpic\@, indir=1
198         .non_lazy_symbol_pointer
199 .Lpic\@:
200         .indirect_symbol \val
201         .word           0
202         .text
203 #else
204         movrel          \rd, \val
205 #endif
206 .endm
207
208 .macro  add_sh          rd,  rn,  rm,  sh:vararg
209 A       add             \rd, \rn, \rm, \sh
210 T       mov             \rm, \rm, \sh
211 T       add             \rd, \rn, \rm
212 .endm
213
214 .macro  ldr_pre         rt,  rn,  rm:vararg
215 A       ldr             \rt, [\rn, \rm]!
216 T       add             \rn, \rn, \rm
217 T       ldr             \rt, [\rn]
218 .endm
219
220 .macro  ldr_dpre        rt,  rn,  rm:vararg
221 A       ldr             \rt, [\rn, -\rm]!
222 T       sub             \rn, \rn, \rm
223 T       ldr             \rt, [\rn]
224 .endm
225
226 .macro  ldr_nreg        rt,  rn,  rm:vararg
227 A       ldr             \rt, [\rn, -\rm]
228 T       sub             \rt, \rn, \rm
229 T       ldr             \rt, [\rt]
230 .endm
231
232 .macro  ldr_post        rt,  rn,  rm:vararg
233 A       ldr             \rt, [\rn], \rm
234 T       ldr             \rt, [\rn]
235 T       add             \rn, \rn, \rm
236 .endm
237
238 .macro  ldrc_pre        cc,  rt,  rn,  rm:vararg
239 A       ldr\cc          \rt, [\rn, \rm]!
240 T       itt             \cc
241 T       add\cc          \rn, \rn, \rm
242 T       ldr\cc          \rt, [\rn]
243 .endm
244
245 .macro  ldrd_reg        rt,  rt2, rn,  rm
246 A       ldrd            \rt, \rt2, [\rn, \rm]
247 T       add             \rt, \rn, \rm
248 T       ldrd            \rt, \rt2, [\rt]
249 .endm
250
251 .macro  ldrd_post       rt,  rt2, rn,  rm
252 A       ldrd            \rt, \rt2, [\rn], \rm
253 T       ldrd            \rt, \rt2, [\rn]
254 T       add             \rn, \rn, \rm
255 .endm
256
257 .macro  ldrh_pre        rt,  rn,  rm
258 A       ldrh            \rt, [\rn, \rm]!
259 T       add             \rn, \rn, \rm
260 T       ldrh            \rt, [\rn]
261 .endm
262
263 .macro  ldrh_dpre       rt,  rn,  rm
264 A       ldrh            \rt, [\rn, -\rm]!
265 T       sub             \rn, \rn, \rm
266 T       ldrh            \rt, [\rn]
267 .endm
268
269 .macro  ldrh_post       rt,  rn,  rm
270 A       ldrh            \rt, [\rn], \rm
271 T       ldrh            \rt, [\rn]
272 T       add             \rn, \rn, \rm
273 .endm
274
275 .macro  ldrb_post       rt,  rn,  rm
276 A       ldrb            \rt, [\rn], \rm
277 T       ldrb            \rt, [\rn]
278 T       add             \rn, \rn, \rm
279 .endm
280
281 .macro  str_post       rt,  rn,  rm:vararg
282 A       str             \rt, [\rn], \rm
283 T       str             \rt, [\rn]
284 T       add             \rn, \rn, \rm
285 .endm
286
287 .macro  strb_post       rt,  rn,  rm:vararg
288 A       strb            \rt, [\rn], \rm
289 T       strb            \rt, [\rn]
290 T       add             \rn, \rn, \rm
291 .endm
292
293 .macro  strd_post       rt,  rt2, rn,  rm
294 A       strd            \rt, \rt2, [\rn], \rm
295 T       strd            \rt, \rt2, [\rn]
296 T       add             \rn, \rn, \rm
297 .endm
298
299 .macro  strh_pre        rt,  rn,  rm
300 A       strh            \rt, [\rn, \rm]!
301 T       add             \rn, \rn, \rm
302 T       strh            \rt, [\rn]
303 .endm
304
305 .macro  strh_dpre       rt,  rn,  rm
306 A       strh            \rt, [\rn, -\rm]!
307 T       sub             \rn, \rn, \rm
308 T       strh            \rt, [\rn]
309 .endm
310
311 .macro  strh_post       rt,  rn,  rm
312 A       strh            \rt, [\rn], \rm
313 T       strh            \rt, [\rn]
314 T       add             \rn, \rn, \rm
315 .endm
316
317 .macro  strh_dpost       rt,  rn,  rm
318 A       strh            \rt, [\rn], -\rm
319 T       strh            \rt, [\rn]
320 T       sub             \rn, \rn, \rm
321 .endm
322
323 #if HAVE_VFP_ARGS
324 ELF     .eabi_attribute 28, 1
325 #   define VFP
326 #   define NOVFP @
327 #else
328 #   define VFP   @
329 #   define NOVFP
330 #endif
331
332 #define GLUE(a, b) a ## b
333 #define JOIN(a, b) GLUE(a, b)
334 #define X(s) JOIN(EXTERN_ASM, s)