summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ggml.c10
-rw-r--r--k_quants.h8
2 files changed, 14 insertions, 4 deletions
diff --git a/ggml.c b/ggml.c
index f5821f1f..3ea8ba6e 100644
--- a/ggml.c
+++ b/ggml.c
@@ -31,11 +31,17 @@
#include <unistd.h>
#endif
+// static_assert should be a #define, but if it's not,
+// fall back to the _Static_assert C11 keyword.
// if C99 - static_assert is noop
// ref: https://stackoverflow.com/a/53923785/4039976
#ifndef static_assert
+#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201100L)
+#define static_assert(cond, msg) _Static_assert(cond, msg)
+#else
#define static_assert(cond, msg) struct global_scope_noop_trick
#endif
+#endif
#if defined(_MSC_VER)
// disable "possible loss of data" to avoid hundreds of casts
@@ -112,10 +118,6 @@ typedef void * thread_ret_t;
#endif
#endif
-#ifdef __HAIKU__
-#define static_assert(cond, msg) _Static_assert(cond, msg)
-#endif
-
/*#define GGML_PERF*/
#define GGML_DEBUG 0
#define GGML_GELU_FP16
diff --git a/k_quants.h b/k_quants.h
index 6abe3d7b..adc6a391 100644
--- a/k_quants.h
+++ b/k_quants.h
@@ -15,6 +15,14 @@
#define K_SCALE_SIZE 12
#endif
+#ifndef static_assert
+#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201100L)
+#define static_assert(cond, msg) _Static_assert(cond, msg)
+#else
+#define static_assert(cond, msg) struct global_scope_noop_trick
+#endif
+#endif
+
//
// Super-block quantization structures
//