projects
/
fio.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
t/zbd: test repeated async write with block size unaligned to zone size
[fio.git]
/
io_u.h
diff --git
a/io_u.h
b/io_u.h
index e75993bd863a9f629e136bbcb2cec542377d1a19..d4c5be4303b3dc4bb7ed9a3cb905b86852231401 100644
(file)
--- a/
io_u.h
+++ b/
io_u.h
@@
-11,9
+11,6
@@
#ifdef CONFIG_LIBAIO
#include <libaio.h>
#endif
#ifdef CONFIG_LIBAIO
#include <libaio.h>
#endif
-#ifdef CONFIG_GUASI
-#include <guasi.h>
-#endif
enum {
IO_U_F_FREE = 1 << 0,
enum {
IO_U_F_FREE = 1 << 0,
@@
-24,6
+21,7
@@
enum {
IO_U_F_TRIMMED = 1 << 5,
IO_U_F_BARRIER = 1 << 6,
IO_U_F_VER_LIST = 1 << 7,
IO_U_F_TRIMMED = 1 << 5,
IO_U_F_BARRIER = 1 << 6,
IO_U_F_VER_LIST = 1 << 7,
+ IO_U_F_PRIORITY = 1 << 8,
};
/*
};
/*
@@
-52,7
+50,8
@@
struct io_u {
* Allocated/set buffer and length
*/
unsigned long long buflen;
* Allocated/set buffer and length
*/
unsigned long long buflen;
- unsigned long long offset;
+ unsigned long long offset; /* is really ->xfer_offset... */
+ unsigned long long verify_offset; /* is really ->offset */
void *buf;
/*
void *buf;
/*
@@
-92,7
+91,6
@@
struct io_u {
struct workqueue_work work;
};
struct workqueue_work work;
};
-#ifdef CONFIG_LINUX_BLKZONED
/*
* ZBD mode zbd_queue_io callback: called after engine->queue operation
* to advance a zone write pointer and eventually unlock the I/O zone.
/*
* ZBD mode zbd_queue_io callback: called after engine->queue operation
* to advance a zone write pointer and eventually unlock the I/O zone.
@@
-100,14
+98,14
@@
struct io_u {
* @success == true means that the I/O operation has been queued or
* completed successfully.
*/
* @success == true means that the I/O operation has been queued or
* completed successfully.
*/
- void (*zbd_queue_io)(struct io_u *, int q, bool success);
+ void (*zbd_queue_io)(struct thread_data *td, struct io_u *, int q,
+ bool success);
/*
* ZBD mode zbd_put_io callback: called in after completion of an I/O
* or commit of an async I/O to unlock the I/O target zone.
*/
/*
* ZBD mode zbd_put_io callback: called in after completion of an I/O
* or commit of an async I/O to unlock the I/O target zone.
*/
- void (*zbd_put_io)(const struct io_u *);
-#endif
+ void (*zbd_put_io)(struct thread_data *td, const struct io_u *);
/*
* Callback for io completion
/*
* Callback for io completion
@@
-124,9
+122,6
@@
struct io_u {
#ifdef FIO_HAVE_SGIO
struct sg_io_hdr hdr;
#endif
#ifdef FIO_HAVE_SGIO
struct sg_io_hdr hdr;
#endif
-#ifdef CONFIG_GUASI
- guasi_req_t greq;
-#endif
#ifdef CONFIG_SOLARISAIO
aio_result_t resultp;
#endif
#ifdef CONFIG_SOLARISAIO
aio_result_t resultp;
#endif
@@
-193,5
+188,7
@@
static inline enum fio_ddir acct_ddir(struct io_u *io_u)
td_flags_clear((td), &(io_u->flags), (val))
#define io_u_set(td, io_u, val) \
td_flags_set((td), &(io_u)->flags, (val))
td_flags_clear((td), &(io_u->flags), (val))
#define io_u_set(td, io_u, val) \
td_flags_set((td), &(io_u)->flags, (val))
+#define io_u_is_prio(io_u) \
+ (io_u->flags & (unsigned int) IO_U_F_PRIORITY) != 0
#endif
#endif