Commit | Line | Data |
---|---|---|
8062f527 JA |
1 | #ifndef FIO_THREAD_OPTIONS_H |
2 | #define FIO_THREAD_OPTIONS_H | |
3 | ||
4 | #include "arch/arch.h" | |
5 | #include "os/os.h" | |
a8523a6a | 6 | #include "options.h" |
8062f527 JA |
7 | #include "stat.h" |
8 | #include "gettime.h" | |
888677a4 | 9 | #include "lib/ieee754.h" |
61b9861d | 10 | #include "lib/pattern.h" |
3c978125 | 11 | #include "td_error.h" |
8062f527 | 12 | |
7b865a2f BVA |
13 | enum fio_zone_mode { |
14 | ZONE_MODE_NOT_SPECIFIED = 0, | |
15 | ZONE_MODE_NONE = 1, | |
16 | ZONE_MODE_STRIDED = 2, /* perform I/O in one zone at a time */ | |
17 | /* perform I/O across multiple zones simultaneously */ | |
18 | ZONE_MODE_ZBD = 3, | |
19 | }; | |
20 | ||
8062f527 JA |
21 | /* |
22 | * What type of allocation to use for io buffers | |
23 | */ | |
24 | enum fio_memtype { | |
25 | MEM_MALLOC = 0, /* ordinary malloc */ | |
26 | MEM_SHM, /* use shared memory segments */ | |
27 | MEM_SHMHUGE, /* use shared memory segments with huge pages */ | |
28 | MEM_MMAP, /* use anonynomous mmap */ | |
29 | MEM_MMAPHUGE, /* memory mapped huge file */ | |
217b0f1d | 30 | MEM_MMAPSHARED, /* use mmap with shared flag */ |
03553853 | 31 | MEM_CUDA_MALLOC,/* use GPU memory */ |
8062f527 JA |
32 | }; |
33 | ||
0d71aa98 BD |
34 | /* |
35 | * What mode to use for deduped data generation | |
36 | */ | |
37 | enum dedupe_mode { | |
38 | DEDUPE_MODE_REPEAT = 0, | |
39 | DEDUPE_MODE_WORKING_SET = 1, | |
40 | }; | |
41 | ||
8062f527 JA |
42 | #define ERROR_STR_MAX 128 |
43 | ||
8062f527 | 44 | #define BSSPLIT_MAX 64 |
3154f1ed | 45 | #define ZONESPLIT_MAX 256 |
8062f527 | 46 | |
f311f5f3 DLM |
47 | struct split { |
48 | unsigned int nr; | |
49 | unsigned long long val1[ZONESPLIT_MAX]; | |
50 | unsigned long long val2[ZONESPLIT_MAX]; | |
51 | }; | |
52 | ||
68be9966 NC |
53 | struct split_prio { |
54 | uint64_t bs; | |
55 | int32_t prio; | |
56 | uint32_t perc; | |
57 | }; | |
58 | ||
8062f527 | 59 | struct bssplit { |
5fff9543 | 60 | uint64_t bs; |
8062f527 JA |
61 | uint32_t perc; |
62 | }; | |
63 | ||
e0a04ac1 JA |
64 | struct zone_split { |
65 | uint8_t access_perc; | |
66 | uint8_t size_perc; | |
59466396 JA |
67 | uint8_t pad[6]; |
68 | uint64_t size; | |
e0a04ac1 JA |
69 | }; |
70 | ||
a8523a6a JA |
71 | #define NR_OPTS_SZ (FIO_MAX_OPTS / (8 * sizeof(uint64_t))) |
72 | ||
cb1402d6 JA |
73 | #define OPT_MAGIC 0x4f50544e |
74 | ||
8062f527 | 75 | struct thread_options { |
cb1402d6 | 76 | int magic; |
a8523a6a | 77 | uint64_t set_options[NR_OPTS_SZ]; |
8062f527 JA |
78 | char *description; |
79 | char *name; | |
9cc8cb91 | 80 | char *wait_for; |
8062f527 JA |
81 | char *directory; |
82 | char *filename; | |
83 | char *filename_format; | |
84 | char *opendir; | |
85 | char *ioengine; | |
6730b40f | 86 | char *ioengine_so_path; |
83ea422a | 87 | char *mmapfile; |
8062f527 JA |
88 | enum td_ddir td_ddir; |
89 | unsigned int rw_seq; | |
90 | unsigned int kb_base; | |
91 | unsigned int unit_base; | |
92 | unsigned int ddir_seq_nr; | |
c46fda90 | 93 | long long ddir_seq_add; |
8062f527 JA |
94 | unsigned int iodepth; |
95 | unsigned int iodepth_low; | |
96 | unsigned int iodepth_batch; | |
82407585 RP |
97 | unsigned int iodepth_batch_complete_min; |
98 | unsigned int iodepth_batch_complete_max; | |
997b5680 | 99 | unsigned int serialize_overlap; |
8062f527 | 100 | |
922a5be8 JA |
101 | unsigned int unique_filename; |
102 | ||
8062f527 | 103 | unsigned long long size; |
5be9bf09 | 104 | unsigned long long io_size; |
8062f527 | 105 | unsigned int size_percent; |
8f39afa7 | 106 | unsigned int size_nz; |
8b38f401 | 107 | unsigned int io_size_percent; |
8f39afa7 | 108 | unsigned int io_size_nz; |
8062f527 | 109 | unsigned int fill_device; |
bedc9dc2 | 110 | unsigned int file_append; |
8062f527 JA |
111 | unsigned long long file_size_low; |
112 | unsigned long long file_size_high; | |
113 | unsigned long long start_offset; | |
83c8b093 | 114 | unsigned long long start_offset_align; |
8f39afa7 | 115 | unsigned int start_offset_nz; |
8062f527 | 116 | |
5fff9543 JF |
117 | unsigned long long bs[DDIR_RWDIR_CNT]; |
118 | unsigned long long ba[DDIR_RWDIR_CNT]; | |
119 | unsigned long long min_bs[DDIR_RWDIR_CNT]; | |
120 | unsigned long long max_bs[DDIR_RWDIR_CNT]; | |
8062f527 JA |
121 | struct bssplit *bssplit[DDIR_RWDIR_CNT]; |
122 | unsigned int bssplit_nr[DDIR_RWDIR_CNT]; | |
123 | ||
124 | int *ignore_error[ERROR_TYPE_CNT]; | |
125 | unsigned int ignore_error_nr[ERROR_TYPE_CNT]; | |
126 | unsigned int error_dump; | |
127 | ||
128 | unsigned int nr_files; | |
129 | unsigned int open_files; | |
130 | enum file_lock_mode file_lock_mode; | |
131 | ||
132 | unsigned int odirect; | |
d01612f3 | 133 | unsigned int oatomic; |
8062f527 JA |
134 | unsigned int invalidate_cache; |
135 | unsigned int create_serialize; | |
136 | unsigned int create_fsync; | |
137 | unsigned int create_on_open; | |
138 | unsigned int create_only; | |
139 | unsigned int end_fsync; | |
140 | unsigned int pre_read; | |
141 | unsigned int sync_io; | |
ae8e559e | 142 | unsigned int write_hint; |
8062f527 JA |
143 | unsigned int verify; |
144 | unsigned int do_verify; | |
8062f527 JA |
145 | unsigned int verify_interval; |
146 | unsigned int verify_offset; | |
147 | char verify_pattern[MAX_PATTERN_SIZE]; | |
148 | unsigned int verify_pattern_bytes; | |
61b9861d RP |
149 | struct pattern_fmt verify_fmt[8]; |
150 | unsigned int verify_fmt_sz; | |
8062f527 JA |
151 | unsigned int verify_fatal; |
152 | unsigned int verify_dump; | |
153 | unsigned int verify_async; | |
154 | unsigned long long verify_backlog; | |
155 | unsigned int verify_batch; | |
156 | unsigned int experimental_verify; | |
ca09be4b JA |
157 | unsigned int verify_state; |
158 | unsigned int verify_state_save; | |
8062f527 JA |
159 | unsigned int use_thread; |
160 | unsigned int unlink; | |
39c1c323 | 161 | unsigned int unlink_each_loop; |
8062f527 JA |
162 | unsigned int do_disk_util; |
163 | unsigned int override_sync; | |
164 | unsigned int rand_repeatable; | |
56e2a5fc | 165 | unsigned int allrand_repeatable; |
363cffa7 | 166 | unsigned long long rand_seed; |
8062f527 | 167 | unsigned int log_avg_msec; |
1e613c9c KC |
168 | unsigned int log_hist_msec; |
169 | unsigned int log_hist_coarseness; | |
e6989e10 | 170 | unsigned int log_max; |
ae588852 | 171 | unsigned int log_offset; |
aee2ab67 | 172 | unsigned int log_gz; |
b26317c9 | 173 | unsigned int log_gz_store; |
3aea75b1 | 174 | unsigned int log_unix_epoch; |
d5b3cfd4 | 175 | unsigned int log_alternate_epoch; |
176 | unsigned int log_alternate_epoch_clock_id; | |
8062f527 JA |
177 | unsigned int norandommap; |
178 | unsigned int softrandommap; | |
179 | unsigned int bs_unaligned; | |
180 | unsigned int fsync_on_close; | |
6aca9b3d | 181 | unsigned int bs_is_seq_rand; |
8062f527 | 182 | |
62167762 JC |
183 | unsigned int verify_only; |
184 | ||
8062f527 | 185 | unsigned int random_distribution; |
f9cafb12 | 186 | unsigned int exitall_error; |
b7f487cf | 187 | |
e0a04ac1 JA |
188 | struct zone_split *zone_split[DDIR_RWDIR_CNT]; |
189 | unsigned int zone_split_nr[DDIR_RWDIR_CNT]; | |
190 | ||
888677a4 JA |
191 | fio_fp64_t zipf_theta; |
192 | fio_fp64_t pareto_h; | |
f88cd222 | 193 | fio_fp64_t gauss_dev; |
a87c90fd | 194 | fio_fp64_t random_center; |
8062f527 JA |
195 | |
196 | unsigned int random_generator; | |
197 | ||
d9472271 | 198 | unsigned int perc_rand[DDIR_RWDIR_CNT]; |
211c9b89 | 199 | |
8062f527 | 200 | unsigned int hugepage_size; |
5fff9543 | 201 | unsigned long long rw_min_bs; |
8062f527 JA |
202 | unsigned int fsync_blocks; |
203 | unsigned int fdatasync_blocks; | |
204 | unsigned int barrier_blocks; | |
205 | unsigned long long start_delay; | |
49050b56 | 206 | unsigned long long start_delay_orig; |
23ed19b0 | 207 | unsigned long long start_delay_high; |
8062f527 JA |
208 | unsigned long long timeout; |
209 | unsigned long long ramp_time; | |
2c5d94bc | 210 | unsigned int ss_state; |
16e56d25 VF |
211 | fio_fp64_t ss_limit; |
212 | unsigned long long ss_dur; | |
213 | unsigned long long ss_ramp_time; | |
8062f527 JA |
214 | unsigned int overwrite; |
215 | unsigned int bw_avg_time; | |
216 | unsigned int iops_avg_time; | |
217 | unsigned int loops; | |
218 | unsigned long long zone_range; | |
219 | unsigned long long zone_size; | |
b8dd9750 | 220 | unsigned long long zone_capacity; |
8062f527 | 221 | unsigned long long zone_skip; |
8f39afa7 | 222 | uint32_t zone_skip_nz; |
7b865a2f | 223 | enum fio_zone_mode zone_mode; |
81c6b6cd | 224 | unsigned long long lockmem; |
8062f527 JA |
225 | enum fio_memtype mem_type; |
226 | unsigned int mem_align; | |
227 | ||
f7cf63bf | 228 | unsigned long long max_latency[DDIR_RWDIR_CNT]; |
8062f527 | 229 | |
fd56c235 AW |
230 | unsigned int exit_what; |
231 | unsigned int stonewall; | |
8062f527 JA |
232 | unsigned int new_group; |
233 | unsigned int numjobs; | |
234 | os_cpu_mask_t cpumask; | |
8062f527 | 235 | os_cpu_mask_t verify_cpumask; |
c08f9fe2 | 236 | os_cpu_mask_t log_gz_cpumask; |
c2acfbac | 237 | unsigned int cpus_allowed_policy; |
43522848 | 238 | char *numa_cpunodes; |
8062f527 JA |
239 | unsigned short numa_mem_mode; |
240 | unsigned int numa_mem_prefer_node; | |
43522848 | 241 | char *numa_memnodes; |
03553853 | 242 | unsigned int gpu_dev_id; |
89978a6b | 243 | unsigned int start_offset_percent; |
03553853 | 244 | |
8062f527 JA |
245 | unsigned int iolog; |
246 | unsigned int rwmixcycle; | |
5054e67c | 247 | unsigned int rwmix[DDIR_RWDIR_CNT]; |
8062f527 | 248 | unsigned int nice; |
81c6b6cd JA |
249 | unsigned int ioprio; |
250 | unsigned int ioprio_class; | |
8062f527 JA |
251 | unsigned int file_service_type; |
252 | unsigned int group_reporting; | |
8243be59 | 253 | unsigned int stats; |
8062f527 JA |
254 | unsigned int fadvise_hint; |
255 | enum fio_fallocate_mode fallocate_mode; | |
256 | unsigned int zero_buffers; | |
257 | unsigned int refill_buffers; | |
258 | unsigned int scramble_buffers; | |
ce35b1ec JA |
259 | char buffer_pattern[MAX_PATTERN_SIZE]; |
260 | unsigned int buffer_pattern_bytes; | |
8062f527 JA |
261 | unsigned int compress_percentage; |
262 | unsigned int compress_chunk; | |
5c94b008 | 263 | unsigned int dedupe_percentage; |
0d71aa98 BD |
264 | unsigned int dedupe_mode; |
265 | unsigned int dedupe_working_set_percentage; | |
8062f527 JA |
266 | unsigned int time_based; |
267 | unsigned int disable_lat; | |
268 | unsigned int disable_clat; | |
269 | unsigned int disable_slat; | |
270 | unsigned int disable_bw; | |
271 | unsigned int unified_rw_rep; | |
272 | unsigned int gtod_reduce; | |
273 | unsigned int gtod_cpu; | |
8062f527 JA |
274 | enum fio_cs clocksource; |
275 | unsigned int no_stall; | |
276 | unsigned int trim_percentage; | |
277 | unsigned int trim_batch; | |
278 | unsigned int trim_zero; | |
279 | unsigned long long trim_backlog; | |
280 | unsigned int clat_percentiles; | |
56440e63 | 281 | unsigned int slat_percentiles; |
b599759b | 282 | unsigned int lat_percentiles; |
8062f527 JA |
283 | unsigned int percentile_precision; /* digits after decimal for percentiles */ |
284 | fio_fp64_t percentile_list[FIO_IO_U_LIST_MAX_LEN]; | |
285 | ||
286 | char *read_iolog_file; | |
98e7161c | 287 | bool read_iolog_chunked; |
8062f527 | 288 | char *write_iolog_file; |
b9921d1a | 289 | char *merge_blktrace_file; |
87a48ada | 290 | fio_fp64_t merge_blktrace_scalars[FIO_IO_U_LIST_MAX_LEN]; |
55bfd8c8 | 291 | fio_fp64_t merge_blktrace_iters[FIO_IO_U_LIST_MAX_LEN]; |
dded427c OS |
292 | |
293 | unsigned int write_bw_log; | |
294 | unsigned int write_lat_log; | |
295 | unsigned int write_iops_log; | |
296 | unsigned int write_hist_log; | |
297 | ||
8062f527 JA |
298 | char *bw_log_file; |
299 | char *lat_log_file; | |
300 | char *iops_log_file; | |
1e613c9c | 301 | char *hist_log_file; |
8062f527 JA |
302 | char *replay_redirect; |
303 | ||
304 | /* | |
305 | * Pre-run and post-run shell | |
306 | */ | |
307 | char *exec_prerun; | |
308 | char *exec_postrun; | |
309 | ||
f7942acd SK |
310 | unsigned int thinktime; |
311 | unsigned int thinktime_spin; | |
312 | unsigned int thinktime_blocks; | |
313 | unsigned int thinktime_blocks_type; | |
314 | unsigned int thinktime_iotime; | |
315 | ||
90eff1c9 SW |
316 | uint64_t rate[DDIR_RWDIR_CNT]; |
317 | uint64_t ratemin[DDIR_RWDIR_CNT]; | |
8062f527 | 318 | unsigned int ratecycle; |
a9da8ab2 | 319 | unsigned int io_submit_mode; |
8062f527 JA |
320 | unsigned int rate_iops[DDIR_RWDIR_CNT]; |
321 | unsigned int rate_iops_min[DDIR_RWDIR_CNT]; | |
6de65959 | 322 | unsigned int rate_process; |
1a9bf814 | 323 | unsigned int rate_ign_think; |
8062f527 JA |
324 | |
325 | char *ioscheduler; | |
326 | ||
8062f527 JA |
327 | /* |
328 | * I/O Error handling | |
329 | */ | |
330 | enum error_type continue_on_error; | |
331 | ||
332 | /* | |
333 | * Benchmark profile type | |
334 | */ | |
335 | char *profile; | |
336 | ||
337 | /* | |
338 | * blkio cgroup support | |
339 | */ | |
340 | char *cgroup; | |
341 | unsigned int cgroup_weight; | |
342 | unsigned int cgroup_nodelete; | |
343 | ||
344 | unsigned int uid; | |
345 | unsigned int gid; | |
346 | ||
0b288ba1 | 347 | unsigned int offset_increment_percent; |
8f39afa7 | 348 | unsigned int offset_increment_nz; |
8062f527 | 349 | unsigned long long offset_increment; |
ddf24e42 | 350 | unsigned long long number_ios; |
8062f527 JA |
351 | |
352 | unsigned int sync_file_range; | |
3e260a46 JA |
353 | |
354 | unsigned long long latency_target; | |
355 | unsigned long long latency_window; | |
356 | fio_fp64_t latency_percentile; | |
e1bcd541 | 357 | uint32_t latency_run; |
66347cfa | 358 | |
d4e74fda DB |
359 | /* |
360 | * flow support | |
361 | */ | |
362 | int flow_id; | |
363 | unsigned int flow; | |
364 | unsigned int flow_sleep; | |
365 | ||
e883cb35 JF |
366 | unsigned int sig_figs; |
367 | ||
66347cfa | 368 | unsigned block_error_hist; |
0c63576e JA |
369 | |
370 | unsigned int replay_align; | |
371 | unsigned int replay_scale; | |
6dd7fa77 | 372 | unsigned int replay_time_scale; |
d7235efb | 373 | unsigned int replay_skip; |
3a5db920 JA |
374 | |
375 | unsigned int per_job_logs; | |
2378826d JA |
376 | |
377 | unsigned int allow_create; | |
e81ecca3 | 378 | unsigned int allow_mounted_write; |
bfbdd35b BVA |
379 | |
380 | /* Parameters that affect zonemode=zbd */ | |
381 | unsigned int read_beyond_wp; | |
59b07544 | 382 | int max_open_zones; |
219c662d | 383 | unsigned int job_max_open_zones; |
575686bb | 384 | unsigned int ignore_zone_limits; |
a7c2b6fc BVA |
385 | fio_fp64_t zrt; |
386 | fio_fp64_t zrf; | |
03ec570f | 387 | |
0a852a50 | 388 | unsigned int log_entries; |
03ec570f | 389 | unsigned int log_prio; |
8062f527 JA |
390 | }; |
391 | ||
2dc1cbb5 JA |
392 | #define FIO_TOP_STR_MAX 256 |
393 | ||
394 | struct thread_options_pack { | |
a8523a6a | 395 | uint64_t set_options[NR_OPTS_SZ]; |
2dc1cbb5 JA |
396 | uint8_t description[FIO_TOP_STR_MAX]; |
397 | uint8_t name[FIO_TOP_STR_MAX]; | |
9cc8cb91 | 398 | uint8_t wait_for[FIO_TOP_STR_MAX]; |
2dc1cbb5 JA |
399 | uint8_t directory[FIO_TOP_STR_MAX]; |
400 | uint8_t filename[FIO_TOP_STR_MAX]; | |
22f80458 | 401 | uint8_t filename_format[FIO_TOP_STR_MAX]; |
2dc1cbb5 JA |
402 | uint8_t opendir[FIO_TOP_STR_MAX]; |
403 | uint8_t ioengine[FIO_TOP_STR_MAX]; | |
83ea422a | 404 | uint8_t mmapfile[FIO_TOP_STR_MAX]; |
2dc1cbb5 JA |
405 | uint32_t td_ddir; |
406 | uint32_t rw_seq; | |
407 | uint32_t kb_base; | |
22f80458 | 408 | uint32_t unit_base; |
2dc1cbb5 JA |
409 | uint32_t ddir_seq_nr; |
410 | uint64_t ddir_seq_add; | |
411 | uint32_t iodepth; | |
412 | uint32_t iodepth_low; | |
413 | uint32_t iodepth_batch; | |
82407585 RP |
414 | uint32_t iodepth_batch_complete_min; |
415 | uint32_t iodepth_batch_complete_max; | |
997b5680 | 416 | uint32_t serialize_overlap; |
56440e63 | 417 | uint32_t pad; |
2dc1cbb5 JA |
418 | |
419 | uint64_t size; | |
5be9bf09 | 420 | uint64_t io_size; |
2dc1cbb5 | 421 | uint32_t size_percent; |
8f39afa7 | 422 | uint32_t size_nz; |
8b38f401 | 423 | uint32_t io_size_percent; |
8f39afa7 | 424 | uint32_t io_size_nz; |
2dc1cbb5 | 425 | uint32_t fill_device; |
bedc9dc2 | 426 | uint32_t file_append; |
922a5be8 | 427 | uint32_t unique_filename; |
8f39afa7 | 428 | uint32_t pad3; |
2dc1cbb5 JA |
429 | uint64_t file_size_low; |
430 | uint64_t file_size_high; | |
431 | uint64_t start_offset; | |
83c8b093 | 432 | uint64_t start_offset_align; |
8f39afa7 AD |
433 | uint32_t start_offset_nz; |
434 | uint32_t pad4; | |
2dc1cbb5 | 435 | |
5fff9543 JF |
436 | uint64_t bs[DDIR_RWDIR_CNT]; |
437 | uint64_t ba[DDIR_RWDIR_CNT]; | |
438 | uint64_t min_bs[DDIR_RWDIR_CNT]; | |
439 | uint64_t max_bs[DDIR_RWDIR_CNT]; | |
b999b3c7 JA |
440 | struct bssplit bssplit[DDIR_RWDIR_CNT][BSSPLIT_MAX]; |
441 | uint32_t bssplit_nr[DDIR_RWDIR_CNT]; | |
2dc1cbb5 | 442 | |
e65a950a JA |
443 | uint32_t ignore_error[ERROR_TYPE_CNT][ERROR_STR_MAX]; |
444 | uint32_t ignore_error_nr[ERROR_TYPE_CNT]; | |
445 | uint32_t error_dump; | |
446 | ||
2dc1cbb5 JA |
447 | uint32_t nr_files; |
448 | uint32_t open_files; | |
449 | uint32_t file_lock_mode; | |
2dc1cbb5 JA |
450 | |
451 | uint32_t odirect; | |
d01612f3 | 452 | uint32_t oatomic; |
2dc1cbb5 JA |
453 | uint32_t invalidate_cache; |
454 | uint32_t create_serialize; | |
455 | uint32_t create_fsync; | |
456 | uint32_t create_on_open; | |
fb390e24 | 457 | uint32_t create_only; |
2dc1cbb5 JA |
458 | uint32_t end_fsync; |
459 | uint32_t pre_read; | |
460 | uint32_t sync_io; | |
ae8e559e | 461 | uint32_t write_hint; |
2dc1cbb5 JA |
462 | uint32_t verify; |
463 | uint32_t do_verify; | |
2dc1cbb5 JA |
464 | uint32_t verify_interval; |
465 | uint32_t verify_offset; | |
466 | uint8_t verify_pattern[MAX_PATTERN_SIZE]; | |
467 | uint32_t verify_pattern_bytes; | |
468 | uint32_t verify_fatal; | |
469 | uint32_t verify_dump; | |
470 | uint32_t verify_async; | |
471 | uint64_t verify_backlog; | |
472 | uint32_t verify_batch; | |
836fcc0f | 473 | uint32_t experimental_verify; |
ca09be4b JA |
474 | uint32_t verify_state; |
475 | uint32_t verify_state_save; | |
2dc1cbb5 JA |
476 | uint32_t use_thread; |
477 | uint32_t unlink; | |
39c1c323 | 478 | uint32_t unlink_each_loop; |
2dc1cbb5 JA |
479 | uint32_t do_disk_util; |
480 | uint32_t override_sync; | |
481 | uint32_t rand_repeatable; | |
56e2a5fc | 482 | uint32_t allrand_repeatable; |
56440e63 | 483 | uint32_t pad2; |
363cffa7 | 484 | uint64_t rand_seed; |
2dc1cbb5 | 485 | uint32_t log_avg_msec; |
1e613c9c KC |
486 | uint32_t log_hist_msec; |
487 | uint32_t log_hist_coarseness; | |
e6989e10 | 488 | uint32_t log_max; |
ae588852 | 489 | uint32_t log_offset; |
aee2ab67 | 490 | uint32_t log_gz; |
b26317c9 | 491 | uint32_t log_gz_store; |
3aea75b1 | 492 | uint32_t log_unix_epoch; |
d5b3cfd4 | 493 | uint32_t log_alternate_epoch; |
494 | uint32_t log_alternate_epoch_clock_id; | |
2dc1cbb5 JA |
495 | uint32_t norandommap; |
496 | uint32_t softrandommap; | |
497 | uint32_t bs_unaligned; | |
498 | uint32_t fsync_on_close; | |
6aca9b3d | 499 | uint32_t bs_is_seq_rand; |
2dc1cbb5 | 500 | |
1e5324e7 | 501 | uint32_t random_distribution; |
f9cafb12 | 502 | uint32_t exitall_error; |
af7d9f1f JA |
503 | |
504 | uint32_t sync_file_range; | |
e0a04ac1 JA |
505 | |
506 | struct zone_split zone_split[DDIR_RWDIR_CNT][ZONESPLIT_MAX]; | |
507 | uint32_t zone_split_nr[DDIR_RWDIR_CNT]; | |
f88cd222 | 508 | |
1e5324e7 JA |
509 | fio_fp64_t zipf_theta; |
510 | fio_fp64_t pareto_h; | |
f88cd222 | 511 | fio_fp64_t gauss_dev; |
a87c90fd | 512 | fio_fp64_t random_center; |
1e5324e7 | 513 | |
49758e11 JA |
514 | uint32_t random_generator; |
515 | ||
d9472271 | 516 | uint32_t perc_rand[DDIR_RWDIR_CNT]; |
211c9b89 | 517 | |
2dc1cbb5 | 518 | uint32_t hugepage_size; |
5fff9543 | 519 | uint64_t rw_min_bs; |
2dc1cbb5 JA |
520 | uint32_t fsync_blocks; |
521 | uint32_t fdatasync_blocks; | |
522 | uint32_t barrier_blocks; | |
523 | uint64_t start_delay; | |
23ed19b0 | 524 | uint64_t start_delay_high; |
2dc1cbb5 JA |
525 | uint64_t timeout; |
526 | uint64_t ramp_time; | |
72863286 JA |
527 | uint64_t ss_dur; |
528 | uint64_t ss_ramp_time; | |
2c5d94bc | 529 | uint32_t ss_state; |
72863286 | 530 | fio_fp64_t ss_limit; |
2dc1cbb5 JA |
531 | uint32_t overwrite; |
532 | uint32_t bw_avg_time; | |
533 | uint32_t iops_avg_time; | |
534 | uint32_t loops; | |
535 | uint64_t zone_range; | |
536 | uint64_t zone_size; | |
b8dd9750 | 537 | uint64_t zone_capacity; |
2dc1cbb5 | 538 | uint64_t zone_skip; |
ae278f9a | 539 | uint64_t lockmem; |
8f39afa7 | 540 | uint32_t zone_skip_nz; |
2dc1cbb5 JA |
541 | uint32_t mem_type; |
542 | uint32_t mem_align; | |
543 | ||
fd56c235 AW |
544 | uint32_t exit_what; |
545 | uint32_t stonewall; | |
2dc1cbb5 JA |
546 | uint32_t new_group; |
547 | uint32_t numjobs; | |
33f42c20 | 548 | |
57535f41 JA |
549 | /* |
550 | * We currently can't convert these, so don't enable them | |
551 | */ | |
552 | #if 0 | |
2dc1cbb5 | 553 | uint8_t cpumask[FIO_TOP_STR_MAX]; |
2dc1cbb5 | 554 | uint8_t verify_cpumask[FIO_TOP_STR_MAX]; |
c08f9fe2 | 555 | uint8_t log_gz_cpumask[FIO_TOP_STR_MAX]; |
57535f41 | 556 | #endif |
6599ce5a | 557 | uint32_t gpu_dev_id; |
89978a6b | 558 | uint32_t start_offset_percent; |
c2acfbac | 559 | uint32_t cpus_allowed_policy; |
2dc1cbb5 JA |
560 | uint32_t iolog; |
561 | uint32_t rwmixcycle; | |
5054e67c | 562 | uint32_t rwmix[DDIR_RWDIR_CNT]; |
2dc1cbb5 | 563 | uint32_t nice; |
28727df7 JA |
564 | uint32_t ioprio; |
565 | uint32_t ioprio_class; | |
2dc1cbb5 JA |
566 | uint32_t file_service_type; |
567 | uint32_t group_reporting; | |
8243be59 | 568 | uint32_t stats; |
2dc1cbb5 JA |
569 | uint32_t fadvise_hint; |
570 | uint32_t fallocate_mode; | |
571 | uint32_t zero_buffers; | |
572 | uint32_t refill_buffers; | |
573 | uint32_t scramble_buffers; | |
ce35b1ec JA |
574 | uint8_t buffer_pattern[MAX_PATTERN_SIZE]; |
575 | uint32_t buffer_pattern_bytes; | |
5c94b008 JA |
576 | uint32_t compress_percentage; |
577 | uint32_t compress_chunk; | |
578 | uint32_t dedupe_percentage; | |
0d71aa98 BD |
579 | uint32_t dedupe_mode; |
580 | uint32_t dedupe_working_set_percentage; | |
2dc1cbb5 JA |
581 | uint32_t time_based; |
582 | uint32_t disable_lat; | |
583 | uint32_t disable_clat; | |
584 | uint32_t disable_slat; | |
585 | uint32_t disable_bw; | |
95820b6e | 586 | uint32_t unified_rw_rep; |
2dc1cbb5 JA |
587 | uint32_t gtod_reduce; |
588 | uint32_t gtod_cpu; | |
2dc1cbb5 JA |
589 | uint32_t clocksource; |
590 | uint32_t no_stall; | |
591 | uint32_t trim_percentage; | |
592 | uint32_t trim_batch; | |
593 | uint32_t trim_zero; | |
594 | uint64_t trim_backlog; | |
595 | uint32_t clat_percentiles; | |
56440e63 VF |
596 | uint32_t lat_percentiles; |
597 | uint32_t slat_percentiles; | |
9db01ef9 | 598 | uint32_t percentile_precision; |
2dc1cbb5 JA |
599 | fio_fp64_t percentile_list[FIO_IO_U_LIST_MAX_LEN]; |
600 | ||
601 | uint8_t read_iolog_file[FIO_TOP_STR_MAX]; | |
602 | uint8_t write_iolog_file[FIO_TOP_STR_MAX]; | |
b9921d1a | 603 | uint8_t merge_blktrace_file[FIO_TOP_STR_MAX]; |
87a48ada | 604 | fio_fp64_t merge_blktrace_scalars[FIO_IO_U_LIST_MAX_LEN]; |
55bfd8c8 | 605 | fio_fp64_t merge_blktrace_iters[FIO_IO_U_LIST_MAX_LEN]; |
dded427c OS |
606 | |
607 | uint32_t write_bw_log; | |
608 | uint32_t write_lat_log; | |
609 | uint32_t write_iops_log; | |
610 | uint32_t write_hist_log; | |
611 | ||
2dc1cbb5 JA |
612 | uint8_t bw_log_file[FIO_TOP_STR_MAX]; |
613 | uint8_t lat_log_file[FIO_TOP_STR_MAX]; | |
614 | uint8_t iops_log_file[FIO_TOP_STR_MAX]; | |
68cebb4b | 615 | uint8_t hist_log_file[FIO_TOP_STR_MAX]; |
2dc1cbb5 JA |
616 | uint8_t replay_redirect[FIO_TOP_STR_MAX]; |
617 | ||
618 | /* | |
619 | * Pre-run and post-run shell | |
620 | */ | |
621 | uint8_t exec_prerun[FIO_TOP_STR_MAX]; | |
622 | uint8_t exec_postrun[FIO_TOP_STR_MAX]; | |
623 | ||
f7942acd SK |
624 | uint32_t thinktime; |
625 | uint32_t thinktime_spin; | |
626 | uint32_t thinktime_blocks; | |
627 | uint32_t thinktime_blocks_type; | |
628 | uint32_t thinktime_iotime; | |
629 | ||
90eff1c9 SW |
630 | uint64_t rate[DDIR_RWDIR_CNT]; |
631 | uint64_t ratemin[DDIR_RWDIR_CNT]; | |
2dc1cbb5 | 632 | uint32_t ratecycle; |
a9da8ab2 | 633 | uint32_t io_submit_mode; |
b999b3c7 JA |
634 | uint32_t rate_iops[DDIR_RWDIR_CNT]; |
635 | uint32_t rate_iops_min[DDIR_RWDIR_CNT]; | |
6de65959 | 636 | uint32_t rate_process; |
1a9bf814 | 637 | uint32_t rate_ign_think; |
2dc1cbb5 JA |
638 | |
639 | uint8_t ioscheduler[FIO_TOP_STR_MAX]; | |
640 | ||
2dc1cbb5 JA |
641 | /* |
642 | * I/O Error handling | |
643 | */ | |
644 | uint32_t continue_on_error; | |
645 | ||
646 | /* | |
647 | * Benchmark profile type | |
648 | */ | |
649 | uint8_t profile[FIO_TOP_STR_MAX]; | |
650 | ||
651 | /* | |
652 | * blkio cgroup support | |
653 | */ | |
654 | uint8_t cgroup[FIO_TOP_STR_MAX]; | |
655 | uint32_t cgroup_weight; | |
656 | uint32_t cgroup_nodelete; | |
657 | ||
658 | uint32_t uid; | |
659 | uint32_t gid; | |
660 | ||
0b288ba1 | 661 | uint32_t offset_increment_percent; |
8f39afa7 | 662 | uint32_t offset_increment_nz; |
6a4cf74f | 663 | uint64_t offset_increment; |
ddf24e42 | 664 | uint64_t number_ios; |
6a4cf74f | 665 | |
3e260a46 JA |
666 | uint64_t latency_target; |
667 | uint64_t latency_window; | |
f7cf63bf | 668 | uint64_t max_latency[DDIR_RWDIR_CNT]; |
3e260a46 | 669 | fio_fp64_t latency_percentile; |
e1bcd541 | 670 | uint32_t latency_run; |
66347cfa | 671 | |
d4e74fda DB |
672 | /* |
673 | * flow support | |
674 | */ | |
675 | int32_t flow_id; | |
676 | uint32_t flow; | |
677 | uint32_t flow_sleep; | |
678 | ||
e883cb35 JF |
679 | uint32_t sig_figs; |
680 | ||
66347cfa | 681 | uint32_t block_error_hist; |
0c63576e JA |
682 | |
683 | uint32_t replay_align; | |
684 | uint32_t replay_scale; | |
6dd7fa77 | 685 | uint32_t replay_time_scale; |
d7235efb | 686 | uint32_t replay_skip; |
3a5db920 JA |
687 | |
688 | uint32_t per_job_logs; | |
2378826d JA |
689 | |
690 | uint32_t allow_create; | |
e81ecca3 | 691 | uint32_t allow_mounted_write; |
7b865a2f BVA |
692 | |
693 | uint32_t zone_mode; | |
6df25f78 | 694 | int32_t max_open_zones; |
575686bb | 695 | uint32_t ignore_zone_limits; |
03ec570f | 696 | |
0a852a50 | 697 | uint32_t log_entries; |
03ec570f | 698 | uint32_t log_prio; |
2dc1cbb5 JA |
699 | } __attribute__((packed)); |
700 | ||
701 | extern void convert_thread_options_to_cpu(struct thread_options *o, struct thread_options_pack *top); | |
702 | extern void convert_thread_options_to_net(struct thread_options_pack *top, struct thread_options *); | |
51167799 | 703 | extern int fio_test_cconv(struct thread_options *); |
588b7f09 | 704 | extern void options_default_fill(struct thread_options *o); |
2dc1cbb5 | 705 | |
f311f5f3 DLM |
706 | typedef int (split_parse_fn)(struct thread_options *, void *, |
707 | enum fio_ddir, char *, bool); | |
708 | ||
709 | extern int str_split_parse(struct thread_data *td, char *str, | |
710 | split_parse_fn *fn, void *eo, bool data); | |
711 | ||
712 | extern int split_parse_ddir(struct thread_options *o, struct split *split, | |
713 | char *str, bool absolute, unsigned int max_splits); | |
714 | ||
68be9966 NC |
715 | extern int split_parse_prio_ddir(struct thread_options *o, |
716 | struct split_prio **entries, int *nr_entries, | |
717 | char *str); | |
718 | ||
8062f527 | 719 | #endif |