summaryrefslogtreecommitdiffstats
path: root/drivers/ata
diff options
context:
space:
mode:
authorRob Herring <rob.herring@calxeda.com>2013-04-17 17:46:52 +0200
committerOlof Johansson <olof@lixom.net>2013-04-18 18:37:46 +0200
commit73053d973dd6f56472309cffa5a5d15a62dd6f96 (patch)
tree0a53ecdc88999040c5c1d760740b06c80aed05b9 /drivers/ata
parentMerge tag 'mvebu_fixes_for_v3.9_round3' of git://git.infradead.org/users/jcoo... (diff)
downloadlinux-73053d973dd6f56472309cffa5a5d15a62dd6f96.tar.xz
linux-73053d973dd6f56472309cffa5a5d15a62dd6f96.zip
ARM: highbank: fix cache flush ordering for cpu hotplug
The L1 data cache flush needs to be after highbank_set_cpu_jump call which pollutes the cache with the l2x0_lock. This causes other cores to deadlock waiting for the l2x0_lock. Moving the flush of the entire data cache after highbank_set_cpu_jump fixes the problem. Use flush_cache_louis instead of flush_cache_all are that is sufficient to flush only the L1 data cache. flush_cache_louis did not exist when highbank_cpu_die was originally written. With PL310 errata 769419 enabled, a wmb is inserted into idle which takes the l2x0_lock. This makes the problem much more easily hit and causes reset to hang. Reported-by: Paolo Pisati <p.pisati@gmail.com> Signed-off-by: Rob Herring <rob.herring@calxeda.com> Signed-off-by: Olof Johansson <olof@lixom.net>
Diffstat (limited to 'drivers/ata')
0 files changed, 0 insertions, 0 deletions