Re: [PATCH] Adds check for numberio during verify phase.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Jens, Ping?
You think you can still integrate the three patches from Juan?

thanks!
grant

On Tue, Sep 17, 2013 at 2:06 PM, Juan Casse <jcasse@xxxxxxxxxxxx> wrote:
> Currently, fio checks the block offset number in a block's header during
> the verify phase.
> We add a check for the io number (numberio) to detect stale blocks. This
> check is performed only on workloads that write data, as those workloads
> know what numberio was written to each block.
> td->io_issues[ddir] = 0; was removed so that numberio does not get reset
> at each iteration; we want numberio to keep incrementing to reflect
> how many times the same data was written.
>
> Signed-off-by: Juan Casse <jcasse@xxxxxxxxxxxx>
> Reviewed-by: Grant Grundler <grundler@xxxxxxxxxxxx>
>
> Fixed typo.
> ---
>  ioengine.h |  1 +
>  iolog.c    |  1 +
>  iolog.h    |  1 +
>  libfio.c   |  1 -
>  verify.c   | 14 +++++++++++++-
>  5 files changed, 16 insertions(+), 2 deletions(-)
>
> diff --git a/ioengine.h b/ioengine.h
> index 31662eb..812febd 100644
> --- a/ioengine.h
> +++ b/ioengine.h
> @@ -50,6 +50,7 @@ struct io_u {
>          */
>         unsigned long buflen;
>         unsigned long long offset;
> +       unsigned short numberio;
>         void *buf;
>
>         /*
> diff --git a/iolog.c b/iolog.c
> index 9bcf0d8..6459d3b 100644
> --- a/iolog.c
> +++ b/iolog.c
> @@ -188,6 +188,7 @@ void log_io_piece(struct thread_data *td, struct io_u *io_u)
>         ipo->file = io_u->file;
>         ipo->offset = io_u->offset;
>         ipo->len = io_u->buflen;
> +       ipo->numberio = io_u->numberio;
>
>         if (io_u_should_trim(td, io_u)) {
>                 flist_add_tail(&ipo->trim_list, &td->trim_list);
> diff --git a/iolog.h b/iolog.h
> index 8fedc19..94e0fc1 100644
> --- a/iolog.h
> +++ b/iolog.h
> @@ -78,6 +78,7 @@ struct io_piece {
>                 struct fio_file *file;
>         };
>         unsigned long long offset;
> +       unsigned short numberio;
>         unsigned long len;
>         unsigned int flags;
>         enum fio_ddir ddir;
> diff --git a/libfio.c b/libfio.c
> index c26d6a3..6e290f4 100644
> --- a/libfio.c
> +++ b/libfio.c
> @@ -83,7 +83,6 @@ static void reset_io_counters(struct thread_data *td)
>                 td->this_io_blocks[ddir] = 0;
>                 td->rate_bytes[ddir] = 0;
>                 td->rate_blocks[ddir] = 0;
> -               td->io_issues[ddir] = 0;
>         }
>         td->zone_bytes = 0;
>
> diff --git a/verify.c b/verify.c
> index 9e88d61..63def12 100644
> --- a/verify.c
> +++ b/verify.c
> @@ -369,6 +369,15 @@ static int verify_io_u_meta(struct verify_header *hdr, struct vcont *vc)
>         if (td->o.verify_pattern_bytes)
>                 ret |= verify_io_u_pattern(hdr, vc);
>
> +       /*
> +        * For read-only workloads, the program cannot be certain of the
> +        * last numberio written to a block. Checking of numberio will be done
> +        * only for workloads that write data.
> +        */
> +       if (td_write(td) || td_rw(td))
> +               if (vh->numberio != io_u->numberio)
> +                       ret = EILSEQ;
> +
>         if (!ret)
>                 return 0;
>
> @@ -768,7 +777,7 @@ static void fill_meta(struct verify_header *hdr, struct thread_data *td,
>         vh->time_sec = io_u->start_time.tv_sec;
>         vh->time_usec = io_u->start_time.tv_usec;
>
> -       vh->numberio = td->io_issues[DDIR_WRITE];
> +       vh->numberio = io_u->numberio;
>
>         vh->offset = io_u->offset + header_num * td->o.verify_interval;
>  }
> @@ -942,6 +951,8 @@ void populate_verify_io_u(struct thread_data *td, struct io_u *io_u)
>         if (td->o.verify == VERIFY_NULL)
>                 return;
>
> +       io_u->numberio = td->io_issues[io_u->ddir];
> +
>         fill_pattern_headers(td, io_u, 0, 0);
>  }
>
> @@ -974,6 +985,7 @@ int get_next_verify(struct thread_data *td, struct io_u *io_u)
>
>                 io_u->offset = ipo->offset;
>                 io_u->buflen = ipo->len;
> +               io_u->numberio = ipo->numberio;
>                 io_u->file = ipo->file;
>                 io_u->flags |= IO_U_F_VER_LIST;
>
> --
> 1.7.12.4
>
--
To unsubscribe from this list: send the line "unsubscribe fio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Kernel]     [Linux SCSI]     [Linux IDE]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux SCSI]

  Powered by Linux