[PATCH] ARM: OMAP: omap_device: Expose omap_device_{alloc, delete, register}

Ohad Ben-Cohen ohad at wizery.com
Wed Nov 9 04:34:13 EST 2011


Hi Kevin,

On Mon, Oct 17, 2011 at 1:41 PM, Ohad Ben-Cohen <ohad at wizery.com> wrote:
> Expose omap_device_{alloc, delete, register} so we can use them outside
> of omap_device.c.

Can you please take this one ?

Please tell me if you want a refreshed version against 3.2-rc1.

Thanks!
Ohad.

>
> This approach allows users, which need to manipulate an archdata member
> of a device before it is registered, to do so. This is also useful
> for users who have their devices created very early so they can be used
> at ->reserve() time to reserve CMA memory.
>
> The immediate use case for this is to set the private iommu archdata
> member, which binds a device to its associated iommu controller.
> This way, generic code will be able to attach omap devices to their
> iommus, without calling any omap-specific API.
>
> With this in hand, we can further clean the existing mainline OMAP iommu
> driver and its mainline users, and focus on generic IOMMU approaches
> for future users (rpmsg/remoteproc and the upcoming generic DMA API).
>
> This patch is still considered an interim solution until DT fully materializes
> for omap; at that point, this functionality will be removed as DT will
> take care of creating the devices and configuring them correctly.
>
> Tested on OMAP4 with a generic rpmsg/remoteproc that doesn't use any
> omap-specific IOMMU API anymore.
>
> Signed-off-by: Ohad Ben-Cohen <ohad at wizery.com>
> ---
>  arch/arm/plat-omap/include/plat/omap_device.h |    7 +++++++
>  arch/arm/plat-omap/omap_device.c              |   13 +++----------
>  2 files changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/arch/arm/plat-omap/include/plat/omap_device.h b/arch/arm/plat-omap/include/plat/omap_device.h
> index 12c5b0c..28d7a38 100644
> --- a/arch/arm/plat-omap/include/plat/omap_device.h
> +++ b/arch/arm/plat-omap/include/plat/omap_device.h
> @@ -100,6 +100,13 @@ struct platform_device *omap_device_build_ss(const char *pdev_name, int pdev_id,
>                                         struct omap_device_pm_latency *pm_lats,
>                                         int pm_lats_cnt, int is_early_device);
>
> +struct omap_device *omap_device_alloc(struct platform_device *pdev,
> +                                     struct omap_hwmod **ohs, int oh_cnt,
> +                                     struct omap_device_pm_latency *pm_lats,
> +                                     int pm_lats_cnt);
> +void omap_device_delete(struct omap_device *od);
> +int omap_device_register(struct platform_device *pdev);
> +
>  void __iomem *omap_device_get_rt_va(struct omap_device *od);
>  struct device *omap_device_get_by_hwmod_name(const char *oh_name);
>
> diff --git a/arch/arm/plat-omap/omap_device.c b/arch/arm/plat-omap/omap_device.c
> index cd90bed..913179c 100644
> --- a/arch/arm/plat-omap/omap_device.c
> +++ b/arch/arm/plat-omap/omap_device.c
> @@ -96,14 +96,7 @@
>  #define USE_WAKEUP_LAT                 0
>  #define IGNORE_WAKEUP_LAT              1
>
> -static int omap_device_register(struct platform_device *pdev);
>  static int omap_early_device_register(struct platform_device *pdev);
> -static struct omap_device *omap_device_alloc(struct platform_device *pdev,
> -                                     struct omap_hwmod **ohs, int oh_cnt,
> -                                     struct omap_device_pm_latency *pm_lats,
> -                                     int pm_lats_cnt);
> -static void omap_device_delete(struct omap_device *od);
> -
>
>  static struct omap_device_pm_latency omap_default_latency[] = {
>        {
> @@ -508,7 +501,7 @@ static int omap_device_fill_resources(struct omap_device *od,
>  *
>  * Returns an struct omap_device pointer or ERR_PTR() on error;
>  */
> -static struct omap_device *omap_device_alloc(struct platform_device *pdev,
> +struct omap_device *omap_device_alloc(struct platform_device *pdev,
>                                        struct omap_hwmod **ohs, int oh_cnt,
>                                        struct omap_device_pm_latency *pm_lats,
>                                        int pm_lats_cnt)
> @@ -590,7 +583,7 @@ oda_exit1:
>        return ERR_PTR(ret);
>  }
>
> -static void omap_device_delete(struct omap_device *od)
> +void omap_device_delete(struct omap_device *od)
>  {
>        if (!od)
>                return;
> @@ -816,7 +809,7 @@ static struct dev_pm_domain omap_device_pm_domain = {
>  * platform_device_register() on the underlying platform_device.
>  * Returns the return value of platform_device_register().
>  */
> -static int omap_device_register(struct platform_device *pdev)
> +int omap_device_register(struct platform_device *pdev)
>  {
>        pr_debug("omap_device: %s: registering\n", pdev->name);
>
> --
> 1.7.4.1
>
>



More information about the linux-arm-kernel mailing list