Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp4165074imw; Tue, 12 Jul 2022 03:10:18 -0700 (PDT) X-Google-Smtp-Source: AGRyM1vgedqCe8/CzNqMQNDLXsmd8q2wjVUm+TX5kbRr2tacmVOmogtfs5ZFpeCjC+Rb3BFmVB5A X-Received: by 2002:a05:6a00:885:b0:510:950f:f787 with SMTP id q5-20020a056a00088500b00510950ff787mr22432730pfj.83.1657620618218; Tue, 12 Jul 2022 03:10:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657620618; cv=none; d=google.com; s=arc-20160816; b=OfeCR6Kc8tQ4CSYHRXfo3Q+b+zFXYdOG0P3VSvNeraGllaVi/h5nH3/ISFlGTeGa/Y LwzmOyaeAmQAE+vyZp53lte048H/Gsuin05uBNWlN0UEYYjcukt/F4vgniIc+CCzbnSg AKazmtf/IVOLvgcI+H5E5cm4kLWla/wJlrL7diSYWVGFJb3e6vMVY6FrSBOhiGe87hmm x1tE+CQn9lTjgHDkO1dzKGiIOwImqOQe7fq6zHtSNiuA3Wa4XbN5LwbwWZHuxAEALFqt l+FsYsBu8Dqp/nwJeazYIH80W8g4n6P5/lvtKeviKOIkvwTc8Z/fz+YSZBkQoBB0xqKI Me5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :dkim-signature; bh=x/kle2uksxTcc6x66ftiegZgKc2BrTGOuQ67dMnzc4Y=; b=b2lwk0z+kMO5MaUftbOV7OA4gNGD7MtuOxuBDcsWT9LDWo12zg0946+GKHeQKk7zcl anI+On1t3pMe8dpmBGlMeirc9/t9QkENdrcUmH4RyByIUYnUROreyCoBVefnJwQuAqW+ /4EdPxlb5Xw6HEW3m5ULjh4dfxkNU6oQ88fdyLHOy9F+HdvJ1I9N5lylaBUmNSJU7F1Z V2q1YqIEgBmCl0mf9fXCW+MZ0pKNUFpaJZqSfu515LbLP/hyVxmgf/tEt1hVxEwMB8k/ 0lSGP2hBrRrU2QtwDVB7/09ibiAD5d39GbsbBT4geEFH+hW/urDaWll99MJvWi5ZdwNo bx0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=kwkTWMMQ; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id o14-20020a170902d4ce00b001640bfb2b6dsi14677504plg.70.2022.07.12.03.10.05; Tue, 12 Jul 2022 03:10:18 -0700 (PDT) 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; dkim=pass header.i=@google.com header.s=20210112 header.b=kwkTWMMQ; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231302AbiGLJ4n (ORCPT + 99 others); Tue, 12 Jul 2022 05:56:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46116 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229780AbiGLJ4m (ORCPT ); Tue, 12 Jul 2022 05:56:42 -0400 Received: from mail-pj1-x1049.google.com (mail-pj1-x1049.google.com [IPv6:2607:f8b0:4864:20::1049]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1F979AA836 for ; Tue, 12 Jul 2022 02:56:40 -0700 (PDT) Received: by mail-pj1-x1049.google.com with SMTP id j23-20020a17090a061700b001e89529d397so4765317pjj.6 for ; Tue, 12 Jul 2022 02:56:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:message-id:mime-version:subject:from:to:cc; bh=x/kle2uksxTcc6x66ftiegZgKc2BrTGOuQ67dMnzc4Y=; b=kwkTWMMQwkkHAKjVLJeMpSK64OpdmOgu236oC0XBqrX0D7J98KaB6ERHvVIsxhbZCI IjZbLhv6i+RjBhueyuRc2z89NREHndLUI7P+1cS2M3rofdySIBUefE8Zx/tKIC62tGPb sBLF+iClr+Zn5Bm0RSvEka+eTWzazkVC/3O2ZFBL8jIT9WJLQsAfwBZSbJkQMZTIfI89 cORewAgFlyPdAdlkPiW7xz3O8SKElU7ZpBuFMq87gGR/aTiD/l0R19PUxl4Rt6t5Q2Qx 4aT5W6gW5nD0vJVxsHCUz3+2p5cFeMveFo94NEWcVBwoseoOsr7S11L+fg9cG/HfuMvd wVwg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=x/kle2uksxTcc6x66ftiegZgKc2BrTGOuQ67dMnzc4Y=; b=ToBS4QDaQ8XSM8wonRDTiC1vlEXIKS8cjSLwsH2ORjh9liXAUdrdagcWcBO0Y3OhoU gpTPijvbCV4Knj8lhEWCFPxpheOFYhOpcLevMXfO7h1M0eOfW8/hFZmqlija3QvOSSmO bu5H1B50+QyhqrQohhuBi0/lSvGHAz/GXJMTSNF5xiv+q2vEF1UNyamYfkTZluEm6EP0 nmNZDN3QnsjMxk/TkTH0xiuth6KyP5TTeXLNNH/JRKiE61f5zeT0XcMJ0LuCCc9sLCJz POLOPfkxqZhdXtAhiUO+FfC2k7voerqPFVoLlo8Mhg8xChNRokepQaX7wBm/ezETI9Jb lj+Q== X-Gm-Message-State: AJIora8Ip08oOddzyo6jb+Kn9Fdv7xtEnxp7+T7YwDgABaXY7QpAT2XP satdpjC2GEF5RRoFCpWzVflTSyUT/Ur7QQ== X-Received: from slicestar.c.googlers.com ([fda3:e722:ac3:cc00:4f:4b78:c0a8:20a1]) (user=davidgow job=sendgmr) by 2002:a17:90a:249:b0:1e0:a8a3:3c6c with SMTP id t9-20020a17090a024900b001e0a8a33c6cmr120662pje.0.1657619799129; Tue, 12 Jul 2022 02:56:39 -0700 (PDT) Date: Tue, 12 Jul 2022 17:56:27 +0800 Message-Id: <20220712095627.1770312-1-davidgow@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.37.0.144.g8ac04bfd2-goog Subject: [PATCH] kunit: executor: Fix a memory leak on failure in kunit_filter_tests From: David Gow To: Daniel Latypov , Brendan Higgins , Shuah Khan Cc: David Gow , kunit-dev@googlegroups.com, linux-kselftest@vger.kernel.org, Linux Kernel Mailing List , llvm@lists.linux.dev, kernel test robot Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL 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 It's possible that memory allocation for the copy will fail, but for the copy of the suite to succeed. In this case, the copy could be leaked. Properly free 'copy' in the error case for the allocation of 'filtered' failing. Note that there may also have been a similar issue in kunit_filter_subsuites, before it was removed in "kunit: flatten kunit_suite*** to kunit_suite** in .kunit_test_suites". This was reported by clang-analyzer via the kernel test robot, here: https://lore.kernel.org/all/c8073b8e-7b9e-0830-4177-87c12f16349c@intel.com/ Fixes: a02353f49162 ("kunit: bail out of test filtering logic quicker if OOM") Reported-by: kernel test robot Signed-off-by: David Gow --- lib/kunit/executor.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/kunit/executor.c b/lib/kunit/executor.c index 6c489d6c5e5d..5e223327196a 100644 --- a/lib/kunit/executor.c +++ b/lib/kunit/executor.c @@ -74,8 +74,10 @@ kunit_filter_tests(const struct kunit_suite *const suite, const char *test_glob) return ERR_PTR(-ENOMEM); filtered = kcalloc(n + 1, sizeof(*filtered), GFP_KERNEL); - if (!filtered) + if (!filtered) { + kfree(copy); return ERR_PTR(-ENOMEM); + } n = 0; kunit_suite_for_each_test_case(suite, test_case) { -- 2.37.0.144.g8ac04bfd2-goog