Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp791025pxb; Fri, 22 Apr 2022 11:12:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzrH3Wj/ngHeMHhdRxqRqPxylPBLIb6Dnn0yj0mhFt/PQnTcgMaEe0cKasl4F7Ys3ahFg36 X-Received: by 2002:a17:903:2c1:b0:158:f9d0:839c with SMTP id s1-20020a17090302c100b00158f9d0839cmr5894562plk.118.1650651152040; Fri, 22 Apr 2022 11:12:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650651152; cv=none; d=google.com; s=arc-20160816; b=OFzPT/1rI7KQdba53x3By8IKb8vSd5KNeg0bJ+nA1nFA9KC3xGOFpRxyFHYQFReYDj NMkvI9F0MZUYL5tUXIjucknLI4kTfIn95A20DKDkHXHH9BP2XrFj9JgSLPGYvQ0mh/H6 9V8W/dvwfrbIx/qZHyV41lQqh/59TAIMnQKiR7SicSC7EXk+7hDOjZq5z6g8PcxrAciX arODsLrc5qxHckMFni1HgVc3lDLftq3PCbOyGgbwAAlPnl1sGGNPay/70BOiRB0LBuoO jV5GNZ2jzGUIyNYbZv8IduCCItHc7kfQzOnb9Q6x7m5prZxT9CrVkRLkf2xNWZyL8//w IFLg== 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; bh=ybM2/MebbmHh9Uk+Civ8p2eG1e4lJfObLB1b9VYbOt0=; b=oBPnuMhI/kghUxtidtjZq7kqXkdb44ySSoD0NFWDatyh2CfbTMkM9djbRdkpOIX9I1 hH7HGOFruaG/M5UeTbKpIVZku4erMY+mok6YdsfPDsoYNq0TTRTZO+J/xwQVdAyea9ny xfRm1RTPOUeZU/mXNPXw3JSgWnFmuUenSVq+Cv5w4OsrZgIi9TgPXYOIxBbWRCmsnUe4 khI+2VLAlQVl8FdWAWoq1ctAfMncZjqkYns4roBeXortfV/MwPJbrgAgTSiC8Gp092WE 5X0t0YISHWinxDQVDoAhberb/PkFyqw7w9T/Trj/x7TkoD1JaDh4Bjfy9YcNl7UGKNkv bz6w== 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:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id y9-20020a655b09000000b00381f73774fasi8575767pgq.355.2022.04.22.11.12.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Apr 2022 11:12:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 9BE34F8E73; Fri, 22 Apr 2022 10:48:14 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1449675AbiDVQBD (ORCPT + 99 others); Fri, 22 Apr 2022 12:01:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34810 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1387797AbiDVQAq (ORCPT ); Fri, 22 Apr 2022 12:00:46 -0400 Received: from mail-qt1-f181.google.com (mail-qt1-f181.google.com [209.85.160.181]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 394AF5DA7E; Fri, 22 Apr 2022 08:57:52 -0700 (PDT) Received: by mail-qt1-f181.google.com with SMTP id ay11so5792186qtb.4; Fri, 22 Apr 2022 08:57:52 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ybM2/MebbmHh9Uk+Civ8p2eG1e4lJfObLB1b9VYbOt0=; b=RMnclBJpofBE2r8P2miIAfi/VDQE7JgeJUsa+zGbk2fMfn1c+T3FkSjluxfia5EX0i w/Aexa9TzXzNliEV2dt36Jgo3gohyQ/ttWjSvh8NZBGmLxPn/ZQj7yBqGVkiFbrR1nQZ NMuJiqiPUy/6f/lxBOUyj/4f5BHs44z3qAab0xRXzj4qtJzIDghJS7lRkFPPpgzy3l5n PlXtN9XxI2WtGnltoewmvr8yyct7rHDYZtQpNSQOh1oY+OVy3ihPQprBMwPr5PRh2/qU PZI7C1NdYbkY81lIYe0VJVTGmvpXNX+gb7sFxQsoRf452msJYSEAISDmJ5CLl36Jv7UM 3ZlQ== X-Gm-Message-State: AOAM531CBKz+5UwLaxCkXzd32kTDefRtawAmb2514NPziJHQ9/dCOd4Z tj58qfYw3HTNmYn8ag+SRVQ= X-Received: by 2002:a05:622a:151:b0:2f1:fe9f:9177 with SMTP id v17-20020a05622a015100b002f1fe9f9177mr3762575qtw.628.1650643071259; Fri, 22 Apr 2022 08:57:51 -0700 (PDT) Received: from localhost (fwdproxy-ash-019.fbsv.net. [2a03:2880:20ff:13::face:b00c]) by smtp.gmail.com with ESMTPSA id c17-20020a05622a025100b002f34db6a3a2sm1543874qtx.4.2022.04.22.08.57.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Apr 2022 08:57:51 -0700 (PDT) From: David Vernet To: akpm@linux-foundation.org Cc: tj@kernel.org, roman.gushchin@linux.dev, linux-kernel@vger.kernel.org, linux-mm@kvack.org, cgroups@vger.kernel.org, hannes@cmpxchg.org, mhocko@kernel.org, shakeelb@google.com, kernel-team@fb.com, void@manifault.com Subject: [PATCH 5/5] cgroup: Fix racy check in alloc_pagecache_max_30M() helper function Date: Fri, 22 Apr 2022 08:57:29 -0700 Message-Id: <20220422155728.3055914-6-void@manifault.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20220422155728.3055914-1-void@manifault.com> References: <20220422155728.3055914-1-void@manifault.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE 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 alloc_pagecache_max_30M() in the cgroup memcg tests performs a 50MB pagecache allocation, which it expects to be capped at 30MB due to the calling process having a memory.high setting of 30MB. After the allocation, the function contains a check that verifies that MB(29) < memory.current <= MB(30). This check can actually fail non-deterministically. The testcases that use this function are test_memcg_high() and test_memcg_max(), which set memory.min and memory.max to 30MB respectively for the cgroup under test. The allocation can slightly exceed this number in both cases, and for memory.max, the process performing the allocation will not have the OOM killer invoked as it's performing a pagecache allocation. This patchset therefore updates the above check to instead use the verify_close() helper function. Signed-off-by: David Vernet --- tools/testing/selftests/cgroup/test_memcontrol.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/tools/testing/selftests/cgroup/test_memcontrol.c b/tools/testing/selftests/cgroup/test_memcontrol.c index c4735fa36a3d..088850f01ae7 100644 --- a/tools/testing/selftests/cgroup/test_memcontrol.c +++ b/tools/testing/selftests/cgroup/test_memcontrol.c @@ -564,9 +564,14 @@ static int alloc_pagecache_max_30M(const char *cgroup, void *arg) { size_t size = MB(50); int ret = -1; - long current; + long current, high, max; int fd; + high = cg_read_long(cgroup, "memory.high"); + max = cg_read_long(cgroup, "memory.max"); + if (high != MB(30) && max != MB(30)) + goto cleanup; + fd = get_temp_fd(); if (fd < 0) return -1; @@ -575,7 +580,7 @@ static int alloc_pagecache_max_30M(const char *cgroup, void *arg) goto cleanup; current = cg_read_long(cgroup, "memory.current"); - if (current <= MB(29) || current > MB(30)) + if (!values_close(current, MB(30), 5)) goto cleanup; ret = 0; -- 2.30.2