asm.S 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  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. #include "config.h"
  21. #ifdef __ELF__
  22. # define ELF
  23. #else
  24. # define ELF @
  25. #endif
  26. #if CONFIG_THUMB
  27. # define A @
  28. # define T
  29. #else
  30. # define A
  31. # define T @
  32. #endif
  33. #if HAVE_AS_FUNC
  34. # define FUNC
  35. #else
  36. # define FUNC @
  37. #endif
  38. #if HAVE_AS_FPU_DIRECTIVE
  39. # define FPU
  40. #else
  41. # define FPU @
  42. #endif
  43. #if HAVE_AS_ARCH_DIRECTIVE
  44. #if HAVE_NEON
  45. .arch armv7-a
  46. #elif HAVE_ARMV6T2
  47. .arch armv6t2
  48. #elif HAVE_ARMV6
  49. .arch armv6
  50. #elif HAVE_ARMV5TE
  51. .arch armv5te
  52. #endif
  53. #endif
  54. #if HAVE_AS_OBJECT_ARCH
  55. ELF .object_arch armv4
  56. #endif
  57. #if HAVE_NEON
  58. FPU .fpu neon
  59. ELF .eabi_attribute 10, 0 @ suppress Tag_FP_arch
  60. ELF .eabi_attribute 12, 0 @ suppress Tag_Advanced_SIMD_arch
  61. #elif HAVE_VFP
  62. FPU .fpu vfp
  63. ELF .eabi_attribute 10, 0 @ suppress Tag_FP_arch
  64. #endif
  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. .macro function name, export=0, align=2
  70. .set .Lpic_idx, 0
  71. .set .Lpic_gp, 0
  72. .macro endfunc
  73. .if .Lpic_idx
  74. .align 2
  75. .altmacro
  76. put_pic %(.Lpic_idx - 1)
  77. .noaltmacro
  78. .endif
  79. .if .Lpic_gp
  80. .unreq gp
  81. .endif
  82. ELF .size \name, . - \name
  83. FUNC .endfunc
  84. .purgem endfunc
  85. .endm
  86. .text
  87. .align \align
  88. .if \export
  89. .global EXTERN_ASM\name
  90. ELF .type EXTERN_ASM\name, %function
  91. FUNC .func EXTERN_ASM\name
  92. EXTERN_ASM\name:
  93. .else
  94. ELF .type \name, %function
  95. FUNC .func \name
  96. \name:
  97. .endif
  98. .endm
  99. .macro const name, align=2, relocate=0
  100. .macro endconst
  101. ELF .size \name, . - \name
  102. .purgem endconst
  103. .endm
  104. #if HAVE_SECTION_DATA_REL_RO
  105. .if \relocate
  106. .section .data.rel.ro
  107. .else
  108. .section .rodata
  109. .endif
  110. #elif !defined(__MACH__)
  111. .section .rodata
  112. #else
  113. .const_data
  114. #endif
  115. .align \align
  116. \name:
  117. .endm
  118. #if !HAVE_ARMV6T2_EXTERNAL
  119. .macro movw rd, val
  120. mov \rd, \val & 255
  121. orr \rd, \val & ~255
  122. .endm
  123. #endif
  124. .macro mov32 rd, val
  125. #if HAVE_ARMV6T2_EXTERNAL
  126. movw \rd, #(\val) & 0xffff
  127. .if (\val) >> 16
  128. movt \rd, #(\val) >> 16
  129. .endif
  130. #else
  131. ldr \rd, =\val
  132. #endif
  133. .endm
  134. .macro put_pic num
  135. put_pic_\num
  136. .endm
  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. .macro def_pic val, label
  149. .altmacro
  150. do_def_pic %.Lpic_idx, \val, \label
  151. .noaltmacro
  152. .set .Lpic_idx, .Lpic_idx + 1
  153. .endm
  154. .macro ldpic rd, val, indir=0
  155. ldr \rd, .Lpicoff\@
  156. .Lpic\@:
  157. .if \indir
  158. A ldr \rd, [pc, \rd]
  159. T add \rd, pc
  160. T ldr \rd, [\rd]
  161. .else
  162. add \rd, pc
  163. .endif
  164. def_pic \val - (.Lpic\@ + (8 >> CONFIG_THUMB)), .Lpicoff\@
  165. .endm
  166. .macro movrel rd, val
  167. #if CONFIG_PIC
  168. ldpic \rd, \val
  169. #elif HAVE_ARMV6T2_EXTERNAL && !defined(__APPLE__)
  170. movw \rd, #:lower16:\val
  171. movt \rd, #:upper16:\val
  172. #else
  173. ldr \rd, =\val
  174. #endif
  175. .endm
  176. .macro movrelx rd, val, gp
  177. .ifc \rd,\gp
  178. .error "movrelx needs two distinct registers"
  179. .endif
  180. .ifc \rd\()_\gp,r12_
  181. .warning "movrelx rd=\rd without explicit set gp"
  182. .endif
  183. .ifc \rd\()_\gp,ip_
  184. .warning "movrelx rd=\rd without explicit set gp"
  185. .endif
  186. #if CONFIG_PIC && defined(__ELF__)
  187. .ifnb \gp
  188. .if .Lpic_gp
  189. .unreq gp
  190. .endif
  191. gp .req \gp
  192. ldpic gp, _GLOBAL_OFFSET_TABLE_
  193. .elseif !.Lpic_gp
  194. gp .req r12
  195. ldpic gp, _GLOBAL_OFFSET_TABLE_
  196. .endif
  197. .set .Lpic_gp, 1
  198. ldr \rd, .Lpicoff\@
  199. ldr \rd, [gp, \rd]
  200. def_pic \val(GOT), .Lpicoff\@
  201. #elif CONFIG_PIC && defined(__APPLE__)
  202. ldpic \rd, .Lpic\@, indir=1
  203. .non_lazy_symbol_pointer
  204. .Lpic\@:
  205. .indirect_symbol \val
  206. .word 0
  207. .text
  208. #else
  209. movrel \rd, \val
  210. #endif
  211. .endm
  212. .macro add_sh rd, rn, rm, sh:vararg
  213. A add \rd, \rn, \rm, \sh
  214. T mov \rm, \rm, \sh
  215. T add \rd, \rn, \rm
  216. .endm
  217. .macro ldr_pre rt, rn, rm:vararg
  218. A ldr \rt, [\rn, \rm]!
  219. T add \rn, \rn, \rm
  220. T ldr \rt, [\rn]
  221. .endm
  222. .macro ldr_dpre rt, rn, rm:vararg
  223. A ldr \rt, [\rn, -\rm]!
  224. T sub \rn, \rn, \rm
  225. T ldr \rt, [\rn]
  226. .endm
  227. .macro ldr_nreg rt, rn, rm:vararg
  228. A ldr \rt, [\rn, -\rm]
  229. T sub \rt, \rn, \rm
  230. T ldr \rt, [\rt]
  231. .endm
  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. .macro ldrc_pre cc, rt, rn, rm:vararg
  238. A ldr\cc \rt, [\rn, \rm]!
  239. T itt \cc
  240. T add\cc \rn, \rn, \rm
  241. T ldr\cc \rt, [\rn]
  242. .endm
  243. .macro ldrd_reg rt, rt2, rn, rm
  244. A ldrd \rt, \rt2, [\rn, \rm]
  245. T add \rt, \rn, \rm
  246. T ldrd \rt, \rt2, [\rt]
  247. .endm
  248. .macro ldrd_post rt, rt2, rn, rm
  249. A ldrd \rt, \rt2, [\rn], \rm
  250. T ldrd \rt, \rt2, [\rn]
  251. T add \rn, \rn, \rm
  252. .endm
  253. .macro ldrh_pre rt, rn, rm
  254. A ldrh \rt, [\rn, \rm]!
  255. T add \rn, \rn, \rm
  256. T ldrh \rt, [\rn]
  257. .endm
  258. .macro ldrh_dpre rt, rn, rm
  259. A ldrh \rt, [\rn, -\rm]!
  260. T sub \rn, \rn, \rm
  261. T ldrh \rt, [\rn]
  262. .endm
  263. .macro ldrh_post rt, rn, rm
  264. A ldrh \rt, [\rn], \rm
  265. T ldrh \rt, [\rn]
  266. T add \rn, \rn, \rm
  267. .endm
  268. .macro ldrb_post rt, rn, rm
  269. A ldrb \rt, [\rn], \rm
  270. T ldrb \rt, [\rn]
  271. T add \rn, \rn, \rm
  272. .endm
  273. .macro str_post rt, rn, rm:vararg
  274. A str \rt, [\rn], \rm
  275. T str \rt, [\rn]
  276. T add \rn, \rn, \rm
  277. .endm
  278. .macro strb_post rt, rn, rm:vararg
  279. A strb \rt, [\rn], \rm
  280. T strb \rt, [\rn]
  281. T add \rn, \rn, \rm
  282. .endm
  283. .macro strd_post rt, rt2, rn, rm
  284. A strd \rt, \rt2, [\rn], \rm
  285. T strd \rt, \rt2, [\rn]
  286. T add \rn, \rn, \rm
  287. .endm
  288. .macro strh_pre rt, rn, rm
  289. A strh \rt, [\rn, \rm]!
  290. T add \rn, \rn, \rm
  291. T strh \rt, [\rn]
  292. .endm
  293. .macro strh_dpre rt, rn, rm
  294. A strh \rt, [\rn, -\rm]!
  295. T sub \rn, \rn, \rm
  296. T strh \rt, [\rn]
  297. .endm
  298. .macro strh_post rt, rn, rm
  299. A strh \rt, [\rn], \rm
  300. T strh \rt, [\rn]
  301. T add \rn, \rn, \rm
  302. .endm
  303. .macro strh_dpost rt, rn, rm
  304. A strh \rt, [\rn], -\rm
  305. T strh \rt, [\rn]
  306. T sub \rn, \rn, \rm
  307. .endm
  308. #if HAVE_VFP_ARGS
  309. ELF .eabi_attribute 28, 1
  310. # define VFP
  311. # define NOVFP @
  312. #else
  313. # define VFP @
  314. # define NOVFP
  315. #endif
  316. #define GLUE(a, b) a ## b
  317. #define JOIN(a, b) GLUE(a, b)
  318. #define X(s) JOIN(EXTERN_ASM, s)