Received: by 2002:a05:7412:3784:b0:e2:908c:2ebd with SMTP id jk4csp1811803rdb; Tue, 3 Oct 2023 01:23:57 -0700 (PDT) X-Google-Smtp-Source: AGHT+IE4fY7nAixOfNbWs8hXVDDbgNjEkGM8hlcLZacDnsoU+LxT3UniVeAB1g9XI51xNUYCO/3Q X-Received: by 2002:a5b:609:0:b0:d81:bd92:d0c with SMTP id d9-20020a5b0609000000b00d81bd920d0cmr12663768ybq.61.1696321436746; Tue, 03 Oct 2023 01:23:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696321436; cv=none; d=google.com; s=arc-20160816; b=VEYo6yGq43b9E36OWueHpeYCt/YB40uyf+t9WNxV2MbxHGo1xXp1L+kuGut+28mKVG jsmjprjauvLn9uX+muKvN+O16Bz/LLihwDPGkY6hwKII4OEjT3n6/yFpHPhejHysWM4O fHjRFYG859BRPEmykCWXb90zHPLSC+iHX9KLW2UP5p7bIh58B5/YVqz+jcirz7SVRAJ4 0ir7P5b9QGcfnPlwlD2sIQAOPFK5Ou6ugarxxZ+vd3iVSE7PvROMtlP3+PRTczTY/KED 1ea4YKzeX4HYw+KVLPJ/uW80CHQxUnU2sKdpQgwllekbZowNK3u+QX412kT88tjN4zmo SriA== 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=8zGAxBJBJ/nKdlR2cgsT4LA+cPc2AG65Q41ph8MLLtE=; fh=ab/I2PCEna5sDgvkoEtl0bZy8pjIneQyEazJiNuJ00g=; b=Wr4/TZazjo0NEWMjOfCVBUg0jWne1O9nD0qGB6LGzmysPC/5PmiZa7DXsKvvoxhmjO TPIQPxBP75UIOdat0kXrd7NGm28PXopPdI92pwsn3USzqCrjF07SlaXSihwEwTOpfqsB X8NZ1pRYjus5eRwOa1FF5FQHRsC3Ea4TXkqHDl37BMLE5gouj3ZG9/nsT/V5Is/00FGd X0RWnS9NQYoI9xaGifNorZAxzAOtaD9T7Ikpye2vhfEwvWu/3XW8taAm65zq5I1dQsMK w0YmzGxfSZPZtdduRn/wlH1M0Af2SWeawUgWMU5IsPM7jMzWzCh03U/6BN9MqQAWEx/W 0vUw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b="N/cv9Xs5"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=suse.com Return-Path: Received: from pete.vger.email (pete.vger.email. [23.128.96.36]) by mx.google.com with ESMTPS id u11-20020a6540cb000000b00565aa20a07asi879672pgp.683.2023.10.03.01.23.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Oct 2023 01:23:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) client-ip=23.128.96.36; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b="N/cv9Xs5"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=suse.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id ADE51802B009; Tue, 3 Oct 2023 01:23:53 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239932AbjJCIXg (ORCPT + 99 others); Tue, 3 Oct 2023 04:23:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59298 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239473AbjJCIX1 (ORCPT ); Tue, 3 Oct 2023 04:23:27 -0400 Received: from smtp-out1.suse.de (smtp-out1.suse.de [195.135.220.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8AE59173F; Tue, 3 Oct 2023 01:09:51 -0700 (PDT) Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id EEBB32188D; Tue, 3 Oct 2023 08:09:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1696320589; 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=8zGAxBJBJ/nKdlR2cgsT4LA+cPc2AG65Q41ph8MLLtE=; b=N/cv9Xs5HY+XMUn5vcDhxDnfnmcLRn0BE1jaeLTWpl41lyhceJyEaLNmVwyGG9KKSf9cy1 ey0aR+GzSoh6XfWvi/n3DqWRLQcJJOZ0vl8H6qJhVXR2l+gBoyRdvLDc64U2c1P/JbLrgi YOR/Fv/5diZYz/Zfn2rG4dVmfu4NjHM= Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 8805C132D4; Tue, 3 Oct 2023 08:09:49 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id V2XoH03MG2WuKQAAMHmgww (envelope-from ); Tue, 03 Oct 2023 08:09:49 +0000 Date: Tue, 3 Oct 2023 10:09:48 +0200 From: Michal Hocko To: Yosry Ahmed Cc: Andrew Morton , Shakeel Butt , Johannes Weiner , Roman Gushchin , Muchun Song , Michal =?iso-8859-1?Q?Koutn=FD?= , linux-mm@kvack.org, cgroups@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 0/2] mm: memcg: fix tracking of pending stats updates values Message-ID: References: <20230922175741.635002-1-yosryahmed@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Tue, 03 Oct 2023 01:23:53 -0700 (PDT) On Tue 03-10-23 01:03:53, Yosry Ahmed wrote: > On Tue, Oct 3, 2023 at 12:57 AM Michal Hocko wrote: > > > > On Mon 25-09-23 10:11:05, Yosry Ahmed wrote: > > > On Mon, Sep 25, 2023 at 6:50 AM Michal Hocko wrote: > > > > > > > > On Fri 22-09-23 17:57:38, Yosry Ahmed wrote: > > > > > While working on adjacent code [1], I realized that the values passed > > > > > into memcg_rstat_updated() to keep track of the magnitude of pending > > > > > updates is consistent. It is mostly in pages, but sometimes it can be in > > > > > bytes or KBs. Fix that. > > > > > > > > What kind of practical difference does this change make? Is it worth > > > > additional code? > > > > > > As explained in patch 2's commit message, the value passed into > > > memcg_rstat_updated() is used for the "flush only if not worth it" > > > heuristic. As we have discussed in different threads in the past few > > > weeks, unnecessary flushes can cause increased global lock contention > > > and/or latency. > > > > > > Byte-sized paths (percpu, slab, zswap, ..) feed bytes into the > > > heuristic, but those are interpreted as pages, which means we will > > > flush earlier than we should. This was noticed by code inspection. How > > > much does this matter in practice? I would say it depends on the > > > workload: how many percpu/slab allocations are being made vs. how many > > > flushes are requested. > > > > > > On a system with 100 cpus, 25M of stat updates are needed for a flush > > > usually, but ~6K of slab/percpu updates will also (mistakenly) cause a > > > flush. > > > > This surely depends on workload and that is understandable. But it would > > be really nice to provide some numbers for typical workloads which > > exercise slab heavily. > > If you have a workload in mind I can run it and see how many flushes > we get with/without this patch. The first thing that pops into my head > is creating a bunch of empty files but I don't know if that's the best > thing to get numbers from. Let me remind you that you are proposing a performance optimization and such a change requires some numbers to actually show it is benefitial. There are cases where the resulting code is clearly an improvement and the performance benefit is just a nice side effect. I do not consider this to be the case. The whole thing is quite convoluted even without a better precision you are proposing. And let me be clear, I am not opposing your patch but I would rather see it based on more than just hand waving. -- Michal Hocko SUSE Labs