Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp847387imm; Fri, 17 Aug 2018 07:39:29 -0700 (PDT) X-Google-Smtp-Source: AA+uWPxvTy9uNCYVHHgP4kxTJ42CormpdfP9kRbVt8Wb9BmWtQZeWWkpbRS6EXHVtm377jMtGD98 X-Received: by 2002:a17:902:bd44:: with SMTP id b4-v6mr17478451plx.144.1534516769049; Fri, 17 Aug 2018 07:39:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534516769; cv=none; d=google.com; s=arc-20160816; b=GXg6Jq08mWA6JeroBEF9CdsdFzeu2N0vAkOkclE0jiJcOaEJtWi03HXO2vuLlxNB1U XFyY0KOJMw9Fk6jWj2d6Uj5tAZ5iLgQ23gV7MBu+K+uSyjSJQ5MKS9SK9ni/GxsOBuXM pQq9CglDSfKOu2JPmiefkXQn8jWhBktIHvaO1wHoGvo/k0c+lV/ru3MUY9hb7w23qGCu 57hQkQWnODN2lAdLwa6OhCdUZxl0XKnxa+6Y6hpyZ9B3O1fuNQo2C92OBpTfcz+pebBb 40ddc1iWUaCfvS1lHo7lBtrhC8RSDYHOlRKN4a83+eMHSamCz58iaspsvn635IqhTUc2 xIXA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=21voVHpfAYO3jrVJiGvTsoWAh/mve2YqXmysnb0saMo=; b=L/c8h5++Gcqc1D+p2nJ3pmVesJDwm4LJkuIxjzqEjjGrUEvLyi7+qhyukqVsOoClHy nk5Y+AMK4IB72aCKrPip9t/kk6vkh26TINzWTm5of9+iwKdY7HqEi5Ku9/1otK90c6sQ ZYdp/mhUBxvn2rOeJpbL2vgdtWcWuJj4SW7iBYLpcdMMNQKy54/VEPZHb0OGzc44igMo SNk1T1Oz6Jbh35Bkn67BkP6sTxJD5U4Bf4Z+AwyIK284iXmNbxoYPA0pXnVVUQFOQims 0wr7UzpY0srAKjfcMlq4ZpUICSYWgI88hPQgNPMEUzb1bZmQleozQbA/7LEc5driAht+ 7IEQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=ZhVzzKVh; dkim=pass header.i=@codeaurora.org header.s=default header.b=ZhVzzKVh; 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 w1-v6si2443454plq.352.2018.08.17.07.39.13; Fri, 17 Aug 2018 07:39:29 -0700 (PDT) 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; dkim=pass header.i=@codeaurora.org header.s=default header.b=ZhVzzKVh; dkim=pass header.i=@codeaurora.org header.s=default header.b=ZhVzzKVh; 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 S1727592AbeHQRlj (ORCPT + 99 others); Fri, 17 Aug 2018 13:41:39 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:54344 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727428AbeHQRlj (ORCPT ); Fri, 17 Aug 2018 13:41:39 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 355656263A; Fri, 17 Aug 2018 14:38:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1534516683; bh=KvZGDdI9d79Ko9aMMWkqgXqJw+ZjKYPwalxl+JD2cUg=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=ZhVzzKVhLWF172f9sCRXDBqHINCZV939r1UYoTuhzxbOSU1/a7t9aDIk7mynu5qg5 Zqq89blxeBNDl82NezNGh0r1+xOVlwDWQ1scFBKNVpGZaRFF+UHjXA9ukP9zO6byXD Cp8x+4JI6xJ36hB/pWKsC2fNZUgcI2azFVYqwNe0= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [10.204.79.100] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: mojha@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id BF3A1622CE; Fri, 17 Aug 2018 14:38:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1534516683; bh=KvZGDdI9d79Ko9aMMWkqgXqJw+ZjKYPwalxl+JD2cUg=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=ZhVzzKVhLWF172f9sCRXDBqHINCZV939r1UYoTuhzxbOSU1/a7t9aDIk7mynu5qg5 Zqq89blxeBNDl82NezNGh0r1+xOVlwDWQ1scFBKNVpGZaRFF+UHjXA9ukP9zO6byXD Cp8x+4JI6xJ36hB/pWKsC2fNZUgcI2azFVYqwNe0= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org BF3A1622CE Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=mojha@codeaurora.org Subject: Re: Query on shrink list To: Al Viro Cc: linux-fsdevel@vger.kernel.org, lkml References: <301a5546-d326-d78e-3be6-41b5a6a08c0e@codeaurora.org> <20180817125812.GC6515@ZenIV.linux.org.uk> From: Mukesh Ojha Message-ID: Date: Fri, 17 Aug 2018 20:07:59 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180817125812.GC6515@ZenIV.linux.org.uk> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/17/2018 6:28 PM, Al Viro wrote: > On Fri, Aug 17, 2018 at 03:39:22PM +0530, Mukesh Ojha wrote: >> Hi Al Viro, >> >> Is there is reason we have kept data->found++, if the dentry already there >> in shrink list ? >> >> static enum d_walk_ret select_collect( >> ... >>         if (dentry->d_flags & DCACHE_SHRINK_LIST) { >>                 data->found++; >>         } else { >>   .. >> >> If the dentry is already there on shrink list, does it not mean that >> data->found is already non-zero ? > Nope. It can be on *another* shrink list - if two processes are doing > that... Ok, if we go out simply,  letting others to do the job will break `shrink_dcache_parent()` and if someone touched that dentry made the refcount > 0 while it is on shrink list  then owner will keep on looping in shrink_dentry_list() until refcount becomes 0 . Am i making sense here ? Thanks. Mukesh > >> Can't we just go out from here directly?