asm.S 7.3 KB

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