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.

309 lines
7.5KB

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