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.

225 lines
6.0KB

  1. /*
  2. * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
  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. /**
  21. * @file
  22. * common internal API header
  23. */
  24. #ifndef AVUTIL_INTERNAL_H
  25. #define AVUTIL_INTERNAL_H
  26. #if !defined(DEBUG) && !defined(NDEBUG)
  27. # define NDEBUG
  28. #endif
  29. #include <limits.h>
  30. #include <stdint.h>
  31. #include <stddef.h>
  32. #include <assert.h>
  33. #include "config.h"
  34. #include "attributes.h"
  35. #include "timer.h"
  36. #include "cpu.h"
  37. #include "dict.h"
  38. struct AVDictionary {
  39. int count;
  40. AVDictionaryEntry *elems;
  41. };
  42. #ifndef attribute_align_arg
  43. #if ARCH_X86_32 && AV_GCC_VERSION_AT_LEAST(4,2)
  44. # define attribute_align_arg __attribute__((force_align_arg_pointer))
  45. #else
  46. # define attribute_align_arg
  47. #endif
  48. #endif
  49. #ifndef INT16_MIN
  50. #define INT16_MIN (-0x7fff - 1)
  51. #endif
  52. #ifndef INT16_MAX
  53. #define INT16_MAX 0x7fff
  54. #endif
  55. #ifndef INT32_MIN
  56. #define INT32_MIN (-0x7fffffff - 1)
  57. #endif
  58. #ifndef INT32_MAX
  59. #define INT32_MAX 0x7fffffff
  60. #endif
  61. #ifndef UINT32_MAX
  62. #define UINT32_MAX 0xffffffff
  63. #endif
  64. #ifndef INT64_MIN
  65. #define INT64_MIN (-0x7fffffffffffffffLL - 1)
  66. #endif
  67. #ifndef INT64_MAX
  68. #define INT64_MAX INT64_C(9223372036854775807)
  69. #endif
  70. #ifndef UINT64_MAX
  71. #define UINT64_MAX UINT64_C(0xFFFFFFFFFFFFFFFF)
  72. #endif
  73. #ifndef INT_BIT
  74. # define INT_BIT (CHAR_BIT * sizeof(int))
  75. #endif
  76. #ifndef offsetof
  77. # define offsetof(T, F) ((unsigned int)((char *)&((T *)0)->F))
  78. #endif
  79. /* debug stuff */
  80. #define av_abort() do { av_log(NULL, AV_LOG_ERROR, "Abort at %s:%d\n", __FILE__, __LINE__); abort(); } while (0)
  81. /* avoid usage of dangerous/inappropriate system functions */
  82. #undef malloc
  83. #define malloc please_use_av_malloc
  84. #undef free
  85. #define free please_use_av_free
  86. #undef realloc
  87. #define realloc please_use_av_realloc
  88. #undef time
  89. #define time time_is_forbidden_due_to_security_issues
  90. #undef rand
  91. #define rand rand_is_forbidden_due_to_state_trashing_use_av_lfg_get
  92. #undef srand
  93. #define srand srand_is_forbidden_due_to_state_trashing_use_av_lfg_init
  94. #undef random
  95. #define random random_is_forbidden_due_to_state_trashing_use_av_lfg_get
  96. #undef sprintf
  97. #define sprintf sprintf_is_forbidden_due_to_security_issues_use_snprintf
  98. #undef strcat
  99. #define strcat strcat_is_forbidden_due_to_security_issues_use_av_strlcat
  100. #undef strncpy
  101. #define strncpy strncpy_is_forbidden_due_to_security_issues_use_av_strlcpy
  102. #undef exit
  103. #define exit exit_is_forbidden
  104. #undef printf
  105. #define printf please_use_av_log_instead_of_printf
  106. #undef fprintf
  107. #define fprintf please_use_av_log_instead_of_fprintf
  108. #undef puts
  109. #define puts please_use_av_log_instead_of_puts
  110. #undef perror
  111. #define perror please_use_av_log_instead_of_perror
  112. #undef strcasecmp
  113. #define strcasecmp please_use_av_strcasecmp
  114. #undef strncasecmp
  115. #define strncasecmp please_use_av_strncasecmp
  116. #define FF_ALLOC_OR_GOTO(ctx, p, size, label)\
  117. {\
  118. p = av_malloc(size);\
  119. if (p == NULL && (size) != 0) {\
  120. av_log(ctx, AV_LOG_ERROR, "Cannot allocate memory.\n");\
  121. goto label;\
  122. }\
  123. }
  124. #define FF_ALLOCZ_OR_GOTO(ctx, p, size, label)\
  125. {\
  126. p = av_mallocz(size);\
  127. if (p == NULL && (size) != 0) {\
  128. av_log(ctx, AV_LOG_ERROR, "Cannot allocate memory.\n");\
  129. goto label;\
  130. }\
  131. }
  132. #include "libm.h"
  133. /**
  134. * Return NULL if CONFIG_SMALL is true, otherwise the argument
  135. * without modification. Used to disable the definition of strings
  136. * (for example AVCodec long_names).
  137. */
  138. #if CONFIG_SMALL
  139. # define NULL_IF_CONFIG_SMALL(x) NULL
  140. #else
  141. # define NULL_IF_CONFIG_SMALL(x) x
  142. #endif
  143. /**
  144. * Define a function with only the non-default version specified.
  145. *
  146. * On systems with ELF shared libraries, all symbols exported from
  147. * FFmpeg libraries are tagged with the name and major version of the
  148. * library to which they belong. If a function is moved from one
  149. * library to another, a wrapper must be retained in the original
  150. * location to preserve binary compatibility.
  151. *
  152. * Functions defined with this macro will never be used to resolve
  153. * symbols by the build-time linker.
  154. *
  155. * @param type return type of function
  156. * @param name name of function
  157. * @param args argument list of function
  158. * @param ver version tag to assign function
  159. */
  160. #if HAVE_SYMVER_ASM_LABEL
  161. # define FF_SYMVER(type, name, args, ver) \
  162. type ff_##name args __asm__ (EXTERN_PREFIX #name "@" ver); \
  163. type ff_##name args
  164. #elif HAVE_SYMVER_GNU_ASM
  165. # define FF_SYMVER(type, name, args, ver) \
  166. __asm__ (".symver ff_" #name "," EXTERN_PREFIX #name "@" ver); \
  167. type ff_##name args; \
  168. type ff_##name args
  169. #endif
  170. /**
  171. * Return NULL if a threading library has not been enabled.
  172. * Used to disable threading functions in AVCodec definitions
  173. * when not needed.
  174. */
  175. #if HAVE_THREADS
  176. # define ONLY_IF_THREADS_ENABLED(x) x
  177. #else
  178. # define ONLY_IF_THREADS_ENABLED(x) NULL
  179. #endif
  180. #if HAVE_MMX && HAVE_INLINE_ASM
  181. /**
  182. * Empty mmx state.
  183. * this must be called between any dsp function and float/double code.
  184. * for example sin(); dsp->idct_put(); emms_c(); cos()
  185. */
  186. static av_always_inline void emms_c(void)
  187. {
  188. if(av_get_cpu_flags() & AV_CPU_FLAG_MMX)
  189. __asm__ volatile ("emms" ::: "memory");
  190. }
  191. #elif HAVE_MMX && HAVE_MM_EMPTY
  192. # include <mmintrin.h>
  193. # define emms_c _mm_empty
  194. #else /* HAVE_MMX */
  195. # define emms_c()
  196. #endif /* HAVE_MMX */
  197. #endif /* AVUTIL_INTERNAL_H */