OSDN Git Service

bcache: Fix an error code in bch_dump_read()
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 3 Sep 2019 13:25:44 +0000 (21:25 +0800)
committerJens Axboe <axboe@kernel.dk>
Tue, 3 Sep 2019 14:08:29 +0000 (08:08 -0600)
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>
drivers/md/bcache/debug.c

index 8b123be..336f439 100644 (file)
@@ -178,10 +178,9 @@ static ssize_t bch_dump_read(struct file *file, char __user *buf,
        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;