Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3519908pxf; Mon, 15 Mar 2021 11:22:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzhk2P3DfE8Vatqkq79gMpb1Q3oIe6ob5Y7PDjtPneipJOqT8Q7YPHc+JA4aQWi8Le8Kegb X-Received: by 2002:a17:907:629e:: with SMTP id nd30mr15060648ejc.407.1615832528935; Mon, 15 Mar 2021 11:22:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615832528; cv=none; d=google.com; s=arc-20160816; b=WAgL9L7tYyJuhTg9r6hv1AIfMFfgBFDY4iT7OPdoUmvPAkt2RzYZk1uNdGiYu+EP6e sDbrdrTmAeSHgnYI7aU8CpFsz98bdNt4Gi+/a8v/00nuEGODtdSSg7dly15XZobNUu13 AzxyN1f0MEpZknJweu3fvtu/n3BXYF6lkGDc6pUOC6pBWRlRceffOmIs2Ch/JT6AfYRX 4ubTAcGghFuFJEYENbKucOJR8EpZryfcCkExWwIevlr1Z4xVea1V8Bgn1IBBULHjBOkN +YozCRbAVZlYydDTOSTw+AF4Bd43fxF1PBSLbSmpRCBPs2acmJbvSr16q4MLntZEUi0S 8Sjw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=NWm8uRb4e/xEzOA7IMQiqCTtzF5A/xS9+bOCYHdmdCc=; b=B85jvHA4luyxUyX73FDHS7L6n9pPiWAh2Jkn0715ebsl4zOTWiWLePXO043AOL+Om9 LvifuhoRhc9wPN3G5EfyINaQPNXzIptz4jXzteqXc81ZY0FYBHKSXbUys7mgJAhtinT+ QJyEwD4dSwplp8nZMZxieBL5eDmpu7NVmuyespzssjGdyyCaAJIIL2DQNBf/RXKtPwyn 1e6rNLujhFRnoBF8NXJScL1tsD48V4rsis5Ks3UTn+o+HHa7ZrFM1qGjzQI+vWoOOlFT R42Zn4HULogtIS7Tx7EfF1bCFIcA7+Ikvc+hT6mIT9zyRHPDWAeAFNIO6N8hMNGqCjM9 W0pA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="sHK28rt/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q23si11314730ejy.641.2021.03.15.11.21.46; Mon, 15 Mar 2021 11:22:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="sHK28rt/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231168AbhCOOTE (ORCPT + 99 others); Mon, 15 Mar 2021 10:19:04 -0400 Received: from mail.kernel.org ([198.145.29.99]:37476 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229870AbhCON7t (ORCPT ); Mon, 15 Mar 2021 09:59:49 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 51B1964F7B; Mon, 15 Mar 2021 13:59:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816756; bh=BZd8ZWTBHXjORfUMwuiP28uoGML+8uvn3smCDSKYvXE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sHK28rt/J3yKD4PlFngVR1BEQpl+4Fw7CFYxjI5fnkWUh/ZEjEL4t1F/9hdbFSU0C JSoK8eeFXMbD5fMRieSvWoCSvb+8B1+e0VZ0XtnQtGVZFOeYeRpXxIhMfVw6Mk0j+p +7t3eADaqUFDgBxQFi3VatGEKspSbJ08GvW8naTs= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Michael Ellerman , Athira Rajeev , Sasha Levin Subject: [PATCH 4.19 048/120] powerpc/perf: Record counter overflow always if SAMPLE_IP is unset Date: Mon, 15 Mar 2021 14:56:39 +0100 Message-Id: <20210315135721.560237991@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135720.002213995@linuxfoundation.org> References: <20210315135720.002213995@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman From: Athira Rajeev [ Upstream commit d137845c973147a22622cc76c7b0bc16f6206323 ] While sampling for marked events, currently we record the sample only if the SIAR valid bit of Sampled Instruction Event Register (SIER) is set. SIAR_VALID bit is used for fetching the instruction address from Sampled Instruction Address Register(SIAR). But there are some usecases, where the user is interested only in the PMU stats at each counter overflow and the exact IP of the overflow event is not required. Dropping SIAR invalid samples will fail to record some of the counter overflows in such cases. Example of such usecase is dumping the PMU stats (event counts) after some regular amount of instructions/events from the userspace (ex: via ptrace). Here counter overflow is indicated to userspace via signal handler, and captured by monitoring and enabling I/O signaling on the event file descriptor. In these cases, we expect to get sample/overflow indication after each specified sample_period. Perf event attribute will not have PERF_SAMPLE_IP set in the sample_type if exact IP of the overflow event is not requested. So while profiling if SAMPLE_IP is not set, just record the counter overflow irrespective of SIAR_VALID check. Suggested-by: Michael Ellerman Signed-off-by: Athira Rajeev [mpe: Reflow comment and if formatting] Signed-off-by: Michael Ellerman Link: https://lore.kernel.org/r/1612516492-1428-1-git-send-email-atrajeev@linux.vnet.ibm.com Signed-off-by: Sasha Levin --- arch/powerpc/perf/core-book3s.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/arch/powerpc/perf/core-book3s.c b/arch/powerpc/perf/core-book3s.c index 70de13822828..091bdeaf02a3 100644 --- a/arch/powerpc/perf/core-book3s.c +++ b/arch/powerpc/perf/core-book3s.c @@ -2046,7 +2046,17 @@ static void record_and_restart(struct perf_event *event, unsigned long val, left += period; if (left <= 0) left = period; - record = siar_valid(regs); + + /* + * If address is not requested in the sample via + * PERF_SAMPLE_IP, just record that sample irrespective + * of SIAR valid check. + */ + if (event->attr.sample_type & PERF_SAMPLE_IP) + record = siar_valid(regs); + else + record = 1; + event->hw.last_period = event->hw.sample_period; } if (left < 0x80000000LL) @@ -2064,9 +2074,10 @@ static void record_and_restart(struct perf_event *event, unsigned long val, * MMCR2. Check attr.exclude_kernel and address to drop the sample in * these cases. */ - if (event->attr.exclude_kernel && record) - if (is_kernel_addr(mfspr(SPRN_SIAR))) - record = 0; + if (event->attr.exclude_kernel && + (event->attr.sample_type & PERF_SAMPLE_IP) && + is_kernel_addr(mfspr(SPRN_SIAR))) + record = 0; /* * Finally record data if requested. -- 2.30.1