* src/vm/jit/i386/arch.h: Define CAS_PROVIDES_FULL_BARRIER.
* src/vm/jit/x86_64/arch.h: Likewise.
if (result == true) {
// Success, we locked it.
- // NOTE: The Java Memory Model requires an instruction barrier
- // here (because of the CAS above).
+ // NOTE: The Java Memory Model requires a memory barrier here.
+#if defined(CAS_PROVIDES_FULL_BARRIER) && CAS_PROVIDES_FULL_BARRIER
+ // On some architectures, the CAS (hidden in the
+ // lockword->lock call above), already provides this barrier,
+ // so we only need to inform the compiler.
Atomic::instruction_barrier();
+#else
+ Atomic::memory_barrier();
+#endif
return true;
}
// Memory barrier for Java Memory Model.
Atomic::write_memory_barrier();
lockword->unlock();
- // Memory barrier for thin locking.
+ // Memory barrier for FLC bit testing.
Atomic::memory_barrier();
/* check if there has been a flat lock contention on this object */
#define USES_NEW_SUBTYPE 1
+/* memory barriers ************************************************************/
+
+#define CAS_PROVIDES_FULL_BARRIER 1
+
#endif /* _ARCH_H */
/* src/vm/jit/x86_64/arch.h - architecture defines for x86_64
- Copyright (C) 1996-2005, 2006, 2007 R. Grafl, A. Krall, C. Kruegel,
- C. Oates, R. Obermaisser, M. Platter, M. Probst, S. Ring,
- E. Steiner, C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich,
- J. Wenninger, Institut f. Computersprachen - TU Wien
+ Copyright (C) 1996-2008, 2009
+ CACAOVM - Verein zur Foerderung der freien virtuellen Maschine CACAO
This file is part of CACAO.
#define USES_NEW_SUBTYPE 1
+/* memory barriers ************************************************************/
+
+#define CAS_PROVIDES_FULL_BARRIER 1
+
#endif /* _ARCH_H */