Received: by 10.192.165.148 with SMTP id m20csp5032768imm; Tue, 24 Apr 2018 12:29:01 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+ufGi4oG3sS8COjXXbMAIrO+8HWhzx5erzRio/uQGkNB+FRouma0a6ox/ooTt1iNKcU+oW X-Received: by 10.98.4.133 with SMTP id 127mr25051951pfe.26.1524598141760; Tue, 24 Apr 2018 12:29:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524598141; cv=none; d=google.com; s=arc-20160816; b=GwaMD/M1hRlciQJH2WFvQWC6FiltylClcHA356zbLSTGAKEhoC2yTF8DOBbOhjdhSO k5CLtv4/fqz9rTja5ZdkuCt/YXCJW8Wsn8f/6mcQYi6ibKqNoPEFvrr6uG1zMchETY/c jd9POPWNTaBErerc7WY/iCsw+STVoBCIj/xupMgJkDweJvF1DerEz+ImgowNQv1uGbTB QXqCm/w9uviEl2QUh5VUZlOd1JIbUF/w+xtE/oWyJxnAFjzUE0906ET5qlHLP7fcSuBT pU5vnJXqizjE04Hxl+oFz3Rv/PZzJ99ZWxfFQ0wNPFYrzZ2ypnxHEWjM8mei/LD3F6LC JxpA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=HfMbfImLOHY/m0ElHYv5kOM/cRUWC2s8lu8lN3fvBFU=; b=lzB/ppUgu7ZCqAQAHqQyTWU1LmXneWa0cL8sBvmqiJj/je539rUAb1M8YuiPggmb1X IF95cxWi+gcXlNvpTvtu+AeeHDBYqVX9g3JGbW28SWyeIUtOR3cdF4qVZeUjKsHu284e y1Hnc5nd9r0ZuRULOAINMTBjc2gmsik5jIn7l/jMPvwHgw1f5142Ge5vqiIUMCU7Oe9j 9m76oIPZPCSivSKSnCdtFe0LOLlr6rA+g7gp5hJj3LaQWpjFyCuQl2Is6vRBTnthaZSk IsOCKgw0I8oCCi0C8IpoBZlBta4Ch2HaPK7Ftrz2NCzKeHzeBn8C68SluaHuyUYTrYrX gCTQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=a2uA//jW; 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 z12si7139889pgp.671.2018.04.24.12.28.47; Tue, 24 Apr 2018 12:29:01 -0700 (PDT) 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; dkim=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=a2uA//jW; 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 S1751095AbeDXT13 (ORCPT + 99 others); Tue, 24 Apr 2018 15:27:29 -0400 Received: from esa2.hgst.iphmx.com ([68.232.143.124]:39383 "EHLO esa2.hgst.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750778AbeDXT12 (ORCPT ); Tue, 24 Apr 2018 15:27:28 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1524598414; x=1556134414; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=PabBVet19oYndxV7SlwSmpesBDrkmRSi4mgvoQBIGmg=; b=a2uA//jWMY0FAqmAq6lKApQfYZZc9xzFm/Am5dxjJu22yfUpuIhtpYMy XvJfjgqxVt+BYbmKlZT9vg7C9Tswrs6CeoSsUXyONbvDRc40YSowpVKDp IHqymuw0bfxQlkZfo3zzzMejmWkNgD/YMQqCSlVvZROOpYXNiWG3Kn/HM kQl++zrpAWQu0G6fDC4clAjBBXj456kNdInAP08QAM88vlj3pxWWpQibq 66Y9tmeo2o8aYKxMVnyX50Voc5ELTS+FNZGdl66WmbgeP+zMP53kQR8r5 u12vHFCkvCMJWhvSP4fGI7KkoWqzJgkjZSDRQKWV3jdkhXSUoZ1ODogCs Q==; X-IronPort-AV: E=Sophos;i="5.49,324,1520870400"; d="scan'208";a="173291108" Received: from h199-255-45-15.hgst.com (HELO uls-op-cesaep02.wdc.com) ([199.255.45.15]) by ob1.hgst.iphmx.com with ESMTP; 25 Apr 2018 03:33:34 +0800 Received: from uls-op-cesaip01.wdc.com ([10.248.3.36]) by uls-op-cesaep02.wdc.com with ESMTP; 24 Apr 2018 12:19:00 -0700 Received: from c02v91rdhtd5.sdcorp.global.sandisk.com (HELO [10.111.65.51]) ([10.111.65.51]) by uls-op-cesaip01.wdc.com with ESMTP; 24 Apr 2018 12:27:27 -0700 Subject: Re: [PATCH v5 0/2] perf: riscv: Preliminary Perf Event Support on RISC-V To: Alan Kao , Palmer Dabbelt , Albert Ou , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Alex Solomatnikov , Jonathan Corbet , "linux-riscv@lists.infradead.org" , "linux-doc@vger.kernel.org" , "linux-kernel@vger.kernel.org" Cc: Greentime Hu , Nick Hu References: <1524180470-8622-1-git-send-email-alankao@andestech.com> From: Atish Patra Message-ID: <661405fd-7b23-5f95-568d-0e2eb1925217@wdc.com> Date: Tue, 24 Apr 2018 12:27:26 -0700 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/24/18 11:07 AM, Atish Patra wrote: > On 4/19/18 4:28 PM, Alan Kao wrote: >> This implements the baseline PMU for RISC-V platforms. >> >> To ease future PMU portings, a guide is also written, containing >> perf concepts, arch porting practices and some hints. >> >> Changes in v5: >> - Fix patch errors from checkpatch.pl. >> >> Changes in v4: >> - Fix several compilation errors. Sorry for that. >> - Raise a warning in the write_counter body. >> >> Changes in v3: >> - Fix typos in the document. >> - Change the initialization routine from statically assigning PMU to >> device-tree-based methods, and set default to the PMU proposed in >> this patch. >> >> Changes in v2: >> - Fix the bug reported by Alex, which was caused by not sufficient >> initialization. Check https://lkml.org/lkml/2018/3/31/251 for the >> discussion. >> >> Alan Kao (2): >> perf: riscv: preliminary RISC-V support >> perf: riscv: Add Document for Future Porting Guide >> >> Documentation/riscv/pmu.txt | 249 ++++++++++++++ >> arch/riscv/Kconfig | 13 + >> arch/riscv/include/asm/perf_event.h | 79 ++++- >> arch/riscv/kernel/Makefile | 1 + >> arch/riscv/kernel/perf_event.c | 485 ++++++++++++++++++++++++++++ >> 5 files changed, 823 insertions(+), 4 deletions(-) >> create mode 100644 Documentation/riscv/pmu.txt >> create mode 100644 arch/riscv/kernel/perf_event.c >> > Most of the perf tests either pass or fail because of unsupported > event/trace point which is fine. > > However, I got an rcu-stall for the test "47: Event times". > # ./perf test -v 47 > 47: Event times : > --- start --- > test child forked, pid 2774 > attaching to spawned child, enable on exec > OK : ena 2243000, run 2243000 > attaching to current thread as enabled > OK : ena 19000, run 19000 > attaching to current thread as disabled > OK : ena 5000, run 5000 > attaching to CPU 0 as enabled > [ 1001.466578] INFO: rcu_sched self-detected stall on CPU > [ 1001.470947] 4-....: (29999 ticks this GP) idle=5fa/140000000000001/0 > softirq=19762/19762 fqs=14602 > [ 1001.480053] (t=30001 jiffies g=3471 c=3470 q=125) > [ 1001.484917] Task dump for CPU 4: > [ 1001.488129] perf R running task 0 2774 2773 > 0x00000008 > [ 1001.495161] Call Trace: > [ 1001.497606] [<000000006a3d4f87>] walk_stackframe+0x0/0xc0 > [ 1001.502980] [<000000004b4b0780>] show_stack+0x3c/0x46 > [ 1001.508024] [<0000000060c96ab8>] sched_show_task+0xd0/0x122 > [ 1001.513573] [<000000007d8bd54e>] dump_cpu_task+0x50/0x5a > [ 1001.518870] [<0000000053990e11>] rcu_dump_cpu_stacks+0x98/0xd2 > [ 1001.524685] [<00000000fe94c593>] rcu_check_callbacks+0x614/0x822 > [ 1001.530680] [<0000000057688dd3>] update_process_times+0x38/0x6a > [ 1001.536585] [<0000000063a96de0>] tick_periodic+0x58/0xd8 > [ 1001.541876] [<0000000013d712f1>] tick_handle_periodic+0x2e/0x7c > [ 1001.547780] [<000000009e2ef428>] riscv_timer_interrupt+0x34/0x3c > [ 1001.553774] [<00000000ff6b1f18>] riscv_intc_irq+0xbc/0xe0 > [ 1001.559153] [<00000000c8614c3b>] ret_from_exception+0x0/0xc > > It is quite possible that we don't support some dependency > infrastructure. I am looking into it. > > Regards, > Atish > > > > > Got it working. The test tries to attach the event to CPU0 which doesn't exist in HighFive Unleashed. Changing it to cpu1 works. diff --git a/tools/perf/tests/event-times.c b/tools/perf/tests/event-times.c index 1a2686f..eb11632f 100644 --- a/tools/perf/tests/event-times.c +++ b/tools/perf/tests/event-times.c @@ -113,9 +113,9 @@ static int attach__cpu_disabled(struct perf_evlist *evlist) struct cpu_map *cpus; int err; - pr_debug("attaching to CPU 0 as enabled\n"); + pr_debug("attaching to CPU 1 as disabled\n"); - cpus = cpu_map__new("0"); + cpus = cpu_map__new("1"); if (cpus == NULL) { pr_debug("failed to call cpu_map__new\n"); return -1; @@ -142,9 +142,9 @@ static int attach__cpu_enabled(struct perf_evlist *evlist) struct cpu_map *cpus; int err; - pr_debug("attaching to CPU 0 as enabled\n"); + pr_debug("attaching to CPU 1 as enabled\n"); - cpus = cpu_map__new("0"); + cpus = cpu_map__new("1"); if (cpus == NULL) { pr_debug("failed to call cpu_map__new\n"); return -1; Palmer, Would it be better to officially document it somewhere that CPU0 doesn't exist in the HighFive Unleashed board ? I fear that there will be other standard tests/code path that may fail because of inherent assumption of cpu0 presence. Regards, Atish