Mercurial > hg > truffle
changeset 523:2ddbaf7b8e1c
Merge
author | xlu |
---|---|
date | Tue, 13 Jan 2009 14:49:07 -0800 |
parents | 9250583801d2 (diff) 52a431267315 (current diff) |
children | c9004fe53695 |
files | |
diffstat | 1 files changed, 6 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/src/share/vm/prims/jni.cpp Tue Jan 13 14:41:44 2009 -0500 +++ b/src/share/vm/prims/jni.cpp Tue Jan 13 14:49:07 2009 -0800 @@ -2691,8 +2691,13 @@ directBufferSupportInitializeEnded = 1; } else { - ThreadInVMfromNative tivn(thread); // set state as yield_all can call os:sleep while (!directBufferSupportInitializeEnded && !directBufferSupportInitializeFailed) { + // Set state as yield_all can call os:sleep. On Solaris, yield_all calls + // os::sleep which requires the VM state transition. On other platforms, it + // is not necessary. The following call to change the VM state is purposely + // put inside the loop to avoid potential deadlock when multiple threads + // try to call this method. See 6791815 for more details. + ThreadInVMfromNative tivn(thread); os::yield_all(); } }