From: Matthias Rosenfelder Date: Thu, 6 Jul 2017 04:56:36 +0000 (-0400) Subject: TLS: Fix length check in do_tls_getsockopt_tx() X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=5a3b886c3cc5de1b9ec618bf27e1b31c6624f3ca;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git TLS: Fix length check in do_tls_getsockopt_tx() copy_to_user() copies the struct the pointer is pointing to, but the length check compares against sizeof(pointer) and not sizeof(struct). On 32-bit the size is probably the same, so it might have worked accidentally. Signed-off-by: Matthias Rosenfelder Signed-off-by: David S. Miller --- diff --git a/net/tls/tls_main.c b/net/tls/tls_main.c index a03130a47b85..60aff60e30ad 100644 --- a/net/tls/tls_main.c +++ b/net/tls/tls_main.c @@ -272,7 +272,7 @@ static int do_tls_getsockopt_tx(struct sock *sk, char __user *optval, goto out; } - if (len == sizeof(crypto_info)) { + if (len == sizeof(*crypto_info)) { if (copy_to_user(optval, crypto_info, sizeof(*crypto_info))) rc = -EFAULT; goto out;