Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp49413yba; Mon, 1 Apr 2019 01:19:20 -0700 (PDT) X-Google-Smtp-Source: APXvYqwximy3nSyBaopIKth8pRpOrAdZ0sM6jDcZFM2stPKXwOZ1p7ilZKMxtogXHI2n9qFS9vS8 X-Received: by 2002:a17:902:b210:: with SMTP id t16mr39342512plr.84.1554106760028; Mon, 01 Apr 2019 01:19:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554106760; cv=none; d=google.com; s=arc-20160816; b=OBjEdKitHThoGSt22i/vQq24zS1YUXLDQXyj/RGhrCBo2tcHJk9YlID/wwEciVvmUT lbHfCST9hctVu7EK0aUGbahVbRzAP2s1VxHDlVDdxihZfKQm9IBPo/NFnUCyvJExSX5+ kqsHzF2XDMCsrGlImrNv1IweG9wnFhkP0dVlDPRJURHN2vStYj8lbpboaCBtCpPwTOJ2 FQljenh8VsmDFDiDWazkx1pYGB3QcGGNyauJK83s2OhMSyEoVTh81uUDK6qDLVk/PADw eRD2D61XA/+xWbZhB//fnc522yupHJ66ooeE0oYfJii7bkExioQ3ma/CeRMRxK8u3gyg Jbpw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=bq0xZl7Ubg5bHTeEL6rrfkqZRzyo3xAh3XoirQwxDXQ=; b=W3NPN1bBTU8SL/ShROuCqpXTbqdDj0QFH1n/sfCUA16pV+dasSSMVtpliEboZ8vAck APdPe7eEIcWiXlj5to7bMd0TUxGROqsSC8bJ9JL1V/lZYr+i6ISxlB9hJodZgPw463Mm VBHeWayC9wgWeeBxJyLo1twCZ9uEehd50a7Q2RUNF9nZKS5tbioimYJjIimlIEX0ntJU 1EdH6E0zHDD7pa4aC0yhJxolv/w6no6O39EBah7khQLxqPAlj7LdtD5lxfLXZoSVlpHe hC/kHZn+0yQBFcMsZpCIG8N64B0jmmqT7iOwanGuMgE+B/T+VKSu/SlawJMepI83n3Km UIVQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r124si5559439pgr.201.2019.04.01.01.19.04; Mon, 01 Apr 2019 01:19:20 -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; 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 S1732088AbfDAISP (ORCPT + 99 others); Mon, 1 Apr 2019 04:18:15 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:57484 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725867AbfDAISO (ORCPT ); Mon, 1 Apr 2019 04:18:14 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 39AF7374; Mon, 1 Apr 2019 01:18:14 -0700 (PDT) Received: from blommer (usa-sjc-mx-foss1.foss.arm.com [217.140.101.70]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 1E9C43F690; Mon, 1 Apr 2019 01:18:10 -0700 (PDT) Date: Mon, 1 Apr 2019 09:17:58 +0100 From: Mark Rutland To: Sodagudi Prasad Cc: Julien Thierry , will.deacon@arm.com, mingo@redhat.com, catalin.marinas@arm.com, linux-arm-kernel@lists.infradead.org, peterz@infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] perf: Change PMCR write to read-modify-write Message-ID: <20190401081757.lbfsuoocltq4lysj@blommer> References: <1553134066-20272-1-git-send-email-psodagud@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20170113 (1.7.2) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Mar 21, 2019 at 01:02:27PM -0700, Sodagudi Prasad wrote: > On 2019-03-21 06:34, Julien Thierry wrote: > > Hi Prasad, > > > > On 21/03/2019 02:07, Prasad Sodagudi wrote: > > > Preserves the bitfields of PMCR_EL0(AArch64) during PMU reset. > > > Reset routine should write a 1 to PMCR.C and PMCR.P fields only > > > to reset the counters. Other fields should not be changed > > > as they could be set before PMU initialization and their > > > value must be preserved even after reset. > > > > Are there any particular bit you are concerned about? Apart from the RO > > ones and the Res0 ones (to which we are already writing 0), I see: > > > > DP -> irrelevant for non-secure > > X -> This one is the only potentially interesting, however it resets to > > an architecturally unknown value, so unless we know for a fact it was > > set before hand, we probably want to clear it > > D -> ignored when we have LC set (and we do) > > E -> Since this is the function we use to reset the PMU on the current > > CPU, we probably want to set this bit to 0 regardless of its previous > > value > > > > So, is there any issue this patch is solving? > > Hi Julien, > > Thanks for taking a look into this patch. Yes. On our Qualcomm platforms, > observed that X bit is getting cleared by kernel. > This bit is getting set by firmware for Qualcomm use cases and non-secure > world is resetting without this patch. Given the kernel reconfigures the PMU dynamically at runtime (e.g. to multiplex events over counters), I don't follow how this is useful. Could you elaborate on how specifically you intend to use this? > I think, changing that register this register modifications to > read-modify-write style make sense. I disagree. In general, RESx bits may be allocated new meanings in future (and will reset to UNKNOWN values), so it is not safe to simply preserve the reset value. Given that, any kernel _must_ explicitly reset registers in order to ensure the expected behaviour. Thanks Mark.