]> git.karo-electronics.de Git - karo-tx-linux.git/commit
Improve atomic.h robustness
authorJoshua Kinard <kumba@gentoo.org>
Mon, 25 Jun 2012 01:01:34 +0000 (21:01 -0400)
committerRalf Baechle <ralf@linux-mips.org>
Tue, 14 Aug 2012 12:38:32 +0000 (14:38 +0200)
commitdd44b0899a6be0699e1735eb808faaf38dfd43f0
tree0569f4cf62ba3b01642d57f229a245564b9c0562
parent0d7614f09c1ebdbaa1599a5aba7593f147bf96ee
Improve atomic.h robustness

I've maintained this patch, originally from Thiemo Seufer in 2004, for a
really long time, but I think it's time for it to get a look at for
possible inclusion.  I have had no problems with it across various SGI
systems over the years.

To quote the post here:
http://www.linux-mips.org/archives/linux-mips/2004-12/msg00000.html

"the atomic functions use so far memory references for the inline
assembler to access the semaphore. This can lead to additional
instructions in the ll/sc loop, because newer compilers don't
expand the memory reference any more but leave it to the assembler.

The appended patch uses registers instead, and makes the ll/sc
arguments more explicit. In some cases it will lead also to better
register scheduling because the register isn't bound to an output
any more."

Signed-off-by: Joshua Kinard <kumba@gentoo.org>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/4029/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/include/asm/atomic.h