From mboxrd@z Thu Jan 1 00:00:00 1970 From: linux@arm.linux.org.uk (Russell King - ARM Linux) Date: Thu, 30 Sep 2010 22:21:01 +0100 Subject: [PATCH 2/2] ARM: S5PV310: Update CPU hotplug implementation In-Reply-To: References: <1284700388-9394-1-git-send-email-kgene.kim@samsung.com> <1284700388-9394-3-git-send-email-kgene.kim@samsung.com> <001901cb5fcd$a0a5b5a0$e1f120e0$%kim@samsung.com> Message-ID: <20100930212101.GC11660@n2100.arm.linux.org.uk> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Thu, Sep 30, 2010 at 10:02:37AM -0700, Colin Cross wrote: > On Wed, Sep 29, 2010 at 4:58 AM, Kukjin Kim wrote: > > Kukjin Kim wrote: > >> > >> From: Changhwan Youn > >> > >> This patch updates CPU hotplug implementation to reduce CPU power > >> consumption > >> and will turn off the CPU power when CPU1 is unplugged while previous CPU > >> hotplug > >> used CPU idle. > >> This patch removes init memory freeing code to use CPU boot code when CPU1 > > is > >> plugged-in again and adds vfp_enable() call to allow to access CP10 and > > CP11. > >> > >> Signed-off-by: Changhwan Youn > >> Signed-off-by: Kukjin Kim > >> Cc: Russell King > > Cc: Tony Lindgren > > Cc: Colin Cross > > Cc: Erik Gilling > > Cc: Olof Johansson > > > > snip > > >> +#ifndef CONFIG_HOTPLUG_CPU > >> ? ? ? if (!machine_is_integrator() && !machine_is_cintegrator()) > >> ? ? ? ? ? ? ? totalram_pages += > > free_area(__phys_to_pfn(__pa(__init_begin)), > >> ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? __phys_to_pfn(__pa(__init_end)), > >> ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? "init"); > >> +#endif > >> ?} > >> > >> ?#ifdef CONFIG_BLK_DEV_INITRD > > I don't think this is necessary. Any symbol that is necessary for CPU > hotplug should be marked with __cpuinit instead of __init. The linker > script will put __cpuinit symbols outside the __init_begin - > __init_end section if CONFIG_HOTPLUG_CPU is enabled. That's the theory, but not everything required for a complete restart of a secondary CPU (iow, if it's powered off) is in the right section yet. I'll have patches hopefully tomorrow to address this.