From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932902AbcERRhx (ORCPT ); Wed, 18 May 2016 13:37:53 -0400 Received: from foss.arm.com ([217.140.101.70]:58978 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932839AbcERRhv (ORCPT ); Wed, 18 May 2016 13:37:51 -0400 From: Sudeep Holla Subject: Re: [PATCH v5 2/5] ACPI / processor_idle: Add support for Low Power Idle(LPI) states To: "Prakash, Prashanth" , linux-acpi@vger.kernel.org, "Rafael J. Wysocki" References: <1462981062-24909-1-git-send-email-sudeep.holla@arm.com> <1462981062-24909-3-git-send-email-sudeep.holla@arm.com> <573B58E5.2020005@codeaurora.org> Cc: Sudeep Holla , linux-kernel@vger.kernel.org, Vikas Sajjan , Sunil , Ashwin Chaugule , Al Stone , Lorenzo Pieralisi Organization: ARM Message-ID: <573CA866.2050804@arm.com> Date: Wed, 18 May 2016 18:37:42 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.7.2 MIME-Version: 1.0 In-Reply-To: <573B58E5.2020005@codeaurora.org> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17/05/16 18:46, Prakash, Prashanth wrote: > Hi Sudeep, > > On 5/11/2016 9:37 AM, Sudeep Holla wrote: >> + >> +static int acpi_processor_get_lpi_info(struct acpi_processor *pr) >> +{ >> + int ret, i; >> + struct acpi_lpi_states_array *info; >> + struct acpi_device *d = NULL; >> + acpi_handle handle = pr->handle, pr_ahandle; >> + acpi_status status; >> + >> + if (!osc_pc_lpi_support_confirmed) >> + return -EOPNOTSUPP; >> + >> + max_leaf_depth = 0; >> + if (!acpi_has_method(handle, "_LPI")) >> + return -EINVAL; >> + flat_state_cnt = 0; >> + >> + while (ACPI_SUCCESS(status = acpi_get_parent(handle, &pr_ahandle))) { >> + if (!acpi_has_method(handle, "_LPI")) >> + continue; >> + >> + acpi_bus_get_device(handle, &d); >> + if (!strcmp(acpi_device_hid(d), ACPI_PROCESSOR_CONTAINER_HID)) >> + break; >> + >> + max_leaf_depth++; >> + handle = pr_ahandle; >> + } >> + > In the above loop, we break when we find a device with HID == > ACPI_PROCESSOR_CONTAINER_HID. Shouldn't we continue to parse as long as the > parent HID == ACPI_PROCESSOR_CONTAINER_HID? This is required to make sure we > parse states in levels higher than cluster level in processor hierarchy. > Yes, thanks for pointing that out. With just clusters in _LPI on my dev board, I missed it. > Also, I think it might be safe to break out of the loop if we didn't find > _LPI package, instead of continuing. Given the presence of LPI entry: > "Enabled Parent State", I can't think of a non-ambiguous scenario where we > might find LPI packages in state N and N+2, but not in N+1, as we will not > be able to figure out which state in N enables which states in N+2. > Thoughts? Though I admit I haven't thought in detail on how to deal with the asymmetric topology, but that was the reason why I continue instead of breaking. Excerpts from the spec: "... This example is symmetric but that is not a requirement. For example, a system may contain a different number of processors in different containers or an asymmetric hierarchy where one side of the topology tree is deeper than another...." -- Regards, Sudeep -- Regards, Sudeep