Merge branches 'samsung/cleanup' and 'samsung/s5p-cleanup-v2', tag 'v3.16-rc6' into...
authorArnd Bergmann <arnd@arndb.de>
Sat, 26 Jul 2014 09:58:35 +0000 (11:58 +0200)
committerArnd Bergmann <arnd@arndb.de>
Sat, 26 Jul 2014 09:59:20 +0000 (11:59 +0200)
The following samsung branches are based on these cleanups,
which are already in mainline before this branch gets pulled.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
1  2  3  4 
arch/arm/Kconfig
arch/arm/Kconfig.debug
arch/arm/Makefile
arch/arm/mach-exynos/exynos.c
arch/arm/mach-exynos/hotplug.c
arch/arm/mach-exynos/platsmp.c
arch/arm/mach-exynos/regs-pmu.h
arch/arm/mach-mvebu/pmsu.c

Simple merge
Simple merge
Simple merge
index c7d960aa95a8fdf679ced2a74465fa91967660d1,46d893fcbe8538ecccea346715487a66d3cc1e01,80cbbc74d2c8dfefc8fef418186f485a2154e4e3,f38cf7c110ccb5b1508117aab9a9d2bf69b67448..2a43a1734eca26d9af13f611d3399f6fedce8cfe
@@@@@ -295,12 -295,10 -332,10 -297,10 +332,12 @@@@@ static void __init exynos_dt_machine_in
         * This is called from smp_prepare_cpus if we've built for SMP, but
         * we still need to set it up for PM and firmware ops if not.
         */
   -    if (!IS_ENABLED(SMP))
   +    if (!IS_ENABLED(CONFIG_SMP))
                exynos_sysram_init();
    
 ---    exynos_cpuidle_init();
 +++    if (!of_machine_is_compatible("samsung,exynos5420"))
 +++            exynos_cpuidle_init();
 +++
        exynos_cpufreq_init();
    
        of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
index 8a134d019cb3af0ab7d792ae3ca177dd039df95d,920a4baa53cd7f4eb290e75d1f0e5c62e4ca8cdd,572f6b1a08f1d1a175c51dae83e7ed8a83e91fcc,69fa483973943a2ad6373e2c6f1c2e7063e1c802..4d86961a7957b497a29e5ab324aa39d93cc82721
@@@@@ -40,15 -40,17 -39,15 -40,21 +39,17 @@@@@ static inline void cpu_leave_lowpower(v
    
    static inline void platform_do_lowpower(unsigned int cpu, int *spurious)
    {
+ ++    u32 mpidr = cpu_logical_map(cpu);
+ ++    u32 core_id = MPIDR_AFFINITY_LEVEL(mpidr, 0);
+ ++
        for (;;) {
    
- --            /* make cpu1 to be turned off at next WFI command */
- --            if (cpu == 1)
- --                    exynos_cpu_power_down(cpu);
+ ++            /* Turn the CPU off on next WFI instruction. */
+ ++            exynos_cpu_power_down(core_id);
    
   -            /*
   -             * here's the WFI
   -             */
   -            asm(".word      0xe320f003\n"
   -                :
   -                :
   -                : "memory", "cc");
   +            wfi();
    
- --            if (pen_release == cpu_logical_map(cpu)) {
+ ++            if (pen_release == core_id) {
                        /*
                         * OK, proper wakeup, we're done
                         */
Simple merge
Simple merge
index 34f173e7267d445d69b3329735ccf13dd176e1b6,25aa8237d66844ca5523ca6b81f1c48e8e2a7cb1,a1d407c0febe9f673dab48ece9099d699eb64d76,53a55c8520bf9a1fbab97919457af791f202ca2d..b31a8293a347c04a1974db7ba1644eb94498a309
@@@@@ -142,8 -142,8 -142,8 -140,15 +142,8 @@@@@ static void armada_370_xp_pmsu_enable_l
        writel(reg, pmsu_mp_base + L2C_NFABRIC_PM_CTL);
    }
    
   -static void armada_370_xp_cpu_resume(void)
   -{
   -    asm volatile("bl    ll_add_cpu_to_smp_group\n\t"
   -                 "bl    ll_enable_coherency\n\t"
   -                 "b     cpu_resume\n\t");
   -}
   -
    /* No locking is needed because we only access per-CPU registers */
 ---void armada_370_xp_pmsu_idle_prepare(bool deepidle)
 +++int armada_370_xp_pmsu_idle_enter(unsigned long deepidle)
    {
        unsigned int hw_cpu = cpu_logical_map(smp_processor_id());
        u32 reg;