X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=filesetup.c;h=8636e16661b3bad68a70e28a6805e227c5e9e543;hp=ac69c65ea8f44956debb01bca32bef41c2675fb2;hb=a5a4fdfd44ec1b55ebab7800a931c148540a7324;hpb=8e600258bad065fbdfd6a1b2856077d12cd521e5 diff --git a/filesetup.c b/filesetup.c index ac69c65e..8636e166 100644 --- a/filesetup.c +++ b/filesetup.c @@ -12,6 +12,7 @@ #include "smalloc.h" #include "filehash.h" #include "os/os.h" +#include "hash.h" #ifdef FIO_HAVE_LINUX_FALLOCATE #include @@ -864,17 +865,18 @@ int pre_read_files(struct thread_data *td) static int __init_rand_distribution(struct thread_data *td, struct fio_file *f) { - unsigned int range_size; + unsigned int range_size, seed; unsigned long nranges; range_size = min(td->o.min_bs[DDIR_READ], td->o.min_bs[DDIR_WRITE]); nranges = (f->real_file_size + range_size - 1) / range_size; + seed = jhash(f->file_name, strlen(f->file_name), 0) * td->thread_number; if (td->o.random_distribution == FIO_RAND_DIST_ZIPF) - zipf_init(&f->zipf, nranges, td->o.zipf_theta); + zipf_init(&f->zipf, nranges, td->o.zipf_theta, seed); else - pareto_init(&f->zipf, nranges, td->o.pareto_h); + pareto_init(&f->zipf, nranges, td->o.pareto_h, seed); return 1; }