net/sunrpc: Fix return value for sysctl sunrpc.transports
authorArtur Molchanov <arturmolchanov@gmail.com>
Sun, 11 Oct 2020 22:00:45 +0000 (01:00 +0300)
committerJ. Bruce Fields <bfields@redhat.com>
Fri, 16 Oct 2020 19:15:04 +0000 (15:15 -0400)
Fix returning value for sysctl sunrpc.transports.
Return error code from sysctl proc_handler function proc_do_xprt instead of number of the written bytes.
Otherwise sysctl returns random garbage for this key.

Since v1:
- Handle negative returned value from memory_read_from_buffer as an error

Signed-off-by: Artur Molchanov <arturmolchanov@gmail.com>
Cc: stable@vger.kernel.org
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
net/sunrpc/sysctl.c

index 999eee1..e81a28f 100644 (file)
@@ -70,7 +70,13 @@ static int proc_do_xprt(struct ctl_table *table, int write,
                return 0;
        }
        len = svc_print_xprts(tmpbuf, sizeof(tmpbuf));
-       return memory_read_from_buffer(buffer, *lenp, ppos, tmpbuf, len);
+       *lenp = memory_read_from_buffer(buffer, *lenp, ppos, tmpbuf, len);
+
+       if (*lenp < 0) {
+               *lenp = 0;
+               return -EINVAL;
+       }
+       return 0;
 }
 
 static int