We have a problem with assert. Actually, a few problems. 1. Our code is written assuming that assert is never compiled out. We have lots of assert(0) and assert(0 == "informative failure message") instances all over the code that should really be something like abort(). If you compile out assert, things won't work (well, fail) as expected. 2. We have a special implementation of assert in include/assert.h that will log the assertion failure to the global debug log, along with a stack track, before crashing. This is normally fine, except that lots of random library or system headers include the system assert (/usr/include/assert.h), which is written such that it does not lib nicely with another definition. From /usr/include/assert.h: #ifdef _ASSERT_H # undef _ASSERT_H # undef assert # undef __ASSERT_VOID_CAST # ifdef __USE_GNU # undef assert_perror # endif #endif /* assert.h */ #define _ASSERT_H 1 That means that if you include our assert, and then some other random header includes /usr/include/assert, it will (silently!) clobber ours. 3. This is all highlighted by the switch to cmake. The current defautl build does not define NDEBUG, which means that assert is compiled away, and we get a bunch of unused variable warnings from code like r = read(...); assert(r > 0); So... what do to? We can fix these instances when we find them, but the #include order is inherently fragile. Note that using the system assert isn't a total disaster: system assert will trigger an abort, which will trigger the SIGABRT handler which *also* dumps a stack trace to the debug log. The problem is that it doesn't show the assertion condition and line number. I suggest: 0. Switch cmake to a debug but optimized build. Ensure the release builds do the same. 1. Do an audit and replace assert(0) et al with ceph_abort(const char *msg), or similar. 2. Replace all other instances of assert with ceph_assert. That's a lot of work, though. Other ideas? sage -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html