Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp1689400rwb; Sat, 19 Nov 2022 01:27:35 -0800 (PST) X-Google-Smtp-Source: AA0mqf7Oc26QAEoAoq3JPPB418akbjoX5MtUzInXCGCgShBtK8fBgJDcJg8YrN2me84G/nbt0c4p X-Received: by 2002:aa7:87c7:0:b0:562:a27a:4a84 with SMTP id i7-20020aa787c7000000b00562a27a4a84mr11758606pfo.50.1668850055435; Sat, 19 Nov 2022 01:27:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668850055; cv=none; d=google.com; s=arc-20160816; b=JdzfjEY2ySIfRLziUK8Nsp1RUZwQ4ux0g7GGpQPmIWCjI3WOppUhAdT1ET2PFxPsSq D2riTCSh1vzbrBXgZ5O189UYRInRN/e/6Qum0nv7x/hgoVowWIslbav9rXjoEennJbnV IV5oMLDWvQFmuthDLgSdcn6T+cGo6Uw5M0k9yXtO5BttoQWGMtrMom54nN1rOFFQGnD3 rLsQ/xlO7sxy0tuRiFpTlwga/vv917/e/eSdanVtiS2TNnnCDH+Iqsa5hAcwFYJ9alwx 85ZhVhpuwWv8PgVfd/yQeFgfjsG73hH/pwZJVSOECzVwyJttY/5le+iXfN5sgZ8YxMCj OWAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=4mWeMyTDhyfLNv3OpmNvW3UCwWvf0zOgm78z1t+Q0ks=; b=XWZqpushI0ddjoB1zUw8DK/qcumSk4rIVxTHenwkra4FLZzIBkfjg+1o0zyPTXsKMi H20ANW7SqfVU6c0XuPGQz7sdJZu3sSEwa3N28Gfy49kK+3sm3rJsujdlrmlXZkZxD/F3 NM2zDjaNbpZAQ9ne40luXOu4bjYovoVXIMqLDtPx3knrWaRhuXl5AZ0wuQcyXoBkPGuE Tv6+wpr0tLpvhHj/UBAgTWGmmWmNHLyCLCucptNYhly9XssnY+A+zDh7O9qAhcUYbXFl h6i6Mv7kFGrSreJK38fNM81ZsezOBJvFUT5YeE7NrWm6n1EAGmLkgNdIoMxYfH1gbssY wgiQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r138-20020a632b90000000b0046fabccb7ffsi5938012pgr.494.2022.11.19.01.27.18; Sat, 19 Nov 2022 01:27:35 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232173AbiKSJCh (ORCPT + 91 others); Sat, 19 Nov 2022 04:02:37 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34248 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231351AbiKSJCd (ORCPT ); Sat, 19 Nov 2022 04:02:33 -0500 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 509509DBA7 for ; Sat, 19 Nov 2022 01:02:32 -0800 (PST) Received: from dggpeml500023.china.huawei.com (unknown [172.30.72.55]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4NDndf6QTTzFqQX; Sat, 19 Nov 2022 16:59:18 +0800 (CST) Received: from ubuntu1804.huawei.com (10.67.174.58) by dggpeml500023.china.huawei.com (7.185.36.114) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Sat, 19 Nov 2022 17:02:30 +0800 From: Xiu Jianfeng To: , , , , , , , CC: , , Subject: [PATCH 1/2] x86/xen: Fix memory leak in xen_smp_intr_init{_pv}() Date: Sat, 19 Nov 2022 16:59:22 +0800 Message-ID: <20221119085923.114889-2-xiujianfeng@huawei.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20221119085923.114889-1-xiujianfeng@huawei.com> References: <20221119085923.114889-1-xiujianfeng@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.67.174.58] X-ClientProxiedBy: dggems702-chm.china.huawei.com (10.3.19.179) To dggpeml500023.china.huawei.com (7.185.36.114) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org These local variables @{resched|pmu|callfunc...}_name saves the new string allocated by kasprintf(), and when bind_{v}ipi_to_irqhandler() fails, it goes to the @fail tag, and calls xen_smp_intr_free{_pv}() to free resource, however the new string is not saved, which cause a memory leak issue. fix it. Fixes: 9702785a747a ("i386: move xen") Signed-off-by: Xiu Jianfeng --- arch/x86/xen/smp.c | 16 ++++++++++++---- arch/x86/xen/smp_pv.c | 8 ++++++-- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/arch/x86/xen/smp.c b/arch/x86/xen/smp.c index c3e1f9a7d43a..6e9426b6b18a 100644 --- a/arch/x86/xen/smp.c +++ b/arch/x86/xen/smp.c @@ -71,8 +71,10 @@ int xen_smp_intr_init(unsigned int cpu) IRQF_PERCPU|IRQF_NOBALANCING, resched_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(resched_name); goto fail; + } per_cpu(xen_resched_irq, cpu).irq = rc; per_cpu(xen_resched_irq, cpu).name = resched_name; @@ -83,8 +85,10 @@ int xen_smp_intr_init(unsigned int cpu) IRQF_PERCPU|IRQF_NOBALANCING, callfunc_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(callfunc_name); goto fail; + } per_cpu(xen_callfunc_irq, cpu).irq = rc; per_cpu(xen_callfunc_irq, cpu).name = callfunc_name; @@ -94,8 +98,10 @@ int xen_smp_intr_init(unsigned int cpu) xen_debug_interrupt, IRQF_PERCPU | IRQF_NOBALANCING, debug_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(debug_name); goto fail; + } per_cpu(xen_debug_irq, cpu).irq = rc; per_cpu(xen_debug_irq, cpu).name = debug_name; } @@ -107,8 +113,10 @@ int xen_smp_intr_init(unsigned int cpu) IRQF_PERCPU|IRQF_NOBALANCING, callfunc_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(callfunc_name); goto fail; + } per_cpu(xen_callfuncsingle_irq, cpu).irq = rc; per_cpu(xen_callfuncsingle_irq, cpu).name = callfunc_name; diff --git a/arch/x86/xen/smp_pv.c b/arch/x86/xen/smp_pv.c index 480be82e9b7b..228d0207380c 100644 --- a/arch/x86/xen/smp_pv.c +++ b/arch/x86/xen/smp_pv.c @@ -124,8 +124,10 @@ int xen_smp_intr_init_pv(unsigned int cpu) IRQF_PERCPU|IRQF_NOBALANCING, callfunc_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(callfunc_name); goto fail; + } per_cpu(xen_irq_work, cpu).irq = rc; per_cpu(xen_irq_work, cpu).name = callfunc_name; @@ -135,8 +137,10 @@ int xen_smp_intr_init_pv(unsigned int cpu) xen_pmu_irq_handler, IRQF_PERCPU|IRQF_NOBALANCING, pmu_name, NULL); - if (rc < 0) + if (rc < 0) { + kfree(pmu_name); goto fail; + } per_cpu(xen_pmu_irq, cpu).irq = rc; per_cpu(xen_pmu_irq, cpu).name = pmu_name; } -- 2.17.1