Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2973103pxv; Mon, 12 Jul 2021 06:29:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy1sp3rm1bi8HsWKYK3D0fdqfbrnp77QsJM6XjBDDdABYnCbQ4LOBC3dNMhj5W7ArtbTxyL X-Received: by 2002:a17:907:62a1:: with SMTP id nd33mr52977953ejc.303.1626096577772; Mon, 12 Jul 2021 06:29:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626096577; cv=none; d=google.com; s=arc-20160816; b=zgmnC47Ph6h20KgU2Ts0v1cpkOhN2CFlakcPDP/MRrMefU/LvAuY54rDh3haT5UVQc 2hurV7IxU5go6atS+SJwAz67kA+SwFqpxekzJ5H0vwhuZdBJZAvYiuvRMBlfPBH3spYh mGCypF+RWzRtg1YaTLe0i5I9CY4UUIUpWDDer5hlbn9p0DIYokeh+9T23qcLBr5OvYA4 U4SK0wrWVW2P1ZWbJHs5Hl6DB+2T6caU3HycIzqgvGWM16kIw9NPPJ7+3EnbWRSjjti9 o6WFtgdn17+PlEAt3XT5YrrZNzZVpAmGUzL2me7/65o9vslYuh/55gemItjX2AwyH+Ao nwSg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:references:cc :to:subject:from:dkim-signature; bh=GlJZHo/qI9/fo4ysvGa0uUuc8YFxgMW0dn4u7fxaW1o=; b=vw+Tx92+75hUZlvg0qP3v0ZyaJesgaRWrzlHqgLtD2TolBhHvVmKUtUzBBjZkBjTyc fpOHQNnIh9JQnXNvrdgo01AKlc/UUmacpm3aspQ3j1beT6rcE/TY8PEhixlPXwaY1+Qb HZKPAArU+WPSlzT/11/CjaqJrEozSK9ydMpsLbpy13SkSpIXOeTg/30unjYkwQZIGSuE gg8asfP1VT2PG1qfJX+j1Rg98V/p8OQQd7smy2tsqijkCf0/xxfsoKwm477d1fuZZxJ8 7XGiFBOLluz8MyuOebEs4L4JfrFzqGCDx2M6uimDq019yuntFnbjKEIG4dPWs56huq/B 40WA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@virtuozzo.com header.s=relay header.b=Xo3cOUSU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=virtuozzo.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g20si16721367edv.570.2021.07.12.06.29.15; Mon, 12 Jul 2021 06:29:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@virtuozzo.com header.s=relay header.b=Xo3cOUSU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=virtuozzo.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234648AbhGLNaP (ORCPT + 99 others); Mon, 12 Jul 2021 09:30:15 -0400 Received: from relay.sw.ru ([185.231.240.75]:49704 "EHLO relay.sw.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234610AbhGLNaN (ORCPT ); Mon, 12 Jul 2021 09:30:13 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=virtuozzo.com; s=relay; h=Content-Type:MIME-Version:Date:Message-ID:Subject :From; bh=GlJZHo/qI9/fo4ysvGa0uUuc8YFxgMW0dn4u7fxaW1o=; b=Xo3cOUSUEXaRia8WZ2c bYUfUALuzICdTSlV3sU8xENPbwqUr5arV2ivLZ+f6Ox2FdNkw9tlwQuFkGo/qmyjt9io4VrOLkwmv CCcNP0kFf4ZDuaGbfRklvcVWS5WxFGwjytg5/OAylGFsgesGsVGs44qFxD9SaRfPh+3DcAMT/Dc=; Received: from [10.93.0.56] by relay.sw.ru with esmtp (Exim 4.94.2) (envelope-from ) id 1m2vxv-003iDv-1f; Mon, 12 Jul 2021 16:27:19 +0300 From: Vasily Averin Subject: [PATCH NET 6/7] ax25: use pskb_realloc_headroom To: "David S. Miller" , Hideaki YOSHIFUJI , David Ahern , Jakub Kicinski , Eric Dumazet Cc: netdev@vger.kernel.org, Joerg Reuter , Ralf Baechle , linux-hams@vger.kernel.org, linux-kernel@vger.kernel.org References: <74e90fba-df9f-5078-13de-41df54d2b257@virtuozzo.com> Message-ID: <42f0c1f1-a40a-6137-aabd-5c01a5da9f41@virtuozzo.com> Date: Mon, 12 Jul 2021 16:27:18 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use pskb_realloc_headroom() in ax25_transmit_buffer and ax25_rt_build_path. Unlike skb_realloc_headroom, new helper pskb_realloc_headroom does not allocate a new skb if possible. Signed-off-by: Vasily Averin --- net/ax25/ax25_out.c | 13 ++++--------- net/ax25/ax25_route.c | 13 ++++--------- 2 files changed, 8 insertions(+), 18 deletions(-) diff --git a/net/ax25/ax25_out.c b/net/ax25/ax25_out.c index f53751b..1f1e581 100644 --- a/net/ax25/ax25_out.c +++ b/net/ax25/ax25_out.c @@ -336,18 +336,13 @@ void ax25_transmit_buffer(ax25_cb *ax25, struct sk_buff *skb, int type) headroom = ax25_addr_size(ax25->digipeat); - if (skb_headroom(skb) < headroom) { - if ((skbn = skb_realloc_headroom(skb, headroom)) == NULL) { + if (unlikely(skb_headroom(skb) < headroom)) { + skb = pskb_realloc_head(roomskb, headroom); + + if (!skb) { printk(KERN_CRIT "AX.25: ax25_transmit_buffer - out of memory\n"); - kfree_skb(skb); return; } - - if (skb->sk != NULL) - skb_set_owner_w(skbn, skb->sk); - - consume_skb(skb); - skb = skbn; } ptr = skb_push(skb, headroom); diff --git a/net/ax25/ax25_route.c b/net/ax25/ax25_route.c index b40e0bc..8f54547 100644 --- a/net/ax25/ax25_route.c +++ b/net/ax25/ax25_route.c @@ -447,18 +447,13 @@ struct sk_buff *ax25_rt_build_path(struct sk_buff *skb, ax25_address *src, len = digi->ndigi * AX25_ADDR_LEN; - if (skb_headroom(skb) < len) { - if ((skbn = skb_realloc_headroom(skb, len)) == NULL) { + if (unlikely(skb_headroom(skb) < len)) { + skb = pskb_realloc_headroom(skb, len); + + if (!skb) { printk(KERN_CRIT "AX.25: ax25_dg_build_path - out of memory\n"); return NULL; } - - if (skb->sk != NULL) - skb_set_owner_w(skbn, skb->sk); - - consume_skb(skb); - - skb = skbn; } bp = skb_push(skb, len); -- 1.8.3.1