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:
parent
6f26a88999
commit
83ae3d5531
@ -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)
|
||||
|
Loading…
x
Reference in New Issue
Block a user