X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=engines%2Fsyslet-rw.c;h=c11e4f21fc39990fc6ece7bfd2dc03bee4c682a2;hb=983a69d71e6f9c0c8f590f24d492f9efba19232b;hp=0fdf75227295540de9defc4976a8b2a84dfb8957;hpb=f3de88a7a8806016ebb27af3f4be1fced172122e;p=fio.git diff --git a/engines/syslet-rw.c b/engines/syslet-rw.c index 0fdf7522..c11e4f21 100644 --- a/engines/syslet-rw.c +++ b/engines/syslet-rw.c @@ -14,7 +14,7 @@ #include #include "../fio.h" -#include "../fls.h" +#include "../lib/fls.h" #ifdef FIO_HAVE_SYSLET @@ -131,6 +131,12 @@ static void fio_syslet_prep_sync(struct fio_file *f, FILL_IN(*regs, __NR_fsync, (long) f->fd); } +static void fio_syslet_prep_datasync(struct fio_file *f, + struct indirect_registers *regs) +{ + FILL_IN(*regs, __NR_fdatasync, (long) f->fd); +} + static void fio_syslet_prep_rw(struct io_u *io_u, struct fio_file *f, struct indirect_registers *regs) { @@ -154,6 +160,8 @@ static void fio_syslet_prep(struct io_u *io_u, struct indirect_registers *regs) if (io_u->ddir == DDIR_SYNC) fio_syslet_prep_sync(f, regs); + else if (io_u->ddir == DDIR_DATASYNC) + fio_syslet_prep_datasync(f, regs); else fio_syslet_prep_rw(io_u, f, regs); } @@ -222,7 +230,6 @@ static void fio_syslet_cleanup(struct thread_data *td) free(sd->events); free(sd->ring); free(sd); - td->io_ops->data = NULL; } } @@ -243,7 +250,7 @@ static int fio_syslet_init(struct thread_data *td) */ ring_nr = td->o.iodepth; if (ring_nr & (ring_nr - 1)) - ring_nr = 1 << fls(ring_nr); + ring_nr = 1 << __fls(ring_nr); ring_size = sizeof(struct syslet_ring) + ring_nr * sizeof(struct syslet_completion); @@ -285,6 +292,7 @@ static struct ioengine_ops ioengine = { .cleanup = fio_syslet_cleanup, .open_file = generic_open_file, .close_file = generic_close_file, + .get_file_size = generic_get_file_size, }; #else /* FIO_HAVE_SYSLET */