summaryrefslogtreecommitdiffstats
path: root/init
diff options
context:
space:
mode:
authorWill Deacon <will.deacon@arm.com>2013-09-19 19:06:46 +0100
committerLinus Torvalds <torvalds@linux-foundation.org>2013-09-20 11:04:28 -0500
commit8f4c344696b9f9f8471d7f342076ef10ed7f66a5 (patch)
tree5266f6e86c81f6694f75e77c84c64a55123b04b1 /init
parentdcb30e659287a6b40dafed1362532da42ec27229 (diff)
downloadop-kernel-dev-8f4c344696b9f9f8471d7f342076ef10ed7f66a5.zip
op-kernel-dev-8f4c344696b9f9f8471d7f342076ef10ed7f66a5.tar.gz
lockref: use cmpxchg64 explicitly for lockless updates
The cmpxchg() function tends not to support 64-bit arguments on 32-bit architectures. This could be either due to use of unsigned long arguments (like on ARM) or lack of instruction support (cmpxchgq on x86). However, these architectures may implement a specific cmpxchg64() function to provide 64-bit cmpxchg support instead. Since the lockref code requires a 64-bit cmpxchg and relies on the architecture selecting ARCH_USE_CMPXCHG_LOCKREF, move to using cmpxchg64 instead of cmpxchg and allow 32-bit architectures to make use of the lockless lockref implementation. Cc: Waiman Long <Waiman.Long@hp.com> Signed-off-by: Will Deacon <will.deacon@arm.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'init')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud