projects
/
fio.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
implement zoned random I/O testing support
[fio.git]
/
fio.h
diff --git
a/fio.h
b/fio.h
index a5405e375da7486cbf8beb687c19ba313130ea30..a9286b86729d6231c899ab533b4ab13110513266 100644
(file)
--- a/
fio.h
+++ b/
fio.h
@@
-65,6
+65,17
@@
enum {
RW_SEQ_IDENT,
};
RW_SEQ_IDENT,
};
+/*
+ * What type of errors to continue on when continue_on_error is used
+ */
+enum error_type {
+ ERROR_TYPE_NONE = 0,
+ ERROR_TYPE_READ = 1 << 0,
+ ERROR_TYPE_WRITE = 1 << 1,
+ ERROR_TYPE_VERIFY = 1 << 2,
+ ERROR_TYPE_ANY = 0xffff,
+};
+
struct bssplit {
unsigned int bs;
unsigned char perc;
struct bssplit {
unsigned int bs;
unsigned char perc;
@@
-136,6
+147,7
@@
struct thread_options {
unsigned int write_lat_log;
unsigned int write_bw_log;
unsigned int write_iops_log;
unsigned int write_lat_log;
unsigned int write_bw_log;
unsigned int write_iops_log;
+ unsigned int log_avg_msec;
unsigned int norandommap;
unsigned int softrandommap;
unsigned int bs_unaligned;
unsigned int norandommap;
unsigned int softrandommap;
unsigned int bs_unaligned;
@@
-156,6
+168,7
@@
struct thread_options {
unsigned int bw_avg_time;
unsigned int iops_avg_time;
unsigned int loops;
unsigned int bw_avg_time;
unsigned int iops_avg_time;
unsigned int loops;
+ unsigned long long zone_range;
unsigned long long zone_size;
unsigned long long zone_skip;
enum fio_memtype mem_type;
unsigned long long zone_size;
unsigned long long zone_skip;
enum fio_memtype mem_type;
@@
-227,7
+240,7
@@
struct thread_options {
/*
* I/O Error handling
*/
/*
* I/O Error handling
*/
-
unsigned int
continue_on_error;
+
enum error_type
continue_on_error;
/*
* Benchmark profile type
/*
* Benchmark profile type
@@
-245,8
+258,6
@@
struct thread_options {
unsigned int gid;
unsigned int sync_file_range;
unsigned int gid;
unsigned int sync_file_range;
-
- unsigned int userspace_libaio_reap;
};
/*
};
/*
@@
-254,6
+265,7
@@
struct thread_options {
*/
struct thread_data {
struct thread_options o;
*/
struct thread_data {
struct thread_options o;
+ void *eo;
char verror[FIO_VERROR_SIZE];
pthread_t thread;
int thread_number;
char verror[FIO_VERROR_SIZE];
pthread_t thread;
int thread_number;
@@
-521,6
+533,15
@@
static inline void fio_ro_check(struct thread_data *td, struct io_u *io_u)
#define td_non_fatal_error(e) ((e) == EIO || (e) == EILSEQ)
#define td_non_fatal_error(e) ((e) == EIO || (e) == EILSEQ)
+static inline enum error_type td_error_type(enum fio_ddir ddir, int err)
+{
+ if (err == EILSEQ)
+ return ERROR_TYPE_VERIFY;
+ if (ddir == DDIR_READ)
+ return ERROR_TYPE_READ;
+ return ERROR_TYPE_WRITE;
+}
+
static inline void update_error_count(struct thread_data *td, int err)
{
td->total_err_count++;
static inline void update_error_count(struct thread_data *td, int err)
{
td->total_err_count++;
@@
-551,16
+572,20
@@
extern void reset_fio_state(void);
extern int fio_options_parse(struct thread_data *, char **, int);
extern void fio_keywords_init(void);
extern int fio_cmd_option_parse(struct thread_data *, const char *, char *);
extern int fio_options_parse(struct thread_data *, char **, int);
extern void fio_keywords_init(void);
extern int fio_cmd_option_parse(struct thread_data *, const char *, char *);
+extern int fio_cmd_ioengine_option_parse(struct thread_data *, const char *, char *);
extern void fio_fill_default_options(struct thread_data *);
extern int fio_show_option_help(const char *);
extern void fio_fill_default_options(struct thread_data *);
extern int fio_show_option_help(const char *);
+extern void fio_options_set_ioengine_opts(struct option *long_options, struct thread_data *td);
extern void fio_options_dup_and_init(struct option *);
extern void fio_options_dup_and_init(struct option *);
-extern void options_mem_dupe(struct thread_data *);
-extern void options_mem_
free(struct thread_data *
);
+extern void
fio_
options_mem_dupe(struct thread_data *);
+extern void options_mem_
dupe(void *data, struct fio_option *options
);
extern void td_fill_rand_seeds(struct thread_data *);
extern void add_job_opts(const char **);
extern char *num2str(unsigned long, int, int, int);
extern void td_fill_rand_seeds(struct thread_data *);
extern void add_job_opts(const char **);
extern char *num2str(unsigned long, int, int, int);
+extern int ioengine_load(struct thread_data *);
-#define FIO_GETOPT_JOB 0x89988998
+#define FIO_GETOPT_JOB 0x89000000
+#define FIO_GETOPT_IOENGINE 0x98000000
#define FIO_NR_OPTIONS (FIO_MAX_OPTS + 128)
/*
#define FIO_NR_OPTIONS (FIO_MAX_OPTS + 128)
/*