Received: by 10.223.176.5 with SMTP id f5csp1715406wra; Thu, 8 Feb 2018 02:12:42 -0800 (PST) X-Google-Smtp-Source: AH8x224W8znUwjRz+XqVpPHj4Tdy6iJ6XxlT0Luei6h+YRd4xAHqADLh/4yL3qobiftNu/pL69dE X-Received: by 10.101.101.84 with SMTP id a20mr112800pgw.163.1518084762190; Thu, 08 Feb 2018 02:12:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518084762; cv=none; d=google.com; s=arc-20160816; b=btXOZ/3nFyHF0pxQ7Yc60BD+rDtSCNtpiMESnWs8gNz3HQSWUrC1oOBvPoETi/Caji KcSQ7ieDeLGR18LcodztXK8tyLxbXLuCAdjOI4ifXNMm7tF/aEcnu7q642ubPmCCu+kp Ef1yz0bQYo3QdPhV5B6dZKQ+uGew+J69ZpRSfHMYI9So9N5hqVVDHYaJOc7aln4TdfyN 4YdqxJars/CXrIguCsg+DcYGyb4ugI1nabSv2uIXT+RNvBVwRz4V1qpZDRba57319HDK Hj+LvSRWgz+bsR+CUa4NvKT1kvsJm3awaPi16wV9C8MNgaJxmTYXKQKcufsJnsbU3ua7 BKKw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=9MopgO6mMbtDQ35p7vyhq4AB5NLU83qmDBItFZ5FNGE=; b=y3MHJQcJ8KqQ5CQaCh74ZjD8W4jKFZaabkr/bSDzBjopnK6j8BNsZYP/cjgFVM+QDp T+hKXYoB7gL4vw9IJZZJGsTRD1ZjgxUcriDrLsqnWV7Hz2bJFOAbUf2HhXp/tVb53U7+ am41j9gXuBdPZG0EvMwI5DjrIhvb7nZxnEJgf0wGi/cEK3pNsUqqUtf8fgzME4z25rVV xjeYQIy0G2KHsfKnyJpvvz3o4BWsh+AWFCtXb1oe7cSt5YGpiS03CrXgazUc5bAH3ZRu pKgc7axP2redSUN7dEMcDcE3gudV2aydjKdJ1hiwdMQDXwWI9W52qtTGuD79kdC7FkPH cQMw== 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 g29-v6si2640252plj.50.2018.02.08.02.12.28; Thu, 08 Feb 2018 02:12:42 -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 S1752292AbeBHKLx (ORCPT + 99 others); Thu, 8 Feb 2018 05:11:53 -0500 Received: from mga01.intel.com ([192.55.52.88]:52720 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752181AbeBHKLw (ORCPT ); Thu, 8 Feb 2018 05:11:52 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 08 Feb 2018 02:11:52 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.46,477,1511856000"; d="scan'208";a="18240636" Received: from gvt-dell.bj.intel.com (HELO gvt-dell-host.bj.intel.com) ([10.238.154.59]) by fmsmga002.fm.intel.com with ESMTP; 08 Feb 2018 02:11:50 -0800 From: changbin.du@intel.com To: jolsa@redhat.com Cc: peterz@infradead.org, mingo@redhat.com, acme@kernel.org, namhyung@kernel.org, linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, Changbin Du Subject: [PATCH] perf sched map: re-annotate shortname if thread comm changed Date: Thu, 8 Feb 2018 18:03:08 +0800 Message-Id: <1518084188-29576-1-git-send-email-changbin.du@intel.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Changbin Du This is to show the real name of thread that created via fork-exec. See below example for shortname *A0*. $ sudo ./perf sched map *A0 80393.050639 secs A0 => perf:22368 *. A0 80393.050748 secs . => swapper:0 . *. 80393.050887 secs *B0 . . 80393.052735 secs B0 => rcu_sched:8 *. . . 80393.052743 secs . *C0 . 80393.056264 secs C0 => kworker/2:1H:287 . *A0 . 80393.056270 secs . *D0 . 80393.056769 secs D0 => ksoftirqd/2:22 . *A0 . 80393.056804 secs A0 => pi:22368 . *. . 80393.056854 secs *B0 . . 80393.060727 secs ... Signed-off-by: Changbin Du --- tools/perf/builtin-sched.c | 4 +++- tools/perf/util/thread.c | 1 + tools/perf/util/thread.h | 1 + 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index 83283fe..53bb8df 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c @@ -1580,7 +1580,7 @@ static int map_switch_event(struct perf_sched *sched, struct perf_evsel *evsel, timestamp__scnprintf_usec(timestamp, stimestamp, sizeof(stimestamp)); color_fprintf(stdout, color, " %12s secs ", stimestamp); - if (new_shortname || (verbose > 0 && sched_in->tid)) { + if (new_shortname || sched_in->comm_changed || (verbose > 0 && sched_in->tid)) { const char *pid_color = color; if (thread__has_color(sched_in)) @@ -1588,6 +1588,8 @@ static int map_switch_event(struct perf_sched *sched, struct perf_evsel *evsel, color_fprintf(stdout, pid_color, "%s => %s:%d", sched_in->shortname, thread__comm_str(sched_in), sched_in->tid); + + sched_in->comm_changed = false; } if (sched->map.comp && new_cpu) diff --git a/tools/perf/util/thread.c b/tools/perf/util/thread.c index 68b65b1..c660fe6 100644 --- a/tools/perf/util/thread.c +++ b/tools/perf/util/thread.c @@ -212,6 +212,7 @@ static int ____thread__set_comm(struct thread *thread, const char *str, unwind__flush_access(thread); } + thread->comm_changed = true; thread->comm_set = true; return 0; diff --git a/tools/perf/util/thread.h b/tools/perf/util/thread.h index 40cfa36..b9a328b 100644 --- a/tools/perf/util/thread.h +++ b/tools/perf/util/thread.h @@ -27,6 +27,7 @@ struct thread { int cpu; refcount_t refcnt; char shortname[3]; + bool comm_changed; bool comm_set; int comm_len; bool dead; /* if set thread has exited */ -- 2.7.4