1
0
mirror of https://review.coreboot.org/flashrom.git synced 2025-08-18 21:00:15 +02:00

Fix undefined behavior in some preprocessor define checks

Macros like the one below would produce undefined behavior when used as
expression/condition in #if preprocessor directives:
This patch replaces all such statements with a more verbose but
well-defined #if/#define x 1/#else/#define x 0/#endif

Found by clang (warning introduced in r258128), reported by Idwer.

Signed-off-by: Stefan Tauner <stefan.tauner@gmx.at>
Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
This commit is contained in:
Stefan Tauner
2016-12-02 02:09:23 +01:00
committed by Stefan Tauner
parent 9fbbf55ecb
commit 51e430392d
2 changed files with 30 additions and 6 deletions

View File

@@ -37,9 +37,21 @@
#error "Unknown operating system"
#endif
#define USE_IOPL (IS_LINUX || IS_MACOSX || defined(__NetBSD__) || defined(__OpenBSD__))
#define USE_DEV_IO (defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__))
#define USE_IOPERM (defined(__gnu_hurd__))
#if (IS_LINUX || IS_MACOSX || defined(__NetBSD__) || defined(__OpenBSD__))
#define USE_IOPL (1)
#else
#define USE_IOPL (0)
#endif
#if (defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__))
#define USE_DEV_IO (1)
#else
#define USE_DEV_IO (0)
#endif
#if (defined(__gnu_hurd__))
#define USE_IOPERM (1)
#else
#define USE_IOPERM (0)
#endif
#if USE_IOPERM
#include <sys/io.h>