Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp449770ybi; Wed, 19 Jun 2019 02:16:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqy8U12asyAE6qbCSb1GeyqZ0OsmEiIjAbZqklQ4ofXzlTiB4yoU1LEYBa5ffe/DGLbvco2U X-Received: by 2002:a63:d0:: with SMTP id 199mr6869389pga.85.1560935795224; Wed, 19 Jun 2019 02:16:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560935795; cv=none; d=google.com; s=arc-20160816; b=SZyVua0h5ZvAmcXw801SaBojVWmqNpc9zPZ6zlqmV+yNtrBgJtIJbdJqXxB/orqnVh RyGhmdvbFiZUEgen3SHigEig12CdrTen2lNmYMLNa+aJIfe54hmoFZ6OfTjDQl5rQbS2 cKXhToXqgOQJVQ8iPKVh683wcD39ZDZYwo3Q38soNCtlNzMoX8X+4qSfKOduPEumbZHC bmDaUkle0QAOQNkWkkYO7Ek46dyhuiR0DdCcASafHqAz17iJTP8u2U5UCamOTw6Jcjpv zzZsOETvPdAUL9RC/ySRlk01NE9lGu/hzd/qBDnVsWMa9o8OfxCz4rBnYqnk8KbiAicB LfGA== 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:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject; bh=70YZh37ob5XDXjbMT/CdCnsM7zUdKpX1LIXOcuqN81A=; b=RUVCWOBD7ywv+umfiltnA+VRMfl5oVm8kMQupgErxnirfhqCBpYI039sp2gQBdOHdl E5I92N3ul8j9dxluesLy9iutjkVnz/vhabJfjGr4M8k7sgRdnzx7z8w18GVU0AiLrWVf gQl3qpUOuYFbAYqcZ5tEzco5zgDJzjzUIiIkoNksmNtN1/ormjWEkluV0CYp+txauS/U cMniyxpd9aNPRsLGlPVBwrSddkgp2mh9pvUfjHsD4nK7Xv5/C6GKFMBmKVeoyoxyggG2 1SbEsCmMo8lU9oeh5yGm2h1gDFrjR9zrfgjaLGnAXwhQUIcC6mDbDaUlRCNTiQQmdSpc NDJg== 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 fr1si910806pjb.57.2019.06.19.02.15.48; Wed, 19 Jun 2019 02:16:35 -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 S1731434AbfFSJPf (ORCPT + 99 others); Wed, 19 Jun 2019 05:15:35 -0400 Received: from szxga07-in.huawei.com ([45.249.212.35]:43174 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726971AbfFSJPe (ORCPT ); Wed, 19 Jun 2019 05:15:34 -0400 Received: from DGGEMS406-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 415A8A9C784478C4C47C; Wed, 19 Jun 2019 17:15:32 +0800 (CST) Received: from [127.0.0.1] (10.202.227.238) by DGGEMS406-HUB.china.huawei.com (10.3.19.206) with Microsoft SMTP Server id 14.3.439.0; Wed, 19 Jun 2019 17:15:30 +0800 Subject: Re: [PATCH v2 1/2] ACPI/PPTT: Add support for ACPI 6.3 thread flag To: Jeremy Linton , Valentin Schneider , References: <20190614223158.49575-1-jeremy.linton@arm.com> <20190614223158.49575-2-jeremy.linton@arm.com> <667f95c0-5aa9-f460-a49a-e6dfefc027d8@arm.com> <2d1b547f-f9ee-391c-c4f3-0232a08a86bc@arm.com> <718438d0-8648-897a-83e8-801146a0af86@arm.com> <11fb712f-b3c2-5491-89ee-ea7efb18ddd8@arm.com> CC: , , , , , , From: John Garry Message-ID: <63f6c6a8-9d79-ae75-3c15-96bded9b14e4@huawei.com> Date: Wed, 19 Jun 2019 10:15:24 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Thunderbird/45.3.0 MIME-Version: 1.0 In-Reply-To: <11fb712f-b3c2-5491-89ee-ea7efb18ddd8@arm.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.202.227.238] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 18/06/2019 22:28, Jeremy Linton wrote: > Hi, > > On 6/18/19 12:23 PM, John Garry wrote: >> On 18/06/2019 15:40, Valentin Schneider wrote: >>> On 18/06/2019 15:21, Jeremy Linton wrote: >>> [...] >>>>>> + * Return: -ENOENT if the PPTT doesn't exist, the CPU cannot be >>>>>> found or >>>>>> + * the table revision isn't new enough. >>>>>> + * Otherwise returns flag value >>>>>> + */ >>>>> >>>>> Nit: strictly speaking we're not returning the flag value but its mask >>>>> applied to the flags field. I don't think anyone will care about >>>>> getting >>>>> the actual flag value, but it should be made obvious in the doc: >>>> >>>> Or I clarify the code to actually do what the comments says. Maybe >>>> that is what John G was also pointing out too? >>>> >> >> No, I was just saying that the kernel topology can be broken without >> this series. >> >>> >>> Mmm I didn't find any reply from John regarding this in v1, but I >>> wouldn't >>> mind either way, as long as the doc & code are aligned. >>> >> >> BTW, to me, function acpi_pptt_cpu_is_thread() seems to try to do too >> much, i.e. check if the PPTT is new enough to support the thread flag >> and also check if it is set for a specific cpu. I'd consider separate >> functions here. > Hi, > ? Your suggesting replacing the > I am not saying definitely that this should be changed, it's just that acpi_pptt_cpu_is_thread() returning false, true, or "no entry" is not a typical API format. How about acpi_pptt_support_thread_info(cpu) and acpi_pptt_cpu_is_threaded(cpu), both returning false/true only? None of this is ideal. BTW, Have you audited which arm64 systems have MT bit set legitimately? > > if (table->revision >= rev) I know that checking the table revision is not on the fast path, but it seems unnecessarily inefficient to always read it this way, I mean calling acpi_table_get(). Can you have a static value for the table revision? Or is this just how other table info is accessed in ACPI code? > cpu_node = acpi_find_processor_node(table, acpi_cpu_id); > > check with > > if (revision_check(table, rev)) > cpu_node = acpi_find_processor_node(table, acpi_cpu_id); > > > and a function like > > static int revision_check(acpixxxx *table, int rev) > { > return (table->revision >= rev); > } > > Although, frankly if one were to do this, it should probably be a macro > with the table type, and used in the dozen or so other places I found > doing similar checks (spcr, iort, etc). > > Or something else? > > > > thanks, John >> >>> [...] >>> >>> . >>> >> >> > > > . >