Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4197666pxk; Tue, 8 Sep 2020 13:17:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx21PuFWGkU/jnT0qMbkw/PDXkWnTbGmWl/PA/nQdgS8h0GmXrCAvH0eepcCDrar4JIBNSl X-Received: by 2002:a17:906:15cc:: with SMTP id l12mr181358ejd.7.1599596254704; Tue, 08 Sep 2020 13:17:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599596254; cv=none; d=google.com; s=arc-20160816; b=KZCjOEJHfV+UX6nA5NUEKU9sHKfm/8hipi42fJKcIUDVF8naNl6MfmNbpUomNS6UMb VIHQ0Nv6ZMxRW44zX8I7TDWNrIgyEnKbfknNGUU8wXPjbtCGF7WmpOqUXQV0KJ95iKaz b9+b/2VTzmNMGqcxwSW3zukaRW20cimMgO4yFB2tCXZQQ9qfa0uelKqVr8tQ46mNRFY0 eXJ6vvJZjhAQVUexfPD96Lbu8wrQk6QrJgSYFpLJJYqa5B9GWfJVPEJqGbbTMV50r7NA 242NyxtFJjMUqBu5Uqhm8gsvy/b3xEHJ2VHrGI+ex2dJ+AXuOxZorcm7yZJH+pG4LDxy 4bYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=pMy9QydvGYXmq6m644yJYpKQg15dAVP3dkQKfpEvB5U=; b=Rq69LIWvH/5RcrIwu1+yiIemJBCEK/l1DIsWByxAzJ9kwD8q78+HIWSiAzJbDVQKFD SF/NXraLFCy1YUTugs8+kLaNFD0ktn+iSaXCOOYwo8R/raC/AIccQUrCyyAwpCnwPpkO bBxFI0TIAnRl5WGhp9JF8Gkw6BSvLzaz2UWhOnUyrg5/lANfJHAkgrJzZPY+Aa04IgBn 0eRwr33BFpMHBy5aVxu3TkKlCgAqxd7pRpEE5OO0G4ghupJVwDWWhG/OXoGiyrD6VsfU G7KCm7gqi9SoiNLK97cdGzkCIrCqw+q8PAXM7wg1ZciY+pIZivu7iV+I07/FoRJiiDjq EmIg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cisco.com header.s=iport header.b=jCZK8OZ6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=cisco.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w13si62350ejc.261.2020.09.08.13.17.11; Tue, 08 Sep 2020 13:17:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@cisco.com header.s=iport header.b=jCZK8OZ6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=cisco.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730484AbgIHUOi (ORCPT + 99 others); Tue, 8 Sep 2020 16:14:38 -0400 Received: from rcdn-iport-9.cisco.com ([173.37.86.80]:59051 "EHLO rcdn-iport-9.cisco.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730634AbgIHUOd (ORCPT ); Tue, 8 Sep 2020 16:14:33 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=cisco.com; i=@cisco.com; l=1785; q=dns/txt; s=iport; t=1599596072; x=1600805672; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=T8mkCE6PfAz3UDsDi/PeT6rnbi3jy36h40OMXp16Ecg=; b=jCZK8OZ67a1lYCRulutuBlJ13wtVq7igOdRqKQokHP+OckMclQuQ58KZ wPCavBuUZa0qw1h1O+GliN6ZWXTX+7OfFwavQxMw3TVuj1rcSfgVuwmBn vklexWsVe6KNiXdYSJFGHv8wOkLt8MmTCqYwjamimMfO62drJJwpiarg9 8=; X-IronPort-AV: E=Sophos;i="5.76,406,1592870400"; d="scan'208";a="732193483" Received: from rcdn-core-4.cisco.com ([173.37.93.155]) by rcdn-iport-9.cisco.com with ESMTP/TLS/DHE-RSA-SEED-SHA; 08 Sep 2020 20:14:30 +0000 Received: from sjc-ads-9087.cisco.com (sjc-ads-9087.cisco.com [10.30.208.97]) by rcdn-core-4.cisco.com (8.15.2/8.15.2) with ESMTP id 088KETHu020960; Tue, 8 Sep 2020 20:14:30 GMT Received: by sjc-ads-9087.cisco.com (Postfix, from userid 396877) id BDD7AA40; Tue, 8 Sep 2020 13:14:29 -0700 (PDT) From: Julius Hemanth Pitti To: hannes@cmpxchg.org, mhocko@kernel.org, vdavydov.dev@gmail.com, akpm@linux-foundation.org, guro@fb.com Cc: cgroups@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, xe-linux-external@cisco.com, Julius Hemanth Pitti Subject: [PATCH v2] mm: memcg: yield cpu when we fail to charge pages Date: Tue, 8 Sep 2020 13:14:26 -0700 Message-Id: <20200908201426.14837-1-jpitti@cisco.com> X-Mailer: git-send-email 2.19.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Auto-Response-Suppress: DR, OOF, AutoReply X-Outbound-SMTP-Client: 10.30.208.97, sjc-ads-9087.cisco.com X-Outbound-Node: rcdn-core-4.cisco.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For non root CG, in try_charge(), we keep trying to charge until we succeed. On non-preemptive kernel, when we are OOM, this results in holding CPU forever. On SMP systems, this doesn't create a big problem because oom_reaper get a change to kill victim and make some free pages. However on a single-core CPU (or cases where oom_reaper pinned to same CPU where try_charge is executing), oom_reaper shall never get scheduled and we stay in try_charge forever. Steps to repo this on non-smp: 1. mount -t tmpfs none /sys/fs/cgroup 2. mkdir /sys/fs/cgroup/memory 3. mount -t cgroup none /sys/fs/cgroup/memory -o memory 4. mkdir /sys/fs/cgroup/memory/0 5. echo 40M > /sys/fs/cgroup/memory/0/memory.limit_in_bytes 6. echo $$ > /sys/fs/cgroup/memory/0/tasks 7. stress -m 5 --vm-bytes 10M --vm-hang 0 Signed-off-by: Julius Hemanth Pitti Acked-by: Roman Gushchin --- Changes in v2: - Added comments. - Added "Acked-by: Roman Gushchin ". --- mm/memcontrol.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/mm/memcontrol.c b/mm/memcontrol.c index cfa6cbad21d5..4f293bf8c7ed 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -2745,6 +2745,15 @@ static int try_charge(struct mem_cgroup *memcg, gfp_t gfp_mask, if (fatal_signal_pending(current)) goto force; + /* + * We failed to charge even after retries, give oom_reaper or + * other process a change to make some free pages. + * + * On non-preemptive, Non-SMP system, this is critical, else + * we keep retrying with no success, forever. + */ + cond_resched(); + /* * keep retrying as long as the memcg oom killer is able to make * a forward progress or bypass the charge if the oom killer -- 2.17.1