]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net/af_iucv: build SG skbs for TRANS_HIPER sockets
authorJulian Wiedmann <jwi@linux.ibm.com>
Thu, 28 Jan 2021 11:41:08 +0000 (12:41 +0100)
committerJakub Kicinski <kuba@kernel.org>
Fri, 29 Jan 2021 04:36:22 +0000 (20:36 -0800)
The TX path no longer falls apart when some of its SG skbs are later
linearized by lower layers of the stack. So enable the use of SG skbs
in iucv_sock_sendmsg() again.

This effectively reverts
commit dc5367bcc556 ("net/af_iucv: don't use paged skbs for TX on HiperSockets").

Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com>
Acked-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/iucv/af_iucv.c

index 0e0656db4ae71320df76562eab57748e744bad9b..6092d5cb71687ee7aae99d26914bca18b191a96a 100644 (file)
@@ -256,7 +256,9 @@ static int afiucv_hs_send(struct iucv_message *imsg, struct sock *sock,
                        err = -EMSGSIZE;
                        goto err_free;
                }
-               skb_trim(skb, skb->dev->mtu);
+               err = pskb_trim(skb, skb->dev->mtu);
+               if (err)
+                       goto err_free;
        }
        skb->protocol = cpu_to_be16(ETH_P_AF_IUCV);
 
@@ -996,7 +998,7 @@ static int iucv_sock_sendmsg(struct socket *sock, struct msghdr *msg,
        if (iucv->transport == AF_IUCV_TRANS_HIPER) {
                headroom = sizeof(struct af_iucv_trans_hdr) +
                           LL_RESERVED_SPACE(iucv->hs_dev);
-               linear = len;
+               linear = min(len, PAGE_SIZE - headroom);
        } else {
                if (len < PAGE_SIZE) {
                        linear = len;