linux/arch/arm/mach-ux500
Russell King 3705ff6da5 ARM: Fix subtle race in CPU pen_release hotplug code
There is a subtle race in the CPU hotplug code, where a CPU which has
been offlined can online itself before being requested, which results
in things going astray on the next online/offline cycle.

What happens in the normal online/offline/online cycle is:

	CPU0			CPU3
	requests boot of CPU3
	pen_release = 3
	flush cache line
				checks pen_release, reads 3
				starts boot
				pen_release = -1
	... requests CPU3 offline ...
				... dies ...
				checks pen_release, reads -1
	requests boot of CPU3
	pen_release = 3
	flush cache line
				checks pen_release, reads 3
				starts boot
				pen_release = -1

However, as the write of -1 of pen_release is not fully flushed back to
memory, and the checking of pen_release is done with caches disabled,
this allows CPU3 the opportunity to read the old value of pen_release:

	CPU0			CPU3
	requests boot of CPU3
	pen_release = 3
	flush cache line
				checks pen_release, reads 3
				starts boot
				pen_release = -1
	... requests CPU3 offline ...
				... dies ...
				checks pen_release, reads 3
				starts boot
				pen_release = -1
	requests boot of CPU3
	pen_release = 3
	flush cache line

Fix this by grouping the write of pen_release along with its cache line
flushing code to ensure that any update to pen_release is always pushed
out to physical memory.

Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
2010-12-20 15:09:13 +00:00
..
include/mach ARM: SMP: remove smp_mpidr.h 2010-12-20 15:09:11 +00:00
board-mop500-regulators.c ARM: 6392/1: ux500: add ab8500-regulators machine specific data 2010-09-19 12:14:35 +01:00
board-mop500-sdi.c ARM: 6335/1: ux500: mop500: register eMMC devices 2010-09-02 15:46:20 +01:00
board-mop500.c Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input 2010-10-25 07:59:01 -07:00
board-mop500.h ARM: 6335/1: ux500: mop500: register eMMC devices 2010-09-02 15:46:20 +01:00
board-u5500.c arm: remove machine_desc.io_pg_offst and .phys_io 2010-10-20 00:27:46 -04:00
clock.c ux500 - add platform data for Nomadik SKE keypad controller 2010-10-13 07:49:24 -07:00
clock.h ARM: 6145/1: ux500 MTU clockrate correction 2010-05-27 10:36:08 +01:00
cpu-db5500.c ARM: 6413/1: ux500: resources for DB5500 mbox driver and modem irq handler 2010-10-04 19:24:10 +01:00
cpu-db8500.c ARM: 6331/1: ux500 cpu/SoC version macros v2 2010-09-02 15:46:19 +01:00
cpu.c ARM: 6473/1: Small update to ux500 specific L2 cache code 2010-11-21 22:05:56 +00:00
devices-db5500.c ARM: 6090/1: ux500: add U5500 support 2010-05-04 17:50:06 +01:00
devices-db8500.c Merge branch 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/djbw/async_tx 2010-10-27 19:04:36 -07:00
devices.c ARM: 6085/1: ux500: reorganize i2c devices 2010-05-04 17:50:04 +01:00
headsmp.S
hotplug.c ARM: CPU hotplug: remove bug checks in platform_cpu_die() 2010-12-20 15:09:10 +00:00
Kconfig ARM: 6441/1: ux500: The platform is not just based on early drop silicon version. 2010-10-18 22:07:26 +01:00
localtimer.c
Makefile ARM: 6417/1: ux500: build configuration for DB5500 mbox and modem irq handler 2010-10-04 19:44:29 +01:00
Makefile.boot ARM: 5832/1: ARM: U8500 Makefile.boot 2009-11-28 10:22:52 +00:00
mbox.c ARM: 6415/1: ux500: DB5500 mailbox driver 2010-10-04 19:44:29 +01:00
modem_irq.c ARM: 6414/1: ux500: DB5500 generic modem IRQ handler 2010-10-04 19:44:28 +01:00
pins-db5500.h ARM: 6371/1: ux500: add DB5500 pins 2010-09-19 12:12:26 +01:00
pins-db8500.h Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input 2010-10-25 07:59:01 -07:00
platsmp.c ARM: Fix subtle race in CPU pen_release hotplug code 2010-12-20 15:09:13 +00:00
prcmu.c ARM: 6336/1: U8500 PRCMU driver 2010-09-02 15:46:21 +01:00
ste-dma40-db5500.h ARM: 6372/1: ux500: add DB5500 DMA event lines 2010-09-19 12:12:27 +01:00
ste-dma40-db8500.h ARM: 6418/1: ux500: rename DB8500 DMA event line macros 2010-10-04 19:46:07 +01:00