Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3759378imu; Mon, 28 Jan 2019 10:16:18 -0800 (PST) X-Google-Smtp-Source: ALg8bN4ogrq22+nbdZxFL2Q2/sPwesZd+MZCBKd1Ge3l+WIN1s9YitSlrkNvEGnMK3SQGmj3mBnf X-Received: by 2002:a62:59c9:: with SMTP id k70mr22790502pfj.243.1548699378604; Mon, 28 Jan 2019 10:16:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548699378; cv=none; d=google.com; s=arc-20160816; b=LqvOSvvANRA6keBF/q65wMW0oPgwaPdupvVA4yOk7fGwV0R9qV3UTKii5RgCaFju9b QBM1es/pKb9fzEXrVUyo1Xcg3WeMXvcaPoJ+FDP3CoCU8qIZh5M7oVnCTK0bQQNB9tCZ ufEj8KwD/YssEQAnHd+QaTJWwfZF80dc86dYb1Xtq+IR5k/kE8gJEO3cfWLG6BwwdSEN qrtBjq2dxn0VfpSOphfw3a786/lBshW4Tsh9/aQTNXMY5YNNdSlzGijHs38uzXDIF8ya 4GDF1igGtzgk+JyySfDq50j3+kNLtEn0nx2JevgfLRj7RE1la0Tj6hDFwYOJ2QAoy7j/ WDsg== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=YLQfkP1Yh3Zq7Vw4IS447I2kGeznx+nwCzDsqeofSZE=; b=eyIPC056kGFq1xnIYgpmdCC5GBWQ7c4/53YT8BtVu7sJTAlQpp2dUPRVOGV2D/D7NW OEQyyIgOUix11+PcKzLq4+iKUh7IGEkjDt2A5tA5zP1WDIex3e8IInJ4moe8ii0Q+Iqb jpkODD2RkoD9tZ2W80TIp9PIeTMbmhg/sLiuPpyjCLKiFo1xsMQhkyyRU88t6NDNfhA4 dwL3Xddjy0df2ohFeE2ABwiZV+fj87MlAf1yFg4GCN427cnSPNAkY6fleZRVutj/sQeS 1CHhKpxaf381694EOekjwRwJAPbybuMEdTvc7FcewFMXba+nPO+Akun5KlG8u4UciZFh Xesg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f5si34107875plo.422.2019.01.28.10.16.02; Mon, 28 Jan 2019 10:16:18 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726942AbfA1SPR (ORCPT + 99 others); Mon, 28 Jan 2019 13:15:17 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:57238 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726735AbfA1SPR (ORCPT ); Mon, 28 Jan 2019 13:15:17 -0500 Received: from akpm3.svl.corp.google.com (unknown [104.133.8.65]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 32F7E25CE; Mon, 28 Jan 2019 18:15:15 +0000 (UTC) Date: Mon, 28 Jan 2019 10:15:13 -0800 From: Andrew Morton To: Tetsuo Handa Cc: Michal Hocko , Arkadiusz =?UTF-8?Q?Mi=C5=9Bkiewicz?= , Tejun Heo , cgroups@vger.kernel.org, Aleksa Sarai , Jay Kamat , Roman Gushchin , Johannes Weiner , linux-kernel@vger.kernel.org, Linus Torvalds , linux-mm Subject: Re: [PATCH v3] oom, oom_reaper: do not enqueue same task twice Message-Id: <20190128101513.f35752d6210f0781d0de8d17@linux-foundation.org> In-Reply-To: References: <480296c4-ed7a-3265-e84a-298e42a0f1d5@I-love.SAKURA.ne.jp> <6da6ca69-5a6e-a9f6-d091-f89a8488982a@gmail.com> <72aa8863-a534-b8df-6b9e-f69cf4dd5c4d@i-love.sakura.ne.jp> <33a07810-6dbc-36be-5bb6-a279773ccf69@i-love.sakura.ne.jp> <34e97b46-0792-cc66-e0f2-d72576cdec59@i-love.sakura.ne.jp> <2b0c7d6c-c58a-da7d-6f0a-4900694ec2d3@gmail.com> <1d161137-55a5-126f-b47e-b2625bd798ca@i-love.sakura.ne.jp> <20190127083724.GA18811@dhcp22.suse.cz> <20190127114021.GB18811@dhcp22.suse.cz> X-Mailer: Sylpheed 3.6.0 (GTK+ 2.24.31; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 27 Jan 2019 23:57:38 +0900 Tetsuo Handa wrote: > Arkadiusz reported that enabling memcg's group oom killing causes > strange memcg statistics where there is no task in a memcg despite > the number of tasks in that memcg is not 0. It turned out that there > is a bug in wake_oom_reaper() which allows enqueuing same task twice > which makes impossible to decrease the number of tasks in that memcg > due to a refcount leak. > > This bug existed since the OOM reaper became invokable from > task_will_free_mem(current) path in out_of_memory() in Linux 4.7, > but memcg's group oom killing made it easier to trigger this bug by > calling wake_oom_reaper() on the same task from one out_of_memory() > request. > > Fix this bug using an approach used by commit 855b018325737f76 > ("oom, oom_reaper: disable oom_reaper for oom_kill_allocating_task"). > As a side effect of this patch, this patch also avoids enqueuing > multiple threads sharing memory via task_will_free_mem(current) path. > Do we think this is serious enough to warrant a -stable backport?