Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp872784imb; Fri, 1 Mar 2019 17:19:34 -0800 (PST) X-Google-Smtp-Source: APXvYqyKNib3NmgYSAJ50WnTIAkRYZSda1E7prKJs5L1AJZBnWBvNbutDDAq+aQLH0t+r6nh9ZZc X-Received: by 2002:a17:902:7082:: with SMTP id z2mr8352455plk.251.1551489574167; Fri, 01 Mar 2019 17:19:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551489574; cv=none; d=google.com; s=arc-20160816; b=DKMUfFN97r8FQF/Ypg+GpzkpY7epWZ+p1e403KzWQgLvqtxWiggJ0J2TKEChJTKJcT HNqkXWrdCOIiQOa891mjeIJM8G62ESxns/d+fYYe2tNkeGJNOeCPV8Z3hexZMDqNIxAW jkbGDyKuvFIloqiMr5u4CLnJ0Rqllr26DA1EmGt24XR0HTMliLg/0Dy9wW6dnT7/i4a2 Z4dALdVkxoG1V5l55V8yzkgEUcFBKBrtW7yDtJdtFHR6g6qLXFQ3tGo5GrLpdmgBNXDC gGNSwmMbw5NtXndx325+z4NTs9/ZaGdcoHd3GZ8bkY3BWoNSJBtvQkSwEdJCGesKKKCu VQNQ== 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; bh=QGYEDUZMst3GxmsZvsKDY/prSl1eRVGrXokeCjNMa8w=; b=gb/t6CQSeO+26C9uVBFPA3TPKoR9+t6CwzgCUmpptSqn1jAlRLT/tzyTl0NtzSZPAz H7gtX8z7YUcqD8c4VymykhP4HfbrraSz/P6Huw1l5CTQIDAzSE7YCA6dfeC8R7vlhioe vuv6PwcrfRxhC8AG5WKY87tw5r6URg5ZoaciQ4+dp7SF0ZlPsRU/UyOLZO24D/k32GDf 42jUqeVv5IJxBZYdXjR2oqv8CugC5lFUt9DWZFdikoImadb68wmpOlZRKW/xv8E5tZCq mSH6RDDTGMH9hzRJmOqKNmUP5UkUqNZtc5UXAUp56P2pHAn1DYbCf4ClnjXRo3fEIytm CkhA== 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 f21si17377050plr.297.2019.03.01.17.19.18; Fri, 01 Mar 2019 17:19:34 -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 S1727870AbfCBBSO (ORCPT + 99 others); Fri, 1 Mar 2019 20:18:14 -0500 Received: from mx2.suse.de ([195.135.220.15]:47636 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727839AbfCBBSL (ORCPT ); Fri, 1 Mar 2019 20:18:11 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 93DCBAD3E; Sat, 2 Mar 2019 01:18:09 +0000 (UTC) From: Tony Jones To: linux-kernel@vger.kernel.org Cc: acme@kernel.org, linux-perf-users@vger.kernel.org, Tony Jones , Seeteena Thoufeek , Adrian Hunter Subject: [PATCH v2 5/7] perf script python: add Python3 support to intel-pt-events.py Date: Fri, 1 Mar 2019 17:19:01 -0800 Message-Id: <20190302011903.2416-6-tonyj@suse.de> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190302011903.2416-1-tonyj@suse.de> References: <20190302011903.2416-1-tonyj@suse.de> 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 Support both Python2 and Python3 in the intel-pt-events.py script There may be differences in the ordering of output lines due to differences in dictionary ordering etc. However the format within lines should be unchanged. The use of 'from __future__' implies the minimum supported Python2 version is now v2.6 Signed-off-by: Tony Jones Signed-off-by: Seeteena Thoufeek Cc: Adrian Hunter --- tools/perf/scripts/python/intel-pt-events.py | 30 +++++++++++++++++----------- 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/tools/perf/scripts/python/intel-pt-events.py b/tools/perf/scripts/python/intel-pt-events.py index 2177722f509e..5c42c4c359dc 100644 --- a/tools/perf/scripts/python/intel-pt-events.py +++ b/tools/perf/scripts/python/intel-pt-events.py @@ -10,6 +10,8 @@ # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for # more details. +from __future__ import print_function + import os import sys import struct @@ -22,10 +24,10 @@ sys.path.append(os.environ['PERF_EXEC_PATH'] + \ #from Core import * def trace_begin(): - print "Intel PT Power Events and PTWRITE" + print("Intel PT Power Events and PTWRITE") def trace_end(): - print "End" + print("End") def trace_unhandled(event_name, context, event_fields_dict): print ' '.join(['%s=%s'%(k,str(v))for k,v in sorted(event_fields_dict.items())]) @@ -35,21 +37,21 @@ def print_ptwrite(raw_buf): flags = data[0] payload = data[1] exact_ip = flags & 1 - print "IP: %u payload: %#x" % (exact_ip, payload), + print("IP: %u payload: %#x" % (exact_ip, payload), end=' ') def print_cbr(raw_buf): data = struct.unpack_from("> 32) & 0x3 - print "hints: %#x extensions: %#x" % (hints, extensions), + print("hints: %#x extensions: %#x" % (hints, extensions), end=' ') def print_pwre(raw_buf): data = struct.unpack_from("> 7) & 1 cstate = (payload >> 12) & 0xf subcstate = (payload >> 8) & 0xf - print "hw: %u cstate: %u sub-cstate: %u" % (hw, cstate, subcstate), + print("hw: %u cstate: %u sub-cstate: %u" % (hw, cstate, subcstate), + end=' ') def print_exstop(raw_buf): data = struct.unpack_from("> 4) & 0xf wake_reason = (payload >> 8) & 0xf - print "deepest cstate: %u last cstate: %u wake reason: %#x" % (deepest_cstate, last_cstate, wake_reason), + print("deepest cstate: %u last cstate: %u wake reason: %#x" % + (deepest_cstate, last_cstate, wake_reason), end=' ') def print_common_start(comm, sample, name): ts = sample["time"] cpu = sample["cpu"] pid = sample["pid"] tid = sample["tid"] - print "%16s %5u/%-5u [%03u] %9u.%09u %7s:" % (comm, pid, tid, cpu, ts / 1000000000, ts %1000000000, name), + print("%16s %5u/%-5u [%03u] %9u.%09u %7s:" % + (comm, pid, tid, cpu, ts / 1000000000, ts %1000000000, name), + end=' ') def print_common_ip(sample, symbol, dso): ip = sample["ip"] - print "%16x %s (%s)" % (ip, symbol, dso) + print("%16x %s (%s)" % (ip, symbol, dso)) def process_event(param_dict): event_attr = param_dict["attr"] @@ -92,12 +98,12 @@ def process_event(param_dict): name = param_dict["ev_name"] # Symbol and dso info are not always resolved - if (param_dict.has_key("dso")): + if "dso" in param_dict: dso = param_dict["dso"] else: dso = "[unknown]" - if (param_dict.has_key("symbol")): + if "symbol" in param_dict: symbol = param_dict["symbol"] else: symbol = "[unknown]" -- 2.16.4