Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp893222pxp; Wed, 16 Mar 2022 20:25:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyzz/v8Z/hddjP8bk32YNlwx92pi3NiHLdQR84XI7b5v+bL+FoEnOBA+E6Z2LsxIXZd5pNk X-Received: by 2002:a63:d13:0:b0:381:f043:c627 with SMTP id c19-20020a630d13000000b00381f043c627mr2083283pgl.168.1647487530707; Wed, 16 Mar 2022 20:25:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647487530; cv=none; d=google.com; s=arc-20160816; b=qCsW4ODepvpSfi20TF7lnl+kc2gxcGWfF4MvVQD7Np/R1gJiz6biQM+/lS7R608W7E dcYPLMgCfbx/kM6sBhsk0hRDdeQSsiIb0WTbtTR3kP5JsL+PbYIMSgdM+rcG+YN058Tb PfVL8VumR7jbHxREpSHxKyDHx5ztP8eqmgXu7Px2fKBNtNopWhXKgrpHaMFitkhLpBi0 73uJhUQQwRA4PPtM4QAd6DtbXjqO6t8Ze174mrrwzYgYkXkbvJv22dKlSzzrul/mBVTW Ip3DnZo64iUpYHBHdauon7NgQ/MPawCEuZ2kiNzpf1/YEALYZ5VJIjl6djsY1kG7MtN+ qTxg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=jyFWc5ep/2Vu7w/DHCKVxrbiyyXzpupkprV4bwLY1Bo=; b=U//Khe5iFMzZwQYTJBcABXRN2s5EVVroE7L8NE+aLVSBiwjYXoEfcr7jM3tPqSvoex zOfjruGsfzeAhBWTfnf2683eMLyqPBULaGo4T2NaGw9OblBzmdYAsf5Ti2OS4tCGGxnx TJ1V4V6WWMy0SV5ZsMVxu5VpZyuahGtnLNENp2Jh28DCaUMUbVVqHjnGBKqfjO7oEPWP 1pw8En3Pha74GcfrwyeCGRMP+f/cRJ2I3pbNtddoKrdoH0HFFmqloQKfcqeesl4O6TYP R7BTkOvNfl5a/US500+5Sx7MtDm7YWkFQDuNs/huI5VRQmTuU5oa+q4w+R9rNqvoKgvS lzdg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id a13-20020a631a0d000000b003816043efbbsi846583pga.432.2022.03.16.20.25.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 16 Mar 2022 20:25:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 1B75D2F007; Wed, 16 Mar 2022 20:24:58 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351147AbiCOSq3 (ORCPT + 99 others); Tue, 15 Mar 2022 14:46:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52084 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241627AbiCOSq2 (ORCPT ); Tue, 15 Mar 2022 14:46:28 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C6D6846146; Tue, 15 Mar 2022 11:45:15 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 7F8FA1474; Tue, 15 Mar 2022 11:45:15 -0700 (PDT) Received: from [10.1.26.153] (e127744.cambridge.arm.com [10.1.26.153]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 345A23F73D; Tue, 15 Mar 2022 11:45:11 -0700 (PDT) Subject: Re: [PATCH v2 2/2] perf mem: Support HITM for when mem_lvl_num is used To: Ali Saidi Cc: Nick.Forrington@arm.com, acme@kernel.org, alexander.shishkin@linux.intel.com, andrew.kilroy@arm.com, benh@kernel.crashing.org, james.clark@arm.com, john.garry@huawei.com, jolsa@kernel.org, kjain@linux.ibm.com, leo.yan@linaro.org, lihuafei1@huawei.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, mark.rutland@arm.com, mathieu.poirier@linaro.org, mingo@redhat.com, namhyung@kernel.org, peterz@infradead.org, will@kernel.org, yao.jin@linux.intel.com References: <20220314183721.3198-1-alisaidi@amazon.com> From: German Gomez Message-ID: <172ce478-b539-2aa4-0470-1b96c6b8169b@arm.com> Date: Tue, 15 Mar 2022 18:44:10 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.14.0 MIME-Version: 1.0 In-Reply-To: <20220314183721.3198-1-alisaidi@amazon.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 14/03/2022 18:37, Ali Saidi wrote: > Hi German and Leo, > > On Mon, 14 Mar 2022 18:00:13 +0000, German Gomez wrote: >> Hi Leo, Ali >> >> On 14/03/2022 06:33, Leo Yan wrote: >>> On Sun, Mar 13, 2022 at 07:19:33PM +0000, Ali Saidi wrote: >>> >>> [...] >>> >>>>>>> + if (lvl & P(LVL, L3) || lnum == P(LVLNUM, L4)) { >>>>>> According to a comment in the previous patch, using L4 is specific to Neoverse, right? >>>>>> >>>>>> Maybe we need to distinguish the Neoverse case from the generic one here as well >>>>>> >>>>>> if (is_neoverse) >>>>>> // treat L4 as llc >>>>>> else >>>>>> // treat L3 as llc >>>>> I personally think it's not good idea to distinguish platforms in the decoding code. >>>> I agree here. The more we talk about this, the more I'm wondering if we're >>>> spending too much code solving a problem that doesn't exist. I know of no >>>> Neoverse systems that actually have 4 cache levels, they all actually have three >>>> even though it's technically possible to have four. I have some doubts anyone >>>> will actually build four levels of cache and perhaps the most prudent path here >>>> is to assume only three levels (and adjust the previous patch) until someone >>>> actually produces a system with four levels instead of a lot of code that is >>>> never actually exercised? >>> I am not right person to say L4 cache is not implemented in Neoverse >>> platforms; my guess for a "System cache" data source might be L3 or >>> L4 and it is a implementation dependent. Maybe German or Arm mates >>> could confirm for this. >> I had a look at the TRMs for the N1[1], V1[2] and N2[3] Neoverse cores >> (specifically the LL_CACHE_RD pmu events). If we were to assign a number >> to the system cache (assuming all caches are implemented): >> >> *For N1*, if L2 and L3 are implemented, system cache would follow at *L4* > To date no one has built 4 level though. Everyone has only built three. The N1SDP board advertises 4 levels (we use it regularly for testing perf patches) | $ cat /sys/devices/system/cpu/cpu0/cache/index4/{level,shared_cpu_list} | 4 | 0-3 Would it be a good idea to obtain the system cache level# from sysfs? >> *For V1 and N2*, if L2 is implemented, system cache would follow at *L3* >> (these don't seem to have the same/similar per-cluster L3 cache from the N1) > And in the future they're not able to build >3. German and Leo if there aren't > strong objections I think the best path forward is for me to respin these > assuming only 3 levels and if someone builds 4 in a far-off-future we can always > change the implementation then. Agreed? > > Thanks, > Ali >