Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753821AbbFLUkG (ORCPT ); Fri, 12 Jun 2015 16:40:06 -0400 Received: from mga03.intel.com ([134.134.136.65]:47625 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751362AbbFLUkD convert rfc822-to-8bit (ORCPT ); Fri, 12 Jun 2015 16:40:03 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.13,604,1427785200"; d="scan'208";a="745772812" From: "Liang, Kan" To: David Ahern , Andi Kleen CC: Arnaldo Carvalho de Melo , "linux-kernel@vger.kernel.org" , "Huang, Ying" Subject: RE: [PATCH 1/1] perf,tools: add time out to force stop endless mmap processing Thread-Topic: [PATCH 1/1] perf,tools: add time out to force stop endless mmap processing Thread-Index: AQHQo44i3glIe3h0sEG/9i/L0QJfWp2m0lUAgAAU7wCAADmvgIAAYMUAgAFtkPD//5AIgIAAk2vg//+KeQCAAJJsMP//j0eAABDMbwA= Date: Fri, 12 Jun 2015 20:39:55 +0000 Message-ID: <37D7C6CF3E00A74B8858931C1DB2F07701876D60@SHSMSX103.ccr.corp.intel.com> References: <1433922364-22580-1-git-send-email-kan.liang@intel.com> <20150611140614.GC2696@kernel.org> <5579A766.4010504@gmail.com> <20150611184737.GU19417@two.firstfloor.org> <557A28F6.8040603@gmail.com> <37D7C6CF3E00A74B8858931C1DB2F077018767AD@SHSMSX103.ccr.corp.intel.com> <557AFDB1.7030902@gmail.com> <37D7C6CF3E00A74B8858931C1DB2F07701876834@SHSMSX103.ccr.corp.intel.com> <557B16C4.7000000@gmail.com> <37D7C6CF3E00A74B8858931C1DB2F07701876CB2@SHSMSX103.ccr.corp.intel.com> <557B3309.4080002@gmail.com> In-Reply-To: <557B3309.4080002@gmail.com> Accept-Language: zh-CN, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.239.127.40] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2183 Lines: 57 > > On 6/12/15 12:19 PM, Liang, Kan wrote: > >>> [perf]$ sudo ./perf record -e instructions:pp --pid 14560 Reading > >>> /proc/14560/maps cost 13.12690599 s ^C[ perf record: Woken up 1 > >>> times to write data ] [ perf record: Captured and wrote 0.108 MB > >>> perf.data > >>> (2783 samples) ] > >> > >> so perf was able to read the proc file? > > > > Yes, perf always can read proc file. The problem is that the proc file > > is huge and keep growing faster than proc reader. > > So perf top do loop in perf_event__synthesize_mmap_events until the > > test case exit. > > I'm confused. How are you getting the above time to read /proc maps if it > never finishes? I just tried to simplify the issue for perf record. So you may noticed that I only read one thread. There are several threads in the system. Also, I do the perf record test when starting the test case. The proc file is not that big. For perf top, it will monitor whole system. So it never finishes. > > for this test case how does perf-record compare between proc and > task_diag? You can use my command for both. It defaults to using > task_diag and then you can add --no-task_diag to have it read /proc. And > as mentioned before it is only setup for 'perf record -a' case. So > > launch your test program > perf record -a -- usleep 1 > perf record -a --no-task_diag -- usleep 1 > Here are the test results. Please note that I get "synthesized threads took..." after the test case exit. It means both way have the same issue. [perf]$ sudo ./perf record -a -- usleep 1 synthesized threads took 278.780762 sec [ perf record: Woken up 1 times to write data ] [ perf record: Captured and wrote 0.617 MB perf.data (7974 samples) ] [perf]$ sudo ./perf record -a --no-task_diag -- usleep 1 synthesized threads took 315.612403 sec [ perf record: Woken up 1 times to write data ] [ perf record: Captured and wrote 0.443 MB perf.data (2754 samples) ] Thanks, Kan -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/