x86-64, rwsem: 64-bit xadd rwsem implementation
authorH. Peter Anvin <hpa@zytor.com>
Mon, 18 Jan 2010 22:00:34 +0000 (14:00 -0800)
committerH. Peter Anvin <hpa@zytor.com>
Mon, 18 Jan 2010 22:00:34 +0000 (14:00 -0800)
commit1838ef1d782f7527e6defe87e180598622d2d071
tree7f8a1a2875ce92b6e27dbd9cffa1cf883988622c
parent4126faf0ab7417fbc6eb99fb0fd407e01e9e9dfe
x86-64, rwsem: 64-bit xadd rwsem implementation

For x86-64, 32767 threads really is not enough.  Change rwsem_count_t
to a signed long, so that it is 64 bits on x86-64.

This required the following changes to the assembly code:

a) %z0 doesn't work on all versions of gcc!  At least gcc 4.4.2 as
   shipped with Fedora 12 emits "ll" not "q" for 64 bits, even for
   integer operands.  Newer gccs apparently do this correctly, but
   avoid this problem by using the _ASM_ macros instead of %z.
b) 64 bits immediates are only allowed in "movq $imm,%reg"
   constructs... no others.  Change some of the constraints to "e",
   and fix the one case where we would have had to use an invalid
   immediate -- in that case, we only care about the upper half
   anyway, so just access the upper half.

Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
LKML-Reference: <tip-bafaecd11df15ad5b1e598adc7736afcd38ee13d@git.kernel.org>
arch/x86/include/asm/rwsem.h