io_u: convert zoned bug warning to fio_did_warn()
authorJens Axboe <axboe@kernel.dk>
Mon, 12 Feb 2018 17:18:32 +0000 (10:18 -0700)
committerJens Axboe <axboe@kernel.dk>
Mon, 12 Feb 2018 17:18:32 +0000 (10:18 -0700)
Signed-off-by: Jens Axboe <axboe@kernel.dk>
debug.h
io_u.c

diff --git a/debug.h b/debug.h
index d10d43e..84d6faf 100644 (file)
--- a/debug.h
+++ b/debug.h
@@ -42,6 +42,7 @@ static inline bool fio_did_warn(unsigned int mask)
 enum {
        FIO_WARN_ROOT_FLUSH     = 1,
        FIO_WARN_VERIFY_BUF     = 2,
+       FIO_WARN_ZONED_BUG      = 4,
 };
 
 #ifdef FIO_INC_DEBUG
diff --git a/io_u.c b/io_u.c
index 404c75b..b54a79c 100644 (file)
--- a/io_u.c
+++ b/io_u.c
@@ -163,7 +163,6 @@ static int __get_next_rand_offset_zoned_abs(struct thread_data *td,
 {
        struct zone_split_index *zsi;
        uint64_t lastb, send, stotal;
-       static int warned;
        unsigned int v;
 
        lastb = last_block(td, f, ddir);
@@ -192,10 +191,8 @@ bail:
         * Should never happen
         */
        if (send == -1U) {
-               if (!warned) {
+               if (!fio_did_warn(FIO_WARN_ZONED_BUG))
                        log_err("fio: bug in zoned generation\n");
-                       warned = 1;
-               }
                goto bail;
        } else if (send > lastb) {
                /*
@@ -223,7 +220,6 @@ static int __get_next_rand_offset_zoned(struct thread_data *td,
 {
        unsigned int v, send, stotal;
        uint64_t offset, lastb;
-       static int warned;
        struct zone_split_index *zsi;
 
        lastb = last_block(td, f, ddir);
@@ -248,10 +244,8 @@ bail:
         * Should never happen
         */
        if (send == -1U) {
-               if (!warned) {
+               if (!fio_did_warn(FIO_WARN_ZONED_BUG))
                        log_err("fio: bug in zoned generation\n");
-                       warned = 1;
-               }
                goto bail;
        }