# HG changeset patch # User Igor Sysoev # Date 1259359239 0 # Node ID b44a7159c5fb998c5933a9ae15f3b799d288708a # Parent d518c65ff0d41d512f24e736450e2a6555648e88 atomic operations test-run diff --git a/auto/cc/conf b/auto/cc/conf --- a/auto/cc/conf +++ b/auto/cc/conf @@ -127,13 +127,18 @@ if [ "$NGX_PLATFORM" != win32 ]; then ngx_feature="gcc builtin atomic operations" ngx_feature_name=NGX_HAVE_GCC_ATOMIC - ngx_feature_run=no + ngx_feature_run=yes ngx_feature_incs= ngx_feature_path= ngx_feature_libs= - ngx_feature_test="long n; - __sync_bool_compare_and_swap(&n, 0, 1); - __sync_fetch_and_add(&n, 1);" + ngx_feature_test="long n = 0; + if (!__sync_bool_compare_and_swap(&n, 0, 1)) + return 1; + if (__sync_fetch_and_add(&n, 1) != 1) + return 1; + if (n != 2) + return 1; + __sync_synchronize();" . auto/feature diff --git a/auto/lib/libatomic/conf b/auto/lib/libatomic/conf --- a/auto/lib/libatomic/conf +++ b/auto/lib/libatomic/conf @@ -13,15 +13,18 @@ else ngx_feature="atomic_ops library" ngx_feature_name=NGX_HAVE_LIBATOMIC - ngx_feature_run=no + ngx_feature_run=yes ngx_feature_incs="#include " ngx_feature_path= ngx_feature_libs="-latomic_ops" - ngx_feature_test="AO_t *n; - AO_compare_and_swap(n, 0, 1); - AO_fetch_and_add(n, 1); + ngx_feature_test="long n = 0; + if (!AO_compare_and_swap(&n, 0, 1)) + return 1; + if (AO_fetch_and_add(&n, 1) != 1) + return 1; + if (n != 2) + return 1; AO_nop();" - . auto/feature if [ $ngx_found = yes ]; then