can: isotp: isotp_sendmsg(): fix return error fix on TX path
authorOliver Hartkopp <socketcan@hartkopp.net>
Wed, 7 Jun 2023 07:27:08 +0000 (09:27 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 1 Jul 2023 11:16:23 +0000 (13:16 +0200)
commit e38910c0072b541a91954682c8b074a93e57c09b upstream.

With commit d674a8f123b4 ("can: isotp: isotp_sendmsg(): fix return
error on FC timeout on TX path") the missing correct return value in
the case of a protocol error was introduced.

But the way the error value has been read and sent to the user space
does not follow the common scheme to clear the error after reading
which is provided by the sock_error() function. This leads to an error
report at the following write() attempt although everything should be
working.

Fixes: d674a8f123b4 ("can: isotp: isotp_sendmsg(): fix return error on FC timeout on TX path")
Reported-by: Carsten Schmidt <carsten.schmidt-achim@t-online.de>
Signed-off-by: Oliver Hartkopp <socketcan@hartkopp.net>
Link: https://lore.kernel.org/all/20230607072708.38809-1-socketcan@hartkopp.net
Cc: stable@vger.kernel.org
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/can/isotp.c

index 1af623839bffab6e3f0e29260580f49b04e5ccc6..b3c2a49b189cc57c2feb6a709127278209f517c1 100644 (file)
@@ -1079,8 +1079,9 @@ wait_free_buffer:
                if (err)
                        goto err_event_drop;
 
-               if (sk->sk_err)
-                       return -sk->sk_err;
+               err = sock_error(sk);
+               if (err)
+                       return err;
        }
 
        return size;