while (!iscsi_tcp_segment_done(tcp_conn, segment, 0, r)) {
                struct scatterlist *sg;
+               struct msghdr msg = {};
+               struct bio_vec bv;
                unsigned int offset, copy;
-               int flags = 0;
 
                r = 0;
                offset = segment->copied;
                copy = segment->size - offset;
 
                if (segment->total_copied + segment->size < segment->total_size)
-                       flags |= MSG_MORE | MSG_SENDPAGE_NOTLAST;
+                       msg.msg_flags |= MSG_MORE;
 
                if (tcp_sw_conn->queue_recv)
-                       flags |= MSG_DONTWAIT;
+                       msg.msg_flags |= MSG_DONTWAIT;
 
-               /* Use sendpage if we can; else fall back to sendmsg */
                if (!segment->data) {
+                       if (!tcp_conn->iscsi_conn->datadgst_en)
+                               msg.msg_flags |= MSG_SPLICE_PAGES;
                        sg = segment->sg;
                        offset += segment->sg_offset + sg->offset;
-                       r = tcp_sw_conn->sendpage(sk, sg_page(sg), offset,
-                                                 copy, flags);
+                       bvec_set_page(&bv, sg_page(sg), copy, offset);
                } else {
-                       struct msghdr msg = { .msg_flags = flags };
-                       struct kvec iov = {
-                               .iov_base = segment->data + offset,
-                               .iov_len = copy
-                       };
-
-                       r = kernel_sendmsg(sk, &msg, &iov, 1, copy);
+                       bvec_set_virt(&bv, segment->data + offset, copy);
                }
+               iov_iter_bvec(&msg.msg_iter, ITER_SOURCE, &bv, 1, copy);
 
+               r = sock_sendmsg(sk, &msg);
                if (r < 0) {
                        iscsi_tcp_segment_unmap(segment);
                        return r;
        sock_no_linger(sk);
 
        iscsi_sw_tcp_conn_set_callbacks(conn);
-       tcp_sw_conn->sendpage = tcp_sw_conn->sock->ops->sendpage;
        /*
         * set receive state machine into initial state
         */
                        return -ENOTCONN;
                }
                iscsi_set_param(cls_conn, param, buf, buflen);
-               tcp_sw_conn->sendpage = conn->datadgst_en ?
-                       sock_no_sendpage : tcp_sw_conn->sock->ops->sendpage;
                mutex_unlock(&tcp_sw_conn->sock_lock);
                break;
        case ISCSI_PARAM_MAX_R2T: