You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

305 lines
7.3KB

  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_NEON
  34. .arch armv7-a
  35. #elif HAVE_ARMV6T2
  36. .arch armv6t2
  37. #elif HAVE_ARMV6
  38. .arch armv6
  39. #elif HAVE_ARMV5TE
  40. .arch armv5te
  41. #endif
  42. #if HAVE_NEON
  43. .fpu neon
  44. #elif HAVE_VFP
  45. .fpu vfp
  46. #endif
  47. .syntax unified
  48. T .thumb
  49. ELF .eabi_attribute 25, 1 @ Tag_ABI_align_preserved
  50. .macro function name, export=0
  51. .set .Lpic_idx, 0
  52. .set .Lpic_gp, 0
  53. .macro endfunc
  54. .if .Lpic_idx
  55. .align 2
  56. .altmacro
  57. put_pic %(.Lpic_idx - 1)
  58. .noaltmacro
  59. .endif
  60. ELF .size \name, . - \name
  61. .endfunc
  62. .purgem endfunc
  63. .endm
  64. .text
  65. .align 2
  66. .if \export
  67. .global EXTERN_ASM\name
  68. EXTERN_ASM\name:
  69. .endif
  70. ELF .type \name, %function
  71. .func \name
  72. \name:
  73. .endm
  74. .macro const name, align=2
  75. .macro endconst
  76. ELF .size \name, . - \name
  77. .purgem endconst
  78. .endm
  79. .section .rodata
  80. .align \align
  81. \name:
  82. .endm
  83. #if !HAVE_ARMV6T2_EXTERNAL
  84. .macro movw rd, val
  85. mov \rd, \val & 255
  86. orr \rd, \val & ~255
  87. .endm
  88. #endif
  89. .macro mov32 rd, val
  90. #if HAVE_ARMV6T2_EXTERNAL
  91. movw \rd, #(\val) & 0xffff
  92. .if (\val) >> 16
  93. movt \rd, #(\val) >> 16
  94. .endif
  95. #else
  96. ldr \rd, =\val
  97. #endif
  98. .endm
  99. .macro put_pic num
  100. put_pic_\num
  101. .endm
  102. .macro do_def_pic num, val, label
  103. .macro put_pic_\num
  104. .if \num
  105. .altmacro
  106. put_pic %(\num - 1)
  107. .noaltmacro
  108. .endif
  109. \label: .word \val
  110. .purgem put_pic_\num
  111. .endm
  112. .endm
  113. .macro def_pic val, label
  114. .altmacro
  115. do_def_pic %.Lpic_idx, \val, \label
  116. .noaltmacro
  117. .set .Lpic_idx, .Lpic_idx + 1
  118. .endm
  119. .macro ldpic rd, val, indir=0
  120. ldr \rd, .Lpicoff\@
  121. .Lpic\@:
  122. .if \indir
  123. A ldr \rd, [pc, \rd]
  124. T add \rd, pc
  125. T ldr \rd, [\rd]
  126. .else
  127. add \rd, pc
  128. .endif
  129. def_pic \val - (.Lpic\@ + (8 >> CONFIG_THUMB)), .Lpicoff\@
  130. .endm
  131. .macro movrel rd, val
  132. #if CONFIG_PIC
  133. ldpic \rd, \val
  134. #elif HAVE_ARMV6T2_EXTERNAL && !defined(__APPLE__)
  135. movw \rd, #:lower16:\val
  136. movt \rd, #:upper16:\val
  137. #else
  138. ldr \rd, =\val
  139. #endif
  140. .endm
  141. .macro movrelx rd, val, gp
  142. #if CONFIG_PIC && defined(__ELF__)
  143. .ifnb \gp
  144. .if .Lpic_gp
  145. .unreq gp
  146. .endif
  147. gp .req \gp
  148. ldpic gp, _GLOBAL_OFFSET_TABLE_
  149. .elseif !.Lpic_gp
  150. gp .req r12
  151. ldpic gp, _GLOBAL_OFFSET_TABLE_
  152. .endif
  153. .set .Lpic_gp, 1
  154. ldr \rd, .Lpicoff\@
  155. ldr \rd, [gp, \rd]
  156. def_pic \val(GOT), .Lpicoff\@
  157. #elif CONFIG_PIC && defined(__APPLE__)
  158. ldpic \rd, .Lpic\@, indir=1
  159. .non_lazy_symbol_pointer
  160. .Lpic\@:
  161. .indirect_symbol \val
  162. .word 0
  163. .text
  164. #else
  165. movrel \rd, \val
  166. #endif
  167. .endm
  168. .macro add_sh rd, rn, rm, sh:vararg
  169. A add \rd, \rn, \rm, \sh
  170. T mov \rm, \rm, \sh
  171. T add \rd, \rn, \rm
  172. .endm
  173. .macro ldr_pre rt, rn, rm:vararg
  174. A ldr \rt, [\rn, \rm]!
  175. T add \rn, \rn, \rm
  176. T ldr \rt, [\rn]
  177. .endm
  178. .macro ldr_dpre rt, rn, rm:vararg
  179. A ldr \rt, [\rn, -\rm]!
  180. T sub \rn, \rn, \rm
  181. T ldr \rt, [\rn]
  182. .endm
  183. .macro ldr_nreg rt, rn, rm:vararg
  184. A ldr \rt, [\rn, -\rm]
  185. T sub \rt, \rn, \rm
  186. T ldr \rt, [\rt]
  187. .endm
  188. .macro ldr_post rt, rn, rm:vararg
  189. A ldr \rt, [\rn], \rm
  190. T ldr \rt, [\rn]
  191. T add \rn, \rn, \rm
  192. .endm
  193. .macro ldrd_reg rt, rt2, rn, rm
  194. A ldrd \rt, \rt2, [\rn, \rm]
  195. T add \rt, \rn, \rm
  196. T ldrd \rt, \rt2, [\rt]
  197. .endm
  198. .macro ldrd_post rt, rt2, rn, rm
  199. A ldrd \rt, \rt2, [\rn], \rm
  200. T ldrd \rt, \rt2, [\rn]
  201. T add \rn, \rn, \rm
  202. .endm
  203. .macro ldrh_pre rt, rn, rm
  204. A ldrh \rt, [\rn, \rm]!
  205. T add \rn, \rn, \rm
  206. T ldrh \rt, [\rn]
  207. .endm
  208. .macro ldrh_dpre rt, rn, rm
  209. A ldrh \rt, [\rn, -\rm]!
  210. T sub \rn, \rn, \rm
  211. T ldrh \rt, [\rn]
  212. .endm
  213. .macro ldrh_post rt, rn, rm
  214. A ldrh \rt, [\rn], \rm
  215. T ldrh \rt, [\rn]
  216. T add \rn, \rn, \rm
  217. .endm
  218. .macro ldrb_post rt, rn, rm
  219. A ldrb \rt, [\rn], \rm
  220. T ldrb \rt, [\rn]
  221. T add \rn, \rn, \rm
  222. .endm
  223. .macro str_post rt, rn, rm:vararg
  224. A str \rt, [\rn], \rm
  225. T str \rt, [\rn]
  226. T add \rn, \rn, \rm
  227. .endm
  228. .macro strb_post rt, rn, rm:vararg
  229. A strb \rt, [\rn], \rm
  230. T strb \rt, [\rn]
  231. T add \rn, \rn, \rm
  232. .endm
  233. .macro strd_post rt, rt2, rn, rm
  234. A strd \rt, \rt2, [\rn], \rm
  235. T strd \rt, \rt2, [\rn]
  236. T add \rn, \rn, \rm
  237. .endm
  238. .macro strh_pre rt, rn, rm
  239. A strh \rt, [\rn, \rm]!
  240. T add \rn, \rn, \rm
  241. T strh \rt, [\rn]
  242. .endm
  243. .macro strh_dpre rt, rn, rm
  244. A strh \rt, [\rn, -\rm]!
  245. T sub \rn, \rn, \rm
  246. T strh \rt, [\rn]
  247. .endm
  248. .macro strh_post rt, rn, rm
  249. A strh \rt, [\rn], \rm
  250. T strh \rt, [\rn]
  251. T add \rn, \rn, \rm
  252. .endm
  253. .macro strh_dpost rt, rn, rm
  254. A strh \rt, [\rn], -\rm
  255. T strh \rt, [\rn]
  256. T sub \rn, \rn, \rm
  257. .endm
  258. #if HAVE_VFP_ARGS
  259. .eabi_attribute 28, 1
  260. # define VFP
  261. # define NOVFP @
  262. #else
  263. # define VFP @
  264. # define NOVFP
  265. #endif
  266. #define GLUE(a, b) a ## b
  267. #define JOIN(a, b) GLUE(a, b)
  268. #define X(s) JOIN(EXTERN_ASM, s)