Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2330773imu; Fri, 23 Nov 2018 07:42:16 -0800 (PST) X-Google-Smtp-Source: AFSGD/UduB0546CWZeZNEjw/Rb5YZWurJbP6UNKzfpfl/KBAa3BrT6Jm71FJUcr0ozeKumaObWWB X-Received: by 2002:a17:902:7e44:: with SMTP id a4mr16227203pln.338.1542987736609; Fri, 23 Nov 2018 07:42:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542987736; cv=none; d=google.com; s=arc-20160816; b=l5Z2m26GxgzR06qSM/jAQoGO/q4MK2q3Kl6V9J8wXAmB2T4WdIiBnd5bNn/V89zrF5 X8yFsmga6Gn0rMVQyv3WRkmru0M3q1FeeTf8sqTDlhQhEUry1u7qnEiiPSA+met4IW45 cBRPbzZ4hb8uQnT9RNSLtC+87zzSpJwu1wHAM4HCQIv+3/C30D1byXpMtBYVq+GrH11z HZfPCEDnSDmnUBoh/nkzdHBfJ2lt0kEePav3T7teZVErP0zjTvKPhm4l+KQ1MmguHIo6 VjNeDY3m/2SO47BUA9kjeclrIjjkTucAEOQlCuyZtHjOVhVz172QA/CepuThf9lleUgG y1Og== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=d4/lCVbTMy47c9jVPoWTmf0Jg+T9mRLVkOsL3i5SVw4=; b=QnYagq3rXnppVDekpvcePy0DhMMGl93C0isOyyPBY+x6NfRqQy4VhA0Di4fIXy6aDF VKnQjuBm6WYmX/6yZmK5OSMvu3w5AnAMQWvgvuYKtQTJRYU69SiYFZ4ZCpYiUI2BgtYq AbA9QcKs3rKfVDpZGgdhTFn3ZgoW1Gn28/6oEHQnkkEoQVByBk/VsQu6o9hzhw2L/1CY /HWWSkycKWDaVV507sQzvpPQKMaGngjSK7zWHoVscuf0JmzOl3UFzHocKucl5N9y40zk TENK4gThZxuZhN5bqFUW7ue6tPLLUhju9Fn4qoIIX06r1ueN1kqBYD5MHYEh6qYjjCib yjzg== ARC-Authentication-Results: i=1; mx.google.com; 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 1-v6si31065473plx.278.2018.11.23.07.41.48; Fri, 23 Nov 2018 07:42:16 -0800 (PST) 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; 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 S2391013AbeKVW6a (ORCPT + 99 others); Thu, 22 Nov 2018 17:58:30 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:15132 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729105AbeKVW6a (ORCPT ); Thu, 22 Nov 2018 17:58:30 -0500 Received: from DGGEMS408-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id BEB3F16A7E52A; Thu, 22 Nov 2018 20:19:18 +0800 (CST) Received: from HGHY2Y004646261.china.huawei.com (10.184.12.158) by DGGEMS408-HUB.china.huawei.com (10.3.19.208) with Microsoft SMTP Server id 14.3.408.0; Thu, 22 Nov 2018 20:19:11 +0800 From: Zenghui Yu To: , , CC: , , , Zenghui Yu Subject: [RFC] tracepoint: fix bad trace value in trace_kvm_exit() Date: Thu, 22 Nov 2018 12:17:30 +0000 Message-ID: <1542889050-23144-1-git-send-email-yuzenghui@huawei.com> X-Mailer: git-send-email 2.6.4.windows.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.184.12.158] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org After enabling KVM event tracing, almost all of trace_kvm_exit()'s printk shows "kvm_exit: IRQ: ..." even if the actual exception_type is NOT IRQ. This slight problem may have existed after commit e6753f2. There are two variables in trace_kvm_exit() and __DO_TRACE() which have the same name, *idx*. Thus the actual value of *idx* will be overwritten when tracing. So, what about this stupid patch? Signed-off-by: Zenghui Yu To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu Cc: Steven Rostedt Cc: Ingo Molnar Cc: Wang Haibin --- include/linux/tracepoint.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/include/linux/tracepoint.h b/include/linux/tracepoint.h index 538ba1a..e9de8ad 100644 --- a/include/linux/tracepoint.h +++ b/include/linux/tracepoint.h @@ -166,7 +166,7 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) struct tracepoint_func *it_func_ptr; \ void *it_func; \ void *__data; \ - int __maybe_unused idx = 0; \ + int __maybe_unused __idx = 0; \ \ if (!(cond)) \ return; \ @@ -182,7 +182,7 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) * doesn't work from the idle path. \ */ \ if (rcuidle) { \ - idx = srcu_read_lock_notrace(&tracepoint_srcu); \ + __idx = srcu_read_lock_notrace(&tracepoint_srcu);\ rcu_irq_enter_irqson(); \ } \ \ @@ -198,7 +198,7 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) \ if (rcuidle) { \ rcu_irq_exit_irqson(); \ - srcu_read_unlock_notrace(&tracepoint_srcu, idx);\ + srcu_read_unlock_notrace(&tracepoint_srcu, __idx);\ } \ \ preempt_enable_notrace(); \ -- 1.8.3.1