On non-64-bit systems (which generally don't have lwsync), use eieio and

isync to implement read and write barriers, following Appendix B.2 of
Book II of the architecture manual. This provides a 25% speed increase
to fork() on the PowerPC G4.
This commit is contained in:
Nathan Whitehorn 2012-04-22 20:23:34 +00:00
parent 6f26a88999
commit 83ae3d5531

View File

@ -38,8 +38,13 @@
/* NOTE: lwsync is equivalent to sync on systems without lwsync */
#define mb() __asm __volatile("lwsync" : : : "memory")
#ifdef __powerpc64__
#define wmb() __asm __volatile("lwsync" : : : "memory")
#define rmb() __asm __volatile("lwsync" : : : "memory")
#else
#define wmb() __asm __volatile("eieio" : : : "memory")
#define rmb() __asm __volatile("isync" : : : "memory")
#endif
/*
* atomic_add(p, v)