From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-0.8 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C2C87C10F29 for ; Tue, 10 Mar 2020 00:48:57 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 8209C2467E for ; Tue, 10 Mar 2020 00:48:57 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=kernel.org header.i=@kernel.org header.b="m2SM3CNe" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 8209C2467E Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=linux-foundation.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 0B27B6B0085; Mon, 9 Mar 2020 20:48:57 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 063946B0087; Mon, 9 Mar 2020 20:48:57 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id EB9AA6B0088; Mon, 9 Mar 2020 20:48:56 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0142.hostedemail.com [216.40.44.142]) by kanga.kvack.org (Postfix) with ESMTP id D0DBF6B0085 for ; Mon, 9 Mar 2020 20:48:56 -0400 (EDT) Received: from smtpin26.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay05.hostedemail.com (Postfix) with ESMTP id 6C494181AC1F5 for ; Tue, 10 Mar 2020 00:48:56 +0000 (UTC) X-FDA: 76577617872.26.level45_30e6febf0e814 X-HE-Tag: level45_30e6febf0e814 X-Filterd-Recvd-Size: 2899 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by imf49.hostedemail.com (Postfix) with ESMTP for ; Tue, 10 Mar 2020 00:48:55 +0000 (UTC) Received: from localhost.localdomain (c-73-231-172-41.hsd1.ca.comcast.net [73.231.172.41]) (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 21F192146E; Tue, 10 Mar 2020 00:48:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1583801335; bh=MyWY5amDJAzJzdzhFcv6Tu9m3xmj/uJuETu5vTpbu1E=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=m2SM3CNeB9AYYwMegS2jCzUUGfrXy4qy+7yHmzpz470bfnGsfowU9w1uN04i1PjNS NPr39yPhzzG/w7UlNxW5oRW4PH5Ukm7/+fUWgOqN8Rk6XTj+mzCpMcXBWHGnfsyjvT JWHDqz5vyedqi0m4W3YIlVS5G458CGUYD97ld12Y= Date: Mon, 9 Mar 2020 17:48:54 -0700 From: Andrew Morton To: Wei Yang Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, Tim Chen Subject: Re: [PATCH] mm/swap_slots.c: don't reset the cache slot after use Message-Id: <20200309174854.b6b8c7f019c3dde048c28f94@linux-foundation.org> In-Reply-To: <20200309090940.34130-1-richard.weiyang@linux.alibaba.com> References: <20200309090940.34130-1-richard.weiyang@linux.alibaba.com> X-Mailer: Sylpheed 3.5.1 (GTK+ 2.24.31; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Mon, 9 Mar 2020 17:09:40 +0800 Wei Yang wrote: > Currently we would clear the cache slot if it is used. While this is not > necessary, since this entry would not be used until refilled. > > Leave it untouched and assigned the value directly to entry which makes > the code little more neat. > > Also this patch merges the else and if, since this is the only case we > refill and repeat swap cache. cc Tim, who can hopefully remember how this code works ;) > --- a/mm/swap_slots.c > +++ b/mm/swap_slots.c > @@ -309,7 +309,7 @@ int free_swap_slot(swp_entry_t entry) > > swp_entry_t get_swap_page(struct page *page) > { > - swp_entry_t entry, *pentry; > + swp_entry_t entry; > struct swap_slots_cache *cache; > > entry.val = 0; > @@ -336,13 +336,10 @@ swp_entry_t get_swap_page(struct page *page) > if (cache->slots) { > repeat: > if (cache->nr) { > - pentry = &cache->slots[cache->cur++]; > - entry = *pentry; > - pentry->val = 0; > + entry = cache->slots[cache->cur++]; > cache->nr--; > - } else { > - if (refill_swap_slots_cache(cache)) > - goto repeat; > + } else if (refill_swap_slots_cache(cache)) { > + goto repeat; > } > } > mutex_unlock(&cache->alloc_lock); > -- > 2.20.1 (Apple Git-117)