smc: simplify abort logic
authorStefan Raspl <stefan.raspl@linux.ibm.com>
Thu, 3 May 2018 16:12:36 +0000 (18:12 +0200)
committerDavid S. Miller <davem@davemloft.net>
Fri, 4 May 2018 15:45:06 +0000 (11:45 -0400)
Some of the conditions to exit recv() are common in two pathes - cleaning up
code by moving the check up so we have it only once.

Signed-off-by: Stefan Raspl <raspl@linux.ibm.com>
Signed-off-by: Ursula Braun <ubraun@linux.ibm.com><
Signed-off-by: David S. Miller <davem@davemloft.net>
net/smc/smc_rx.c

index af851d8..def33fb 100644 (file)
@@ -112,26 +112,22 @@ int smc_rx_recvmsg(struct smc_sock *smc, struct msghdr *msg, size_t len,
                if (atomic_read(&conn->bytes_to_rcv))
                        goto copy;
 
+               if (sk->sk_shutdown & RCV_SHUTDOWN ||
+                   smc_cdc_rxed_any_close_or_senddone(conn) ||
+                   conn->local_tx_ctrl.conn_state_flags.peer_conn_abort)
+                       break;
+
                if (read_done) {
                        if (sk->sk_err ||
                            sk->sk_state == SMC_CLOSED ||
-                           sk->sk_shutdown & RCV_SHUTDOWN ||
                            !timeo ||
-                           signal_pending(current) ||
-                           smc_cdc_rxed_any_close_or_senddone(conn) ||
-                           conn->local_tx_ctrl.conn_state_flags.
-                           peer_conn_abort)
+                           signal_pending(current))
                                break;
                } else {
                        if (sk->sk_err) {
                                read_done = sock_error(sk);
                                break;
                        }
-                       if (sk->sk_shutdown & RCV_SHUTDOWN ||
-                           smc_cdc_rxed_any_close_or_senddone(conn) ||
-                           conn->local_tx_ctrl.conn_state_flags.
-                           peer_conn_abort)
-                               break;
                        if (sk->sk_state == SMC_CLOSED) {
                                if (!sock_flag(sk, SOCK_DONE)) {
                                        /* This occurs when user tries to read