The copy_to_user() function returns the number of bytes remaining to be
copied, but the intention here was to return -EFAULT if the copy fails.
Fixes: cafe56359144 ("bcache: A block layer cache")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Coly Li <colyli@suse.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
        while (size) {
                struct keybuf_key *w;
                unsigned int bytes = min(i->bytes, size);
-               int err = copy_to_user(buf, i->buf, bytes);
 
-               if (err)
-                       return err;
+               if (copy_to_user(buf, i->buf, bytes))
+                       return -EFAULT;
 
                ret      += bytes;
                buf      += bytes;