Received: by 10.223.164.202 with SMTP id h10csp382640wrb; Thu, 30 Nov 2017 00:34:06 -0800 (PST) X-Google-Smtp-Source: AGs4zMY4NhUd1lrj892JO3iKHvpI6CZU1uMjRzWDa1nbCwsyijDsfrnrw4Gna9cw0mjWIyfiKtRL X-Received: by 10.98.19.92 with SMTP id b89mr5914356pfj.124.1512030846832; Thu, 30 Nov 2017 00:34:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1512030846; cv=none; d=google.com; s=arc-20160816; b=YIvuoHcXupHxwxBPSQvO9K3fL/3GentQY7nULgDadJ8FzQKqIV5EUKJZq1Lp01Jjao UWiibAHdGjG7E75++lf18lmYCwFwYBpMDA86OW8/dLjSi8V1mdMZJF8GGbeNRfasIWeb zvQSt3bIAJaBCrxBNF6zjZ60GcSSHekeWTU4Ah6Dm2Vzvrds26gUVP604VMANVbY2mNg wZoL9n2AUxUFXy5ipDyBNGP5Q4e0NYibushiSIjFbPm2906gm3bKzx44Q1+bttOJ+F8b j5yqzc2V5HoBFmoN98b4G7tN8fXJ/0viaEBWkeC4O94SlgkJUinFXMs+qY9mzTQQO9iY vBTg== 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=4htGMVNpqX/jYFkQ6Hehs9MK1k2tJOXKkCSz5XlsZTI=; b=XIxAwJXmrYacY67xZ+If8cRjYa7AGW2fT/C/NHsUt5fncRV2mFhUYC3mtK2Q2HVXbO NXE9d0KRDr2QzsGSyQAzC8yj1EUSYTdq8T9D8it/9wydrUrDSK7FMaEQriFxT3tBCHIc Yacfl0y8uRSPwBCuxTcyTJUWxCvTZrS7A+D+2EhPWjPWT4z1aM2DDWsUTc/N89urCRkS 1xXcl6HJ+gmvDMhjdx8rFXS7orGw3KXU6fWlb3tvD21o+2KFi4NlSifqGxDaDNVWAS33 HhpFFALPArP8JMrjMiUMeG9Zerog/Hl1+a5TpbiNMd+o8l58iYwhcP9ZD0N2yefSnaJJ VYHg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q8si2022144pgp.701.2017.11.30.00.33.52; Thu, 30 Nov 2017 00:34:06 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751748AbdK3IdH (ORCPT + 99 others); Thu, 30 Nov 2017 03:33:07 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:56664 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750943AbdK3IdG (ORCPT ); Thu, 30 Nov 2017 03:33:06 -0500 Received: from pps.filterd (m0098417.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id vAU8VUXw128523 for ; Thu, 30 Nov 2017 03:33:06 -0500 Received: from e06smtp11.uk.ibm.com (e06smtp11.uk.ibm.com [195.75.94.107]) by mx0a-001b2d01.pphosted.com with ESMTP id 2ejcqdvchd-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Thu, 30 Nov 2017 03:33:05 -0500 Received: from localhost by e06smtp11.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Thu, 30 Nov 2017 08:33:03 -0000 Received: from b06cxnps4076.portsmouth.uk.ibm.com (9.149.109.198) by e06smtp11.uk.ibm.com (192.168.101.141) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Thu, 30 Nov 2017 08:33:01 -0000 Received: from d06av21.portsmouth.uk.ibm.com (d06av21.portsmouth.uk.ibm.com [9.149.105.232]) by b06cxnps4076.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id vAU8X1Dl20709608; Thu, 30 Nov 2017 08:33:01 GMT Received: from d06av21.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 9C98F52041; Thu, 30 Nov 2017 07:26:22 +0000 (GMT) Received: from bangoria.in.ibm.com (unknown [9.124.31.213]) by d06av21.portsmouth.uk.ibm.com (Postfix) with ESMTP id EC8635203F; Thu, 30 Nov 2017 07:26:20 +0000 (GMT) From: Ravi Bangoria To: mpe@ellerman.id.au Cc: benh@kernel.crashing.org, paulus@samba.org, maddy@linux.vnet.ibm.com, tglx@linutronix.de, kan.liang@intel.com, sukadev@linux.vnet.ibm.com, linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org, Ravi Bangoria Subject: [PATCH] powerpc/perf: Fix oops when grouping different pmu events Date: Thu, 30 Nov 2017 14:03:22 +0530 X-Mailer: git-send-email 2.13.6 X-TM-AS-GCONF: 00 x-cbid: 17113008-0040-0000-0000-000004144890 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17113008-0041-0000-0000-000020B72F60 Message-Id: <20171130083322.31206-1-ravi.bangoria@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-11-30_02:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=1 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1711300114 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When user tries to group imc (In-Memory Collections) event with normal event, (sometime) kernel crashes with following log: Faulting instruction address: 0x00000000 [link register ] c00000000010ce88 power_check_constraints+0x128/0x980 ... c00000000010e238 power_pmu_event_init+0x268/0x6f0 c0000000002dc60c perf_try_init_event+0xdc/0x1a0 c0000000002dce88 perf_event_alloc+0x7b8/0xac0 c0000000002e92e0 SyS_perf_event_open+0x530/0xda0 c00000000000b004 system_call+0x38/0xe0 'event_base' field of 'struct hw_perf_event' is used as flags for normal hw events and used as memory address for imc events. While grouping these two types of events, collect_events() tries to interpret imc 'event_base' as a flag, which causes a corruption resulting in a crash. Consider only those events which belongs to 'perf_hw_context' in collect_events(). Signed-off-by: Ravi Bangoria --- arch/powerpc/perf/core-book3s.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/arch/powerpc/perf/core-book3s.c b/arch/powerpc/perf/core-book3s.c index 9e3da16..1538129 100644 --- a/arch/powerpc/perf/core-book3s.c +++ b/arch/powerpc/perf/core-book3s.c @@ -1415,7 +1415,7 @@ static int collect_events(struct perf_event *group, int max_count, int n = 0; struct perf_event *event; - if (!is_software_event(group)) { + if (group->pmu->task_ctx_nr == perf_hw_context) { if (n >= max_count) return -1; ctrs[n] = group; @@ -1423,7 +1423,7 @@ static int collect_events(struct perf_event *group, int max_count, events[n++] = group->hw.config; } list_for_each_entry(event, &group->sibling_list, group_entry) { - if (!is_software_event(event) && + if (event->pmu->task_ctx_nr == perf_hw_context && event->state != PERF_EVENT_STATE_OFF) { if (n >= max_count) return -1; -- 1.8.3.1 From 1584913346551566867@xxx Fri Nov 24 02:39:12 +0000 2017 X-GM-THRID: 1584913346551566867 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread