1a92bf335SAdrian Hunter# SPDX-License-Identifier: GPL-2.0 2a92bf335SAdrian Hunter# intel-pt-events.py: Print Intel PT Events including Power Events and PTWRITE 3a92bf335SAdrian Hunter# Copyright (c) 2017-2021, Intel Corporation. 4cc892720SAdrian Hunter# 5cc892720SAdrian Hunter# This program is free software; you can redistribute it and/or modify it 6cc892720SAdrian Hunter# under the terms and conditions of the GNU General Public License, 7cc892720SAdrian Hunter# version 2, as published by the Free Software Foundation. 8cc892720SAdrian Hunter# 9cc892720SAdrian Hunter# This program is distributed in the hope it will be useful, but WITHOUT 10cc892720SAdrian Hunter# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11cc892720SAdrian Hunter# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 12cc892720SAdrian Hunter# more details. 13cc892720SAdrian Hunter 14fdf2460cSTony Jonesfrom __future__ import print_function 15fdf2460cSTony Jones 16cc892720SAdrian Hunterimport os 17cc892720SAdrian Hunterimport sys 18cc892720SAdrian Hunterimport struct 19*a483e64cSAdrian Hunterimport argparse 20*a483e64cSAdrian Hunter 21*a483e64cSAdrian Hunterfrom libxed import LibXED 22*a483e64cSAdrian Hunterfrom ctypes import create_string_buffer, addressof 23cc892720SAdrian Hunter 24cc892720SAdrian Huntersys.path.append(os.environ['PERF_EXEC_PATH'] + \ 25cc892720SAdrian Hunter '/scripts/python/Perf-Trace-Util/lib/Perf/Trace') 26cc892720SAdrian Hunter 27*a483e64cSAdrian Hunterfrom perf_trace_context import perf_set_itrace_options, \ 28*a483e64cSAdrian Hunter perf_sample_insn, perf_sample_srccode 29cc892720SAdrian Hunter 30a92bf335SAdrian Huntertry: 31a92bf335SAdrian Hunter broken_pipe_exception = BrokenPipeError 32a92bf335SAdrian Hunterexcept: 33a92bf335SAdrian Hunter broken_pipe_exception = IOError 34a92bf335SAdrian Hunter 35a92bf335SAdrian Hunterglb_switch_str = None 36a92bf335SAdrian Hunterglb_switch_printed = True 37*a483e64cSAdrian Hunterglb_insn = False 38*a483e64cSAdrian Hunterglb_disassembler = None 39*a483e64cSAdrian Hunterglb_src = False 40*a483e64cSAdrian Hunterglb_source_file_name = None 41*a483e64cSAdrian Hunterglb_line_number = None 42*a483e64cSAdrian Hunterglb_dso = None 43a92bf335SAdrian Hunter 44a92bf335SAdrian Hunterdef get_optional_null(perf_dict, field): 45a92bf335SAdrian Hunter if field in perf_dict: 46a92bf335SAdrian Hunter return perf_dict[field] 47a92bf335SAdrian Hunter return "" 48a92bf335SAdrian Hunter 49a92bf335SAdrian Hunterdef get_optional_zero(perf_dict, field): 50a92bf335SAdrian Hunter if field in perf_dict: 51a92bf335SAdrian Hunter return perf_dict[field] 52a92bf335SAdrian Hunter return 0 53a92bf335SAdrian Hunter 54*a483e64cSAdrian Hunterdef get_optional_bytes(perf_dict, field): 55*a483e64cSAdrian Hunter if field in perf_dict: 56*a483e64cSAdrian Hunter return perf_dict[field] 57*a483e64cSAdrian Hunter return bytes() 58*a483e64cSAdrian Hunter 59a92bf335SAdrian Hunterdef get_optional(perf_dict, field): 60a92bf335SAdrian Hunter if field in perf_dict: 61a92bf335SAdrian Hunter return perf_dict[field] 62a92bf335SAdrian Hunter return "[unknown]" 63a92bf335SAdrian Hunter 64a92bf335SAdrian Hunterdef get_offset(perf_dict, field): 65a92bf335SAdrian Hunter if field in perf_dict: 66a92bf335SAdrian Hunter return "+%#x" % perf_dict[field] 67a92bf335SAdrian Hunter return "" 68a92bf335SAdrian Hunter 69cc892720SAdrian Hunterdef trace_begin(): 70*a483e64cSAdrian Hunter ap = argparse.ArgumentParser(usage = "", add_help = False) 71*a483e64cSAdrian Hunter ap.add_argument("--insn-trace", action='store_true') 72*a483e64cSAdrian Hunter ap.add_argument("--src-trace", action='store_true') 73*a483e64cSAdrian Hunter global glb_args 74*a483e64cSAdrian Hunter global glb_insn 75*a483e64cSAdrian Hunter global glb_src 76*a483e64cSAdrian Hunter glb_args = ap.parse_args() 77*a483e64cSAdrian Hunter if glb_args.insn_trace: 78*a483e64cSAdrian Hunter print("Intel PT Instruction Trace") 79*a483e64cSAdrian Hunter itrace = "i0nsepwx" 80*a483e64cSAdrian Hunter glb_insn = True 81*a483e64cSAdrian Hunter elif glb_args.src_trace: 82*a483e64cSAdrian Hunter print("Intel PT Source Trace") 83*a483e64cSAdrian Hunter itrace = "i0nsepwx" 84*a483e64cSAdrian Hunter glb_insn = True 85*a483e64cSAdrian Hunter glb_src = True 86*a483e64cSAdrian Hunter else: 87a92bf335SAdrian Hunter print("Intel PT Branch Trace, Power Events and PTWRITE") 88*a483e64cSAdrian Hunter itrace = "bepwx" 89*a483e64cSAdrian Hunter global glb_disassembler 90*a483e64cSAdrian Hunter try: 91*a483e64cSAdrian Hunter glb_disassembler = LibXED() 92*a483e64cSAdrian Hunter except: 93*a483e64cSAdrian Hunter glb_disassembler = None 94*a483e64cSAdrian Hunter perf_set_itrace_options(perf_script_context, itrace) 95cc892720SAdrian Hunter 96cc892720SAdrian Hunterdef trace_end(): 97fdf2460cSTony Jones print("End") 98cc892720SAdrian Hunter 99cc892720SAdrian Hunterdef trace_unhandled(event_name, context, event_fields_dict): 100fdf2460cSTony Jones print(' '.join(['%s=%s'%(k,str(v))for k,v in sorted(event_fields_dict.items())])) 101cc892720SAdrian Hunter 102cc892720SAdrian Hunterdef print_ptwrite(raw_buf): 103cc892720SAdrian Hunter data = struct.unpack_from("<IQ", raw_buf) 104cc892720SAdrian Hunter flags = data[0] 105cc892720SAdrian Hunter payload = data[1] 106cc892720SAdrian Hunter exact_ip = flags & 1 107fdf2460cSTony Jones print("IP: %u payload: %#x" % (exact_ip, payload), end=' ') 108cc892720SAdrian Hunter 109cc892720SAdrian Hunterdef print_cbr(raw_buf): 110cc892720SAdrian Hunter data = struct.unpack_from("<BBBBII", raw_buf) 111cc892720SAdrian Hunter cbr = data[0] 112cc892720SAdrian Hunter f = (data[4] + 500) / 1000 113cc892720SAdrian Hunter p = ((cbr * 1000 / data[2]) + 5) / 10 114fdf2460cSTony Jones print("%3u freq: %4u MHz (%3u%%)" % (cbr, f, p), end=' ') 115cc892720SAdrian Hunter 116cc892720SAdrian Hunterdef print_mwait(raw_buf): 117cc892720SAdrian Hunter data = struct.unpack_from("<IQ", raw_buf) 118cc892720SAdrian Hunter payload = data[1] 119cc892720SAdrian Hunter hints = payload & 0xff 120cc892720SAdrian Hunter extensions = (payload >> 32) & 0x3 121fdf2460cSTony Jones print("hints: %#x extensions: %#x" % (hints, extensions), end=' ') 122cc892720SAdrian Hunter 123cc892720SAdrian Hunterdef print_pwre(raw_buf): 124cc892720SAdrian Hunter data = struct.unpack_from("<IQ", raw_buf) 125cc892720SAdrian Hunter payload = data[1] 126cc892720SAdrian Hunter hw = (payload >> 7) & 1 127cc892720SAdrian Hunter cstate = (payload >> 12) & 0xf 128cc892720SAdrian Hunter subcstate = (payload >> 8) & 0xf 129fdf2460cSTony Jones print("hw: %u cstate: %u sub-cstate: %u" % (hw, cstate, subcstate), 130fdf2460cSTony Jones end=' ') 131cc892720SAdrian Hunter 132cc892720SAdrian Hunterdef print_exstop(raw_buf): 133cc892720SAdrian Hunter data = struct.unpack_from("<I", raw_buf) 134cc892720SAdrian Hunter flags = data[0] 135cc892720SAdrian Hunter exact_ip = flags & 1 136fdf2460cSTony Jones print("IP: %u" % (exact_ip), end=' ') 137cc892720SAdrian Hunter 138cc892720SAdrian Hunterdef print_pwrx(raw_buf): 139cc892720SAdrian Hunter data = struct.unpack_from("<IQ", raw_buf) 140cc892720SAdrian Hunter payload = data[1] 141cc892720SAdrian Hunter deepest_cstate = payload & 0xf 142cc892720SAdrian Hunter last_cstate = (payload >> 4) & 0xf 143cc892720SAdrian Hunter wake_reason = (payload >> 8) & 0xf 144fdf2460cSTony Jones print("deepest cstate: %u last cstate: %u wake reason: %#x" % 145fdf2460cSTony Jones (deepest_cstate, last_cstate, wake_reason), end=' ') 146cc892720SAdrian Hunter 147a92bf335SAdrian Hunterdef print_psb(raw_buf): 148a92bf335SAdrian Hunter data = struct.unpack_from("<IQ", raw_buf) 149a92bf335SAdrian Hunter offset = data[1] 150a92bf335SAdrian Hunter print("offset: %#x" % (offset), end=' ') 151a92bf335SAdrian Hunter 152*a483e64cSAdrian Hunterdef common_start_str(comm, sample): 153cc892720SAdrian Hunter ts = sample["time"] 154cc892720SAdrian Hunter cpu = sample["cpu"] 155cc892720SAdrian Hunter pid = sample["pid"] 156cc892720SAdrian Hunter tid = sample["tid"] 157*a483e64cSAdrian Hunter return "%16s %5u/%-5u [%03u] %9u.%09u " % (comm, pid, tid, cpu, ts / 1000000000, ts %1000000000) 158*a483e64cSAdrian Hunter 159*a483e64cSAdrian Hunterdef print_common_start(comm, sample, name): 160a92bf335SAdrian Hunter flags_disp = get_optional_null(sample, "flags_disp") 161a92bf335SAdrian Hunter # Unused fields: 162a92bf335SAdrian Hunter # period = sample["period"] 163a92bf335SAdrian Hunter # phys_addr = sample["phys_addr"] 164a92bf335SAdrian Hunter # weight = sample["weight"] 165a92bf335SAdrian Hunter # transaction = sample["transaction"] 166a92bf335SAdrian Hunter # cpumode = get_optional_zero(sample, "cpumode") 167*a483e64cSAdrian Hunter print(common_start_str(comm, sample) + "%7s %19s" % (name, flags_disp), end=' ') 168*a483e64cSAdrian Hunter 169*a483e64cSAdrian Hunterdef print_instructions_start(comm, sample): 170*a483e64cSAdrian Hunter if "x" in get_optional_null(sample, "flags"): 171*a483e64cSAdrian Hunter print(common_start_str(comm, sample) + "x", end=' ') 172*a483e64cSAdrian Hunter else: 173*a483e64cSAdrian Hunter print(common_start_str(comm, sample), end=' ') 174*a483e64cSAdrian Hunter 175*a483e64cSAdrian Hunterdef disassem(insn, ip): 176*a483e64cSAdrian Hunter inst = glb_disassembler.Instruction() 177*a483e64cSAdrian Hunter glb_disassembler.SetMode(inst, 0) # Assume 64-bit 178*a483e64cSAdrian Hunter buf = create_string_buffer(64) 179*a483e64cSAdrian Hunter buf.value = insn 180*a483e64cSAdrian Hunter return glb_disassembler.DisassembleOne(inst, addressof(buf), len(insn), ip) 181cc892720SAdrian Hunter 182a92bf335SAdrian Hunterdef print_common_ip(param_dict, sample, symbol, dso): 183cc892720SAdrian Hunter ip = sample["ip"] 184a92bf335SAdrian Hunter offs = get_offset(param_dict, "symoff") 185*a483e64cSAdrian Hunter if "cyc_cnt" in sample: 186*a483e64cSAdrian Hunter cyc_cnt = sample["cyc_cnt"] 187*a483e64cSAdrian Hunter insn_cnt = get_optional_zero(sample, "insn_cnt") 188*a483e64cSAdrian Hunter ipc_str = " IPC: %#.2f (%u/%u)" % (insn_cnt / cyc_cnt, insn_cnt, cyc_cnt) 189*a483e64cSAdrian Hunter else: 190*a483e64cSAdrian Hunter ipc_str = "" 191*a483e64cSAdrian Hunter if glb_insn and glb_disassembler is not None: 192*a483e64cSAdrian Hunter insn = perf_sample_insn(perf_script_context) 193*a483e64cSAdrian Hunter if insn and len(insn): 194*a483e64cSAdrian Hunter cnt, text = disassem(insn, ip) 195*a483e64cSAdrian Hunter byte_str = ("%x" % ip).rjust(16) 196*a483e64cSAdrian Hunter if sys.version_info.major >= 3: 197*a483e64cSAdrian Hunter for k in range(cnt): 198*a483e64cSAdrian Hunter byte_str += " %02x" % insn[k] 199*a483e64cSAdrian Hunter else: 200*a483e64cSAdrian Hunter for k in xrange(cnt): 201*a483e64cSAdrian Hunter byte_str += " %02x" % ord(insn[k]) 202*a483e64cSAdrian Hunter print("%-40s %-30s" % (byte_str, text), end=' ') 203*a483e64cSAdrian Hunter print("%s%s (%s)" % (symbol, offs, dso), end=' ') 204*a483e64cSAdrian Hunter else: 205a92bf335SAdrian Hunter print("%16x %s%s (%s)" % (ip, symbol, offs, dso), end=' ') 206a92bf335SAdrian Hunter if "addr_correlates_sym" in sample: 207a92bf335SAdrian Hunter addr = sample["addr"] 208a92bf335SAdrian Hunter dso = get_optional(sample, "addr_dso") 209a92bf335SAdrian Hunter symbol = get_optional(sample, "addr_symbol") 210a92bf335SAdrian Hunter offs = get_offset(sample, "addr_symoff") 211*a483e64cSAdrian Hunter print("=> %x %s%s (%s)%s" % (addr, symbol, offs, dso, ipc_str)) 212a92bf335SAdrian Hunter else: 213*a483e64cSAdrian Hunter print(ipc_str) 214*a483e64cSAdrian Hunter 215*a483e64cSAdrian Hunterdef print_srccode(comm, param_dict, sample, symbol, dso, with_insn): 216*a483e64cSAdrian Hunter ip = sample["ip"] 217*a483e64cSAdrian Hunter if symbol == "[unknown]": 218*a483e64cSAdrian Hunter start_str = common_start_str(comm, sample) + ("%x" % ip).rjust(16).ljust(40) 219*a483e64cSAdrian Hunter else: 220*a483e64cSAdrian Hunter offs = get_offset(param_dict, "symoff") 221*a483e64cSAdrian Hunter start_str = common_start_str(comm, sample) + (symbol + offs).ljust(40) 222*a483e64cSAdrian Hunter 223*a483e64cSAdrian Hunter if with_insn and glb_insn and glb_disassembler is not None: 224*a483e64cSAdrian Hunter insn = perf_sample_insn(perf_script_context) 225*a483e64cSAdrian Hunter if insn and len(insn): 226*a483e64cSAdrian Hunter cnt, text = disassem(insn, ip) 227*a483e64cSAdrian Hunter start_str += text.ljust(30) 228*a483e64cSAdrian Hunter 229*a483e64cSAdrian Hunter global glb_source_file_name 230*a483e64cSAdrian Hunter global glb_line_number 231*a483e64cSAdrian Hunter global glb_dso 232*a483e64cSAdrian Hunter 233*a483e64cSAdrian Hunter source_file_name, line_number, source_line = perf_sample_srccode(perf_script_context) 234*a483e64cSAdrian Hunter if source_file_name: 235*a483e64cSAdrian Hunter if glb_line_number == line_number and glb_source_file_name == source_file_name: 236*a483e64cSAdrian Hunter src_str = "" 237*a483e64cSAdrian Hunter else: 238*a483e64cSAdrian Hunter if len(source_file_name) > 40: 239*a483e64cSAdrian Hunter src_file = ("..." + source_file_name[-37:]) + " " 240*a483e64cSAdrian Hunter else: 241*a483e64cSAdrian Hunter src_file = source_file_name.ljust(41) 242*a483e64cSAdrian Hunter if source_line is None: 243*a483e64cSAdrian Hunter src_str = src_file + str(line_number).rjust(4) + " <source not found>" 244*a483e64cSAdrian Hunter else: 245*a483e64cSAdrian Hunter src_str = src_file + str(line_number).rjust(4) + " " + source_line 246*a483e64cSAdrian Hunter glb_dso = None 247*a483e64cSAdrian Hunter elif dso == glb_dso: 248*a483e64cSAdrian Hunter src_str = "" 249*a483e64cSAdrian Hunter else: 250*a483e64cSAdrian Hunter src_str = dso 251*a483e64cSAdrian Hunter glb_dso = dso 252*a483e64cSAdrian Hunter 253*a483e64cSAdrian Hunter glb_line_number = line_number 254*a483e64cSAdrian Hunter glb_source_file_name = source_file_name 255*a483e64cSAdrian Hunter 256*a483e64cSAdrian Hunter print(start_str, src_str) 257cc892720SAdrian Hunter 258a92bf335SAdrian Hunterdef do_process_event(param_dict): 259a92bf335SAdrian Hunter global glb_switch_printed 260a92bf335SAdrian Hunter if not glb_switch_printed: 261a92bf335SAdrian Hunter print(glb_switch_str) 262a92bf335SAdrian Hunter glb_switch_printed = True 263cc892720SAdrian Hunter event_attr = param_dict["attr"] 264cc892720SAdrian Hunter sample = param_dict["sample"] 265cc892720SAdrian Hunter raw_buf = param_dict["raw_buf"] 266cc892720SAdrian Hunter comm = param_dict["comm"] 267cc892720SAdrian Hunter name = param_dict["ev_name"] 268a92bf335SAdrian Hunter # Unused fields: 269a92bf335SAdrian Hunter # callchain = param_dict["callchain"] 270a92bf335SAdrian Hunter # brstack = param_dict["brstack"] 271a92bf335SAdrian Hunter # brstacksym = param_dict["brstacksym"] 272cc892720SAdrian Hunter 273cc892720SAdrian Hunter # Symbol and dso info are not always resolved 274a92bf335SAdrian Hunter dso = get_optional(param_dict, "dso") 275a92bf335SAdrian Hunter symbol = get_optional(param_dict, "symbol") 276cc892720SAdrian Hunter 277*a483e64cSAdrian Hunter if name[0:12] == "instructions": 278*a483e64cSAdrian Hunter if glb_src: 279*a483e64cSAdrian Hunter print_srccode(comm, param_dict, sample, symbol, dso, True) 280*a483e64cSAdrian Hunter else: 281*a483e64cSAdrian Hunter print_instructions_start(comm, sample) 282*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 283*a483e64cSAdrian Hunter elif name[0:8] == "branches": 284*a483e64cSAdrian Hunter if glb_src: 285*a483e64cSAdrian Hunter print_srccode(comm, param_dict, sample, symbol, dso, False) 286*a483e64cSAdrian Hunter else: 287a92bf335SAdrian Hunter print_common_start(comm, sample, name) 288*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 289*a483e64cSAdrian Hunter elif name == "ptwrite": 290*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 291cc892720SAdrian Hunter print_ptwrite(raw_buf) 292*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 293cc892720SAdrian Hunter elif name == "cbr": 294*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 295cc892720SAdrian Hunter print_cbr(raw_buf) 296*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 297cc892720SAdrian Hunter elif name == "mwait": 298*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 299cc892720SAdrian Hunter print_mwait(raw_buf) 300*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 301cc892720SAdrian Hunter elif name == "pwre": 302*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 303cc892720SAdrian Hunter print_pwre(raw_buf) 304*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 305cc892720SAdrian Hunter elif name == "exstop": 306*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 307cc892720SAdrian Hunter print_exstop(raw_buf) 308*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 309cc892720SAdrian Hunter elif name == "pwrx": 310*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 311cc892720SAdrian Hunter print_pwrx(raw_buf) 312*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 313a92bf335SAdrian Hunter elif name == "psb": 314*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 315a92bf335SAdrian Hunter print_psb(raw_buf) 316*a483e64cSAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 317*a483e64cSAdrian Hunter else: 318*a483e64cSAdrian Hunter print_common_start(comm, sample, name) 319a92bf335SAdrian Hunter print_common_ip(param_dict, sample, symbol, dso) 320a92bf335SAdrian Hunter 321a92bf335SAdrian Hunterdef process_event(param_dict): 322a92bf335SAdrian Hunter try: 323a92bf335SAdrian Hunter do_process_event(param_dict) 324a92bf335SAdrian Hunter except broken_pipe_exception: 325a92bf335SAdrian Hunter # Stop python printing broken pipe errors and traceback 326a92bf335SAdrian Hunter sys.stdout = open(os.devnull, 'w') 327a92bf335SAdrian Hunter sys.exit(1) 328a92bf335SAdrian Hunter 329a92bf335SAdrian Hunterdef auxtrace_error(typ, code, cpu, pid, tid, ip, ts, msg, cpumode, *x): 330a92bf335SAdrian Hunter try: 331a92bf335SAdrian Hunter print("%16s %5u/%-5u [%03u] %9u.%09u error type %u code %u: %s ip 0x%16x" % 332a92bf335SAdrian Hunter ("Trace error", pid, tid, cpu, ts / 1000000000, ts %1000000000, typ, code, msg, ip)) 333a92bf335SAdrian Hunter except broken_pipe_exception: 334a92bf335SAdrian Hunter # Stop python printing broken pipe errors and traceback 335a92bf335SAdrian Hunter sys.stdout = open(os.devnull, 'w') 336a92bf335SAdrian Hunter sys.exit(1) 337a92bf335SAdrian Hunter 338a92bf335SAdrian Hunterdef context_switch(ts, cpu, pid, tid, np_pid, np_tid, machine_pid, out, out_preempt, *x): 339a92bf335SAdrian Hunter global glb_switch_printed 340a92bf335SAdrian Hunter global glb_switch_str 341a92bf335SAdrian Hunter if out: 342a92bf335SAdrian Hunter out_str = "Switch out " 343a92bf335SAdrian Hunter else: 344a92bf335SAdrian Hunter out_str = "Switch In " 345a92bf335SAdrian Hunter if out_preempt: 346a92bf335SAdrian Hunter preempt_str = "preempt" 347a92bf335SAdrian Hunter else: 348a92bf335SAdrian Hunter preempt_str = "" 349a92bf335SAdrian Hunter if machine_pid == -1: 350a92bf335SAdrian Hunter machine_str = "" 351a92bf335SAdrian Hunter else: 352a92bf335SAdrian Hunter machine_str = "machine PID %d" % machine_pid 353a92bf335SAdrian Hunter glb_switch_str = "%16s %5d/%-5d [%03u] %9u.%09u %5d/%-5d %s %s" % \ 354a92bf335SAdrian Hunter (out_str, pid, tid, cpu, ts / 1000000000, ts %1000000000, np_pid, np_tid, machine_str, preempt_str) 355a92bf335SAdrian Hunter glb_switch_printed = False 356