[Spice-devel] [spice-common v3] log: Let gcc know about the logging macros which abort
Frediano Ziglio
fziglio at redhat.com
Mon Apr 1 11:27:49 UTC 2019
>
> This commit adds a SPICE_UNREACHABLE macro (courtesy of Frediano)
> so that gcc does not think that code control can go past
> spice_return_{val_,}if_fail(), spice_critical() and spice_error()
>
> This avoids this kind of warnings:
>
> fallthrough.c:
>
> #include "log.h"
>
> int main(int argc, char **argv)
> {
> switch(argc) {
> case 1:
> spice_critical("foo");
> default:
> return 0;
> }
> }
>
> $ gcc -c $(pkg-config --cflags --libs glib-2.0 spice-protocol)
> -I common -Wimplicit-fallthrough=5 ./fallthrough.c
> In file included from ./fallthrough.c:1:
> ./fallthrough.c: In function 'main':
> common/log.h:73:5: warning: this statement may fall through
> [-Wimplicit-fallthrough=]
> 73 | spice_log(G_LOG_LEVEL_CRITICAL, SPICE_STRLOC, __FUNCTION__, ""
> format, ## __VA_ARGS__); \
> | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> ./fallthrough.c:8:25: note: in expansion of macro 'spice_critical'
> 8 | spice_critical("foo");
> | ^~~~~~~~~~~~~~
> ./fallthrough.c:9:17: note: here
> 9 | default:
> | ^~~~~~~
>
> Signed-off-by: Christophe Fergeau <cfergeau at redhat.com>
> ---
> Maybe a bit too much for a single commit, I can split :)
>
Acked-by: Frediano Ziglio <fziglio at redhat.com>
> common/log.h | 8 ++++++--
> common/macros.h | 8 ++++++++
> 2 files changed, 14 insertions(+), 2 deletions(-)
>
> diff --git a/common/log.h b/common/log.h
> index 7c67e7a..201c87a 100644
> --- a/common/log.h
> +++ b/common/log.h
> @@ -39,16 +39,18 @@ void spice_log(GLogLevelFlags log_level,
> const char *format,
> ...) G_GNUC_PRINTF(4, 5);
>
> +/* FIXME: name is misleading, this aborts.. */
> #define spice_return_if_fail(x) G_STMT_START { \
> if G_LIKELY(x) { } else { \
> - spice_log(G_LOG_LEVEL_CRITICAL, SPICE_STRLOC, G_STRFUNC, "condition
> `%s' failed", #x); \
> + spice_critical("condition `%s' failed", #x); \
> return; \
> } \
> } G_STMT_END
>
> +/* FIXME: name is misleading, this aborts.. */
> #define spice_return_val_if_fail(x, val) G_STMT_START { \
> if G_LIKELY(x) { } else { \
> - spice_log(G_LOG_LEVEL_CRITICAL, SPICE_STRLOC, __FUNCTION__,
> "condition `%s' failed", #x); \
> + spice_critical("condition `%s' failed", #x); \
> return (val); \
> } \
> } G_STMT_END
> @@ -71,10 +73,12 @@ void spice_log(GLogLevelFlags log_level,
>
> #define spice_critical(format, ...) G_STMT_START {
> \
> spice_log(G_LOG_LEVEL_CRITICAL, SPICE_STRLOC, __FUNCTION__, "" format,
> ## __VA_ARGS__); \
> + SPICE_UNREACHABLE;
> \
> } G_STMT_END
>
> #define spice_error(format, ...) G_STMT_START { \
> spice_log(G_LOG_LEVEL_ERROR, SPICE_STRLOC, __FUNCTION__, "" format, ##
> __VA_ARGS__); \
> + SPICE_UNREACHABLE;
> \
> } G_STMT_END
>
> #define spice_warn_if_fail(x) G_STMT_START { \
> diff --git a/common/macros.h b/common/macros.h
> index 2f24ada..92cd82c 100644
> --- a/common/macros.h
> +++ b/common/macros.h
> @@ -55,4 +55,12 @@
>
> #define SPICE_VERIFY(cond) verify_expr(cond, (void)1)
>
> +#if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5)
> +#define SPICE_UNREACHABLE __builtin_unreachable()
> +#elif defined(_MSC_VER)
> +#define SPICE_UNREACHABLE __assume(0)
> +#else
> +#define SPICE_UNREACHABLE for(;;) continue
> +#endif
> +
> #endif // H_SPICE_COMMON_MACROS
Frediano
More information about the Spice-devel
mailing list