Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp71983rwb; Fri, 2 Sep 2022 10:20:46 -0700 (PDT) X-Google-Smtp-Source: AA6agR61+wD5okWvIbB+azhdULjgZv9g+oWpqS3X1fMHLq0PIF/8l9dJFQyVYuO35shQ66gXBKo/ X-Received: by 2002:a63:ff5a:0:b0:42c:61f:b81 with SMTP id s26-20020a63ff5a000000b0042c061f0b81mr22167196pgk.254.1662139245707; Fri, 02 Sep 2022 10:20:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662139245; cv=none; d=google.com; s=arc-20160816; b=fVu/vufhWdZrJyk3O+qRK0HB22kiXnr6Y9rPee8qjqadBrty3ZZ76ekjxG7MUbBI+W 7K8XEUYNnkH5XFwcXkM1FBqN8IvYk/vC84RYfSL74khR3tpshgRYXBVTBTtWxNbuWSku 4G5RYjEIKmAQjLPdIzpfClz+3JdMlO+M+FOveylsSI2/fE6e+qLNBFaXBUCAP3gXQMng rwgx3fquFas8hsA65q4uLgmKAXxYEMIrR6n/XpzZqPqGF3SIXvWZZe7xzfD5Uxr7n+Rw djGE0Ehek+dOWTMHyL0URhyWizA+7gGwTm1RFKSzu10D6Ze778UIKfBgdszBS3AUnHRP q/CA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=Z9IitS21cBtCKR6TZilE0ZEiEznv+RAyaJgr9VXDB18=; b=HxYYZXUxizI94sVBbOVFL25iehR9esCOpjOTR0utUfZzK2HeWm5aMkxtKW8t8HxCYR I3XOUVnVg9hYgsL2ZtSD7a3YA8tKQIIknPVIVhy+cSKC+DAuFV2du+FSt2pmtNnzS5W6 bsv4jr++LfGAvNQ3IgfS2eSJ81IyvBWf8fK7Srlxlp/EJHyq7Q4Xy6fy852UlRvhQdVl gahDPWE7yAtQs06MB6Y94XMAAd9ZyCTmt5SGVQPmiHkLnVQd2MX6/LizUyG4wrTNlYNo rE41ojpRrHTLVPF1eGpTcf27ONQyqsVW9esmJW06xtt6rTTVqM46sS9DSNcYyRazq4Ye rFsQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w29-20020aa79a1d000000b0052d9edab4e1si2509943pfj.86.2022.09.02.10.20.32; Fri, 02 Sep 2022 10:20:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236233AbiIBQtu (ORCPT + 99 others); Fri, 2 Sep 2022 12:49:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54068 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236293AbiIBQtr (ORCPT ); Fri, 2 Sep 2022 12:49:47 -0400 Received: from smtp.smtpout.orange.fr (smtp09.smtpout.orange.fr [80.12.242.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C2E6B11A26 for ; Fri, 2 Sep 2022 09:39:55 -0700 (PDT) Received: from pop-os.home ([90.11.190.129]) by smtp.orange.fr with ESMTPA id U9hwotD6YjJi0U9hxo8ald; Fri, 02 Sep 2022 18:39:54 +0200 X-ME-Helo: pop-os.home X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Fri, 02 Sep 2022 18:39:54 +0200 X-ME-IP: 90.11.190.129 From: Christophe JAILLET To: Andrew Morton Cc: linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET , linux-mm@kvack.org Subject: [PATCH v2] mm/mremap_pages: Save a few cycles in get_dev_pagemap() Date: Fri, 2 Sep 2022 18:39:52 +0200 Message-Id: <9ef1562a1975371360f3e263856e9f1c5749b656.1662136782.git.christophe.jaillet@wanadoo.fr> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 Use 'percpu_ref_tryget_live_rcu()' instead of 'percpu_ref_tryget_live()' to save a few cycles when it is known that the rcu lock is already taken/released. Signed-off-by: Christophe JAILLET --- Matthew Wilcox commented on v1 that it is just a slow path... but it is also just an easy patch :) If considered as useless, let me know and I'll drop it from my WIP list. Changes in v2: * (no code change) * synch with latest -next v1: https://lore.kernel.org/all/b4a47154877853cc64be3a35dcfd594d40cc2bce.1635975283.git.christophe.jaillet@wanadoo.fr/ --- mm/memremap.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mm/memremap.c b/mm/memremap.c index 58b20c3c300b..25029a474d30 100644 --- a/mm/memremap.c +++ b/mm/memremap.c @@ -454,7 +454,7 @@ struct dev_pagemap *get_dev_pagemap(unsigned long pfn, /* fall back to slow path lookup */ rcu_read_lock(); pgmap = xa_load(&pgmap_array, PHYS_PFN(phys)); - if (pgmap && !percpu_ref_tryget_live(&pgmap->ref)) + if (pgmap && !percpu_ref_tryget_live_rcu(&pgmap->ref)) pgmap = NULL; rcu_read_unlock(); -- 2.34.1