Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755391AbZFCI4u (ORCPT ); Wed, 3 Jun 2009 04:56:50 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752635AbZFCI4m (ORCPT ); Wed, 3 Jun 2009 04:56:42 -0400 Received: from ogre.sisk.pl ([217.79.144.158]:36789 "EHLO ogre.sisk.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752836AbZFCI4m (ORCPT ); Wed, 3 Jun 2009 04:56:42 -0400 From: "Rafael J. Wysocki" To: Kevin Hilman Subject: Re: [PATCH] Driver Core: Add platform device arch data V2 Date: Wed, 3 Jun 2009 10:56:37 +0200 User-Agent: KMail/1.11.2 (Linux/2.6.30-rc6-rjw; KDE/4.2.3; x86_64; ; ) Cc: Magnus Damm , linux-kernel@vger.kernel.org, paul@pwsan.com, gregkh@suse.de, stern@rowland.harvard.edu, linux-pm@lists.linux-foundation.org References: <20090601101614.10720.93804.sendpatchset@rx1.opensource.se> <87d49mk5zl.fsf@deeprootsystems.com> In-Reply-To: <87d49mk5zl.fsf@deeprootsystems.com> MIME-Version: 1.0 Content-Type: Text/Plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200906031056.38364.rjw@sisk.pl> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3533 Lines: 81 On Tuesday 02 June 2009, Kevin Hilman wrote: > Magnus Damm writes: > > > 2009/6/2 Rafael J. Wysocki : > >> On Monday 01 June 2009, Rafael J. Wysocki wrote: > >>> On Monday 01 June 2009, Magnus Damm wrote: > >>> > From: Magnus Damm > >>> > > >>> > Allow architecture specific data in struct platform_device V2. > >>> > The structure pdev_archdata is added to struct platform_device, > >>> > similar to struct dev_archdata in struct device. > >>> > > >>> > Useful for architecture code that needs to keep extra data > >>> > associated with each platform device. This data shall not > >>> > be accessed by platform drivers, only architecture code. > >>> > > >>> > Needed for platform device runtime PM. > >>> > >>> What exactly do you need this data for? > > > > I'd like to keep a hardware block id associated with each platform > > device on our SoC. > > Please have a look at "PATCH [04/04] sh: Runtime platform device PM mockup", > > http://patchwork.kernel.org/patch/26421/ > > And in OMAP, we will keep a pointer to an SoC-specific struct of > HW specific data to be used in idle/wakeup decision making. > > >> Anyway, I think you can introduce something like: > >> > >> struct _platform_device { > >> struct platform_device dev; > >> ; > >> ... > >> }; > >> > >> define your platform devices using the struct above and pass its dev member to > >> the functions that need 'struct platform_device' as an argument. > >> > >> Then you won't need to add arch members to 'struct platform_device' itself. > > > > Thanks for your suggestion. I'm usually a friend of wrapping > > structures and using offsetof(), but in this case I don't think it > > will work very well. > > Neither do I in this case... > > > I'd like to keep a SoC specific hardware block id in this architecture > > specific struct. Then let the arch specific functions > > platform_device_idle() and platform_device_wakeup() use this hardware > > block id to locate which clocks to stop and which power domains to > > fiddle with within the SoC. If we only consider this on-SoC case then > > wrapping and offsetof() works well. > > > > However, a typical embedded system has a wide range of platform > > devices. Some are for the SoC itself and some are for external > > devices, like on board ethernet controlllers (not on chip like the SoC > > platform devices). And since idle() and wakeup() work with struct > > platform device, with a wrapped data structure we need some way to > > check if the platform data is actually wrapped and offsetof() is > > valid. I guess we could use some platform device specific flag for > > this, but that seems overly complicated in my opinion. And modifying > > idle() and wakup() to take arch specific structures is not so good > > since we want to use the same platform driver on multiple > > architectures. > > Also, there many cases where platform_devices are not declared > statically and using the wrapper method doesn't work well if you are > using platform_device_alloc(). In addition to not being able to use > container_of() etc. the memory allocated potentially lasts longer than > the existence of the platform_device. OK, that is a valid point. Best, Rafael -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/