From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752619Ab2KJTfx (ORCPT ); Sat, 10 Nov 2012 14:35:53 -0500 Received: from ogre.sisk.pl ([193.178.161.156]:37268 "EHLO ogre.sisk.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752378Ab2KJTft (ORCPT ); Sat, 10 Nov 2012 14:35:49 -0500 From: "Rafael J. Wysocki" To: Bjorn Helgaas Cc: Grant Likely , Mika Westerberg , linux-kernel@vger.kernel.org, lenb@kernel.org, rafael.j.wysocki@intel.com, broonie@opensource.wolfsonmicro.com, linus.walleij@linaro.org, khali@linux-fr.org, ben-linux@fluff.org, w.sang@pengutronix.de, mathias.nyman@linux.intel.com, linux-acpi@vger.kernel.org, Greg Kroah-Hartman , "H. Peter Anvin" , Tony Luck Subject: Re: [PATCH 2/3] spi / ACPI: add ACPI enumeration support Date: Sat, 10 Nov 2012 20:40:05 +0100 Message-ID: <6905069.Zyn4j8K74b@vostro.rjw.lan> User-Agent: KMail/4.8.5 (Linux/3.7.0-rc4+; KDE/4.8.5; x86_64; ; ) In-Reply-To: References: <1351928793-14375-1-git-send-email-mika.westerberg@linux.intel.com> <24155036.h7GFQbIk2D@vostro.rjw.lan> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="utf-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Saturday, November 10, 2012 10:14:47 AM Bjorn Helgaas wrote: > On Sat, Nov 10, 2012 at 4:10 AM, Rafael J. Wysocki wrote: > > On Friday, November 09, 2012 09:53:26 AM Bjorn Helgaas wrote: > >> On Fri, Nov 9, 2012 at 9:43 AM, Grant Likely wrote: > >> > On Fri, Nov 9, 2012 at 4:35 PM, Bjorn Helgaas wrote: > >> >> On Fri, Nov 9, 2012 at 8:45 AM, Grant Likely wrote: > >> >>> On Fri, Nov 9, 2012 at 3:11 PM, Bjorn Helgaas wrote: > >> >>>> [+cc Greg, Peter, Tony since they acked the original patch [1]] > >> >>>> > >> >>>> On Thu, Nov 8, 2012 at 1:04 PM, Mika Westerberg > >> >>>> wrote: > >> >>>>> On Thu, Nov 08, 2012 at 12:32:25PM -0700, Bjorn Helgaas wrote: > >> >>>>>> Struct device_driver is a generic structure, so it seems strange to > >> >>>>>> have to include non-generic things like of_device_id and now > >> >>>>>> acpi_match_table there. > >> >>>>> > >> >>>>> Yes, but in a sense the DT and ACPI are "generic". So that they are used to > >> >>>>> describe the configuration of a machine. > >> >>>> > >> >>>> What I meant by "generic" was "useful across all architectures." The > >> >>>> new acpi_match_table and acpi_handle fields [1] are not generic in > >> >>>> that sense because they're present on all architectures but used only > >> >>>> on x86 and ia64. The existing of_match_table and of_node are > >> >>>> similarly unused on many architectures. This doesn't seem like a > >> >>>> scalable strategy to me. Are we going to add a pnpbios_node for x86 > >> >>>> PNPBIOS machines without ACPI, a pdc_hpa for parisc machines with PDC, > >> >>>> etc.? > >> >>>> > >> >>>> [1] https://patchwork.kernel.org/patch/1677221/ > >> >>> > >> >>> Ultimately yes, I think that is what we want to do, > >> >> > >> >> Just to be clear, you think we *should* add things like pnpbios_node, > >> >> pdc_hpa, etc., to struct device, one field for every scheme of telling > >> >> the OS about non-enumerable devices, where only one of the N fields is > >> >> used on any given machine? That seems surprising to me, but maybe I > >> >> just need to be educated :) > >> > > >> > Ah, I see what you're asking. > >> > > >> > In the short term, yes but only because we don't have any other > >> > alternative. What I'd really rather have is a safe way to attach datum > >> > (ie. acpi_device or device_node) to a struct device and get it back > >> > later in a type safe way. > >> > >> Yep, *that* makes perfect sense to me. Something along these lines, maybe: > >> > >> #define dev_is_acpi(d) ((d)->bus == &acpi_bus_type) > > > > No, that's not right. It won't work for things like SPI and I2C with a > > "backing" ACPI device node anyway (and for PCI too, by the way :-)). > > > >> #define dev_acpi_handle(d) (dev_is_acpi(d) ? (acpi_handle) > >> d->datum : NULL) > > > > The problem basically is how we can tell that the given struct device has > > a "backing" object containing device information (e.g. resources) and what > > that "backing" object is. For device trees that would be a struct device_node > > and for ACPI that would be an acpi_handle or a struct acpi_device etc. And by > > the way, they _can_ be used simultaneously, in principle. > > > > So we need something like of_node(dev) or acpi_node(dev), but that can't be > > something following two pointers or calling a function just in order to check > > if the pointer _is_ _there_ in either case. > > > > And since we added of_node to struct device at one point, it is only logical to > > treat ACPI in the same way. If we come up with a better idea _later_, then we > > can convert _all_ things to this new idea, whatever it is. > > > > Are you seriously expecting us to come up with such an idea on the fly just so > > that we can use ACPI support, which already is there in the form of > > archdata.acpi_handle anyway, on equal footing with Device Trees? > > Of course not. I'm just trying to understand where we're headed. > That was not obvious from the patches I've seen so far. No, it wasn't, fair enough. Thanks, Rafael -- I speak only for myself. Rafael J. Wysocki, Intel Open Source Technology Center.