From: Tomohiro Kusumi Date: Mon, 13 Feb 2017 16:13:43 +0000 (+0200) Subject: Be more verbose on endianness detection failure X-Git-Tag: fio-2.18~25 X-Git-Url: https://git.kernel.dk/?p=fio.git;a=commitdiff_plain;h=1a50e7f010661f5faa9bb9d631d25b896e029844 Be more verbose on endianness detection failure > I think this deserves and enum. That also enables the compiler to check > if the below switch covers all the potential values. Updated with enum ENDIAN_XXX, which you can change the naming if it doesn't sound good. Signed-off-by: Tomohiro Kusumi Signed-off-by: Jens Axboe --- diff --git a/libfio.c b/libfio.c index 960daf69..7e0d32c3 100644 --- a/libfio.c +++ b/libfio.c @@ -311,6 +311,13 @@ int fio_set_fd_nonblocking(int fd, const char *who) return flags; } +enum { + ENDIAN_INVALID_BE = 1, + ENDIAN_INVALID_LE, + ENDIAN_INVALID_CONFIG, + ENDIAN_BROKEN, +}; + static int endian_check(void) { union { @@ -327,16 +334,16 @@ static int endian_check(void) #if defined(CONFIG_LITTLE_ENDIAN) if (be) - return 1; + return ENDIAN_INVALID_BE; #elif defined(CONFIG_BIG_ENDIAN) if (le) - return 1; + return ENDIAN_INVALID_LE; #else - return 1; + return ENDIAN_INVALID_CONFIG; #endif if (!le && !be) - return 1; + return ENDIAN_BROKEN; return 0; } @@ -344,6 +351,7 @@ static int endian_check(void) int initialize_fio(char *envp[]) { long ps; + int err; /* * We need these to be properly 64-bit aligned, otherwise we @@ -359,8 +367,26 @@ int initialize_fio(char *envp[]) compiletime_assert((offsetof(struct thread_options_pack, percentile_list) % 8) == 0, "percentile_list"); compiletime_assert((offsetof(struct thread_options_pack, latency_percentile) % 8) == 0, "latency_percentile"); - if (endian_check()) { + err = endian_check(); + if (err) { log_err("fio: endianness settings appear wrong.\n"); + switch (err) { + case ENDIAN_INVALID_BE: + log_err("fio: got big-endian when configured for little\n"); + break; + case ENDIAN_INVALID_LE: + log_err("fio: got little-endian when configured for big\n"); + break; + case ENDIAN_INVALID_CONFIG: + log_err("fio: not configured to any endianness\n"); + break; + case ENDIAN_BROKEN: + log_err("fio: failed to detect endianness\n"); + break; + default: + assert(0); + break; + } log_err("fio: please report this to fio@vger.kernel.org\n"); return 1; }