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.

350 lines
8.5KB

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