Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp11813702rwl; Tue, 3 Jan 2023 05:14:14 -0800 (PST) X-Google-Smtp-Source: AMrXdXttQB2tpccHf1blRaaYmEwwAAXt5JDUKm9Ckkhy+8FQEqudFetJum3vSSx+JHcLsdsM6oj2 X-Received: by 2002:a17:902:eb84:b0:192:9094:cbb6 with SMTP id q4-20020a170902eb8400b001929094cbb6mr23112105plg.65.1672751654508; Tue, 03 Jan 2023 05:14:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672751654; cv=none; d=google.com; s=arc-20160816; b=eONflpV41FcEBYeSvPTqvKCIBKl4RsR4+LclJ36i1bbCUf4PlLFf6h21mDeowR8Ham hQJx9ehjuwzyacJnVec2cUhSfVMBYK4vJI52kU6O/WTqYGkJoargRKpEQmqngtW2Ge0D ZYw0aU1oTZp5jUdnvHNAZwJrTjbdugavMj00Ou71dKtbowcKDIU9QO4foNQFF2k1mcom xBGBXuIAvrih4WWbulc0vpN05qsWrT/rw6LrxA23DQs3T0x2mHqi8JNOv9PopaxdPiQb zjM8vl+1XNVaRbtDcPlGI+6bRv8YtyVNj2XtG4MQXxoXe0CZ4ueNiwjj5tLPRJIGKqgy J0Qg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=cg9NBeuSYbmn+DA79/KjX0RMB03P0+uV8JtF3hf3uM8=; b=x44nFr8HJxN0sOO+HBdgct6yqJ70dg+L/ZaJOBxxKPPydLsryvAT7s7dkeildrcaPs 1gOC9GAzef4xlATMlRxdUScrvZitxazM3kzsjdqHAFAOQ1xpl/daaRdqubXuO+1cJ/I8 BhRUU0dP52YKM0ErN1XP3QiNw3kxcA2boaI3lbcLGzTTIMfW/Xkhktfbc/pGmvwj6eB8 jbKbmR0toVnwkxGGROOwiPi9G7XSAouh/M+PBZBmg4gNtamHZwNe0hTnmMfa1EWPzkiB 0zxmq4pHwuW6GoOLinMY8/AJMjk2CjY87tJ2+pj/YX7tOFXUyH1SUAEeoCtsubRrjloD KQjQ== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q21-20020a170902edd500b00192d633db20si3123779plk.366.2023.01.03.05.14.05; Tue, 03 Jan 2023 05:14:14 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237534AbjACNGx (ORCPT + 60 others); Tue, 3 Jan 2023 08:06:53 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51498 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237649AbjACNGu (ORCPT ); Tue, 3 Jan 2023 08:06:50 -0500 Received: from mail-yb1-f176.google.com (mail-yb1-f176.google.com [209.85.219.176]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 74AF0267E for ; Tue, 3 Jan 2023 05:06:49 -0800 (PST) Received: by mail-yb1-f176.google.com with SMTP id c124so32939901ybb.13 for ; Tue, 03 Jan 2023 05:06:49 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=cg9NBeuSYbmn+DA79/KjX0RMB03P0+uV8JtF3hf3uM8=; b=3sz9FlCvhHPwLkdpXYnFPsXdtgUnAr2DElPd0GUC3tqwaQ1kQbOovSBWeNoDKcRTi3 fLSTrOZP28Rd0rTooBRFwk2DEgG1RxZPt1SIWJi9JofDutM0tvJrUhlqSgUUllKNbs6E o8HvDuQtw8Qq9aXRcG/HQxmCEXW1J4y1AbUr8jqKFfj326YHvrldqfUrCW396gpAuxq+ ZXxoWPMpq2pTtkhFEphZuEVY/RO5aUlcEjxL0fj3b/RQA+unG3BKB5YH2Pdsm9hKB5I/ rcni2OQtmhWEazE4sO8wK/i3lNdw/BUIsFN1tHlUt/VfQv/IFX37Xxie0s7ZvZ3iRfo7 pYug== X-Gm-Message-State: AFqh2kqnUg6TLifGhC56iG8oyGyFr0mQpnmUwcfwWjL0PelY0J6SppAj 0EuDyuCZrF8hTgBQVETii19pKzQhmY3g0Q== X-Received: by 2002:a25:3c85:0:b0:70c:419a:faf0 with SMTP id j127-20020a253c85000000b0070c419afaf0mr36983204yba.49.1672751208437; Tue, 03 Jan 2023 05:06:48 -0800 (PST) Received: from mail-yb1-f176.google.com (mail-yb1-f176.google.com. [209.85.219.176]) by smtp.gmail.com with ESMTPSA id n78-20020a374051000000b006f9ddaaf01esm21887473qka.102.2023.01.03.05.06.47 for (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 03 Jan 2023 05:06:48 -0800 (PST) Received: by mail-yb1-f176.google.com with SMTP id b16so33050117yba.0 for ; Tue, 03 Jan 2023 05:06:47 -0800 (PST) X-Received: by 2002:a25:3143:0:b0:77a:b5f3:d0ac with SMTP id x64-20020a253143000000b0077ab5f3d0acmr2508697ybx.202.1672751207466; Tue, 03 Jan 2023 05:06:47 -0800 (PST) MIME-Version: 1.0 References: <20221229075323.1394010-1-linmq006@gmail.com> In-Reply-To: From: Geert Uytterhoeven Date: Tue, 3 Jan 2023 14:06:35 +0100 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH] um: vector: Fix memory leak in vector_config To: Miaoqian Lin Cc: Anton Ivanov , Richard Weinberger , Johannes Berg , Jakub Kicinski , "David S. Miller" , Wolfram Sang , linux-um@lists.infradead.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-1.4 required=5.0 tests=BAYES_00, FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=no 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 Hi Miaoqian, On Tue, Jan 3, 2023 at 1:17 PM Miaoqian Lin wrote: > On 2023/1/3 18:28, Anton Ivanov wrote: > > On 03/01/2023 08:00, Geert Uytterhoeven wrote: > >> On Thu, Dec 29, 2022 at 8:53 AM Miaoqian Lin wrote: > >>> kstrdup() return newly allocated copy of the string. > >>> Call kfree() to release the memory when after use. > >>> > >>> Fixes: 49da7e64f33e ("High Performance UML Vector Network Driver") > >>> Signed-off-by: Miaoqian Lin > >> Thanks for your patch! > >> > >>> --- a/arch/um/drivers/vector_kern.c > >>> +++ b/arch/um/drivers/vector_kern.c > >>> @@ -765,6 +765,7 @@ static int vector_config(char *str, char **error_out) > >>> > >>> parsed = uml_parse_vector_ifspec(params); > >>> > >>> + kfree(params); > >> Are you sure the memory pointed to by "params" is no longer used? > >> "parsed" seems to contain pointers pointing to (parts of) the string > >> pointed to by "params", so it cannot be freed. > > > > +1. > > > > I was just about to send the same comment. > > > Oh yes, thanks for spotting this. We should only perform release when uml_parse_vector_ifspec() fails (returns NULL). In this situation, 'params' is no longer used. Do you agree? Yes, that sounds fine to me. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds