OSDN Git Service

ARM: davinci: PM: rework init, remove platform device
authorKevin Hilman <khilman@baylibre.com>
Tue, 15 Nov 2016 19:54:19 +0000 (11:54 -0800)
committerSekhar Nori <nsekhar@ti.com>
Wed, 16 Nov 2016 09:11:29 +0000 (14:41 +0530)
Remove fake platform device used for PM init.  Move pdata values which
are common across all current platforms into pm.c.

Also, since PM is only used on da8xx, remove davinci_pm_init() from
common init code, and only use in da850/omapl138 board files that are
currently creating the fake platform_device.

Suggested-by: Sekhar Nori <nsekhar@ti.com>
Signed-off-by: Kevin Hilman <khilman@baylibre.com>
[nsekhar@ti.com: subject line adjustment]
Signed-off-by: Sekhar Nori <nsekhar@ti.com>
arch/arm/mach-davinci/board-da850-evm.c
arch/arm/mach-davinci/board-mityomapl138.c
arch/arm/mach-davinci/common.c
arch/arm/mach-davinci/da850.c
arch/arm/mach-davinci/include/mach/da8xx.h
arch/arm/mach-davinci/pm.c

index 8e4539f..4e88723 100644 (file)
@@ -196,18 +196,6 @@ static struct platform_device da850_evm_norflash_device = {
        .resource       = da850_evm_norflash_resource,
 };
 
-static struct davinci_pm_config da850_pm_pdata = {
-       .sleepcount = 128,
-};
-
-static struct platform_device da850_pm_device = {
-       .name           = "pm-davinci",
-       .dev = {
-               .platform_data  = &da850_pm_pdata,
-       },
-       .id             = -1,
-};
-
 /* DA850/OMAP-L138 EVM includes a 512 MByte large-page NAND flash
  * (128K blocks). It may be used instead of the (default) SPI flash
  * to boot, using TI's tools to install the secondary boot loader
@@ -1453,10 +1441,7 @@ static __init void da850_evm_init(void)
        if (ret)
                pr_warn("%s: cpuidle registration failed: %d\n", __func__, ret);
 
-       ret = da850_register_pm(&da850_pm_device);
-       if (ret)
-               pr_warn("%s: suspend registration failed: %d\n", __func__, ret);
-
+       davinci_pm_init();
        da850_vpif_init();
 
        ret = spi_register_board_info(da850evm_spi_info,
index bc4e63f..9e7388b 100644 (file)
@@ -498,18 +498,6 @@ static void __init mityomapl138_config_emac(void)
                pr_warn("emac registration failed: %d\n", ret);
 }
 
-static struct davinci_pm_config da850_pm_pdata = {
-       .sleepcount = 128,
-};
-
-static struct platform_device da850_pm_device = {
-       .name   = "pm-davinci",
-       .dev = {
-               .platform_data  = &da850_pm_pdata,
-       },
-       .id     = -1,
-};
-
 static void __init mityomapl138_init(void)
 {
        int ret;
@@ -555,9 +543,7 @@ static void __init mityomapl138_init(void)
        if (ret)
                pr_warn("cpuidle registration failed: %d\n", ret);
 
-       ret = da850_register_pm(&da850_pm_device);
-       if (ret)
-               pr_warn("suspend registration failed: %d\n", ret);
+       davinci_pm_init();
 }
 
 #ifdef CONFIG_SERIAL_8250_CONSOLE
index 049025f..9f9fbfa 100644 (file)
@@ -118,6 +118,5 @@ err:
 void __init davinci_init_late(void)
 {
        davinci_cpufreq_init();
-       davinci_pm_init();
        davinci_clk_disable_unused();
 }
index ed3d0e9..2877192 100644 (file)
@@ -1172,44 +1172,6 @@ static int da850_round_armrate(struct clk *clk, unsigned long rate)
 }
 #endif
 
-int __init da850_register_pm(struct platform_device *pdev)
-{
-       int ret;
-       struct davinci_pm_config *pdata = pdev->dev.platform_data;
-
-       ret = davinci_cfg_reg(DA850_RTC_ALARM);
-       if (ret)
-               return ret;
-
-       pdata->ddr2_ctlr_base = da8xx_get_mem_ctlr();
-       pdata->deepsleep_reg = DA8XX_SYSCFG1_VIRT(DA8XX_DEEPSLEEP_REG);
-       pdata->ddrpsc_num = DA8XX_LPSC1_EMIF3C;
-
-       pdata->cpupll_reg_base = ioremap(DA8XX_PLL0_BASE, SZ_4K);
-       if (!pdata->cpupll_reg_base)
-               return -ENOMEM;
-
-       pdata->ddrpll_reg_base = ioremap(DA850_PLL1_BASE, SZ_4K);
-       if (!pdata->ddrpll_reg_base) {
-               ret = -ENOMEM;
-               goto no_ddrpll_mem;
-       }
-
-       pdata->ddrpsc_reg_base = ioremap(DA8XX_PSC1_BASE, SZ_4K);
-       if (!pdata->ddrpsc_reg_base) {
-               ret = -ENOMEM;
-               goto no_ddrpsc_mem;
-       }
-
-       return platform_device_register(pdev);
-
-no_ddrpsc_mem:
-       iounmap(pdata->ddrpll_reg_base);
-no_ddrpll_mem:
-       iounmap(pdata->cpupll_reg_base);
-       return ret;
-}
-
 /* VPIF resource, platform data */
 static u64 da850_vpif_dma_mask = DMA_BIT_MASK(32);
 
index f9f9713..3d7a137 100644 (file)
@@ -101,7 +101,6 @@ int da8xx_register_gpio(void *pdata);
 int da850_register_cpufreq(char *async_clk);
 int da8xx_register_cpuidle(void);
 void __iomem *da8xx_get_mem_ctlr(void);
-int da850_register_pm(struct platform_device *pdev);
 int da850_register_sata(unsigned long refclkpn);
 int da850_register_vpif(void);
 int da850_register_vpif_display
index 8929569..4392c4e 100644 (file)
 
 #include <mach/common.h>
 #include <mach/da8xx.h>
-#include "sram.h"
+#include <mach/mux.h>
 #include <mach/pm.h>
 
 #include "clock.h"
+#include "psc.h"
+#include "sram.h"
 
+#define DA850_PLL1_BASE                0x01e1a000
 #define DEEPSLEEP_SLEEPCOUNT_MASK      0xFFFF
+#define DEEPSLEEP_SLEEPCOUNT           128
 
 static void (*davinci_sram_suspend) (struct davinci_pm_config *);
-static struct davinci_pm_config *pdata;
+static struct davinci_pm_config pm_config = {
+       .sleepcount = DEEPSLEEP_SLEEPCOUNT,
+       .ddrpsc_num = DA8XX_LPSC1_EMIF3C,
+};
+
+static struct davinci_pm_config *pdata = &pm_config;
 
 static void davinci_sram_push(void *dest, void *src, unsigned int size)
 {
@@ -117,17 +126,36 @@ static const struct platform_suspend_ops davinci_pm_ops = {
        .valid          = suspend_valid_only_mem,
 };
 
-static int __init davinci_pm_probe(struct platform_device *pdev)
+int __init davinci_pm_init(void)
 {
-       pdata = pdev->dev.platform_data;
-       if (!pdata) {
-               dev_err(&pdev->dev, "cannot get platform data\n");
-               return -ENOENT;
+       int ret;
+
+       ret = davinci_cfg_reg(DA850_RTC_ALARM);
+       if (ret)
+               return ret;
+
+       pdata->ddr2_ctlr_base = da8xx_get_mem_ctlr();
+       pdata->deepsleep_reg = DA8XX_SYSCFG1_VIRT(DA8XX_DEEPSLEEP_REG);
+
+       pdata->cpupll_reg_base = ioremap(DA8XX_PLL0_BASE, SZ_4K);
+       if (!pdata->cpupll_reg_base)
+               return -ENOMEM;
+
+       pdata->ddrpll_reg_base = ioremap(DA850_PLL1_BASE, SZ_4K);
+       if (!pdata->ddrpll_reg_base) {
+               ret = -ENOMEM;
+               goto no_ddrpll_mem;
+       }
+
+       pdata->ddrpsc_reg_base = ioremap(DA8XX_PSC1_BASE, SZ_4K);
+       if (!pdata->ddrpsc_reg_base) {
+               ret = -ENOMEM;
+               goto no_ddrpsc_mem;
        }
 
        davinci_sram_suspend = sram_alloc(davinci_cpu_suspend_sz, NULL);
        if (!davinci_sram_suspend) {
-               dev_err(&pdev->dev, "cannot allocate SRAM memory\n");
+               pr_err("PM: cannot allocate SRAM memory\n");
                return -ENOMEM;
        }
 
@@ -136,23 +164,9 @@ static int __init davinci_pm_probe(struct platform_device *pdev)
 
        suspend_set_ops(&davinci_pm_ops);
 
-       return 0;
-}
-
-static int __exit davinci_pm_remove(struct platform_device *pdev)
-{
-       sram_free(davinci_sram_suspend, davinci_cpu_suspend_sz);
-       return 0;
-}
-
-static struct platform_driver davinci_pm_driver = {
-       .driver = {
-               .name    = "pm-davinci",
-       },
-       .remove = __exit_p(davinci_pm_remove),
-};
-
-int __init davinci_pm_init(void)
-{
-       return platform_driver_probe(&davinci_pm_driver, davinci_pm_probe);
+no_ddrpsc_mem:
+       iounmap(pdata->ddrpll_reg_base);
+no_ddrpll_mem:
+       iounmap(pdata->cpupll_reg_base);
+       return ret;
 }