Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1259676imm; Fri, 13 Jul 2018 14:57:12 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdSESdlMuvqzPrmC/+CEC7+KY5FK+9SqRNyT0c1qQrWLBecXkedWrvNMjfFp9EY27PltPbl X-Received: by 2002:a17:902:8645:: with SMTP id y5-v6mr7993009plt.334.1531519032266; Fri, 13 Jul 2018 14:57:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531519032; cv=none; d=google.com; s=arc-20160816; b=VnP6lLszumfpiGaO/4++J3kwjIxvpl/qf0Za9tcPcf6Fa/UQmNl7qipp3js6/0grQ5 adPjkf4FAXSR+Rp17OL6rAmJ7p0a8Ojw0whKvhKGrEEBXA1AeMNi29Ql4HkPLcTDLFA0 9shRnR02ux/vqLs+B0Lp6SybBsz7hqSQcFnSTdd82gapT2OMf7gpLLX40MUnMZALN/DW xl3gm+3r1AfwnJ2Bz3R7nGa3KcJvVOdM8scGXZTRRXCJIE7VdH3jOh/+li6k5JyafR9A 2PZgGNRb5efOjpBhq8M8qt3zkIUKRKhYAu8NFyvK7bXWjTAjZF3y7UlT3f0Ht3Kv2p1q u5kA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=1mYBJsHMIqmk37mLKsMQrlBQi1HvJKTuqoh+4Ivrmk4=; b=jrNn1GUq2RXTUePigUo81uE/woKH+AB3SFb6ODuhUo+jaJq02cj4OU8MthJjNr9i3Z qASkVRLrp+ctzCqgkaiHOllm5u3F6oQxioTfXyQ2bDRjqExm4VdfAGuMP3ECUXH2t906 wOQ6vRX1q+FE8TiKe79dlIQWSXVfEc1o6VkOfTMijnJjeDKzQ/NWVgWvP2YfS8z0glJl oV6HBI8CD2P7906+/wk+nbY7mqm3VrANwlmasn9e47etBmZVF49Hvjs/7T0GWFwnAcQB W7hFF8BwlIrUfeaHfmGClYleOQLmCSXftaXsjFaaAGrS3ov6fcFR/KpUfX7ZBeWy9VNp KUxw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=WaBev1vj; 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 a10-v6si25778608pln.349.2018.07.13.14.56.57; Fri, 13 Jul 2018 14:57:12 -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=@joelfernandes.org header.s=google header.b=WaBev1vj; 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 S1731910AbeGMWMZ (ORCPT + 99 others); Fri, 13 Jul 2018 18:12:25 -0400 Received: from mail-pf0-f196.google.com ([209.85.192.196]:36375 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726161AbeGMWMY (ORCPT ); Fri, 13 Jul 2018 18:12:24 -0400 Received: by mail-pf0-f196.google.com with SMTP id u16-v6so23323260pfh.3 for ; Fri, 13 Jul 2018 14:55:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=1mYBJsHMIqmk37mLKsMQrlBQi1HvJKTuqoh+4Ivrmk4=; b=WaBev1vjFXPyxNcVV88HFc9oCYz0rzrcVaskkQsTHfMiQ43AR2gsvFbx2bOMmt/q6W ez7Wxa8aBdtLcK33Y/SXPv/IlzJNG8S1qaPMsXPjYWijtFcHnx7vSg5jl+pLZ0ZLSFP4 bAN/fqJl231ETR8S9qikW4LvxCR9q+3R7rg60= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=1mYBJsHMIqmk37mLKsMQrlBQi1HvJKTuqoh+4Ivrmk4=; b=UeglM8ObnUo0a1eNp6yYsagHtfzQ+jB1YRvq4qGwhh1j4/a20X/ujJFaay5GtRmvOr KwTywlMIkAwroZQQYBkWNk8mg7EC+aGRDohyJv6qp+OxE+nseovJPCHUHgYW/2sjTGrF 8Cd8vpFkjPxAP3/VJzoo0EpP+wHR/Rd58JMmzKA2TAVk84weLwLeU02NP4CNg9BMJeN8 WsqqUP6UBytMKFPXjMP2tZG3uO6gTovVeI+8yACMeaP83RTAr9Y4s/6vho7FhJ7gLq2x nxvEPUTtbjlT0AyGsO+ijDUVhgSl5USW9ettysyq0fyzAhwBUc7vEvKMZKh+POm7sqzC rCEA== X-Gm-Message-State: AOUpUlHx7xqUVLbEl+wfmGDj5aLL7l7OXQYRFsmXB96RWEho/RVu3UMO aq0FEKOKI7C/Ehol5WVu24LLl/Cgd6Y= X-Received: by 2002:a62:b29c:: with SMTP id z28-v6mr8918631pfl.8.1531518955522; Fri, 13 Jul 2018 14:55:55 -0700 (PDT) Received: from joelaf.mtv.corp.google.com ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id k4-v6sm35232990pgo.49.2018.07.13.14.55.54 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 13 Jul 2018 14:55:55 -0700 (PDT) From: Joel Fernandes To: linux-kernel@vger.kernel.org Cc: kernel-team@android.com, "Joel Fernandes (Google)" , Boqun Feng , Byungchul Park , Erick Reyes , Ingo Molnar , Julia Cartwright , Masami Hiramatsu , Mathieu Desnoyers , Namhyung Kim , Paul McKenney , Peter Zijlstra , Steven Rostedt , Thomas Glexiner , Todd Kjos , Tom Zanussi , Will Deacon Subject: [PATCH v10 1/3] lockdep: use this_cpu_ptr instead of get_cpu_var stats Date: Fri, 13 Jul 2018 14:55:45 -0700 Message-Id: <20180713215547.255620-2-joel@joelfernandes.org> X-Mailer: git-send-email 2.18.0.203.gfac676dfb9-goog In-Reply-To: <20180713215547.255620-1-joel@joelfernandes.org> References: <20180713215547.255620-1-joel@joelfernandes.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Joel Fernandes (Google)" get_cpu_var disables preemption which has the potential to call into the preemption disable trace points causing some complications. There's also no need to disable preemption in uses of get_lock_stats anyway since preempt is already disabled. So lets simplify the code. Suggested-by: Peter Zijlstra Signed-off-by: Joel Fernandes (Google) --- kernel/locking/lockdep.c | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/kernel/locking/lockdep.c b/kernel/locking/lockdep.c index 5fa4d3138bf1..8f5ce0048d15 100644 --- a/kernel/locking/lockdep.c +++ b/kernel/locking/lockdep.c @@ -248,12 +248,7 @@ void clear_lock_stats(struct lock_class *class) static struct lock_class_stats *get_lock_stats(struct lock_class *class) { - return &get_cpu_var(cpu_lock_stats)[class - lock_classes]; -} - -static void put_lock_stats(struct lock_class_stats *stats) -{ - put_cpu_var(cpu_lock_stats); + return &this_cpu_ptr(&cpu_lock_stats)[class - lock_classes]; } static void lock_release_holdtime(struct held_lock *hlock) @@ -271,7 +266,6 @@ static void lock_release_holdtime(struct held_lock *hlock) lock_time_inc(&stats->read_holdtime, holdtime); else lock_time_inc(&stats->write_holdtime, holdtime); - put_lock_stats(stats); } #else static inline void lock_release_holdtime(struct held_lock *hlock) @@ -4090,7 +4084,6 @@ __lock_contended(struct lockdep_map *lock, unsigned long ip) stats->contending_point[contending_point]++; if (lock->cpu != smp_processor_id()) stats->bounces[bounce_contended + !!hlock->read]++; - put_lock_stats(stats); } static void @@ -4138,7 +4131,6 @@ __lock_acquired(struct lockdep_map *lock, unsigned long ip) } if (lock->cpu != cpu) stats->bounces[bounce_acquired + !!hlock->read]++; - put_lock_stats(stats); lock->cpu = cpu; lock->ip = ip; -- 2.18.0.203.gfac676dfb9-goog