Use specified compression/pattern for verify buffers too
authorJens Axboe <axboe@fb.com>
Thu, 4 Dec 2014 22:40:32 +0000 (15:40 -0700)
committerJens Axboe <axboe@fb.com>
Thu, 4 Dec 2014 22:40:32 +0000 (15:40 -0700)
Signed-off-by: Jens Axboe <axboe@fb.com>
lib/rand.c
lib/rand.h
verify.c

index e5332bfe792492651e7685c4cd35595ca981ddf0..618a2f06349dbc90389971b8720c9ea067024e28 100644 (file)
@@ -117,12 +117,11 @@ void fill_pattern(void *p, unsigned int len, char *pattern,
        }
 }
 
-unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf,
-                                        unsigned int percentage,
-                                        unsigned int segment, unsigned int len,
-                                        char *pattern, unsigned int pbytes)
+void __fill_random_buf_percentage(unsigned long seed, void *buf,
+                                 unsigned int percentage,
+                                 unsigned int segment, unsigned int len,
+                                 char *pattern, unsigned int pbytes)
 {
-       unsigned long r = __rand(fs);
        unsigned int this_len;
 
        if (percentage == 100) {
@@ -130,15 +129,12 @@ unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf,
                        fill_pattern(buf, len, pattern, pbytes);
                else
                        memset(buf, 0, len);
-               return 0;
+               return;
        }
 
        if (segment > len)
                segment = len;
 
-       if (sizeof(int) != sizeof(long *))
-               r *= (unsigned long) __rand(fs);
-
        while (len) {
                /*
                 * Fill random chunk
@@ -147,7 +143,7 @@ unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf,
                if (this_len > len)
                        this_len = len;
 
-               __fill_random_buf(buf, this_len, r);
+               __fill_random_buf(buf, this_len, seed);
 
                len -= this_len;
                buf += this_len;
@@ -159,9 +155,23 @@ unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf,
                        fill_pattern(buf, this_len, pattern, pbytes);
                else
                        memset(buf, 0, this_len);
+
                len -= this_len;
                buf += this_len;
        }
+}
+
+unsigned long fill_random_buf_percentage(struct frand_state *fs, void *buf,
+                                        unsigned int percentage,
+                                        unsigned int segment, unsigned int len,
+                                        char *pattern, unsigned int pbytes)
+{
+       unsigned long r = __rand(fs);
+
+       if (sizeof(int) != sizeof(long *))
+               r *= (unsigned long) __rand(fs);
 
+       __fill_random_buf_percentage(r, buf, percentage, segment, len,
+                                       pattern, pbytes);
        return r;
 }
index 803bea484757aa8ef30bf5f63a1f24c43192c7ae..089837dbf0267c326dc4b355782558c24080abf1 100644 (file)
@@ -30,6 +30,7 @@ extern void init_rand(struct frand_state *);
 extern void init_rand_seed(struct frand_state *, unsigned int seed);
 extern void __fill_random_buf(void *buf, unsigned int len, unsigned long seed);
 extern unsigned long fill_random_buf(struct frand_state *, void *buf, unsigned int len);
+extern void __fill_random_buf_percentage(unsigned long, void *, unsigned int, unsigned int, unsigned int, char *, unsigned int);
 extern unsigned long fill_random_buf_percentage(struct frand_state *, void *, unsigned int, unsigned int, unsigned int, char *, unsigned int);
 extern void fill_pattern(void *p, unsigned int len, char *pattern, unsigned int pattern_bytes);
 
index c1791fc69743c08d40fbdaebdda122545b93037c..6a3f028f765be90ee22fd4028440ec0fa351fd7f 100644 (file)
--- a/verify.c
+++ b/verify.c
@@ -37,24 +37,28 @@ void fill_buffer_pattern(struct thread_data *td, void *p, unsigned int len)
 void fill_verify_pattern(struct thread_data *td, void *p, unsigned int len,
                         struct io_u *io_u, unsigned long seed, int use_seed)
 {
-       if (!td->o.verify_pattern_bytes) {
+       struct thread_options *o = &td->o;
+
+       if (!o->verify_pattern_bytes) {
                dprint(FD_VERIFY, "fill random bytes len=%u\n", len);
 
                if (use_seed)
-                       __fill_random_buf(p, len, seed);
-               else
-                       io_u->rand_seed = fill_random_buf(&td->verify_state, p, len);
+                       __fill_random_buf_percentage(seed, p, o->compress_percentage, len, len, o->buffer_pattern, o->buffer_pattern_bytes);
+               else {
+                       struct frand_state *fs = &td->verify_state;
+
+                       io_u->rand_seed = fill_random_buf_percentage(fs, p, o->compress_percentage, len, len, o->buffer_pattern, o->buffer_pattern_bytes);
+               }
                return;
        }
 
        if (io_u->buf_filled_len >= len) {
                dprint(FD_VERIFY, "using already filled verify pattern b=%d len=%u\n",
-                       td->o.verify_pattern_bytes, len);
+                       o->verify_pattern_bytes, len);
                return;
        }
 
-       fill_pattern(p, len, td->o.verify_pattern, td->o.verify_pattern_bytes);
-
+       fill_pattern(p, len, o->verify_pattern, o->verify_pattern_bytes);
        io_u->buf_filled_len = len;
 }