Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp5877187rwb; Mon, 14 Nov 2022 10:41:23 -0800 (PST) X-Google-Smtp-Source: AA0mqf7eHSnwhNXPQc97MYIwKY782zRvniyQxtT68P5iufdbbovNXX1oixsm3+LIYQSsQuoGmlBB X-Received: by 2002:a17:906:a986:b0:78c:c893:1965 with SMTP id jr6-20020a170906a98600b0078cc8931965mr10985647ejb.247.1668451283478; Mon, 14 Nov 2022 10:41:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668451283; cv=none; d=google.com; s=arc-20160816; b=pkh/GQYgK8CyuCLIaFvcv0CDczlBlbaMrwXOkdQFmP/nVQve6ItFbnn5g4GXuTmFYj VD8pzoTFz39ts/oo5TyCiast2XBRz942kNcHr4jUDm9cuKotrLAfQ2Uez4jgY2lh+LHs qim1yuXchIAaso8xYebgS4aat/qAX3u4STv/5b3vdU/z67rwefJRbtBnrbS05spyTp7C Ky8IdpP7J18370eeOTju6OdyS6+DTyNDCE2e9t2zKmoHdXS/jxVEqKBCwWvbNUQdp5IS XJd5x1chw5Fvy7XbLd0gvlXSeM3NvInO3JkT32CrCXkdRPLz3J3adC68MDAPrnlcS3qF 7kUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=9WKz7xa5HUQV2+mpfK1D0nsRtWfjAHQqAO3pOwayfIM=; b=F89E03MYp+Cph26P+VKUJYCW73cZWglNf5BEucGAcUsWuTu1eMhpJuevh6Wtr/ZgMG 5XkMiFsepRqtBRfdODTnWJRXlUv52c9gW0xirHIQzNHketPd9W4GJHO4nc2mXLTcrLO+ msKUXK9m3Qdte+zJfY16PJDCFzS6CgvM5E93FmamTVfP1WAGZcqGanCSYlCFB5ZyU77x d4bHmkAz3oBuaGPMYHwYhiBoXgSXC9FJ5RTFWebzacaHVOUe/tX5hrjONDVRlNemEBCk ZlJqfi6IIuumOMYKYsC/c62Kt39twlBzLyGvvCuXFK6rdkORM8sBQOTmUuuvPkueIvQU SsOA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=bY29PN+C; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g6-20020a056402320600b00461701dab0csi9351769eda.526.2022.11.14.10.41.00; Mon, 14 Nov 2022 10:41:23 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=bY29PN+C; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236900AbiKNSaW (ORCPT + 88 others); Mon, 14 Nov 2022 13:30:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57192 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236921AbiKNSaS (ORCPT ); Mon, 14 Nov 2022 13:30:18 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 729E625C47 for ; Mon, 14 Nov 2022 10:30:09 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 287A0B81158 for ; Mon, 14 Nov 2022 18:30:08 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 5FF7DC433D6; Mon, 14 Nov 2022 18:30:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1668450606; bh=KjLeGyUJTbZpSiKhaAFgRkOpgkH4ndx+JjCuYdxHGcY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bY29PN+CyQgg6/VdgLjSq/jugOiRFtHQw+Xxc1h2PxY+BLAsSfEJ7e2CBv4KzGmfy 9/aoiEiu5ZSpriSJuR0gSVUmS+zYRvGafuYYtqMPEQDS2NhqQ1kwYdncApO+p92FTX stqy0WYhQYHGIR+bGkXrE3FUPMGugEp+sWfx013Sj93aJjNN7z2YCazcoSLdPWMwYs QdyULgUxl+x46SDTihwnGa4I8eGqJGE7esekjFcM5kv73P444WCvBH9nP8vA/qDCO7 rNn+jHctDyZHC5FSnsfooLElEb7u553FDcpbSBpBYlKV87QumPpjh6nmUZjpp5/d6T jXDfBuLGLo+CQ== From: SeongJae Park To: SeongJae Park , Andrew Morton Cc: damon@lists.linux.dev, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [PATCH mm-unstable 2/2] mm/damon/sysfs-schemes: skip schemes regions clearing if the scheme directory has removed Date: Mon, 14 Nov 2022 18:29:54 +0000 Message-Id: <20221114182954.4745-3-sj@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221114182954.4745-1-sj@kernel.org> References: <20221114182954.4745-1-sj@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, 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 A DAMON sysfs interface user can start DAMON with a scheme, remove the sysfs directory for the scheme, and then ask clearing of the scheme's tried regions. Because the schemes tried regions clearing logic doesn't aware of the situation, it results in an invalid memory access. Fix the bug by checking if the scheme sysfs directory exists. Fixes: bb9641eb3a3e ("mm/damon/sysfs-schemes: implement DAMOS-tried regions clear command") # mm-unstable Signed-off-by: SeongJae Park --- mm/damon/sysfs-schemes.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/mm/damon/sysfs-schemes.c b/mm/damon/sysfs-schemes.c index 4df3c99983e8..e6baf55d617d 100644 --- a/mm/damon/sysfs-schemes.c +++ b/mm/damon/sysfs-schemes.c @@ -1260,6 +1260,10 @@ int damon_sysfs_schemes_clear_regions( damon_for_each_scheme(scheme, ctx) { struct damon_sysfs_scheme *sysfs_scheme; + /* user could removed the scheme sysfs dir */ + if (schemes_idx >= sysfs_schemes->nr) + break; + sysfs_scheme = sysfs_schemes->schemes_arr[schemes_idx++]; damon_sysfs_scheme_regions_rm_dirs( sysfs_scheme->tried_regions); -- 2.25.1