Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp7590753imm; Thu, 28 Jun 2018 06:21:45 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKWmEhvAZdR8+tDXAfRw0NcEsWaEnygYudAM9waAmSSrXZq9jjP0laBS4VfzoeRpbPuairU X-Received: by 2002:a65:654d:: with SMTP id a13-v6mr8979414pgw.132.1530192105474; Thu, 28 Jun 2018 06:21:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530192105; cv=none; d=google.com; s=arc-20160816; b=HLXyh4E5Z+L4JHIWbLdblPhRJMAn/VXeC9rpXOcOSVRrJJYVl+czDHYN+1mt5PthL9 6ZStjKku1mRPDeof2QEENWxDHffMECXVuqbUQM2mftVGcMp+O6wruqokq9KtKE19PMV8 xzPGMO08TpN9EnFxoPZmKzlQjWYKVlJSag3ENiy5R8y1PrnN+awQSsf+40cHiQac8Jhj kdWntcWO1vLc97P2JveOTaBJY/Wl8Rn1Mi82PV2pUXpMXGocAVW2+ihiPbIx4x+oxKFe zv3GGHmDh06iG6fyuLsAmLF/HF8WmcBKHWHduvJ+c9WH1M6g1DHzMSyZQ2ej+I4knqvi CsIQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=WihfRXy/75UwS0IhipqSb7AcJZySCzt8kTTLh6SOxnk=; b=Sr6scvTokW+eieYGyVzrsiJlMpRJRQSkZQtBU2kfzUDwmVO3m7j0OdJ8nzChDUyy8d 4T3Db954E79QWhJfL06g1a6aNE3+colk2NKlHEfvGCaMNl055Zg0Bp47SmLzQjyOBhU5 nMOSuIAM7M+mz8g7MRQOslmW68NyKsEWLse1MjPd+yao16QZUISlATE5isIB/8dklTUZ cy/MFog9JkqUy1EgrYaPBzNBUxdMEE7IgQNCRQY2l6tfg4b1hKMXUACUXKKMIVzS4Frf NEJWI3aiZyAioc7b0srgNtFLYqxLx6WD8qEibuDvM+nXQ7DufkiVLLDWZNcdQqqRTyAo iKtw== 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 x24-v6si6707190pln.22.2018.06.28.06.21.31; Thu, 28 Jun 2018 06:21:45 -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 S965945AbeF1NTe (ORCPT + 99 others); Thu, 28 Jun 2018 09:19:34 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:47566 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753784AbeF1NTd (ORCPT ); Thu, 28 Jun 2018 09:19:33 -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 9FAA218A; Thu, 28 Jun 2018 06:19:33 -0700 (PDT) Received: from [192.168.100.244] (usa-sjc-mx-foss1.foss.arm.com [217.140.101.70]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 320493F5C0; Thu, 28 Jun 2018 06:19:33 -0700 (PDT) Subject: Re: [RFC PATCH] arm64: topology: Map PPTT node offset to logic physical package id To: Sudeep Holla , Andrew Jones Cc: Shunyong Yang , catalin.marinas@arm.com, will.deacon@arm.com, linux-kernel@vger.kernel.org, Joey Zheng References: <1530177508-15298-1-git-send-email-shunyong.yang@hxt-semitech.com> <20180628115748.kprobde6c3joc6ll@kamzik.brq.redhat.com> From: Jeremy Linton Message-ID: Date: Thu, 28 Jun 2018 08:19:26 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 06/28/2018 07:12 AM, Sudeep Holla wrote: > > > On 28/06/18 12:57, Andrew Jones wrote: >> On Thu, Jun 28, 2018 at 10:38:24AM +0100, Sudeep Holla wrote: >>> Hi Shunyong, >>> >>> On 28/06/18 10:18, Shunyong Yang wrote: >>>> As PPTT spec doesn't define the physical package id, >>>> find_acpi_cpu_topology_package() will return offset of the node with >>>> Physical package field set when querying physical package id. So, it >>>> returns 162(0xA2) in following example. >>>> >>>> [0A2h 0162 1] Subtable Type : 00 [Processor Hierarchy >>>> Node] >>>> [0A3h 0163 1] Length : 1C >>>> [0A4h 0164 2] Reserved : 0000 >>>> [0A6h 0166 4] Flags (decoded below) : 00000003 >>>> Physical package : 1 >>>> ACPI Processor ID valid : 1 >>>> [0AAh 0170 4] Parent : 00000000 >>>> [0AEh 0174 4] ACPI Processor ID : 00001000 >>>> [0B2h 0178 4] Private Resource Number : 00000002 >>>> [0B6h 0182 4] Private Resource : 0000006C >>>> [0BAh 0186 4] Private Resource : 00000084 >>>> >>>> So, when "cat physical_package" in /sys/devices/system/cpu/cpu0/topology/, >>>> it will output 162(0xA2). And if some items are added before the node >>>> above, the output will change to other value. >>>> >>>> This patch maps the node offset to a logic package id. It maps the first >>>> node offset to 0, the second to 1, and so on. >>>> >>>> Then, it will not output a big value, such as 162 above. And it will >>>> not change when some nodes(Physical package not set) are added. >>>> >>>> And as long as the nodes with Physical package field set in PPTT keeps >>>> the real hardware order, the logic id can map to hardware package id to >>>> some extent. >>>> >>>> Hope to get feedback from you. >>> >>> Thanks for the patch, but Andrew Jones has also posted a patch[1] which >>> I had a look but was not sure what is the best approach to fix it yet. >>> I will think about it and respond to that. >>> >> >> I'll send a v1 yet today. The RFC version was actually OK, as the concern >> with ACPI nodes not being in the expected order wasn't actually a problem. >> The thread-id or core-id would only be reset to zero when a yet to be >> remapped core-id (and all its peers) was found when iterating the PEs. >> Since all peers were handled at the same time, the counter reset was >> correct, even when the ACPI nodes were out-of-order. The code didn't make >> that very obvious, though, and there was some room for other cleanups, >> so I've reworked it. Once I run it through a couple more rounds of testing >> I'll repost. >> > > OK sure. I liked the approach in Shunyong's patch. I was thinking if we > can avoid the list and dynamic allocation on each addition and make it > more simpler. > This one reads simpler, but yes I agree we should try to avoid the dynamic allocation. OTOH, I think that dropping the dynamic allocation leads to an algorithm that picks a value and replaces all the matches. Which of course is Andrew's patch, although I did have to read it a couple times to get a grasp how it works. I'm guessing that is due to the fact that he seems to have optimized 3 double loops into a single loop with two individual nested loops. AKA its probably more efficient than the naive implementation, but readability seems to have suffered a bit in the initial version he posted. I'm not sure the optimization is worth it, but I'm guessing there is a middle ground which makes it more readable. Finally, @Shunyong, thanks for putting the effort into this...