Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1230953pxb; Fri, 21 Jan 2022 12:53:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJzlktKRtZXG2ZZ9QImbMv6ASEq+w+gKYBM/Bg6dDGVpTlEw8kesGF+NFo3fPWPHPiLnKgmM X-Received: by 2002:a05:6a00:190a:b0:4c4:7273:6aed with SMTP id y10-20020a056a00190a00b004c472736aedmr5059933pfi.33.1642798433255; Fri, 21 Jan 2022 12:53:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642798433; cv=none; d=google.com; s=arc-20160816; b=A5BeaLbHG2GhVGUy9nHuL7x+qu1PT+4bTNYH7jqAp6mG3tXvvg5mxweIhYm/1ADX2Q +DELtGO6r6zi4tHF4LWH6i50DhljmjAMW+aWVeSoJoMfkPdfF1BppbxABkkVAr2v5D1Y OfRgXO1Wi+0R5leJRX1+07gAMOeo6Rjqk7cRDM/IW7+A0Qe3ILUxqDZ23PfHlibmRuKz RgZn0AY2H13Ojmm8pI9JDFN5rA87slup4KFgUYATKvMwJJDFV4QOPkOiS1b/BceIKDqS ZFxbDbAJ1u1MJVTTG2NENlDthXVyTijrA9PlvoBOJCiKtRREuphlMDW8pvFlokG+0Lkc lmtA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :dkim-signature; bh=tA2eESNey0k0XP9lk3g/bAUxhAQW5/EDDgeejjFfXNg=; b=rmD+w3OpVe8uBdN58H09+nDRchl+UbWZW/+BA5IBZqRnlEHKJHsRq4NymK5kV3MJIz nab7nYV/YLuxGuM4CqTnljhIfTsgIFDt/wzve03QerhumV/e/vZam8gFrzLfZyp8ixTY i7nyD35Jvt6aA5s9XS4iWeqEMV5CI8b5zzLIL7b7lP/o2AJzQgR6kZXT6rNQGbDLJqtk YSRjZ8FP6a0ZeDqkT5LQo5BTuvH0ePMmgjQZcEGxZqQud7H8zKxZ4+q0ndo4RU0WsmCd Y1BgFCIpmZom8+1/MA0SmMD2fZC9ponrch9l37rbnVJmZraG5dUDKPOBrN/A2JaDsJN4 lW5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=J3HQT9kr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g6si6518109plt.615.2022.01.21.12.53.41; Fri, 21 Jan 2022 12:53:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=J3HQT9kr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237499AbiATBMK (ORCPT + 99 others); Wed, 19 Jan 2022 20:12:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50270 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233976AbiATBMJ (ORCPT ); Wed, 19 Jan 2022 20:12:09 -0500 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A957DC061574 for ; Wed, 19 Jan 2022 17:12:09 -0800 (PST) Received: by mail-yb1-xb49.google.com with SMTP id z15-20020a25bb0f000000b00613388c7d99so8525086ybg.8 for ; Wed, 19 Jan 2022 17:12:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=date:message-id:mime-version:subject:from:to:cc; bh=tA2eESNey0k0XP9lk3g/bAUxhAQW5/EDDgeejjFfXNg=; b=J3HQT9krlZpsQHQTFN3l8Z8u2Xf/3ewg0BZLCCsSyi7tFH4eLStKDf57djLK731CyH 2r766eOGcq9rdqLNOJrGcFlsrzoPV46P5LdGiKJmson3U5GH8I/is7v0u5OMLh/I51pU n4ocALKdQwW+oeKJENm84eCGpAsDqPaYUxQmMIBz3zGWoVWohLW3g3a+rJsXUAVzrSIl Ecl1bJw/BpuRnv1x/vgqFs/zDoTBSHDe1YyhkOThvZc1vjQnStHhiSL9t0CynG+n5mse Jw2Jhj1G8Ay/lodL/w4dwWnjl3tqe1F/qt6981+t+OpYfhWHQD9DeFMbbgOpYrTHQbuY cfbQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=tA2eESNey0k0XP9lk3g/bAUxhAQW5/EDDgeejjFfXNg=; b=n5Jumd7szEjvzOt5XI9exnwvXCWs5PmcK4AWyN4JnPWiaFwIOyMn5bzxKutmZDNlDD Pe8d04aZ8f8e8pNkVK4jbIkLT2yI4On/G2TVpUAKUd/qeljZ3fiG1l0rR4iPqMmuMbUg bx4J0SW3OUjXCswDwDSrsdsH+VVCkmTT2SSBu8WtjU98cUUnJKzkahYVU9a6KOv7qT1s Ca/rG5sCg2oJLTvKM7vCU8lrndTTHFQiXQeOGx3F4QgAq4EKco+83spmsTLoGr6uMfi2 plC7Uia8vLPYdjEM7Uknf4XHft8aPpyE8s+ae+Mstk0v6zRkb2pYGC6bHm7hkHZhKaq0 9Weg== X-Gm-Message-State: AOAM5332jH97qLWs3ogEZiSb5QUrTftCYTK7HrubKun3djwzmGPgcLzu yEN7bg63zHUB58/5gcfyntrPSjc= X-Received: from pcc-desktop.svl.corp.google.com ([2620:15c:2ce:200:7641:d112:dd90:7ea1]) (user=pcc job=sendgmr) by 2002:a25:bb45:: with SMTP id b5mr27616743ybk.174.1642641128808; Wed, 19 Jan 2022 17:12:08 -0800 (PST) Date: Wed, 19 Jan 2022 17:11:59 -0800 Message-Id: <20220120011200.1322836-1-pcc@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.34.1.703.g22d0c6ccf7-goog Subject: [PATCH v2] mm/mmzone.c: use try_cmpxchg() in page_cpupid_xchg_last() From: Peter Collingbourne To: Andrey Konovalov , Andrew Morton Cc: Peter Collingbourne , linux-mm@kvack.org, linux-kernel@vger.kernel.org, Peter Zijlstra , Mel Gorman Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This will let us avoid an additional read from page->flags when retrying the compare-exchange on some architectures. Suggested-by: Peter Zijlstra Signed-off-by: Peter Collingbourne Link: https://linux-review.googlesource.com/id/I2e1f5b5b080ac9c4e0eb7f98768dba6fd7821693 --- mm/mmzone.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/mm/mmzone.c b/mm/mmzone.c index eb89d6e018e2..d8a9b0e1b526 100644 --- a/mm/mmzone.c +++ b/mm/mmzone.c @@ -89,13 +89,14 @@ int page_cpupid_xchg_last(struct page *page, int cpupid) unsigned long old_flags, flags; int last_cpupid; + old_flags = READ_ONCE(page->flags); do { - old_flags = flags = page->flags; - last_cpupid = page_cpupid_last(page); + flags = old_flags; + last_cpupid = (flags >> LAST_CPUPID_PGSHIFT) & LAST_CPUPID_MASK; flags &= ~(LAST_CPUPID_MASK << LAST_CPUPID_PGSHIFT); flags |= (cpupid & LAST_CPUPID_MASK) << LAST_CPUPID_PGSHIFT; - } while (unlikely(cmpxchg(&page->flags, old_flags, flags) != old_flags)); + } while (unlikely(!try_cmpxchg(&page->flags, &old_flags, flags))); return last_cpupid; } -- 2.34.1.703.g22d0c6ccf7-goog