Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp74166iof; Sun, 5 Jun 2022 21:33:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzUgazl+m8nmR7dDYRx0VBkSeUA7Uo9iZhcdU9ejswuVv+Rma/vAfO9dAe4OwFJ1wblELMV X-Received: by 2002:a63:8641:0:b0:3fd:94e8:a650 with SMTP id x62-20020a638641000000b003fd94e8a650mr5785784pgd.367.1654489992320; Sun, 05 Jun 2022 21:33:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654489992; cv=none; d=google.com; s=arc-20160816; b=t3f7zsiqKHRwMZt4hECzoEDYI3ZalYgMTa6YhrRRJDCH8Ru+IZEViv/K5+NdbmVe47 akU0q1epKVgCQ7OmhDUXhguKVmZtntDY54TQxMnZ/vRz2wBBWSpJ4uyi1RXZ21yG6ew+ nH7XF37g8DbAdPy5AOxAhUKWxFK784kQCIMhl5acIWeTSkI9IOupXWvbLCdIA98f/n3t xSQ55i/LLvVL0i1w6h6OTcCpHeknVjysQttRZrnytWoIElSMpT+6uRGGUg6Pobu9C9+s t2qqOfrFiIgQ2WC8a1lNSaAc0enfHsBFdkJwhiV9/9h/VhxA3nYbYhedEgHcXHhySCyR cjAw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=pWb05ClHmJuc3d15U8X+zctrU2tw1LsTSZw71z5quKs=; b=J6KfpOvmjxPmxenwPYNcnK8rboVOGHzjFGdaS1JGKSK2mPhUh8xoFo7/EAI8aDPQuI urNW1oNWnxlEqMwMJa5JxzUaX+zam+g+S3KHvm5mLAUllEPG86xTtTqrEyVYyTGstYn1 d14Wsj+ur6MVNgHz0vK2ugmDOX9Q8N8kX3mxLoj9HXSmwbo/4pYYMWh8rB+dm6cdKs8j cYHdayNJBmsZ9W3c9qqXSsr0GQOosFPOIAU+QDiGgS3q+tbVQ3Ym77x56G8uFHYxqoiE RESgAt/2QsqwKpjuiFPIIBMeyZ5jBvtDdfFjpAmtfYFYaTlQ3A6apw8fqUxRMZ5yLbn7 vK+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=HWpaPlBg; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id z16-20020a170903019000b00163daed2483si21850955plg.313.2022.06.05.21.33.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 05 Jun 2022 21:33:12 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=HWpaPlBg; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 893361A385; Sun, 5 Jun 2022 20:59:16 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352220AbiFFC62 (ORCPT + 99 others); Sun, 5 Jun 2022 22:58:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50410 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352189AbiFFC6Z (ORCPT ); Sun, 5 Jun 2022 22:58:25 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 79D39E083 for ; Sun, 5 Jun 2022 19:58:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1654484302; h=from:from:reply-to:subject:subject: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=pWb05ClHmJuc3d15U8X+zctrU2tw1LsTSZw71z5quKs=; b=HWpaPlBgJgqBykUE3qCwZd+dNI2WZ0KqR7n+gbQy2IuUkvWeNLIBy92ZaLxT6QLYxP5VwJ yBryawj0XFaS+BgfAdFYAWYhXU7xjz8A4ENR7xIwudvLpMCz/aTCjsOLyutzdATdB84/66 PggcF/xP/cg2aXypyF9YGmKvpl8uB/E= Received: from mimecast-mx02.redhat.com (mx3-rdu2.redhat.com [66.187.233.73]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-582-jKsharMZPtm2Dlrz80OLWw-1; Sun, 05 Jun 2022 22:58:16 -0400 X-MC-Unique: jKsharMZPtm2Dlrz80OLWw-1 Received: from smtp.corp.redhat.com (int-mx10.intmail.prod.int.rdu2.redhat.com [10.11.54.10]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 0A2F71E7DCC7; Mon, 6 Jun 2022 02:58:16 +0000 (UTC) Received: from [10.22.32.31] (unknown [10.22.32.31]) by smtp.corp.redhat.com (Postfix) with ESMTP id B40DE492C3B; Mon, 6 Jun 2022 02:58:15 +0000 (UTC) Message-ID: <9272d9ba-1b34-991b-78b5-beca5e170a23@redhat.com> Date: Sun, 5 Jun 2022 22:58:15 -0400 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.0 Subject: Re: [PATCH v6 3/3] blk-cgroup: Optimize blkcg_rstat_flush() Content-Language: en-US To: Ming Lei Cc: Tejun Heo , Jens Axboe , cgroups@vger.kernel.org, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org References: <20220602192020.166940-1-longman@redhat.com> <20220602192020.166940-4-longman@redhat.com> From: Waiman Long In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.85 on 10.11.54.10 X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE, T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 On 6/5/22 22:23, Ming Lei wrote: > On Sun, Jun 05, 2022 at 09:59:50PM -0400, Waiman Long wrote: >> On 6/5/22 21:39, Ming Lei wrote: >>> On Sun, Jun 05, 2022 at 07:15:27PM -0400, Waiman Long wrote: >>>> On 6/3/22 23:58, Ming Lei wrote: >>>> >>>>> diff --git a/mm/memcontrol.c b/mm/memcontrol.c >>>>> index abec50f31fe6..8c4f204dbf5b 100644 >>>>> --- a/mm/memcontrol.c >>>>> +++ b/mm/memcontrol.c >>>>> @@ -622,7 +622,7 @@ static inline void memcg_rstat_updated(struct mem_cgroup *memcg, int val) >>>>> { >>>>> unsigned int x; >>>>> - cgroup_rstat_updated(memcg->css.cgroup, smp_processor_id()); >>>>> + cgroup_rstat_updated(memcg->css.cgroup, smp_processor_id(), NULL); >>>>> x = __this_cpu_add_return(stats_updates, abs(val)); >>>>> if (x > MEMCG_CHARGE_BATCH) { >>>> I think the rstat set of functions are doing that already. So flush will >>>> only call CPUs that have called cgroup_rstat_updated() before. However, one >>> Yeah, I guess the detail is in cgroup_rstat_cpu_pop_updated(), but the >>> percpu lock(raw_spin_lock_irqsave) is still required, and cgroup_rstat_cpu_pop_updated() >>> is still called even through there isn't any update on this CPU. >> Yes, I think we may need to add a bitmask of what controllers have updates >> in cgroup_rstat_cpu structure. >>>> deficiency that I am aware of is that there is no bitmap of which controller >>>> have update. The problem that I saw in cgroup v2 is that in a cgroup with >>>> both memory controller and block controller enabled, a >>>> cgroup_rstat_updated() call from memory cgroup later causes the rstat >>>> function to call into block cgroup flush method even though there is no >>>> update in the block controller. This is an area that needs improvement. >>>> >>>> Your code does allow the block controller to be aware of that and avoid >>>> further action, but I think it has to be done in the rstat code to be >>>> applicable to all controllers instead of just specific to block controller. >>> I guess it can be done by adding one percpu variable to 'struct cgroup'. >>> >>>> There is another problem that this approach. Suppose the system have 20 >>>> block devices and one of them has an IO operation. Now the flush method >>>> still needs to iterate all the 20 blkg's to do an update. The block >>>> controller is kind of special that the number of per-cgroup IO stats depends >>>> on the number of block devices present. Other controllers just have one set >>>> of stats per cgroup. >>> Yeah, and this one is really blkio specific issue, and your patch does >>> cover this one. Maybe you can add one callback to >>> cgroup_rstat_updated(), so the "blkg_iostat_set" instance is added into >>> percpu list under percpu lock of cgroup_rstat_cpu_lock, then the lockless >>> list isn't needed. >> The rstat API is generic. It may not be a good idea to put controller >> specific information into it. Yes, cgroup_rstat_cpu_lock is taken at the >> read side (flush). It may not taken on the write side (update). So it may > Both cgroup_rstat_flush_locked()/cgroup_rstat_updated() take the percpu > cgroup_rstat_cpu_lock, so the new invented lockless list can be > replaced with plain list. cgroup_rstat_updated() should only take the percpu cgroup_rstat_cpu_lock the first time it transition from "!updated" to "updated". After that, it returns immediately without the the lock. With a regular list, you will have to take the lock every time a new block device has an update. So there isn't much saving on the update side. In general, the lock/unlock sequence has a bit more overhead than the lockless insertion. On the flush side, there may be a bit of saving, but it is not the fast path. Cheers, Longman