X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=init.c;h=3117d60e5d68e530fde45fed328b7b6bb4e39108;hp=1fc694d373a7ce60d5e74431ecc282cfb7e93b69;hb=2c0ecd28459b6a1b236c865defb5ef76ce8bfa02;hpb=e9c047a0d8dfc32634b896e1600c6f1aa4174378 diff --git a/init.c b/init.c index 1fc694d3..3117d60e 100644 --- a/init.c +++ b/init.c @@ -65,51 +65,12 @@ static struct thread_data *get_new_job(int global, struct thread_data *parent) return NULL; td = &threads[thread_number++]; - if (parent) - *td = *parent; - else - memset(td, 0, sizeof(*td)); + *td = *parent; + td->name[0] = '\0'; td->fd = -1; td->thread_number = thread_number; - td->ddir = parent->ddir; - td->ioprio = parent->ioprio; - td->sequential = parent->sequential; - td->bs = parent->bs; - td->min_bs = parent->min_bs; - td->max_bs = parent->max_bs; - td->odirect = parent->odirect; - td->thinktime = parent->thinktime; - td->fsync_blocks = parent->fsync_blocks; - td->start_delay = parent->start_delay; - td->timeout = parent->timeout; - td->io_engine = parent->io_engine; - td->create_file = parent->create_file; - td->overwrite = parent->overwrite; - td->invalidate_cache = parent->invalidate_cache; - td->file_size = parent->file_size; - td->file_offset = parent->file_offset; - td->zone_size = parent->zone_size; - td->zone_skip = parent->zone_skip; - td->rate = parent->rate; - td->ratemin = parent->ratemin; - td->ratecycle = parent->ratecycle; - td->iodepth = parent->iodepth; - td->sync_io = parent->sync_io; - td->mem_type = parent->mem_type; - td->bw_avg_time = parent->bw_avg_time; - td->create_serialize = parent->create_serialize; - td->create_fsync = parent->create_fsync; - td->loops = parent->loops; - td->verify = parent->verify; - td->stonewall = parent->stonewall; - td->numjobs = parent->numjobs; - td->use_thread = parent->use_thread; - td->do_disk_util = parent->do_disk_util; - memcpy(&td->cpumask, &parent->cpumask, sizeof(td->cpumask)); - strcpy(td->io_engine_name, parent->io_engine_name); - return td; } @@ -871,16 +832,22 @@ int parse_jobs_ini(char *file) continue; } if (!check_strstore(p, "iolog", tmpbuf)) { + if (td->write_iolog) { + fprintf(stderr, "fio: read iolog overrides given write_iolog\n"); + free(td->iolog_file); + td->write_iolog = 0; + } td->iolog_file = strdup(tmpbuf); td->read_iolog = 1; - td->write_iolog = 0; fgetpos(f, &off); continue; } - if (!td->read_iolog && - !check_strstore(p, "write_iolog", tmpbuf)) { - td->iolog_file = strdup(tmpbuf); - td->write_iolog = 1; + if (!check_strstore(p, "write_iolog", tmpbuf)) { + if (!td->read_iolog) { + td->iolog_file = strdup(tmpbuf); + td->write_iolog = 1; + } else + fprintf(stderr, "fio: read iolog overrides given write_iolog\n"); fgetpos(f, &off); continue; } @@ -1046,7 +1013,7 @@ static void free_shm(void) struct shmid_ds sbuf; if (threads) { - shmdt(threads); + shmdt((void *) threads); threads = NULL; shmctl(shm_id, IPC_RMID, &sbuf); }