< prev index next >

test/hotspot/gtest/oops/test_markWord.cpp

Print this page
@@ -1,7 +1,7 @@
  /*
-  * Copyright (c) 2019, 2024, Oracle and/or its affiliates. All rights reserved.
+  * Copyright (c) 2019, 2025, Oracle and/or its affiliates. All rights reserved.
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   *
   * This code is free software; you can redistribute it and/or modify it
   * under the terms of the GNU General Public License version 2 only, as
   * published by the Free Software Foundation.

@@ -45,10 +45,20 @@
    stringStream st;
    object->print_on(&st);
    ASSERT_THAT(st.base(), testing::HasSubstr(pattern));
  }
  
+ static void assert_mark_word_print_pattern(Handle object, const char* pattern) {
+   if (LockingMode == LM_MONITOR) {
+     // With heavy monitors, we do not use the mark word. Printing the oop only shows "monitor" regardless of the
+     // locking state.
+     assert_test_pattern(object, "monitor");
+   } else {
+     assert_test_pattern(object, pattern);
+   }
+ }
+ 
  class LockerThread : public JavaTestThread {
    oop _obj;
    public:
    LockerThread(Semaphore* post, oop obj) : JavaTestThread(post), _obj(obj) {}
    virtual ~LockerThread() {}

@@ -84,17 +94,17 @@
    Handle h_obj(THREAD, obj);
  
    // Thread tries to lock it.
    {
      ObjectLocker ol(h_obj, THREAD);
-     assert_test_pattern(h_obj, "locked");
+     assert_mark_word_print_pattern(h_obj, "locked");
    }
-   assert_test_pattern(h_obj, "is_unlocked no_hash");
+   assert_mark_word_print_pattern(h_obj, "is_unlocked no_hash");
  
    // Hash the object then print it.
    intx hash = h_obj->identity_hash();
-   assert_test_pattern(h_obj, "is_unlocked hash=0x");
+   assert_mark_word_print_pattern(h_obj, "is_unlocked hash=0x");
  
    // Wait gets the lock inflated.
    {
      ObjectLocker ol(h_obj, THREAD);
  

@@ -106,6 +116,145 @@
      ol.wait(THREAD);
      assert_test_pattern(h_obj, "monitor");
      done.wait_with_safepoint_check(THREAD);  // wait till the thread is done.
    }
  }
+ 
+ static void assert_unlocked_state(markWord mark) {
+   EXPECT_FALSE(mark.has_displaced_mark_helper());
+   if (LockingMode == LM_LEGACY) {
+     EXPECT_FALSE(mark.has_locker());
+   } else if (LockingMode == LM_LIGHTWEIGHT) {
+     EXPECT_FALSE(mark.is_fast_locked());
+   }
+   EXPECT_FALSE(mark.has_monitor());
+   EXPECT_FALSE(mark.is_being_inflated());
+   EXPECT_FALSE(mark.is_locked());
+   EXPECT_TRUE(mark.is_unlocked());
+ }
+ 
+ static void assert_copy_set_hash(markWord mark) {
+   const intptr_t hash = 4711;
+   EXPECT_TRUE(mark.has_no_hash());
+   markWord copy = mark.copy_set_hash(hash);
+   EXPECT_EQ(hash, copy.hash());
+   EXPECT_FALSE(copy.has_no_hash());
+ }
+ 
+ static void assert_type(markWord mark) {
+   EXPECT_FALSE(mark.is_flat_array());
+   EXPECT_FALSE(mark.is_inline_type());
+   EXPECT_FALSE(mark.is_larval_state());
+   EXPECT_FALSE(mark.is_null_free_array());
+ }
+ 
+ TEST_VM(markWord, prototype) {
+   markWord mark = markWord::prototype();
+   assert_unlocked_state(mark);
+   EXPECT_TRUE(mark.is_neutral());
+ 
+   assert_type(mark);
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ 
+   assert_copy_set_hash(mark);
+   assert_type(mark);
+ }
+ 
+ static void assert_inline_type(markWord mark) {
+   EXPECT_FALSE(mark.is_flat_array());
+   EXPECT_TRUE(mark.is_inline_type());
+   EXPECT_FALSE(mark.is_null_free_array());
+ }
+ 
+ TEST_VM(markWord, inline_type_prototype) {
+   markWord mark = markWord::inline_type_prototype();
+   assert_unlocked_state(mark);
+   EXPECT_FALSE(mark.is_neutral());
+ 
+   assert_inline_type(mark);
+   EXPECT_FALSE(mark.is_larval_state());
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ 
+   markWord larval = mark.enter_larval_state();
+   EXPECT_TRUE(larval.is_larval_state());
+   assert_inline_type(larval);
+   mark = larval.exit_larval_state();
+   EXPECT_FALSE(mark.is_larval_state());
+   assert_inline_type(mark);
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ }
+ 
+ #if _LP64
+ 
+ static void assert_flat_array_type(markWord mark) {
+   EXPECT_TRUE(mark.is_flat_array());
+   EXPECT_FALSE(mark.is_inline_type());
+   EXPECT_FALSE(mark.is_larval_state());
+ }
+ 
+ TEST_VM(markWord, null_free_flat_array_prototype) {
+   markWord mark = markWord::flat_array_prototype(LayoutKind::NON_ATOMIC_FLAT);
+   assert_unlocked_state(mark);
+   EXPECT_TRUE(mark.is_neutral());
+ 
+   assert_flat_array_type(mark);
+   EXPECT_TRUE(mark.is_null_free_array());
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ 
+   assert_copy_set_hash(mark);
+   assert_flat_array_type(mark);
+   EXPECT_TRUE(mark.is_null_free_array());
+ }
+ 
+ TEST_VM(markWord, nullable_flat_array_prototype) {
+   markWord mark = markWord::flat_array_prototype(LayoutKind::NULLABLE_ATOMIC_FLAT);
+   assert_unlocked_state(mark);
+   EXPECT_TRUE(mark.is_neutral());
+ 
+   assert_flat_array_type(mark);
+   EXPECT_FALSE(mark.is_null_free_array());
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ 
+   assert_copy_set_hash(mark);
+   assert_flat_array_type(mark);
+   EXPECT_FALSE(mark.is_null_free_array());
+ }
+ 
+ static void assert_null_free_array_type(markWord mark) {
+   EXPECT_FALSE(mark.is_flat_array());
+   EXPECT_FALSE(mark.is_inline_type());
+   EXPECT_FALSE(mark.is_larval_state());
+   EXPECT_TRUE(mark.is_null_free_array());
+ }
+ 
+ TEST_VM(markWord, null_free_array_prototype) {
+   markWord mark = markWord::null_free_array_prototype();
+   assert_unlocked_state(mark);
+   EXPECT_TRUE(mark.is_neutral());
+ 
+   assert_null_free_array_type(mark);
+ 
+   EXPECT_TRUE(mark.has_no_hash());
+   EXPECT_FALSE(mark.is_marked());
+   EXPECT_TRUE(mark.decode_pointer() == NULL);
+ 
+   assert_copy_set_hash(mark);
+   assert_null_free_array_type(mark);
+ }
+ #endif // _LP64
+ 
  #endif // PRODUCT
< prev index next >