Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp4090025pxb; Tue, 26 Jan 2021 12:06:54 -0800 (PST) X-Google-Smtp-Source: ABdhPJyiankBH5/RTeKADCeK63FZRZ3d7Nnu21CN3/qOcdIEjVF9lHfrbn3KLc9lS8cHaM0MPzKk X-Received: by 2002:aa7:c3c4:: with SMTP id l4mr5727360edr.255.1611691614750; Tue, 26 Jan 2021 12:06:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611691614; cv=none; d=google.com; s=arc-20160816; b=yWKyMDo1uYY9aA1Mrio1X14AJ//X8rhDTdYR4OoM9KJZonqxgU4jqIFKCoBEmNvXCP JFbpTythlg0u6wEgbTYbtAZBtsJDmX8fa9Flgk/12nBlr5p52PLYmQ3NhuSO+eOOTuWa t0G9Y/ij6XjqEy+dKnTlZpsUrDMgR8WRmHPG5FXHTSGf21p2FbklgvWJxnD9RPDZDs/Z VZKXMjusdQX/4CWrx9doFkQuTYfaNzMNzhi9ya45a60HzNVLnEYVAnDIxVP3zzoOYT2E lrs0AZrYL3ERAZbO+sXUYMPzaw+CypGl+qT7TeqsbBIDRN3XOGTecMgVybx+5aSFv5Xg lB2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=9slJ+Ud3Qp4uGdxPfooc/fvRWSdUmMjQcd1zwclQhNE=; b=RnYMu3YkZX5LYafWLiFLmk6rcs9vcJVisHCWBgRlZbEbMJUNurJCRZ3SfFU3KKBXQK 6CYlRKJfJJ1+We4ZgSOm16KOkfhBzA2mjyweFlnUbwwR55AxuvPqyFWxuEpg9oQa0DNJ g2dalBPP4lQ8vj+U5u0BwmWQ86rG+uYGf7AFC4QwHCVXrkwCmyHJzLPgI6xa0jDvzr1v 78uC3AlcudqhLyW/vLaHWwgeSlv9fCgzvR06ZAhKofdXmfxlgI5gqixQenwCrOzJsYkB tTu2zU8YelaFwWaBVVvDjZMXnx69t9iEBjjHIgSh+72sARFziYj6eZn5EyjEikUFLxOW 7j2Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=BqSNfuQw; 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=NONE dis=NONE) header.from=suse.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c24si7584840eja.436.2021.01.26.12.06.29; Tue, 26 Jan 2021 12:06:54 -0800 (PST) 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=@suse.com header.s=susede1 header.b=BqSNfuQw; 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=NONE dis=NONE) header.from=suse.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2392758AbhAZRjz (ORCPT + 99 others); Tue, 26 Jan 2021 12:39:55 -0500 Received: from mx2.suse.de ([195.135.220.15]:34774 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389672AbhAZIBr (ORCPT ); Tue, 26 Jan 2021 03:01:47 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1611648061; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=9slJ+Ud3Qp4uGdxPfooc/fvRWSdUmMjQcd1zwclQhNE=; b=BqSNfuQw+L7EsMgvK+5Nq1aDStIFDn3EWnzSOTHH+JyJ+5H6YFgje+4FqkNJHtZg6w7OU4 hTRElZv2hMncP46wT1TZJGUYN0tZ/ab9xRlu8BHxw5UUs4p0GJZwzNOyRQxVGcAi/oq5yY 6cP3FJDMFNjT45b6GZ3jBF1neXenBOo= Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 762F5ADD6; Tue, 26 Jan 2021 08:01:01 +0000 (UTC) Date: Tue, 26 Jan 2021 09:01:00 +0100 From: Michal Hocko To: Waiman Long Cc: Johannes Weiner , Matthew Wilcox , Andrew Morton , Alex Shi , linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm/filemap: Adding missing mem_cgroup_uncharge() to __add_to_page_cache_locked() Message-ID: <20210126080100.GC827@dhcp22.suse.cz> References: <20210125042441.20030-1-longman@redhat.com> <20210125092815.GB827@dhcp22.suse.cz> <20210125160328.GP827@dhcp22.suse.cz> <20210125162506.GF308988@casper.infradead.org> <20210125164118.GS827@dhcp22.suse.cz> <20210125181436.GV827@dhcp22.suse.cz> <53eb7692-e559-a914-e103-adfe951d7a7c@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon 25-01-21 13:57:18, Waiman Long wrote: > On 1/25/21 1:52 PM, Johannes Weiner wrote: > > On Mon, Jan 25, 2021 at 01:23:58PM -0500, Waiman Long wrote: > > > On 1/25/21 1:14 PM, Michal Hocko wrote: [...] > > > > With the proposed simplification by Willy > > > > Acked-by: Michal Hocko > > > Thank for the ack. However, I am a bit confused about what you mean by > > > simplification. There is another linux-next patch that changes the condition > > > for mem_cgroup_charge() to > > > > > > -?????? if (!huge) { > > > +?????? if (!huge && !page_is_secretmem(page)) { > > > ??????????????? error = mem_cgroup_charge(page, current->mm, gfp); > > > > > > That is the main reason why I introduced the boolean variable as I don't > > > want to call the external page_is_secretmem() function twice. > > The variable works for me. > > > > On the other hand, as Michal points out, the uncharge function will be > > called again on the page when it's being freed (in non-fscache cases), > > so you're already relying on being able to call it on any page - > > charged, uncharged, never charged. It would be fine to call it > > unconditionally in the error path. Aesthetic preference, I guess. Yes aesthetic preference... Just compare to diff --git a/mm/filemap.c b/mm/filemap.c index 5c9d564317a5..7aa05420107e 100644 --- a/mm/filemap.c +++ b/mm/filemap.c @@ -896,11 +896,14 @@ noinline int __add_to_page_cache_locked(struct page *page, if (xas_error(&xas)) { error = xas_error(&xas); - goto error; + goto error_uncharge; } trace_mm_filemap_add_to_page_cache(page); return 0; +error_uncharge: + /* memcg will ignore uncharged pages */ + mem_cgroup_uncharge(page); error: page->mapping = NULL; /* Leave page->index set: truncation relies upon it */ which resembles our usual state unwinding style much more. > That may be true. However, I haven't fully studied how the huge page memory > accounting work to make sure the uncharge function can be called for huge > pages. ... but this is rather lame argument to make, don't you think. This sounds like a ducktaping engineering to me. Over time this leads to a terrible code. Seriously! All that being said I do not want to block this or bother people with more emails but geez -- Michal Hocko SUSE Labs