Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp194785imm; Thu, 26 Jul 2018 16:54:41 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdOgiMd8iXT97yrYL7yTkQnPl0V8Ej7fC+9vBX/EI1G0phhqzEy3bwze0oGaQc12CYcrLAq X-Received: by 2002:a63:5350:: with SMTP id t16-v6mr3743761pgl.196.1532649280955; Thu, 26 Jul 2018 16:54:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532649280; cv=none; d=google.com; s=arc-20160816; b=tONGtj7YoNdspZBb/8NkNSyPdZM1xqz1iA/01pjFErsIaqMb1Dhz1QSFpqP9jl1jUx 2HT/giaXptqLHEBisRWm/F5MX6VW5THdyd8mO+kGI5auWhCtiiONU6xwYnVtd0Qz5zDn LkWqlJj1pMbil89H5JDs3t2rLTh5n63h6EkIQQqsyF4VdRh7TGOI8r+4DhjsJMs8+aoM CoEy3+aBO+CABMxpee0ZyOPzUNVnk1q1RzVVLvVcdPdQVR3pxNiVD8gYEzEtZ4bupQMu Q225oXm5aEKxUAX2HDik1lRdHLy0Td+kVjwCWKC9TVYGHzQr34LujDvA8XCEiOxuy1kB sp+g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=qK3jlpJqPwzr9IyuaohdlGRYRs3VMHf+Mv/c7WztzZE=; b=cMuxD25BnA0kyy2RMoJelKgepFQru/aYyspcEAA7een9zimK3A3cn7HZWv/Mi1tuHB 76QRiyvQTPVI5WNTq454Ng+ghcf2DyQxHtYh6Vr8zNVnT6HxxMX9B5aDgFnIDk351P2w qF5B4u011EILZHgWVqxenha8zT6e1/TcPW/oJMtKGLRh5TVsQMbXUhv/Y6mH64LWQ/2J 3G+odzFyuGGLKN/RYDznQ4po43L1y8yhTAtApdaKGKzY0NZGx8kzTs6eWRX4IXQRCD/e Vh3lvT5sJZiy5XfNgDpPqKH1KLL5gar3XdoUijj8o4U8q7s5iFzRSdHpIWBWaktI6wH5 UCQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=q0DopVhT; 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 n8-v6si2213244plk.255.2018.07.26.16.54.24; Thu, 26 Jul 2018 16:54:40 -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=q0DopVhT; 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 S1732028AbeG0BKK (ORCPT + 99 others); Thu, 26 Jul 2018 21:10:10 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:33364 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731629AbeG0BKJ (ORCPT ); Thu, 26 Jul 2018 21:10:09 -0400 Received: by mail-pl0-f68.google.com with SMTP id 6-v6so1496542plb.0 for ; Thu, 26 Jul 2018 16:51:02 -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 :mime-version:content-transfer-encoding; bh=qK3jlpJqPwzr9IyuaohdlGRYRs3VMHf+Mv/c7WztzZE=; b=q0DopVhTOS8S1XOcMBEC2b/n2t/0LcYDePX9in/Zi/UucVBquGSqoDnVCcn+ynRqi5 OxARdIhKsi4Vnp1lm1xjOJ6nT3NwCARDd9Grksy/ArGiRT4stmFp+1RJvWKC0gW3OpJq Bl0aqAT2FKkA2mTof5HQidxz0bazFNLT+xG/M= 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:mime-version:content-transfer-encoding; bh=qK3jlpJqPwzr9IyuaohdlGRYRs3VMHf+Mv/c7WztzZE=; b=Hxmxw1BuYvZx8qHs2tat5BGQZCkk4qf2gaUJn2WjTq7iyiYFCTPQorVeUc6FiyeDFj s3sk3i4XUwgOah1ad1hMiTew19tKy/F4D9//i7PzxnsYCcv0bRxLip06WB3u1ah3JaCd DgXS8ruJzfwIwGx4zxdNyPXSCK7cDdXSWve8TmeiLw8Wodq8wgcXuYP54WuBFz120TqQ COgeI3Vyd9as4UUdYPHpTUIy3P+eHSqJeHTirMxgU1dM8yTukSdF8DHfzbuyUhUtbOmw HoTjbThdGBMpdP1MolzhvdLJam6LRcYzzGzeCrlw2HxhZW9fBfB++ts9522kgIPQOFf8 9qtQ== X-Gm-Message-State: AOUpUlG4DP4xtdj5pBpkdNaK68zip4F5Zr+hU87b5lcsem6K0wqnerDc Hqgb/Ic9wgMuxd0WT8oMbrAxbthCfPM= X-Received: by 2002:a17:902:bd07:: with SMTP id p7-v6mr3873983pls.32.1532649061953; Thu, 26 Jul 2018 16:51:01 -0700 (PDT) Received: from joelaf.mtv.corp.google.com ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id t76-v6sm3818840pfe.109.2018.07.26.16.51.00 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 26 Jul 2018 16:51:01 -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 v11 1/3] lockdep: use this_cpu_ptr instead of get_cpu_var stats Date: Thu, 26 Jul 2018 16:50:42 -0700 Message-Id: <20180726235044.10195-2-joel@joelfernandes.org> X-Mailer: git-send-email 2.18.0.345.g5c9ce644c3-goog In-Reply-To: <20180726235044.10195-1-joel@joelfernandes.org> References: <20180726235044.10195-1-joel@joelfernandes.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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.345.g5c9ce644c3-goog