Received: by 10.223.164.202 with SMTP id h10csp307569wrb; Tue, 14 Nov 2017 15:57:06 -0800 (PST) X-Google-Smtp-Source: AGs4zMaBii44v4FyeVk9QzK9OHTyQnDifotxDaOxJYHoBLyzhD/9A/cxKduRDVDyr5kqKHqRBX4D X-Received: by 10.99.113.72 with SMTP id b8mr13914097pgn.42.1510703826266; Tue, 14 Nov 2017 15:57:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510703826; cv=none; d=google.com; s=arc-20160816; b=vTwwna91ovyB0VBf99twxSJ0U6ixSJl0njb98nR52vEj4woXsedumQ1lAxUUIs9zNZ 8/xh2TNyykR06sA+FOKS+fMtNaKYgF1bj5760CM0K9ZNCkMo088Fw3OECeHFBV1kjTpj yAP4P8kyfO326IpWEuJAVan+CPPB+JIqnY2cMC1N7bvu8rgofZjGvcqkbYZxqgv6jzlm rybzlW4C4ZSGGk/39CbFhrn94WHgeoUpK8QY2Gh+do1hH9lipPHnLr+GeF+H7F13JvAi 80V1NnOC+YLYD6rhuCT5vZqZ3qdaiZB+n+zC9HWerM1noZVktXBcm5be0apaw+fKJamt Fmqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dmarc-filter:arc-authentication-results; bh=wjIweWx5g0Xp/tAKSwLxhumKifk/wc7mxr+UMLgrDdc=; b=hp1MYDfiMuACbuYIaptiNA705BJsLtQ7F4FuIcNkGdzrjg4h49DBrTDygeIjMKueo7 92mXHvn2/vuFJhEvD07ywBkIbIlQ/JRl6ShG8v6iIOO6XI+3Uc5253GuglWof1IZpGys 8a70ghlEgZ+kANQZCh6v91B0bHDlFMQ8NSnetpl4XvISASbnWUfpNug/45ScZ6MlJQmq IDGVIz5A4xs4+CIliZXU8jOhPRkX5LwuLqdWfJPOnhTbveBarvtFpfMJyq558Ue7lP2D rOl+bzkczrOchgWm63tifoMGcAPx+SGyHO7/jlQe0bvGJsdxsdEuSZTXsb3YZ4SnS3fd VSnA== 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 t18si17584789plo.255.2017.11.14.15.56.54; Tue, 14 Nov 2017 15:57:06 -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 S1756224AbdKNXMf (ORCPT + 87 others); Tue, 14 Nov 2017 18:12:35 -0500 Received: from mail.kernel.org ([198.145.29.99]:49538 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754709AbdKNXM2 (ORCPT ); Tue, 14 Nov 2017 18:12:28 -0500 Received: from kernel.org (unknown [199.201.64.138]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C46FA21872; Tue, 14 Nov 2017 23:12:27 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org C46FA21872 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=shli@kernel.org Date: Tue, 14 Nov 2017 15:12:26 -0800 From: Shaohua Li To: Tejun Heo Cc: axboe@kernel.dk, linux-kernel@vger.kernel.org, kernel-team@fb.com, lizefan@huawei.com, hannes@cmpxchg.org, cgroups@vger.kernel.org, guro@fb.com Subject: Re: [PATCH 1/7] blkcg: relocate __blkg_release_rcu() Message-ID: <20171114231226.bnqrb2xadiw7ba2q@kernel.org> References: <20171112222613.3613362-1-tj@kernel.org> <20171112222613.3613362-2-tj@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20171112222613.3613362-2-tj@kernel.org> User-Agent: NeoMutt/20170609 (1.8.3) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Nov 12, 2017 at 02:26:07PM -0800, Tejun Heo wrote: > Move __blkg_release_rcu() above blkg_alloc(). This is a pure code > reorganization to prepare for the switch to percpu_ref. > > Signed-off-by: Tejun Heo Reviewed-by: Shaohua Li > --- > block/blk-cgroup.c | 46 +++++++++++++++++++++++----------------------- > 1 file changed, 23 insertions(+), 23 deletions(-) > > diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c > index d3f56ba..6482be5 100644 > --- a/block/blk-cgroup.c > +++ b/block/blk-cgroup.c > @@ -81,6 +81,29 @@ static void blkg_free(struct blkcg_gq *blkg) > kfree(blkg); > } > > +/* > + * A group is RCU protected, but having an rcu lock does not mean that one > + * can access all the fields of blkg and assume these are valid. For > + * example, don't try to follow throtl_data and request queue links. > + * > + * Having a reference to blkg under an rcu allows accesses to only values > + * local to groups like group stats and group rate limits. > + */ > +void __blkg_release_rcu(struct rcu_head *rcu_head) > +{ > + struct blkcg_gq *blkg = container_of(rcu_head, struct blkcg_gq, rcu_head); > + > + /* release the blkcg and parent blkg refs this blkg has been holding */ > + css_put(&blkg->blkcg->css); > + if (blkg->parent) > + blkg_put(blkg->parent); > + > + wb_congested_put(blkg->wb_congested); > + > + blkg_free(blkg); > +} > +EXPORT_SYMBOL_GPL(__blkg_release_rcu); > + > /** > * blkg_alloc - allocate a blkg > * @blkcg: block cgroup the new blkg is associated with > @@ -378,29 +401,6 @@ static void blkg_destroy_all(struct request_queue *q) > } > > /* > - * A group is RCU protected, but having an rcu lock does not mean that one > - * can access all the fields of blkg and assume these are valid. For > - * example, don't try to follow throtl_data and request queue links. > - * > - * Having a reference to blkg under an rcu allows accesses to only values > - * local to groups like group stats and group rate limits. > - */ > -void __blkg_release_rcu(struct rcu_head *rcu_head) > -{ > - struct blkcg_gq *blkg = container_of(rcu_head, struct blkcg_gq, rcu_head); > - > - /* release the blkcg and parent blkg refs this blkg has been holding */ > - css_put(&blkg->blkcg->css); > - if (blkg->parent) > - blkg_put(blkg->parent); > - > - wb_congested_put(blkg->wb_congested); > - > - blkg_free(blkg); > -} > -EXPORT_SYMBOL_GPL(__blkg_release_rcu); > - > -/* > * The next function used by blk_queue_for_each_rl(). It's a bit tricky > * because the root blkg uses @q->root_rl instead of its own rl. > */ > -- > 2.9.5 > From 1583901006045663523@xxx Sun Nov 12 22:28:29 +0000 2017 X-GM-THRID: 1583901006045663523 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread