Gustavo Sverzut Barbieri | 822ce23 | 2011-12-10 22:26:40 -0200 | [diff] [blame] | 1 | dnl Macros to check the presence of generic (non-typed) symbols. |
| 2 | dnl Copyright (c) 2006-2008 Diego Pettenò <flameeyes@gmail.com> |
| 3 | dnl Copyright (c) 2006-2008 xine project |
| 4 | dnl |
| 5 | dnl This program is free software; you can redistribute it and/or modify |
| 6 | dnl it under the terms of the GNU General Public License as published by |
| 7 | dnl the Free Software Foundation; either version 2, or (at your option) |
| 8 | dnl any later version. |
| 9 | dnl |
| 10 | dnl This program is distributed in the hope that it will be useful, |
| 11 | dnl but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | dnl GNU General Public License for more details. |
| 14 | dnl |
| 15 | dnl You should have received a copy of the GNU General Public License |
| 16 | dnl along with this program; if not, write to the Free Software |
| 17 | dnl Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA |
| 18 | dnl 02110-1301, USA. |
| 19 | dnl |
| 20 | dnl As a special exception, the copyright owners of the |
| 21 | dnl macro gives unlimited permission to copy, distribute and modify the |
| 22 | dnl configure scripts that are the output of Autoconf when processing the |
| 23 | dnl Macro. You need not follow the terms of the GNU General Public |
| 24 | dnl License when using or distributing such scripts, even though portions |
| 25 | dnl of the text of the Macro appear in them. The GNU General Public |
| 26 | dnl License (GPL) does govern all other use of the material that |
| 27 | dnl constitutes the Autoconf Macro. |
| 28 | dnl |
| 29 | dnl This special exception to the GPL applies to versions of the |
| 30 | dnl Autoconf Macro released by this project. When you make and |
| 31 | dnl distribute a modified version of the Autoconf Macro, you may extend |
| 32 | dnl this special exception to the GPL to apply to your modified version as |
| 33 | dnl well. |
| 34 | |
| 35 | dnl Check if the flag is supported by compiler |
| 36 | dnl CC_CHECK_CFLAGS_SILENT([FLAG], [ACTION-IF-FOUND],[ACTION-IF-NOT-FOUND]) |
| 37 | |
| 38 | AC_DEFUN([CC_CHECK_CFLAGS_SILENT], [ |
| 39 | AC_CACHE_VAL(AS_TR_SH([cc_cv_cflags_$1]), |
| 40 | [ac_save_CFLAGS="$CFLAGS" |
| 41 | CFLAGS="$CFLAGS $1" |
| 42 | AC_COMPILE_IFELSE([AC_LANG_SOURCE([int a;])], |
| 43 | [eval "AS_TR_SH([cc_cv_cflags_$1])='yes'"], |
| 44 | [eval "AS_TR_SH([cc_cv_cflags_$1])='no'"]) |
| 45 | CFLAGS="$ac_save_CFLAGS" |
| 46 | ]) |
| 47 | |
| 48 | AS_IF([eval test x$]AS_TR_SH([cc_cv_cflags_$1])[ = xyes], |
| 49 | [$2], [$3]) |
| 50 | ]) |
| 51 | |
| 52 | dnl Check if the flag is supported by compiler (cacheable) |
| 53 | dnl CC_CHECK_CFLAGS([FLAG], [ACTION-IF-FOUND],[ACTION-IF-NOT-FOUND]) |
| 54 | |
| 55 | AC_DEFUN([CC_CHECK_CFLAGS], [ |
| 56 | AC_CACHE_CHECK([if $CC supports $1 flag], |
| 57 | AS_TR_SH([cc_cv_cflags_$1]), |
| 58 | CC_CHECK_CFLAGS_SILENT([$1]) dnl Don't execute actions here! |
| 59 | ) |
| 60 | |
| 61 | AS_IF([eval test x$]AS_TR_SH([cc_cv_cflags_$1])[ = xyes], |
| 62 | [$2], [$3]) |
| 63 | ]) |
| 64 | |
| 65 | dnl CC_CHECK_CFLAG_APPEND(FLAG, [action-if-found], [action-if-not-found]) |
| 66 | dnl Check for CFLAG and appends them to CFLAGS if supported |
| 67 | AC_DEFUN([CC_CHECK_CFLAG_APPEND], [ |
| 68 | AC_CACHE_CHECK([if $CC supports $1 flag], |
| 69 | AS_TR_SH([cc_cv_cflags_$1]), |
| 70 | CC_CHECK_CFLAGS_SILENT([$1]) dnl Don't execute actions here! |
| 71 | ) |
| 72 | |
| 73 | AS_IF([eval test x$]AS_TR_SH([cc_cv_cflags_$1])[ = xyes], |
| 74 | [CFLAGS="$CFLAGS $1"; DEBUG_CFLAGS="$DEBUG_CFLAGS $1"; $2], [$3]) |
| 75 | ]) |
| 76 | |
| 77 | dnl CC_CHECK_CFLAGS_APPEND([FLAG1 FLAG2], [action-if-found], [action-if-not]) |
| 78 | AC_DEFUN([CC_CHECK_CFLAGS_APPEND], [ |
| 79 | for flag in $1; do |
| 80 | CC_CHECK_CFLAG_APPEND($flag, [$2], [$3]) |
| 81 | done |
| 82 | ]) |
| 83 | |
| 84 | dnl Check if the flag is supported by linker (cacheable) |
| 85 | dnl CC_CHECK_LDFLAGS([FLAG], [ACTION-IF-FOUND],[ACTION-IF-NOT-FOUND]) |
| 86 | |
| 87 | AC_DEFUN([CC_CHECK_LDFLAGS], [ |
| 88 | AC_CACHE_CHECK([if $CC supports $1 flag], |
| 89 | AS_TR_SH([cc_cv_ldflags_$1]), |
| 90 | [ac_save_LDFLAGS="$LDFLAGS" |
| 91 | LDFLAGS="$LDFLAGS $1" |
| 92 | AC_LINK_IFELSE([int main() { return 1; }], |
| 93 | [eval "AS_TR_SH([cc_cv_ldflags_$1])='yes'"], |
| 94 | [eval "AS_TR_SH([cc_cv_ldflags_$1])="]) |
| 95 | LDFLAGS="$ac_save_LDFLAGS" |
| 96 | ]) |
| 97 | |
| 98 | AS_IF([eval test x$]AS_TR_SH([cc_cv_ldflags_$1])[ = xyes], |
| 99 | [$2], [$3]) |
| 100 | ]) |
| 101 | |
| 102 | dnl define the LDFLAGS_NOUNDEFINED variable with the correct value for |
| 103 | dnl the current linker to avoid undefined references in a shared object. |
| 104 | AC_DEFUN([CC_NOUNDEFINED], [ |
| 105 | dnl We check $host for which systems to enable this for. |
| 106 | AC_REQUIRE([AC_CANONICAL_HOST]) |
| 107 | |
| 108 | case $host in |
| 109 | dnl FreeBSD (et al.) does not complete linking for shared objects when pthreads |
| 110 | dnl are requested, as different implementations are present; to avoid problems |
| 111 | dnl use -Wl,-z,defs only for those platform not behaving this way. |
| 112 | *-freebsd* | *-openbsd*) ;; |
| 113 | *) |
| 114 | dnl First of all check for the --no-undefined variant of GNU ld. This allows |
| 115 | dnl for a much more readable commandline, so that people can understand what |
| 116 | dnl it does without going to look for what the heck -z defs does. |
| 117 | for possible_flags in "-Wl,--no-undefined" "-Wl,-z,defs"; do |
| 118 | CC_CHECK_LDFLAGS([$possible_flags], [LDFLAGS_NOUNDEFINED="$possible_flags"]) |
| 119 | break |
| 120 | done |
| 121 | ;; |
| 122 | esac |
| 123 | |
| 124 | AC_SUBST([LDFLAGS_NOUNDEFINED]) |
| 125 | ]) |
| 126 | |
| 127 | dnl Check for a -Werror flag or equivalent. -Werror is the GCC |
| 128 | dnl and ICC flag that tells the compiler to treat all the warnings |
| 129 | dnl as fatal. We usually need this option to make sure that some |
| 130 | dnl constructs (like attributes) are not simply ignored. |
| 131 | dnl |
| 132 | dnl Other compilers don't support -Werror per se, but they support |
| 133 | dnl an equivalent flag: |
| 134 | dnl - Sun Studio compiler supports -errwarn=%all |
| 135 | AC_DEFUN([CC_CHECK_WERROR], [ |
| 136 | AC_CACHE_CHECK( |
| 137 | [for $CC way to treat warnings as errors], |
| 138 | [cc_cv_werror], |
| 139 | [CC_CHECK_CFLAGS_SILENT([-Werror], [cc_cv_werror=-Werror], |
| 140 | [CC_CHECK_CFLAGS_SILENT([-errwarn=%all], [cc_cv_werror=-errwarn=%all])]) |
| 141 | ]) |
| 142 | ]) |
| 143 | |
| 144 | AC_DEFUN([CC_CHECK_ATTRIBUTE], [ |
| 145 | AC_REQUIRE([CC_CHECK_WERROR]) |
| 146 | AC_CACHE_CHECK([if $CC supports __attribute__(( ifelse([$2], , [$1], [$2]) ))], |
| 147 | AS_TR_SH([cc_cv_attribute_$1]), |
| 148 | [ac_save_CFLAGS="$CFLAGS" |
| 149 | CFLAGS="$CFLAGS $cc_cv_werror" |
| 150 | AC_COMPILE_IFELSE([AC_LANG_SOURCE([$3])], |
| 151 | [eval "AS_TR_SH([cc_cv_attribute_$1])='yes'"], |
| 152 | [eval "AS_TR_SH([cc_cv_attribute_$1])='no'"]) |
| 153 | CFLAGS="$ac_save_CFLAGS" |
| 154 | ]) |
| 155 | |
| 156 | AS_IF([eval test x$]AS_TR_SH([cc_cv_attribute_$1])[ = xyes], |
| 157 | [AC_DEFINE( |
| 158 | AS_TR_CPP([SUPPORT_ATTRIBUTE_$1]), 1, |
| 159 | [Define this if the compiler supports __attribute__(( ifelse([$2], , [$1], [$2]) ))] |
| 160 | ) |
| 161 | $4], |
| 162 | [$5]) |
| 163 | ]) |
| 164 | |
| 165 | AC_DEFUN([CC_ATTRIBUTE_CONSTRUCTOR], [ |
| 166 | CC_CHECK_ATTRIBUTE( |
| 167 | [constructor],, |
| 168 | [void __attribute__((constructor)) ctor() { int a; }], |
| 169 | [$1], [$2]) |
| 170 | ]) |
| 171 | |
| 172 | AC_DEFUN([CC_ATTRIBUTE_FORMAT], [ |
| 173 | CC_CHECK_ATTRIBUTE( |
| 174 | [format], [format(printf, n, n)], |
| 175 | [void __attribute__((format(printf, 1, 2))) printflike(const char *fmt, ...) { fmt = (void *)0; }], |
| 176 | [$1], [$2]) |
| 177 | ]) |
| 178 | |
| 179 | AC_DEFUN([CC_ATTRIBUTE_FORMAT_ARG], [ |
| 180 | CC_CHECK_ATTRIBUTE( |
| 181 | [format_arg], [format_arg(printf)], |
| 182 | [char *__attribute__((format_arg(1))) gettextlike(const char *fmt) { fmt = (void *)0; }], |
| 183 | [$1], [$2]) |
| 184 | ]) |
| 185 | |
| 186 | AC_DEFUN([CC_ATTRIBUTE_VISIBILITY], [ |
| 187 | CC_CHECK_ATTRIBUTE( |
| 188 | [visibility_$1], [visibility("$1")], |
| 189 | [void __attribute__((visibility("$1"))) $1_function() { }], |
| 190 | [$2], [$3]) |
| 191 | ]) |
| 192 | |
| 193 | AC_DEFUN([CC_ATTRIBUTE_NONNULL], [ |
| 194 | CC_CHECK_ATTRIBUTE( |
| 195 | [nonnull], [nonnull()], |
| 196 | [void __attribute__((nonnull())) some_function(void *foo, void *bar) { foo = (void*)0; bar = (void*)0; }], |
| 197 | [$1], [$2]) |
| 198 | ]) |
| 199 | |
| 200 | AC_DEFUN([CC_ATTRIBUTE_UNUSED], [ |
| 201 | CC_CHECK_ATTRIBUTE( |
| 202 | [unused], , |
| 203 | [void some_function(void *foo, __attribute__((unused)) void *bar);], |
| 204 | [$1], [$2]) |
| 205 | ]) |
| 206 | |
| 207 | AC_DEFUN([CC_ATTRIBUTE_SENTINEL], [ |
| 208 | CC_CHECK_ATTRIBUTE( |
| 209 | [sentinel], , |
| 210 | [void some_function(void *foo, ...) __attribute__((sentinel));], |
| 211 | [$1], [$2]) |
| 212 | ]) |
| 213 | |
| 214 | AC_DEFUN([CC_ATTRIBUTE_DEPRECATED], [ |
| 215 | CC_CHECK_ATTRIBUTE( |
| 216 | [deprecated], , |
| 217 | [void some_function(void *foo, ...) __attribute__((deprecated));], |
| 218 | [$1], [$2]) |
| 219 | ]) |
| 220 | |
| 221 | AC_DEFUN([CC_ATTRIBUTE_ALIAS], [ |
| 222 | CC_CHECK_ATTRIBUTE( |
| 223 | [alias], [weak, alias], |
| 224 | [void other_function(void *foo) { } |
| 225 | void some_function(void *foo) __attribute__((weak, alias("other_function")));], |
| 226 | [$1], [$2]) |
| 227 | ]) |
| 228 | |
| 229 | AC_DEFUN([CC_ATTRIBUTE_MALLOC], [ |
| 230 | CC_CHECK_ATTRIBUTE( |
| 231 | [malloc], , |
| 232 | [void * __attribute__((malloc)) my_alloc(int n);], |
| 233 | [$1], [$2]) |
| 234 | ]) |
| 235 | |
| 236 | AC_DEFUN([CC_ATTRIBUTE_PACKED], [ |
| 237 | CC_CHECK_ATTRIBUTE( |
| 238 | [packed], , |
| 239 | [struct astructure { char a; int b; long c; void *d; } __attribute__((packed));], |
| 240 | [$1], [$2]) |
| 241 | ]) |
| 242 | |
| 243 | AC_DEFUN([CC_ATTRIBUTE_CONST], [ |
| 244 | CC_CHECK_ATTRIBUTE( |
| 245 | [const], , |
| 246 | [int __attribute__((const)) twopow(int n) { return 1 << n; } ], |
| 247 | [$1], [$2]) |
| 248 | ]) |
| 249 | |
| 250 | AC_DEFUN([CC_FLAG_VISIBILITY], [ |
| 251 | AC_REQUIRE([CC_CHECK_WERROR]) |
| 252 | AC_CACHE_CHECK([if $CC supports -fvisibility=hidden], |
| 253 | [cc_cv_flag_visibility], |
| 254 | [cc_flag_visibility_save_CFLAGS="$CFLAGS" |
| 255 | CFLAGS="$CFLAGS $cc_cv_werror" |
| 256 | CC_CHECK_CFLAGS_SILENT([-fvisibility=hidden], |
| 257 | cc_cv_flag_visibility='yes', |
| 258 | cc_cv_flag_visibility='no') |
| 259 | CFLAGS="$cc_flag_visibility_save_CFLAGS"]) |
| 260 | |
| 261 | AS_IF([test "x$cc_cv_flag_visibility" = "xyes"], |
| 262 | [AC_DEFINE([SUPPORT_FLAG_VISIBILITY], 1, |
| 263 | [Define this if the compiler supports the -fvisibility flag]) |
| 264 | $1], |
| 265 | [$2]) |
| 266 | ]) |
| 267 | |
| 268 | AC_DEFUN([CC_FUNC_EXPECT], [ |
| 269 | AC_REQUIRE([CC_CHECK_WERROR]) |
| 270 | AC_CACHE_CHECK([if compiler has __builtin_expect function], |
| 271 | [cc_cv_func_expect], |
| 272 | [ac_save_CFLAGS="$CFLAGS" |
| 273 | CFLAGS="$CFLAGS $cc_cv_werror" |
| 274 | AC_COMPILE_IFELSE([AC_LANG_SOURCE( |
| 275 | [int some_function() { |
| 276 | int a = 3; |
| 277 | return (int)__builtin_expect(a, 3); |
| 278 | }])], |
| 279 | [cc_cv_func_expect=yes], |
| 280 | [cc_cv_func_expect=no]) |
| 281 | CFLAGS="$ac_save_CFLAGS" |
| 282 | ]) |
| 283 | |
| 284 | AS_IF([test "x$cc_cv_func_expect" = "xyes"], |
| 285 | [AC_DEFINE([SUPPORT__BUILTIN_EXPECT], 1, |
| 286 | [Define this if the compiler supports __builtin_expect() function]) |
| 287 | $1], |
| 288 | [$2]) |
| 289 | ]) |
| 290 | |
| 291 | AC_DEFUN([CC_ATTRIBUTE_ALIGNED], [ |
| 292 | AC_REQUIRE([CC_CHECK_WERROR]) |
| 293 | AC_CACHE_CHECK([highest __attribute__ ((aligned ())) supported], |
| 294 | [cc_cv_attribute_aligned], |
| 295 | [ac_save_CFLAGS="$CFLAGS" |
| 296 | CFLAGS="$CFLAGS $cc_cv_werror" |
| 297 | for cc_attribute_align_try in 64 32 16 8 4 2; do |
| 298 | AC_COMPILE_IFELSE([AC_LANG_SOURCE([ |
| 299 | int main() { |
| 300 | static char c __attribute__ ((aligned($cc_attribute_align_try))) = 0; |
| 301 | return c; |
| 302 | }])], [cc_cv_attribute_aligned=$cc_attribute_align_try; break]) |
| 303 | done |
| 304 | CFLAGS="$ac_save_CFLAGS" |
| 305 | ]) |
| 306 | |
| 307 | if test "x$cc_cv_attribute_aligned" != "x"; then |
| 308 | AC_DEFINE_UNQUOTED([ATTRIBUTE_ALIGNED_MAX], [$cc_cv_attribute_aligned], |
| 309 | [Define the highest alignment supported]) |
| 310 | fi |
| 311 | ]) |