Received: by 2002:a9a:4c47:0:b029:116:c383:538 with SMTP id u7csp962169lko; Tue, 13 Jul 2021 14:00:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJywbAkbuZ/uchV33ed5SQGqEi22Bjz0l174Jn/gZbqOrocEwhg96D/SwYrFxzOM3Rsa4xNj X-Received: by 2002:a6b:cf12:: with SMTP id o18mr4678803ioa.86.1626210017895; Tue, 13 Jul 2021 14:00:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626210017; cv=none; d=google.com; s=arc-20160816; b=v2h4FkTfg0TV31XMhZhSjuH+7kjKf5SJJWnbNIr/Fs1YhT9Dh7QeqLEfuHJcppSd35 4le3jDXS3t6ixL9eZQi1nIR+3k6TMCQB/vkYfXRHlc3HO2hs4uHAcQNVmc8gb7gggFc9 2T6YHM/QOzFIHbuja9pufknb250nwLr5fmoaYO9lPKWwxLjR53s1mk7N8Hv+m2LV5BMj RvvZ41QkgitJLIFH0SDuiWL1gCWSkouQWGYgIpBoZ3JYfII272AHPFzgI9GkySgtVGbq 5LI+DnqHrBhEMepv/oWHwhW8spb58K+0nrumEmprT3AdXeSit6e79NNaRqT36YeFc7mR KKNw== 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=pOmbvmoHCRf0LxILnkccI0/aUdAXXU2GWmHyziW8kQk=; b=ZFSmDjbNtrbsxEi2J+kba2k0U9jYGLoW1fENhql720bo7noMFqMIIT3LZuxMvmBpNh RAl++9EKHaVJnmfmh+TemEch2bVT+s+v31PZIuXjLBOaXFb7PiHtbbzYJd+0jpXEDnD5 zt1ToTnSGkQEq/v51L2ecqNu32Td01AVlJxH5mQtCK6lHhbwoW8f/BOOFEYJWiDvUtth 5aF77ZyFS+lcSq5vTkY6n0XEDqrrybY3bkozU5C63TAV9h873aI/ElbLXh+BXaK0mMJ0 BlqUWTSX972S7XyYE+bAfDW66eUt/MsB+lrRDiyjvVGiTMfVztFmsPJxO3YgSHaDNf8e d4DQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@virtuozzo.com header.s=relay header.b=RR7slBsK; 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 l21si8996ioh.103.2021.07.13.14.00.05; Tue, 13 Jul 2021 14:00:17 -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=RR7slBsK; 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 S236133AbhGMVB2 (ORCPT + 99 others); Tue, 13 Jul 2021 17:01:28 -0400 Received: from relay.sw.ru ([185.231.240.75]:56838 "EHLO relay.sw.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236038AbhGMVB2 (ORCPT ); Tue, 13 Jul 2021 17:01:28 -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=pOmbvmoHCRf0LxILnkccI0/aUdAXXU2GWmHyziW8kQk=; b=RR7slBsKmKFzPKcpr5z 6igD9tUKJw1w5a+UPpq3hGO8pGpuKS4PT/rcVkxiDvhco8/e8CM70GDI8H093IeW2skEoxy4XDZDo WmUa+jeszHadQsCcZFsrht4zqQvNkszJ6uphMGeDGlrJldUTSMUl89y1WdzlhKV0sznLznUS5nA=; Received: from [10.93.0.56] by relay.sw.ru with esmtp (Exim 4.94.2) (envelope-from ) id 1m3PUC-003saU-MM; Tue, 13 Jul 2021 23:58:36 +0300 From: Vasily Averin Subject: [PATCH NET v2 6/7] ax25: use skb_expand_head 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: <55c9e2ae-b060-baa2-460c-90eb3e9ded5c@virtuozzo.com> Message-ID: <33cecb71-0582-308d-08b1-9445b4638ad7@virtuozzo.com> Date: Tue, 13 Jul 2021 23:58:36 +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 skb_expand_head() in ax25_transmit_buffer and ax25_rt_build_path. Unlike skb_realloc_headroom, new helper does not allocate a new skb if possible. Signed-off-by: Vasily Averin --- v2: removed kfree_skb() in ax25_rt_build_path caller ax25_ip_xmit net/ax25/ax25_ip.c | 4 +--- net/ax25/ax25_out.c | 12 +++--------- net/ax25/ax25_route.c | 13 +++---------- 3 files changed, 7 insertions(+), 22 deletions(-) diff --git a/net/ax25/ax25_ip.c b/net/ax25/ax25_ip.c index e4f63dd..3624977 100644 --- a/net/ax25/ax25_ip.c +++ b/net/ax25/ax25_ip.c @@ -193,10 +193,8 @@ netdev_tx_t ax25_ip_xmit(struct sk_buff *skb) skb_pull(skb, AX25_KISS_HEADER_LEN); if (digipeat != NULL) { - if ((ourskb = ax25_rt_build_path(skb, src, dst, route->digipeat)) == NULL) { - kfree_skb(skb); + if ((ourskb = ax25_rt_build_path(skb, src, dst, route->digipeat)) == NULL) goto put; - } skb = ourskb; } diff --git a/net/ax25/ax25_out.c b/net/ax25/ax25_out.c index f53751b..af4a10e 100644 --- a/net/ax25/ax25_out.c +++ b/net/ax25/ax25_out.c @@ -336,18 +336,12 @@ 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 = skb_expand_head(skb, 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..d0b2e09 100644 --- a/net/ax25/ax25_route.c +++ b/net/ax25/ax25_route.c @@ -441,24 +441,17 @@ int ax25_rt_autobind(ax25_cb *ax25, ax25_address *addr) struct sk_buff *ax25_rt_build_path(struct sk_buff *skb, ax25_address *src, ax25_address *dest, ax25_digi *digi) { - struct sk_buff *skbn; unsigned char *bp; int len; 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 = skb_expand_head(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