The `cv_internal_thread_to_JavaThread` method will now check if the thread is a mounted virtual thread, and if so protect the carrier thread. User's of the API that need to deal with virtual threads must still check the carrier themselves as it could change asynchronously, but it is now guaranteed that the carrier JavaThread returned via this method cannot terminate whilst being used (the same as regular platform JavaThreads).
It was noticed whilst updating the documentation that the `JvmtiExport` variant `cv_oop_to_JavaThread` is unused and so can be removed. Testing: - tiers 1-4 Thanks ------------- Commit messages: - Revert to simpler fix without new API - Revert "Adapt ThreadSnapshotFactory::get_thread_snapshot to use the new API" - Remove unused JvmtiExport::cv_oop_to_JavaThread API - Adapt ThreadSnapshotFactory::get_thread_snapshot to use the new API - Adapt thread conversion routines to return (and protect) the carrier Changes: https://git.openjdk.org/jdk/pull/26287/files Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=26287&range=00 Issue: https://bugs.openjdk.org/browse/JDK-8361912 Stats: 87 lines in 4 files changed: 19 ins; 54 del; 14 mod Patch: https://git.openjdk.org/jdk/pull/26287.diff Fetch: git fetch https://git.openjdk.org/jdk.git pull/26287/head:pull/26287 PR: https://git.openjdk.org/jdk/pull/26287