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.

335 lines
8.2KB

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