Fix: don't generate incorrect macros for debian/ubuntu version check
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Thu, 14 May 2015 15:33:47 +0000 (11:33 -0400)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Thu, 14 May 2015 15:33:47 +0000 (11:33 -0400)
When the debian/ubuntu macros are unset, we end up generating macros
that have no right hand operand to "+", which seems to break compilation
on some compilers, even though it will always be optimized away.

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
lttng-kernel-version.h

index 59e19df55ff775a82eeaf747b1590555ab31c5be..46ee8ab9da4ff9b141272301f1295e6ee1d2c70a 100644 (file)
 #define LTTNG_UBUNTU_KERNEL_VERSION(a, b, c, d) \
        (((a) << 24) + ((b) << 16) + (c << 8) + (d))
 
+#ifdef UTS_UBUNTU_RELEASE_ABI
 #define LTTNG_UBUNTU_VERSION_CODE \
        ((LINUX_VERSION_CODE << 8) + UTS_UBUNTU_RELEASE_ABI)
+#else
+#define LTTNG_UBUNTU_VERSION_CODE      0
+#endif
 
 #define LTTNG_UBUNTU_KERNEL_RANGE(a_low, b_low, c_low, d_low, \
                a_high, b_high, c_high, d_high) \
-       (defined(UTS_UBUNTU_RELEASE_ABI) && \
-               LTTNG_UBUNTU_VERSION_CODE >= \
+       (LTTNG_UBUNTU_VERSION_CODE >= \
                LTTNG_UBUNTU_KERNEL_VERSION(a_low, b_low, c_low, d_low) && \
                LTTNG_UBUNTU_VERSION_CODE < \
                LTTNG_UBUNTU_KERNEL_VERSION(a_high, b_high, c_high, d_high))
 #define LTTNG_DEBIAN_KERNEL_VERSION(a, b, c, d, e, f) \
        (((((a) << 16) + ((b) << 8) + (c)) * 1000000ULL) + ((d) * 10000) + ((e) * 100) + (f))
 
+#ifdef DEBIAN_API_VERSION
 #define LTTNG_DEBIAN_VERSION_CODE \
        ((LINUX_VERSION_CODE * 1000000ULL) + DEBIAN_API_VERSION)
+#else
+#define LTTNG_DEBIAN_VERSION_CODE      0
+#endif
 
 #define LTTNG_DEBIAN_KERNEL_RANGE(a_low, b_low, c_low, d_low, e_low, f_low, \
                a_high, b_high, c_high, d_high, e_high, f_high) \
-       (defined(DEBIAN_API_VERSION) && \
-               LTTNG_DEBIAN_VERSION_CODE >= \
+       (LTTNG_DEBIAN_VERSION_CODE >= \
                LTTNG_DEBIAN_KERNEL_VERSION(a_low, b_low, c_low, d_low, e_low, f_low) && \
                LTTNG_DEBIAN_VERSION_CODE < \
                LTTNG_DEBIAN_KERNEL_VERSION(a_high, b_high, c_high, d_high, e_high, f_high))
This page took 0.030521 seconds and 4 git commands to generate.