Fengguang Wu <fengguang.wu@xxxxxxxxx> writes: > On Tue, Aug 14, 2012 at 01:55:16AM +0800, Fengguang Wu wrote: >> > >I'd suggest to fix it in m68k and make atomic64_t generally available. >> > >> > Fengguang in your testing on any architechtures is atomic64_t missing on anything except some m68k subarchtechtures? >> >> Eric, it only complaints for m68k, among the architechtures the build >> tests covered (alpha arm avr32 blackfin cris frv h8300 i386 ia64 m32r >> m68k mips mn10300 openrisc parisc powerpc s390 sh sparc sparc64 tile >> um x86_64 xtensa). > > Sorry, I must missed something (in my system, build errors are only > recorded on first sight).. > > wfg /c/linux% for arch in arch/*/; do grep -ir -q atomic64 $arch || echo $arch; done > arch/c6x/ > arch/h8300/ > arch/mn10300/ > arch/score/ > arch/unicore32/ > > So the above archs are likely still missing atomic64_t support. > However it should be trivial to add support to them, by adding > "select GENERIC_ATOMIC64" lines to them. So I just looked a little deeper and it appears architectures that do not support atomic64_t are broken. The generic atomic64 support came in 2009 to support the perf subsystem with the expectation that all architectures would implement atomic64 support. Furthermore upon inspection of the kernel atomic64_t is used in a fair number of places beyond the performance counters: block/blk-cgroup.c drivers/acpi/apei/ drivers/block/rbd.c drivers/crypto/nx/nx.h drivers/gpu/drm/radeon/radeon.h drivers/infiniband/hw/ipath/ drivers/infiniband/hw/qib/ drivers/staging/octeon/ fs/xfs/ include/linux/perf_event.h include/net/netfilter/nf_conntrack_acct.h kernel/events/ kernel/trace/ net/mac80211/key.h net/rds/ The block control group, infiniband, xfs, crypto, 802.11, netfilter. Nothing quite so fundamental as fs/namespace.c but definitely in multiplatform-code that should work, and is already broken on those architecutres. Looking at the implementation of atomic64_add_return in lib/atomic64.c the code looks as efficient as these kinds of things get. Which leads me to the conclusion that we need atomic64 support on all architectures. Arch folks can you please take care of your achitectures and ensure that atomic64_t is supported? Eric commit 09d4e0edd4614e787393acc582ac701c6ec3565b Author: Paul Mackerras <paulus@xxxxxxxxx> Date: Fri Jun 12 21:10:05 2009 +0000 lib: Provide generic atomic64_t implementation Many processor architectures have no 64-bit atomic instructions, but we need atomic64_t in order to support the perf_counter subsystem. This adds an implementation of 64-bit atomic operations using hashed spinlocks to provide atomicity. For each atomic operation, the address of the atomic64_t variable is hashed to an index into an array of 16 spinlocks. That spinlock is taken (with interrupts disabled) around the operation, which can then be coded non-atomically within the lock. On UP, all the spinlock manipulation goes away and we simply disable interrupts around each operation. In fact gcc eliminates the whole atomic64_lock variable as well. Signed-off-by: Paul Mackerras <paulus@xxxxxxxxx> Signed-off-by: Benjamin Herrenschmidt <benh@xxxxxxxxxxxxxxxxxxx> -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html