Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp5999723ybc; Wed, 27 Nov 2019 13:10:10 -0800 (PST) X-Google-Smtp-Source: APXvYqydiSHgL9gQzsg0THAEJcTldxnQOA1s1FylGekOVH+6QiU8n5FSlOav5hW/YIbDnrgvHrGL X-Received: by 2002:a05:6402:6c7:: with SMTP id n7mr30780785edy.177.1574889010450; Wed, 27 Nov 2019 13:10:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574889010; cv=none; d=google.com; s=arc-20160816; b=tU+ubTPFuBEQysazAtVUPncsod2gQnlUe0BTCi47L01iJNmgMF9dUFpEqcaLCXWPD+ kjfeOB6P2/Q1BrU4/d6HVHVfN7vMVgTQyfaYq0PTBNy+4prA35vs3HF5pYAEHzaunluh eknqHrtM1ZxLQ3JULUw1/CBKRN3XAhCN5H2bk/fCcRguWDQtaB+JE0789EhMHFx+nla4 TMG1FkU/bOm+8hvL0hWkxkQwRCHYS6ZKioKsv9ZSwy+ocQkzRXpnAF11jiHmQwAAXJSg QCCcrIe61e4km4PjIUp8h524Bzu3QPcOu+j2mQeuUWGpmzJwH+rhFfamSb3b06vDkC/c wGag== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=rGlIHfVpM8vvTlJWbAip/swXudfZnNrMD3SqVxQrA4s=; b=YMXCbOgDSExWF7of7NSXkqEwuILKjGMw3K669L+JGht9yIq3HX4/8V2X/StfReQb52 aH9NYRISseTpGzpjaYQkaEYR3LLK2TeuLsYVAkLZAu6RFV7YaCDzoYs7nBl3TEJKUEGA 8MYWq44eyylXxbdZQWAExwfdRa/qEKkxxu+6ewn5pqr+XFI8a/HJ2D5pTKWEziyyll/c 1RMB2my2NcbKxvI1bTsb/Q8kpk3iWbN8UEjXnUZu2WxRVi/JV9L6srQHA6SXJCZf6JUC ZhyI0xS71/aaLIe5gyogxBzK3MxOlMXyRWBixoqE0nI4sT9zzwUhlIGE3TOXgoooB/gT zoJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Lme+Ct4Y; 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 c36si11956993edf.165.2019.11.27.13.09.47; Wed, 27 Nov 2019 13:10:10 -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; dkim=pass header.i=@kernel.org header.s=default header.b=Lme+Ct4Y; 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 S1732424AbfK0VG0 (ORCPT + 99 others); Wed, 27 Nov 2019 16:06:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:60420 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732410AbfK0VGX (ORCPT ); Wed, 27 Nov 2019 16:06:23 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 029882080F; Wed, 27 Nov 2019 21:06:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574888782; bh=W3hwjXMYKbNOB98aUJ5wPNlUM3SaFCCFZQLG1S7wBjQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Lme+Ct4YpZ5wxD5UGXj6bMi/+CrKXQCGbBJ0bzpqx5S1shL8VoIQFMMwYR15HjyQv YPK5PwqWFWrYopAjgmbTH0aJHvhHWdZberNagsyTw+dJ01JicT8rpkjg5Cuf+xaqv+ CI+IHBk1uR0kZdzBSkNbf+cg9ilQJ9RF7M3dym84= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Alexey Brodkin , Vineet Gupta Subject: [PATCH 4.19 266/306] ARC: perf: Accommodate big-endian CPU Date: Wed, 27 Nov 2019 21:31:56 +0100 Message-Id: <20191127203134.266441817@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191127203114.766709977@linuxfoundation.org> References: <20191127203114.766709977@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alexey Brodkin commit 5effc09c4907901f0e71e68e5f2e14211d9a203f upstream. 8-letter strings representing ARC perf events are stores in two 32-bit registers as ASCII characters like that: "IJMP", "IALL", "IJMPTAK" etc. And the same order of bytes in the word is used regardless CPU endianness. Which means in case of big-endian CPU core we need to swap bytes to get the same order as if it was on little-endian CPU. Otherwise we're seeing the following error message on boot: ------------------------->8---------------------- ARC perf : 8 counters (32 bits), 40 conditions, [overflow IRQ support] sysfs: cannot create duplicate filename '/devices/arc_pct/events/pmji' CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.2.18 #3 Stack Trace: arc_unwind_core+0xd4/0xfc dump_stack+0x64/0x80 sysfs_warn_dup+0x46/0x58 sysfs_add_file_mode_ns+0xb2/0x168 create_files+0x70/0x2a0 ------------[ cut here ]------------ WARNING: CPU: 0 PID: 1 at kernel/events/core.c:12144 perf_event_sysfs_init+0x70/0xa0 Failed to register pmu: arc_pct, reason -17 Modules linked in: CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.2.18 #3 Stack Trace: arc_unwind_core+0xd4/0xfc dump_stack+0x64/0x80 __warn+0x9c/0xd4 warn_slowpath_fmt+0x22/0x2c perf_event_sysfs_init+0x70/0xa0 ---[ end trace a75fb9a9837bd1ec ]--- ------------------------->8---------------------- What happens here we're trying to register more than one raw perf event with the same name "PMJI". Why? Because ARC perf events are 4 to 8 letters and encoded into two 32-bit words. In this particular case we deal with 2 events: * "IJMP____" which counts all jump & branch instructions * "IJMPC___" which counts only conditional jumps & branches Those strings are split in two 32-bit words this way "IJMP" + "____" & "IJMP" + "C___" correspondingly. Now if we read them swapped due to CPU core being big-endian then we read "PMJI" + "____" & "PMJI" + "___C". And since we interpret read array of ASCII letters as a null-terminated string on big-endian CPU we end up with 2 events of the same name "PMJI". Signed-off-by: Alexey Brodkin Cc: stable@vger.kernel.org Signed-off-by: Vineet Gupta Signed-off-by: Greg Kroah-Hartman --- arch/arc/kernel/perf_event.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/arch/arc/kernel/perf_event.c +++ b/arch/arc/kernel/perf_event.c @@ -490,8 +490,8 @@ static int arc_pmu_device_probe(struct p /* loop thru all available h/w condition indexes */ for (j = 0; j < cc_bcr.c; j++) { write_aux_reg(ARC_REG_CC_INDEX, j); - cc_name.indiv.word0 = read_aux_reg(ARC_REG_CC_NAME0); - cc_name.indiv.word1 = read_aux_reg(ARC_REG_CC_NAME1); + cc_name.indiv.word0 = le32_to_cpu(read_aux_reg(ARC_REG_CC_NAME0)); + cc_name.indiv.word1 = le32_to_cpu(read_aux_reg(ARC_REG_CC_NAME1)); /* See if it has been mapped to a perf event_id */ for (i = 0; i < ARRAY_SIZE(arc_pmu_ev_hw_map); i++) {