ENDIF(NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
CHECK_C_SOURCE_RUNS("
+#include <stdbool.h>
int main(int argc, char **argv) {
- int a = 0;
- if (__sync_bool_compare_and_swap(&a, 0, 1)) {
+ int a = 0, b = 0;
+ if (__atomic_compare_exchange_n(&a, &b, 1, false, __ATOMIC_RELEASE, __ATOMIC_RELAXED)) {
return 0;
}
return -1;
}
" HAVE_ATOMIC_BUILTINS)
+IF(NOT HAVE_ATOMIC_BUILTINS)
+ MESSAGE(STATUS "atomic builtins are -NOT- supported")
+ELSE()
+ MESSAGE(STATUS "atomic builtins are supported")
+ENDIF()
+
# Check queue.h compatibility
IF(NOT HAVE_COMPATIBLE_QUEUE_H)
INCLUDE_DIRECTORIES(compat)
#cmakedefine HAVE_SETSIG 1
#cmakedefine HAVE_OASYNC 1
#cmakedefine WITH_SNOWBALL 1
+#cmakedefine HAVE_ATOMIC_BUILTINS 1
/* Configure allocator */
#define uthash_malloc(sz) g_slice_alloc(sz)
ham += stat->actions_stat[i];
}
if (do_reset) {
+#ifndef HAVE_ATOMIC_BUILTINS
session->ctx->worker->srv->stat->actions_stat[i] = 0;
+#else
+ __atomic_store_n(&session->ctx->worker->srv->stat->actions_stat[i],
+ 0, __ATOMIC_RELEASE);
+#endif
}
}
ucl_object_insert_key (top, sub, "actions", 0, false);
result = rspamd_fuzzy_backend_check (session->ctx->backend, cmd,
session->ctx->expire);
/* XXX: actually, these updates are not atomic, but we don't care */
+#ifndef HAVE_ATOMIC_BUILTINS
server_stat->fuzzy_hashes_checked[session->epoch] ++;
if (result.prob > 0.5) {
server_stat->fuzzy_hashes_found[session->epoch] ++;
}
+#else
+ __atomic_add_fetch (&server_stat->fuzzy_hashes_checked[session->epoch],
+ 1, __ATOMIC_RELEASE);
+
+ if (result.prob > 0.5) {
+ __atomic_add_fetch (&server_stat->fuzzy_hashes_found[session->epoch],
+ 1, __ATOMIC_RELEASE);
+ }
+#endif
}
else {
result.flag = cmd->flag;
action = rspamd_check_action_metric (task, metric_res->score, &required_score,
metric_res->metric);
if (action <= METRIC_ACTION_NOACTION) {
+#ifndef HAVE_ATOMIC_BUILTINS
task->worker->srv->stat->actions_stat[action]++;
+#else
+ __atomic_add_fetch (&task->worker->srv->stat->actions_stat[action],
+ 1, __ATOMIC_RELEASE);
+#endif
}
}
/* Increase counters */
-
+#ifndef HAVE_ATOMIC_BUILTINS
task->worker->srv->stat->messages_scanned++;
+#else
+ __atomic_add_fetch (&task->worker->srv->stat->messages_scanned,
+ 1, __ATOMIC_RELEASE);
+#endif
}
}
#ifdef HAVE_ATOMIC_BUILTINS
#define REF_RETAIN(obj) do { \
if ((obj) != NULL) { \
- __sync_add_and_fetch (&(obj)->ref.refcount, 1); \
+ __atomic_add_fetch (&(obj)->ref.refcount, 1, __ATOMIC_RELEASE); \
} \
} while (0)
#define REF_RELEASE(obj) do { \
if ((obj) != NULL) { \
- unsigned int _rc_priv = __sync_sub_and_fetch (&(obj)->ref.refcount, 1); \
+ unsigned int _rc_priv = __atomic_sub_fetch (&(obj)->ref.refcount, 1, __ATOMIC_ACQ_REL); \
if (_rc_priv == 0 && (obj)->ref.dtor) { \
(obj)->ref.dtor (obj); \
} \