summaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorVladimir Murzin <vladimir.murzin@arm.com>2014-11-27 11:39:04 +0100
committerRussell King <rmk+kernel@arm.linux.org.uk>2014-11-27 16:55:35 +0100
commit3f4aa45ceea5789a4aade536acc27f2e0d3da5e1 (patch)
treedba92986639331c3ded36813c241fe9099180660 /drivers
parentARM: 8222/1: mvebu: enable strex backoff delay (diff)
downloadlinux-3f4aa45ceea5789a4aade536acc27f2e0d3da5e1.tar.xz
linux-3f4aa45ceea5789a4aade536acc27f2e0d3da5e1.zip
ARM: 8226/1: cacheflush: get rid of restarting block
We cannot restart cacheflush safely if a process provides user-defined signal handler and signal is pending. In this case -EINTR is returned and it is expected that process re-invokes syscall. However, there are a few problems with that: * looks like nobody bothers checking return value from cacheflush * but if it did, we don't provide the restart address for that, so the process has to use the same range again * ...and again, what might lead to looping forever So, remove cacheflush restarting code and terminate cache flushing as early as fatal signal is pending. Cc: stable@vger.kernel.org # 3.12+ Reported-by: Chanho Min <chanho.min@lge.com> Signed-off-by: Vladimir Murzin <vladimir.murzin@arm.com> Acked-by: Will Deacon <will.deacon@arm.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'drivers')
0 files changed, 0 insertions, 0 deletions