Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp4263511pxa; Mon, 10 Aug 2020 05:19:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxHiLIsmhWrJ3wJmnwZ0bo1PGdvwxGPn0omHDsTIA0cuuAUstrnyHXqpXCllNytfGif1n2/ X-Received: by 2002:a17:907:100f:: with SMTP id ox15mr22477141ejb.125.1597061988723; Mon, 10 Aug 2020 05:19:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597061988; cv=none; d=google.com; s=arc-20160816; b=HfGbyfSpu0IWlwGCLLl0ZVUg7Kb+o3s/1EIaEBlVMdXZHu0ApaKyF8ZkeMw78g+oKo Loav8vrmHgdJ5fjc/+AhTQWEQYG6N/U6mD6d3aWXNnNBjUYtr4rootKvXPJjWD+NKF+O h2j0Ai4WcymuEKlKeXdwqFxEYsqpBu3b6pcOz4K+LNXI9CzzYAXWatx5dtWV0u05OB4A 2g5YAz0TFbX5/jNxBTUnjqTKU54c4hnfKXES4rQ8d14IYRUn3DvqvDA2f/pNSFes+7xH uzjHR5xlcemvNlMXDv0e6FywYI2msI7g9eyx6J3d4+0jgLw1QrKMGaDT1+NXiDairgWt ISdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=rYyS29JUUwVkx4e+DImA+QbNg4aGmloudDwKOkPnaPU=; b=05ynzlhqQKhkzIzrK47LM2RoAcblCGev+rfQNE2FaM1HNKuroGSPMfhZBFb2hlMwRl QeVYQC0hMj0Pg/CwxsZ8XMiFH0211Dy81woqH3vWmfJrG7DZa70KQc3QmOXCJuKyabP0 TSVcUS/1o4TXOjT9/+9uhULSFghhbkJWV6bmNQ4ZNdKF8qkH0BxxlYlZkoSjJLQn/nrm miInLoJ0nDUHjwfKLoyYXCOxk38CnvvK/FEaqeRGJEhA+LNmjPneP4LKBlMPOkL8KiNw g8Ahg1QTZ8Xg5oNaPHMdsocGjWS/rrNIdnC75jSEi5MkTpM9qyCSzi7yRXHnh0zN/WYE Pe8Q== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p12si10216064ejz.478.2020.08.10.05.19.25; Mon, 10 Aug 2020 05:19:48 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726804AbgHJMSR (ORCPT + 99 others); Mon, 10 Aug 2020 08:18:17 -0400 Received: from szxga05-in.huawei.com ([45.249.212.191]:9256 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726146AbgHJMSP (ORCPT ); Mon, 10 Aug 2020 08:18:15 -0400 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 4D9A955539E3F4B410D8; Mon, 10 Aug 2020 20:18:12 +0800 (CST) Received: from huawei.com (10.175.104.175) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.487.0; Mon, 10 Aug 2020 20:18:02 +0800 From: Miaohe Lin To: , , , , , , , CC: , , Subject: [PATCH] net: Fix potential memory leak in proto_register() Date: Mon, 10 Aug 2020 08:16:58 -0400 Message-ID: <20200810121658.54657-1-linmiaohe@huawei.com> X-Mailer: git-send-email 2.19.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.104.175] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If we failed to assign proto idx, we free the twsk_slab_name but forget to free the twsk_slab. Add a helper function tw_prot_cleanup() to free these together and also use this helper function in proto_unregister(). Fixes: b45ce32135d1 ("sock: fix potential memory leak in proto_register()") Signed-off-by: Miaohe Lin --- net/core/sock.c | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/net/core/sock.c b/net/core/sock.c index 49cd5ffe673e..c9083ad44ea1 100644 --- a/net/core/sock.c +++ b/net/core/sock.c @@ -3406,6 +3406,16 @@ static void sock_inuse_add(struct net *net, int val) } #endif +static void tw_prot_cleanup(struct timewait_sock_ops *twsk_prot) +{ + if (!twsk_prot) + return; + kfree(twsk_prot->twsk_slab_name); + twsk_prot->twsk_slab_name = NULL; + kmem_cache_destroy(twsk_prot->twsk_slab); + twsk_prot->twsk_slab = NULL; +} + static void req_prot_cleanup(struct request_sock_ops *rsk_prot) { if (!rsk_prot) @@ -3476,7 +3486,7 @@ int proto_register(struct proto *prot, int alloc_slab) prot->slab_flags, NULL); if (prot->twsk_prot->twsk_slab == NULL) - goto out_free_timewait_sock_slab_name; + goto out_free_timewait_sock_slab; } } @@ -3484,15 +3494,15 @@ int proto_register(struct proto *prot, int alloc_slab) ret = assign_proto_idx(prot); if (ret) { mutex_unlock(&proto_list_mutex); - goto out_free_timewait_sock_slab_name; + goto out_free_timewait_sock_slab; } list_add(&prot->node, &proto_list); mutex_unlock(&proto_list_mutex); return ret; -out_free_timewait_sock_slab_name: +out_free_timewait_sock_slab: if (alloc_slab && prot->twsk_prot) - kfree(prot->twsk_prot->twsk_slab_name); + tw_prot_cleanup(prot->twsk_prot); out_free_request_sock_slab: if (alloc_slab) { req_prot_cleanup(prot->rsk_prot); @@ -3516,12 +3526,7 @@ void proto_unregister(struct proto *prot) prot->slab = NULL; req_prot_cleanup(prot->rsk_prot); - - if (prot->twsk_prot != NULL && prot->twsk_prot->twsk_slab != NULL) { - kmem_cache_destroy(prot->twsk_prot->twsk_slab); - kfree(prot->twsk_prot->twsk_slab_name); - prot->twsk_prot->twsk_slab = NULL; - } + tw_prot_cleanup(prot->twsk_prot); } EXPORT_SYMBOL(proto_unregister); -- 2.19.1