projects
/
fio.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
time: use bool for ramp time
[fio.git]
/
parse.h
diff --git
a/parse.h
b/parse.h
index 2a1e06a45c540f2e29354a94ad52f8b026194473..dfe7f1620c6aa762f217840dba89e663277fd7c2 100644
(file)
--- a/
parse.h
+++ b/
parse.h
@@
-1,6
+1,7
@@
#ifndef FIO_PARSE_H
#define FIO_PARSE_H
#ifndef FIO_PARSE_H
#define FIO_PARSE_H
+#include <inttypes.h>
#include "flist.h"
/*
#include "flist.h"
/*
@@
-19,6
+20,7
@@
enum fio_opt_type {
FIO_OPT_FLOAT_LIST,
FIO_OPT_STR_SET,
FIO_OPT_DEPRECATED,
FIO_OPT_FLOAT_LIST,
FIO_OPT_STR_SET,
FIO_OPT_DEPRECATED,
+ FIO_OPT_UNSUPPORTED,
};
/*
};
/*
@@
-69,30
+71,34
@@
struct fio_option {
int (*verify)(struct fio_option *, void *);
const char *prof_name; /* only valid for specific profile */
void *prof_opts;
int (*verify)(struct fio_option *, void *);
const char *prof_name; /* only valid for specific profile */
void *prof_opts;
- u
nsigned int category;
/* what type of option */
- u
nsigned int group;
/* who to group with */
+ u
int64_t category;
/* what type of option */
+ u
int64_t group;
/* who to group with */
void *gui_data;
int is_seconds; /* time value with seconds base */
void *gui_data;
int is_seconds; /* time value with seconds base */
+ int is_time; /* time based value */
int no_warn_def;
int no_warn_def;
+ int pow2; /* must be a power-of-2 */
+ int no_free;
};
};
-typedef int (str_cb_fn)(void *, char *);
-
-extern int parse_option(char *, const char *, struct fio_option *, struct fio_option **, void *, int);
+extern int parse_option(char *, const char *, struct fio_option *, struct fio_option **, void *, struct flist_head *);
extern void sort_options(char **, struct fio_option *, int);
extern void sort_options(char **, struct fio_option *, int);
-extern int parse_cmd_option(const char *t, const char *l, struct fio_option *, void *);
+extern int parse_cmd_option(const char *t, const char *l, struct fio_option *, void *
, struct flist_head *
);
extern int show_cmd_help(struct fio_option *, const char *);
extern void fill_default_options(void *, struct fio_option *);
extern int show_cmd_help(struct fio_option *, const char *);
extern void fill_default_options(void *, struct fio_option *);
-extern void option_init(struct fio_option *);
extern void options_init(struct fio_option *);
extern void options_init(struct fio_option *);
+extern void options_mem_dupe(struct fio_option *, void *);
extern void options_free(struct fio_option *, void *);
extern void strip_blank_front(char **);
extern void strip_blank_end(char *);
extern void options_free(struct fio_option *, void *);
extern void strip_blank_front(char **);
extern void strip_blank_end(char *);
-extern int str_to_decimal(const char *, long long *, int, void *, int);
+extern int str_to_decimal(const char *, long long *, int, void *, int
, int
);
extern int check_str_bytes(const char *p, long long *val, void *data);
extern int check_str_time(const char *p, long long *val, int);
extern int check_str_bytes(const char *p, long long *val, void *data);
extern int check_str_time(const char *p, long long *val, int);
-extern int str_to_float(const char *str, double *val);
+extern int str_to_float(const char *str, double *val, int is_time);
+
+extern int string_distance(const char *s1, const char *s2);
+extern int string_distance_ok(const char *s1, int dist);
/*
* Handlers for the options
/*
* Handlers for the options
@@
-100,18
+106,18
@@
extern int str_to_float(const char *str, double *val);
typedef int (fio_opt_str_fn)(void *, const char *);
typedef int (fio_opt_str_val_fn)(void *, long long *);
typedef int (fio_opt_int_fn)(void *, int *);
typedef int (fio_opt_str_fn)(void *, const char *);
typedef int (fio_opt_str_val_fn)(void *, long long *);
typedef int (fio_opt_int_fn)(void *, int *);
-typedef int (fio_opt_str_set_fn)(void *);
-
-#define __td_var(start, offset) ((char *) start + (offset))
struct thread_options;
struct thread_options;
-static inline void *td_var(struct thread_options *to, struct fio_option *o,
- unsigned int offset)
+static inline void *td_var(void *to, struct fio_option *o, unsigned int offset)
{
{
+ void *ret;
+
if (o->prof_opts)
if (o->prof_opts)
- return __td_var(o->prof_opts, offset);
+ ret = o->prof_opts;
+ else
+ ret = to;
- return
__td_var(to, offset)
;
+ return
(char *) ret + offset
;
}
static inline int parse_is_percent(unsigned long long val)
}
static inline int parse_is_percent(unsigned long long val)
@@
-119,4
+125,10
@@
static inline int parse_is_percent(unsigned long long val)
return val <= -1ULL && val >= (-1ULL - 100ULL);
}
return val <= -1ULL && val >= (-1ULL - 100ULL);
}
+struct print_option {
+ struct flist_head list;
+ char *name;
+ char *value;
+};
+
#endif
#endif