From: Jens Axboe Date: Fri, 2 Mar 2012 21:23:36 +0000 (+0100) Subject: Compression fixes X-Git-Tag: fio-2.0.6~29 X-Git-Url: https://git.kernel.dk/?p=fio.git;a=commitdiff_plain;h=811ac503a6196f13da22565eb165c278988da4da Compression fixes - memset() remainder of buffer instead of copying random segment. Provides more reliable compression (yes yes, you told me so). - Allow 100 as well, just means full memset. Make that just set zero_buffers=1 instead, since we only need to do it once instead of for every write. Signed-off-by: Jens Axboe Signed-off-by: Jens Axboe --- diff --git a/init.c b/init.c index 710e8673..6c74ea6b 100644 --- a/init.c +++ b/init.c @@ -568,6 +568,15 @@ static int fixup_options(struct thread_data *td) } #endif + /* + * For fully compressible data, just zero them at init time. + * It's faster than repeatedly filling it. + */ + if (td->o.compress_percentage == 100) { + td->o.zero_buffers = 1; + td->o.compress_percentage = 0; + } + return ret; } diff --git a/lib/rand.c b/lib/rand.c index 66d04729..995035fe 100644 --- a/lib/rand.c +++ b/lib/rand.c @@ -34,7 +34,6 @@ */ #include -#include #include "rand.h" #include "../hash.h" @@ -95,10 +94,16 @@ unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf, unsigned int percentage, unsigned int segment, unsigned int len) { - unsigned int this_len, rep_len; unsigned long r = __rand(fs); + unsigned int this_len; - assert(segment <= len); + if (percentage == 100) { + memset(buf, 0, len); + return 0; + } + + if (segment > len) + segment = len; if (sizeof(int) != sizeof(long *)) r *= (unsigned long) __rand(fs); @@ -116,16 +121,10 @@ unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf, len -= this_len; buf += this_len; - /* - * Now duplicate random chunk in rest of buf - */ - rep_len = segment - this_len; - if (rep_len > len) - rep_len = len; + if (this_len > len) + this_len = len; - memcpy(buf, buf + rep_len, rep_len); - buf += rep_len; - len -= rep_len; + memset(buf, 0, this_len); } return r;