From mboxrd@z Thu Jan 1 00:00:00 1970 From: graeme.gregory@linaro.org (graeme.gregory at linaro.org) Date: Wed, 20 Aug 2014 16:43:58 +0100 Subject: [PATCH 06/19] ARM64 / ACPI: Parse FADT table to get PSCI flags for PSCI init In-Reply-To: <20140820152944.GR24600@localhost> References: <1406206825-15590-1-git-send-email-hanjun.guo@linaro.org> <1406206825-15590-7-git-send-email-hanjun.guo@linaro.org> <20140820150029.0BB3FC41205@trevor.secretlab.ca> <20140820152944.GR24600@localhost> Message-ID: <20140820154358.GA27927@xora-yoga-deb.xora.org.uk> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Wed, Aug 20, 2014 at 04:29:44PM +0100, Catalin Marinas wrote: > On Wed, Aug 20, 2014 at 04:00:28PM +0100, Grant Likely wrote: > > On Thu, 24 Jul 2014 21:00:12 +0800, Hanjun Guo wrote: > > > @@ -345,13 +378,19 @@ int __init psci_init(void) > > > const struct of_device_id *matched_np; > > > psci_initcall_t init_fn; > > > > > > - np = of_find_matching_node_and_match(NULL, psci_of_match, &matched_np); > > > + if (acpi_disabled) { > > > + np = of_find_matching_node_and_match(NULL, > > > + psci_of_match, &matched_np); > > > > > > - if (!np) > > > - return -ENODEV; > > > + if (!np) > > > + return -ENODEV; > > > + > > > + init_fn = (psci_initcall_t)matched_np->data; > > > + > > > + return init_fn(np); > > > + } > > > > > > - init_fn = (psci_initcall_t)matched_np->data; > > > - return init_fn(np); > > > + return psci_0_2_init_acpi(); > > > } > > > > So, while the functionality is sound, this is kind of a stinky diff. The > > ACPI path should not push the OF code into a sub branch. Make it look > > like this instead (with the advantage that the diff will be simpler): > > > > + if (IS_ENABLED(CONFIG_ACPI) && !acpi_disabled) > > + return psci_0_2_init_acpi(); > > Minor point: we should define acpi_disabled to 1 when !CONFIG_ACPI and > avoid additional IS_ENABLED(CONFIG_ACPI) checks (unless already don this > way). > This is the default behaviour already. Graeme