1 #include <string.h> 2 3 #include "thread_options.h" 4 5 static void string_to_cpu(char **dst, const uint8_t *src) 6 { 7 const char *__src = (const char *) src; 8 9 if (strlen(__src)) 10 *dst = strdup(__src); 11 } 12 13 static void __string_to_net(uint8_t *dst, const char *src, size_t dst_size) 14 { 15 if (src) { 16 dst[dst_size - 1] = '\0'; 17 strncpy((char *) dst, src, dst_size - 1); 18 } else 19 dst[0] = '\0'; 20 } 21 22 #define string_to_net(dst, src) __string_to_net((dst), (src), sizeof(dst)) 23 24 static void free_thread_options_to_cpu(struct thread_options *o) 25 { 26 int i; 27 28 free(o->description); 29 free(o->name); 30 free(o->wait_for); 31 free(o->directory); 32 free(o->filename); 33 free(o->filename_format); 34 free(o->opendir); 35 free(o->ioengine); 36 free(o->mmapfile); 37 free(o->read_iolog_file); 38 free(o->write_iolog_file); 39 free(o->bw_log_file); 40 free(o->lat_log_file); 41 free(o->iops_log_file); 42 free(o->hist_log_file); 43 free(o->replay_redirect); 44 free(o->exec_prerun); 45 free(o->exec_postrun); 46 free(o->ioscheduler); 47 free(o->profile); 48 free(o->cgroup); 49 50 for (i = 0; i < DDIR_RWDIR_CNT; i++) { 51 free(o->bssplit[i]); 52 free(o->zone_split[i]); 53 } 54 } 55 56 void convert_thread_options_to_cpu(struct thread_options *o, 57 struct thread_options_pack *top) 58 { 59 int i, j; 60 61 for (i = 0; i < NR_OPTS_SZ; i++) 62 o->set_options[i] = le64_to_cpu(top->set_options[i]); 63 64 string_to_cpu(&o->description, top->description); 65 string_to_cpu(&o->name, top->name); 66 string_to_cpu(&o->wait_for, top->wait_for); 67 string_to_cpu(&o->directory, top->directory); 68 string_to_cpu(&o->filename, top->filename); 69 string_to_cpu(&o->filename_format, top->filename_format); 70 string_to_cpu(&o->opendir, top->opendir); 71 string_to_cpu(&o->ioengine, top->ioengine); 72 string_to_cpu(&o->mmapfile, top->mmapfile); 73 string_to_cpu(&o->read_iolog_file, top->read_iolog_file); 74 string_to_cpu(&o->write_iolog_file, top->write_iolog_file); 75 string_to_cpu(&o->bw_log_file, top->bw_log_file); 76 string_to_cpu(&o->lat_log_file, top->lat_log_file); 77 string_to_cpu(&o->iops_log_file, top->iops_log_file); 78 string_to_cpu(&o->hist_log_file, top->hist_log_file); 79 string_to_cpu(&o->replay_redirect, top->replay_redirect); 80 string_to_cpu(&o->exec_prerun, top->exec_prerun); 81 string_to_cpu(&o->exec_postrun, top->exec_postrun); 82 string_to_cpu(&o->ioscheduler, top->ioscheduler); 83 string_to_cpu(&o->profile, top->profile); 84 string_to_cpu(&o->cgroup, top->cgroup); 85 86 o->allow_create = le32_to_cpu(top->allow_create); 87 o->allow_mounted_write = le32_to_cpu(top->allow_mounted_write); 88 o->td_ddir = le32_to_cpu(top->td_ddir); 89 o->rw_seq = le32_to_cpu(top->rw_seq); 90 o->kb_base = le32_to_cpu(top->kb_base); 91 o->unit_base = le32_to_cpu(top->unit_base); 92 o->ddir_seq_nr = le32_to_cpu(top->ddir_seq_nr); 93 o->ddir_seq_add = le64_to_cpu(top->ddir_seq_add); 94 o->iodepth = le32_to_cpu(top->iodepth); 95 o->iodepth_low = le32_to_cpu(top->iodepth_low); 96 o->iodepth_batch = le32_to_cpu(top->iodepth_batch); 97 o->iodepth_batch_complete_min = le32_to_cpu(top->iodepth_batch_complete_min); 98 o->iodepth_batch_complete_max = le32_to_cpu(top->iodepth_batch_complete_max); 99 o->size = le64_to_cpu(top->size); 100 o->io_size = le64_to_cpu(top->io_size); 101 o->size_percent = le32_to_cpu(top->size_percent); 102 o->fill_device = le32_to_cpu(top->fill_device); 103 o->file_append = le32_to_cpu(top->file_append); 104 o->file_size_low = le64_to_cpu(top->file_size_low); 105 o->file_size_high = le64_to_cpu(top->file_size_high); 106 o->start_offset = le64_to_cpu(top->start_offset); 107 108 for (i = 0; i < DDIR_RWDIR_CNT; i++) { 109 o->bs[i] = le32_to_cpu(top->bs[i]); 110 o->ba[i] = le32_to_cpu(top->ba[i]); 111 o->min_bs[i] = le32_to_cpu(top->min_bs[i]); 112 o->max_bs[i] = le32_to_cpu(top->max_bs[i]); 113 o->bssplit_nr[i] = le32_to_cpu(top->bssplit_nr[i]); 114 115 if (o->bssplit_nr[i]) { 116 o->bssplit[i] = malloc(o->bssplit_nr[i] * sizeof(struct bssplit)); 117 for (j = 0; j < o->bssplit_nr[i]; j++) { 118 o->bssplit[i][j].bs = le32_to_cpu(top->bssplit[i][j].bs); 119 o->bssplit[i][j].perc = le32_to_cpu(top->bssplit[i][j].perc); 120 } 121 } 122 123 o->zone_split_nr[i] = le32_to_cpu(top->zone_split_nr[i]); 124 125 if (o->zone_split_nr[i]) { 126 o->zone_split[i] = malloc(o->zone_split_nr[i] * sizeof(struct zone_split)); 127 for (j = 0; j < o->zone_split_nr[i]; j++) { 128 o->zone_split[i][j].access_perc = top->zone_split[i][j].access_perc; 129 o->zone_split[i][j].size_perc = top->zone_split[i][j].size_perc; 130 } 131 } 132 133 o->rwmix[i] = le32_to_cpu(top->rwmix[i]); 134 o->rate[i] = le64_to_cpu(top->rate[i]); 135 o->ratemin[i] = le64_to_cpu(top->ratemin[i]); 136 o->rate_iops[i] = le32_to_cpu(top->rate_iops[i]); 137 o->rate_iops_min[i] = le32_to_cpu(top->rate_iops_min[i]); 138 139 o->perc_rand[i] = le32_to_cpu(top->perc_rand[i]); 140 } 141 142 o->ratecycle = le32_to_cpu(top->ratecycle); 143 o->io_submit_mode = le32_to_cpu(top->io_submit_mode); 144 o->unique_filename = le32_to_cpu(top->unique_filename); 145 o->nr_files = le32_to_cpu(top->nr_files); 146 o->open_files = le32_to_cpu(top->open_files); 147 o->file_lock_mode = le32_to_cpu(top->file_lock_mode); 148 o->odirect = le32_to_cpu(top->odirect); 149 o->oatomic = le32_to_cpu(top->oatomic); 150 o->invalidate_cache = le32_to_cpu(top->invalidate_cache); 151 o->create_serialize = le32_to_cpu(top->create_serialize); 152 o->create_fsync = le32_to_cpu(top->create_fsync); 153 o->create_on_open = le32_to_cpu(top->create_on_open); 154 o->create_only = le32_to_cpu(top->create_only); 155 o->end_fsync = le32_to_cpu(top->end_fsync); 156 o->pre_read = le32_to_cpu(top->pre_read); 157 o->sync_io = le32_to_cpu(top->sync_io); 158 o->verify = le32_to_cpu(top->verify); 159 o->do_verify = le32_to_cpu(top->do_verify); 160 o->verifysort = le32_to_cpu(top->verifysort); 161 o->verifysort_nr = le32_to_cpu(top->verifysort_nr); 162 o->experimental_verify = le32_to_cpu(top->experimental_verify); 163 o->verify_state = le32_to_cpu(top->verify_state); 164 o->verify_interval = le32_to_cpu(top->verify_interval); 165 o->verify_offset = le32_to_cpu(top->verify_offset); 166 167 memcpy(o->verify_pattern, top->verify_pattern, MAX_PATTERN_SIZE); 168 memcpy(o->buffer_pattern, top->buffer_pattern, MAX_PATTERN_SIZE); 169 170 o->verify_pattern_bytes = le32_to_cpu(top->verify_pattern_bytes); 171 o->verify_fatal = le32_to_cpu(top->verify_fatal); 172 o->verify_dump = le32_to_cpu(top->verify_dump); 173 o->verify_async = le32_to_cpu(top->verify_async); 174 o->verify_batch = le32_to_cpu(top->verify_batch); 175 o->use_thread = le32_to_cpu(top->use_thread); 176 o->unlink = le32_to_cpu(top->unlink); 177 o->unlink_each_loop = le32_to_cpu(top->unlink_each_loop); 178 o->do_disk_util = le32_to_cpu(top->do_disk_util); 179 o->override_sync = le32_to_cpu(top->override_sync); 180 o->rand_repeatable = le32_to_cpu(top->rand_repeatable); 181 o->allrand_repeatable = le32_to_cpu(top->allrand_repeatable); 182 o->rand_seed = le64_to_cpu(top->rand_seed); 183 o->log_avg_msec = le32_to_cpu(top->log_avg_msec); 184 o->log_hist_msec = le32_to_cpu(top->log_hist_msec); 185 o->log_hist_coarseness = le32_to_cpu(top->log_hist_coarseness); 186 o->log_max = le32_to_cpu(top->log_max); 187 o->log_offset = le32_to_cpu(top->log_offset); 188 o->log_gz = le32_to_cpu(top->log_gz); 189 o->log_gz_store = le32_to_cpu(top->log_gz_store); 190 o->log_unix_epoch = le32_to_cpu(top->log_unix_epoch); 191 o->norandommap = le32_to_cpu(top->norandommap); 192 o->softrandommap = le32_to_cpu(top->softrandommap); 193 o->bs_unaligned = le32_to_cpu(top->bs_unaligned); 194 o->fsync_on_close = le32_to_cpu(top->fsync_on_close); 195 o->bs_is_seq_rand = le32_to_cpu(top->bs_is_seq_rand); 196 o->random_distribution = le32_to_cpu(top->random_distribution); 197 o->exitall_error = le32_to_cpu(top->exitall_error); 198 o->zipf_theta.u.f = fio_uint64_to_double(le64_to_cpu(top->zipf_theta.u.i)); 199 o->pareto_h.u.f = fio_uint64_to_double(le64_to_cpu(top->pareto_h.u.i)); 200 o->gauss_dev.u.f = fio_uint64_to_double(le64_to_cpu(top->gauss_dev.u.i)); 201 o->random_generator = le32_to_cpu(top->random_generator); 202 o->hugepage_size = le32_to_cpu(top->hugepage_size); 203 o->rw_min_bs = le32_to_cpu(top->rw_min_bs); 204 o->thinktime = le32_to_cpu(top->thinktime); 205 o->thinktime_spin = le32_to_cpu(top->thinktime_spin); 206 o->thinktime_blocks = le32_to_cpu(top->thinktime_blocks); 207 o->fsync_blocks = le32_to_cpu(top->fsync_blocks); 208 o->fdatasync_blocks = le32_to_cpu(top->fdatasync_blocks); 209 o->barrier_blocks = le32_to_cpu(top->barrier_blocks); 210 211 o->verify_backlog = le64_to_cpu(top->verify_backlog); 212 o->start_delay = le64_to_cpu(top->start_delay); 213 o->start_delay_high = le64_to_cpu(top->start_delay_high); 214 o->timeout = le64_to_cpu(top->timeout); 215 o->ramp_time = le64_to_cpu(top->ramp_time); 216 o->ss_dur = le64_to_cpu(top->ss_dur); 217 o->ss_ramp_time = le64_to_cpu(top->ss_ramp_time); 218 o->ss_state = le32_to_cpu(top->ss_state); 219 o->ss_limit.u.f = fio_uint64_to_double(le64_to_cpu(top->ss_limit.u.i)); 220 o->zone_range = le64_to_cpu(top->zone_range); 221 o->zone_size = le64_to_cpu(top->zone_size); 222 o->zone_skip = le64_to_cpu(top->zone_skip); 223 o->lockmem = le64_to_cpu(top->lockmem); 224 o->offset_increment = le64_to_cpu(top->offset_increment); 225 o->number_ios = le64_to_cpu(top->number_ios); 226 227 o->overwrite = le32_to_cpu(top->overwrite); 228 o->bw_avg_time = le32_to_cpu(top->bw_avg_time); 229 o->iops_avg_time = le32_to_cpu(top->iops_avg_time); 230 o->loops = le32_to_cpu(top->loops); 231 o->mem_type = le32_to_cpu(top->mem_type); 232 o->mem_align = le32_to_cpu(top->mem_align); 233 o->max_latency = le32_to_cpu(top->max_latency); 234 o->stonewall = le32_to_cpu(top->stonewall); 235 o->new_group = le32_to_cpu(top->new_group); 236 o->numjobs = le32_to_cpu(top->numjobs); 237 o->cpus_allowed_policy = le32_to_cpu(top->cpus_allowed_policy); 238 o->gpu_dev_id = le32_to_cpu(top->gpu_dev_id); 239 o->iolog = le32_to_cpu(top->iolog); 240 o->rwmixcycle = le32_to_cpu(top->rwmixcycle); 241 o->nice = le32_to_cpu(top->nice); 242 o->ioprio = le32_to_cpu(top->ioprio); 243 o->ioprio_class = le32_to_cpu(top->ioprio_class); 244 o->file_service_type = le32_to_cpu(top->file_service_type); 245 o->group_reporting = le32_to_cpu(top->group_reporting); 246 o->stats = le32_to_cpu(top->stats); 247 o->fadvise_hint = le32_to_cpu(top->fadvise_hint); 248 o->fallocate_mode = le32_to_cpu(top->fallocate_mode); 249 o->zero_buffers = le32_to_cpu(top->zero_buffers); 250 o->refill_buffers = le32_to_cpu(top->refill_buffers); 251 o->scramble_buffers = le32_to_cpu(top->scramble_buffers); 252 o->buffer_pattern_bytes = le32_to_cpu(top->buffer_pattern_bytes); 253 o->time_based = le32_to_cpu(top->time_based); 254 o->disable_lat = le32_to_cpu(top->disable_lat); 255 o->disable_clat = le32_to_cpu(top->disable_clat); 256 o->disable_slat = le32_to_cpu(top->disable_slat); 257 o->disable_bw = le32_to_cpu(top->disable_bw); 258 o->unified_rw_rep = le32_to_cpu(top->unified_rw_rep); 259 o->gtod_reduce = le32_to_cpu(top->gtod_reduce); 260 o->gtod_cpu = le32_to_cpu(top->gtod_cpu); 261 o->clocksource = le32_to_cpu(top->clocksource); 262 o->no_stall = le32_to_cpu(top->no_stall); 263 o->trim_percentage = le32_to_cpu(top->trim_percentage); 264 o->trim_batch = le32_to_cpu(top->trim_batch); 265 o->trim_zero = le32_to_cpu(top->trim_zero); 266 o->clat_percentiles = le32_to_cpu(top->clat_percentiles); 267 o->percentile_precision = le32_to_cpu(top->percentile_precision); 268 o->continue_on_error = le32_to_cpu(top->continue_on_error); 269 o->cgroup_weight = le32_to_cpu(top->cgroup_weight); 270 o->cgroup_nodelete = le32_to_cpu(top->cgroup_nodelete); 271 o->uid = le32_to_cpu(top->uid); 272 o->gid = le32_to_cpu(top->gid); 273 o->flow_id = __le32_to_cpu(top->flow_id); 274 o->flow = __le32_to_cpu(top->flow); 275 o->flow_watermark = __le32_to_cpu(top->flow_watermark); 276 o->flow_sleep = le32_to_cpu(top->flow_sleep); 277 o->sync_file_range = le32_to_cpu(top->sync_file_range); 278 o->latency_target = le64_to_cpu(top->latency_target); 279 o->latency_window = le64_to_cpu(top->latency_window); 280 o->latency_percentile.u.f = fio_uint64_to_double(le64_to_cpu(top->latency_percentile.u.i)); 281 o->compress_percentage = le32_to_cpu(top->compress_percentage); 282 o->compress_chunk = le32_to_cpu(top->compress_chunk); 283 o->dedupe_percentage = le32_to_cpu(top->dedupe_percentage); 284 o->skip_bad = le32_to_cpu(top->skip_bad); 285 o->block_error_hist = le32_to_cpu(top->block_error_hist); 286 o->replay_align = le32_to_cpu(top->replay_align); 287 o->replay_scale = le32_to_cpu(top->replay_scale); 288 o->per_job_logs = le32_to_cpu(top->per_job_logs); 289 o->write_bw_log = le32_to_cpu(top->write_bw_log); 290 o->write_lat_log = le32_to_cpu(top->write_lat_log); 291 o->write_iops_log = le32_to_cpu(top->write_iops_log); 292 o->write_hist_log = le32_to_cpu(top->write_hist_log); 293 294 o->trim_backlog = le64_to_cpu(top->trim_backlog); 295 o->rate_process = le32_to_cpu(top->rate_process); 296 297 for (i = 0; i < FIO_IO_U_LIST_MAX_LEN; i++) 298 o->percentile_list[i].u.f = fio_uint64_to_double(le64_to_cpu(top->percentile_list[i].u.i)); 299 #if 0 300 uint8_t cpumask[FIO_TOP_STR_MAX]; 301 uint8_t verify_cpumask[FIO_TOP_STR_MAX]; 302 uint8_t log_gz_cpumask[FIO_TOP_STR_MAX]; 303 #endif 304 } 305 306 void convert_thread_options_to_net(struct thread_options_pack *top, 307 struct thread_options *o) 308 { 309 int i, j; 310 311 for (i = 0; i < NR_OPTS_SZ; i++) 312 top->set_options[i] = cpu_to_le64(o->set_options[i]); 313 314 string_to_net(top->description, o->description); 315 string_to_net(top->name, o->name); 316 string_to_net(top->wait_for, o->wait_for); 317 string_to_net(top->directory, o->directory); 318 string_to_net(top->filename, o->filename); 319 string_to_net(top->filename_format, o->filename_format); 320 string_to_net(top->opendir, o->opendir); 321 string_to_net(top->ioengine, o->ioengine); 322 string_to_net(top->mmapfile, o->mmapfile); 323 string_to_net(top->read_iolog_file, o->read_iolog_file); 324 string_to_net(top->write_iolog_file, o->write_iolog_file); 325 string_to_net(top->bw_log_file, o->bw_log_file); 326 string_to_net(top->lat_log_file, o->lat_log_file); 327 string_to_net(top->iops_log_file, o->iops_log_file); 328 string_to_net(top->hist_log_file, o->hist_log_file); 329 string_to_net(top->replay_redirect, o->replay_redirect); 330 string_to_net(top->exec_prerun, o->exec_prerun); 331 string_to_net(top->exec_postrun, o->exec_postrun); 332 string_to_net(top->ioscheduler, o->ioscheduler); 333 string_to_net(top->profile, o->profile); 334 string_to_net(top->cgroup, o->cgroup); 335 336 top->allow_create = cpu_to_le32(o->allow_create); 337 top->allow_mounted_write = cpu_to_le32(o->allow_mounted_write); 338 top->td_ddir = cpu_to_le32(o->td_ddir); 339 top->rw_seq = cpu_to_le32(o->rw_seq); 340 top->kb_base = cpu_to_le32(o->kb_base); 341 top->unit_base = cpu_to_le32(o->unit_base); 342 top->ddir_seq_nr = cpu_to_le32(o->ddir_seq_nr); 343 top->iodepth = cpu_to_le32(o->iodepth); 344 top->iodepth_low = cpu_to_le32(o->iodepth_low); 345 top->iodepth_batch = cpu_to_le32(o->iodepth_batch); 346 top->iodepth_batch_complete_min = cpu_to_le32(o->iodepth_batch_complete_min); 347 top->iodepth_batch_complete_max = cpu_to_le32(o->iodepth_batch_complete_max); 348 top->size_percent = cpu_to_le32(o->size_percent); 349 top->fill_device = cpu_to_le32(o->fill_device); 350 top->file_append = cpu_to_le32(o->file_append); 351 top->ratecycle = cpu_to_le32(o->ratecycle); 352 top->io_submit_mode = cpu_to_le32(o->io_submit_mode); 353 top->nr_files = cpu_to_le32(o->nr_files); 354 top->unique_filename = cpu_to_le32(o->unique_filename); 355 top->open_files = cpu_to_le32(o->open_files); 356 top->file_lock_mode = cpu_to_le32(o->file_lock_mode); 357 top->odirect = cpu_to_le32(o->odirect); 358 top->oatomic = cpu_to_le32(o->oatomic); 359 top->invalidate_cache = cpu_to_le32(o->invalidate_cache); 360 top->create_serialize = cpu_to_le32(o->create_serialize); 361 top->create_fsync = cpu_to_le32(o->create_fsync); 362 top->create_on_open = cpu_to_le32(o->create_on_open); 363 top->create_only = cpu_to_le32(o->create_only); 364 top->end_fsync = cpu_to_le32(o->end_fsync); 365 top->pre_read = cpu_to_le32(o->pre_read); 366 top->sync_io = cpu_to_le32(o->sync_io); 367 top->verify = cpu_to_le32(o->verify); 368 top->do_verify = cpu_to_le32(o->do_verify); 369 top->verifysort = cpu_to_le32(o->verifysort); 370 top->verifysort_nr = cpu_to_le32(o->verifysort_nr); 371 top->experimental_verify = cpu_to_le32(o->experimental_verify); 372 top->verify_state = cpu_to_le32(o->verify_state); 373 top->verify_interval = cpu_to_le32(o->verify_interval); 374 top->verify_offset = cpu_to_le32(o->verify_offset); 375 top->verify_pattern_bytes = cpu_to_le32(o->verify_pattern_bytes); 376 top->verify_fatal = cpu_to_le32(o->verify_fatal); 377 top->verify_dump = cpu_to_le32(o->verify_dump); 378 top->verify_async = cpu_to_le32(o->verify_async); 379 top->verify_batch = cpu_to_le32(o->verify_batch); 380 top->use_thread = cpu_to_le32(o->use_thread); 381 top->unlink = cpu_to_le32(o->unlink); 382 top->unlink_each_loop = cpu_to_le32(o->unlink_each_loop); 383 top->do_disk_util = cpu_to_le32(o->do_disk_util); 384 top->override_sync = cpu_to_le32(o->override_sync); 385 top->rand_repeatable = cpu_to_le32(o->rand_repeatable); 386 top->allrand_repeatable = cpu_to_le32(o->allrand_repeatable); 387 top->rand_seed = __cpu_to_le64(o->rand_seed); 388 top->log_avg_msec = cpu_to_le32(o->log_avg_msec); 389 top->log_max = cpu_to_le32(o->log_max); 390 top->log_offset = cpu_to_le32(o->log_offset); 391 top->log_gz = cpu_to_le32(o->log_gz); 392 top->log_gz_store = cpu_to_le32(o->log_gz_store); 393 top->log_unix_epoch = cpu_to_le32(o->log_unix_epoch); 394 top->norandommap = cpu_to_le32(o->norandommap); 395 top->softrandommap = cpu_to_le32(o->softrandommap); 396 top->bs_unaligned = cpu_to_le32(o->bs_unaligned); 397 top->fsync_on_close = cpu_to_le32(o->fsync_on_close); 398 top->bs_is_seq_rand = cpu_to_le32(o->bs_is_seq_rand); 399 top->random_distribution = cpu_to_le32(o->random_distribution); 400 top->exitall_error = cpu_to_le32(o->exitall_error); 401 top->zipf_theta.u.i = __cpu_to_le64(fio_double_to_uint64(o->zipf_theta.u.f)); 402 top->pareto_h.u.i = __cpu_to_le64(fio_double_to_uint64(o->pareto_h.u.f)); 403 top->gauss_dev.u.i = __cpu_to_le64(fio_double_to_uint64(o->gauss_dev.u.f)); 404 top->random_generator = cpu_to_le32(o->random_generator); 405 top->hugepage_size = cpu_to_le32(o->hugepage_size); 406 top->rw_min_bs = cpu_to_le32(o->rw_min_bs); 407 top->thinktime = cpu_to_le32(o->thinktime); 408 top->thinktime_spin = cpu_to_le32(o->thinktime_spin); 409 top->thinktime_blocks = cpu_to_le32(o->thinktime_blocks); 410 top->fsync_blocks = cpu_to_le32(o->fsync_blocks); 411 top->fdatasync_blocks = cpu_to_le32(o->fdatasync_blocks); 412 top->barrier_blocks = cpu_to_le32(o->barrier_blocks); 413 top->overwrite = cpu_to_le32(o->overwrite); 414 top->bw_avg_time = cpu_to_le32(o->bw_avg_time); 415 top->iops_avg_time = cpu_to_le32(o->iops_avg_time); 416 top->loops = cpu_to_le32(o->loops); 417 top->mem_type = cpu_to_le32(o->mem_type); 418 top->mem_align = cpu_to_le32(o->mem_align); 419 top->max_latency = cpu_to_le32(o->max_latency); 420 top->stonewall = cpu_to_le32(o->stonewall); 421 top->new_group = cpu_to_le32(o->new_group); 422 top->numjobs = cpu_to_le32(o->numjobs); 423 top->cpus_allowed_policy = cpu_to_le32(o->cpus_allowed_policy); 424 top->gpu_dev_id = cpu_to_le32(o->gpu_dev_id); 425 top->iolog = cpu_to_le32(o->iolog); 426 top->rwmixcycle = cpu_to_le32(o->rwmixcycle); 427 top->nice = cpu_to_le32(o->nice); 428 top->ioprio = cpu_to_le32(o->ioprio); 429 top->ioprio_class = cpu_to_le32(o->ioprio_class); 430 top->file_service_type = cpu_to_le32(o->file_service_type); 431 top->group_reporting = cpu_to_le32(o->group_reporting); 432 top->stats = cpu_to_le32(o->stats); 433 top->fadvise_hint = cpu_to_le32(o->fadvise_hint); 434 top->fallocate_mode = cpu_to_le32(o->fallocate_mode); 435 top->zero_buffers = cpu_to_le32(o->zero_buffers); 436 top->refill_buffers = cpu_to_le32(o->refill_buffers); 437 top->scramble_buffers = cpu_to_le32(o->scramble_buffers); 438 top->buffer_pattern_bytes = cpu_to_le32(o->buffer_pattern_bytes); 439 top->time_based = cpu_to_le32(o->time_based); 440 top->disable_lat = cpu_to_le32(o->disable_lat); 441 top->disable_clat = cpu_to_le32(o->disable_clat); 442 top->disable_slat = cpu_to_le32(o->disable_slat); 443 top->disable_bw = cpu_to_le32(o->disable_bw); 444 top->unified_rw_rep = cpu_to_le32(o->unified_rw_rep); 445 top->gtod_reduce = cpu_to_le32(o->gtod_reduce); 446 top->gtod_cpu = cpu_to_le32(o->gtod_cpu); 447 top->clocksource = cpu_to_le32(o->clocksource); 448 top->no_stall = cpu_to_le32(o->no_stall); 449 top->trim_percentage = cpu_to_le32(o->trim_percentage); 450 top->trim_batch = cpu_to_le32(o->trim_batch); 451 top->trim_zero = cpu_to_le32(o->trim_zero); 452 top->clat_percentiles = cpu_to_le32(o->clat_percentiles); 453 top->percentile_precision = cpu_to_le32(o->percentile_precision); 454 top->continue_on_error = cpu_to_le32(o->continue_on_error); 455 top->cgroup_weight = cpu_to_le32(o->cgroup_weight); 456 top->cgroup_nodelete = cpu_to_le32(o->cgroup_nodelete); 457 top->uid = cpu_to_le32(o->uid); 458 top->gid = cpu_to_le32(o->gid); 459 top->flow_id = __cpu_to_le32(o->flow_id); 460 top->flow = __cpu_to_le32(o->flow); 461 top->flow_watermark = __cpu_to_le32(o->flow_watermark); 462 top->flow_sleep = cpu_to_le32(o->flow_sleep); 463 top->sync_file_range = cpu_to_le32(o->sync_file_range); 464 top->latency_target = __cpu_to_le64(o->latency_target); 465 top->latency_window = __cpu_to_le64(o->latency_window); 466 top->latency_percentile.u.i = __cpu_to_le64(fio_double_to_uint64(o->latency_percentile.u.f)); 467 top->compress_percentage = cpu_to_le32(o->compress_percentage); 468 top->compress_chunk = cpu_to_le32(o->compress_chunk); 469 top->dedupe_percentage = cpu_to_le32(o->dedupe_percentage); 470 top->block_error_hist = cpu_to_le32(o->block_error_hist); 471 top->skip_bad = cpu_to_le32(o->skip_bad); 472 top->replay_align = cpu_to_le32(o->replay_align); 473 top->replay_scale = cpu_to_le32(o->replay_scale); 474 top->per_job_logs = cpu_to_le32(o->per_job_logs); 475 top->write_bw_log = cpu_to_le32(o->write_bw_log); 476 top->write_lat_log = cpu_to_le32(o->write_lat_log); 477 top->write_iops_log = cpu_to_le32(o->write_iops_log); 478 top->write_hist_log = cpu_to_le32(o->write_hist_log); 479 480 for (i = 0; i < DDIR_RWDIR_CNT; i++) { 481 top->bs[i] = cpu_to_le32(o->bs[i]); 482 top->ba[i] = cpu_to_le32(o->ba[i]); 483 top->min_bs[i] = cpu_to_le32(o->min_bs[i]); 484 top->max_bs[i] = cpu_to_le32(o->max_bs[i]); 485 top->bssplit_nr[i] = cpu_to_le32(o->bssplit_nr[i]); 486 487 if (o->bssplit_nr[i]) { 488 unsigned int bssplit_nr = o->bssplit_nr[i]; 489 490 if (bssplit_nr > BSSPLIT_MAX) { 491 log_err("fio: BSSPLIT_MAX is too small\n"); 492 bssplit_nr = BSSPLIT_MAX; 493 } 494 for (j = 0; j < bssplit_nr; j++) { 495 top->bssplit[i][j].bs = cpu_to_le32(o->bssplit[i][j].bs); 496 top->bssplit[i][j].perc = cpu_to_le32(o->bssplit[i][j].perc); 497 } 498 } 499 500 top->zone_split_nr[i] = cpu_to_le32(o->zone_split_nr[i]); 501 502 if (o->zone_split_nr[i]) { 503 unsigned int zone_split_nr = o->zone_split_nr[i]; 504 505 if (zone_split_nr > ZONESPLIT_MAX) { 506 log_err("fio: ZONESPLIT_MAX is too small\n"); 507 zone_split_nr = ZONESPLIT_MAX; 508 } 509 for (j = 0; j < zone_split_nr; j++) { 510 top->zone_split[i][j].access_perc = o->zone_split[i][j].access_perc; 511 top->zone_split[i][j].size_perc = o->zone_split[i][j].size_perc; 512 } 513 } 514 515 top->rwmix[i] = cpu_to_le32(o->rwmix[i]); 516 top->rate[i] = cpu_to_le64(o->rate[i]); 517 top->ratemin[i] = cpu_to_le64(o->ratemin[i]); 518 top->rate_iops[i] = cpu_to_le32(o->rate_iops[i]); 519 top->rate_iops_min[i] = cpu_to_le32(o->rate_iops_min[i]); 520 521 top->perc_rand[i] = cpu_to_le32(o->perc_rand[i]); 522 } 523 524 memcpy(top->verify_pattern, o->verify_pattern, MAX_PATTERN_SIZE); 525 memcpy(top->buffer_pattern, o->buffer_pattern, MAX_PATTERN_SIZE); 526 527 top->size = __cpu_to_le64(o->size); 528 top->io_size = __cpu_to_le64(o->io_size); 529 top->verify_backlog = __cpu_to_le64(o->verify_backlog); 530 top->start_delay = __cpu_to_le64(o->start_delay); 531 top->start_delay_high = __cpu_to_le64(o->start_delay_high); 532 top->timeout = __cpu_to_le64(o->timeout); 533 top->ramp_time = __cpu_to_le64(o->ramp_time); 534 top->ss_dur = __cpu_to_le64(top->ss_dur); 535 top->ss_ramp_time = __cpu_to_le64(top->ss_ramp_time); 536 top->ss_state = cpu_to_le32(top->ss_state); 537 top->ss_limit.u.i = __cpu_to_le64(fio_double_to_uint64(o->ss_limit.u.f)); 538 top->zone_range = __cpu_to_le64(o->zone_range); 539 top->zone_size = __cpu_to_le64(o->zone_size); 540 top->zone_skip = __cpu_to_le64(o->zone_skip); 541 top->lockmem = __cpu_to_le64(o->lockmem); 542 top->ddir_seq_add = __cpu_to_le64(o->ddir_seq_add); 543 top->file_size_low = __cpu_to_le64(o->file_size_low); 544 top->file_size_high = __cpu_to_le64(o->file_size_high); 545 top->start_offset = __cpu_to_le64(o->start_offset); 546 top->trim_backlog = __cpu_to_le64(o->trim_backlog); 547 top->offset_increment = __cpu_to_le64(o->offset_increment); 548 top->number_ios = __cpu_to_le64(o->number_ios); 549 top->rate_process = cpu_to_le32(o->rate_process); 550 551 for (i = 0; i < FIO_IO_U_LIST_MAX_LEN; i++) 552 top->percentile_list[i].u.i = __cpu_to_le64(fio_double_to_uint64(o->percentile_list[i].u.f)); 553 #if 0 554 uint8_t cpumask[FIO_TOP_STR_MAX]; 555 uint8_t verify_cpumask[FIO_TOP_STR_MAX]; 556 uint8_t log_gz_cpumask[FIO_TOP_STR_MAX]; 557 #endif 558 559 } 560 561 /* 562 * Basic conversion test. We'd really need to fill in more of the options 563 * to have a thorough test. Even better, we should auto-generate the 564 * converter functions... 565 */ 566 int fio_test_cconv(struct thread_options *__o) 567 { 568 struct thread_options o; 569 struct thread_options_pack top1, top2; 570 571 memset(&top1, 0, sizeof(top1)); 572 memset(&top2, 0, sizeof(top2)); 573 574 convert_thread_options_to_net(&top1, __o); 575 memset(&o, 0, sizeof(o)); 576 convert_thread_options_to_cpu(&o, &top1); 577 convert_thread_options_to_net(&top2, &o); 578 579 free_thread_options_to_cpu(&o); 580 581 return memcmp(&top1, &top2, sizeof(top1)); 582 } 583