< prev index next >

src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp

Print this page
rev 56524 : [mq]: fix-shenandoah


  37   f(total_pause_gross,                              "Total Pauses (G)")                 \
  38   f(total_pause,                                    "Total Pauses (N)")                 \
  39   f(init_mark_gross,                                "Pause Init Mark (G)")              \
  40   f(init_mark,                                      "Pause Init Mark (N)")              \
  41   f(make_parsable,                                  "  Make Parsable")                  \
  42   f(clear_liveness,                                 "  Clear Liveness")                 \
  43                                                                                         \
  44   /* Per-thread timer block, should have "roots" counters in consistent order */        \
  45   f(scan_roots,                                     "  Scan Roots")                     \
  46   f(scan_thread_roots,                              "    S: Thread Roots")              \
  47   f(scan_code_roots,                                "    S: Code Cache Roots")          \
  48   f(scan_universe_roots,                            "    S: Universe Roots")            \
  49   f(scan_jni_roots,                                 "    S: JNI Roots")                 \
  50   f(scan_jvmti_weak_roots,                          "    S: JVMTI Weak Roots")          \
  51   f(scan_jfr_weak_roots,                            "    S: JFR Weak Roots")            \
  52   f(scan_jni_weak_roots,                            "    S: JNI Weak Roots")            \
  53   f(scan_stringtable_roots,                         "    S: String Table Roots")        \
  54   f(scan_resolved_method_table_roots,               "    S: Resolved Table Roots")      \
  55   f(scan_vm_global_roots,                           "    S: VM Global Roots")           \
  56   f(scan_vm_weak_roots,                             "    S: VM Weak Roots")             \

  57   f(scan_synchronizer_roots,                        "    S: Synchronizer Roots")        \
  58   f(scan_management_roots,                          "    S: Management Roots")          \
  59   f(scan_system_dictionary_roots,                   "    S: System Dict Roots")         \
  60   f(scan_cldg_roots,                                "    S: CLDG Roots")                \
  61   f(scan_jvmti_roots,                               "    S: JVMTI Roots")               \
  62   f(scan_string_dedup_table_roots,                  "    S: Dedup Table Roots")         \
  63   f(scan_string_dedup_queue_roots,                  "    S: Dedup Queue Roots")         \
  64   f(scan_finish_queues,                             "    S: Finish Queues" )            \
  65                                                                                         \
  66   f(resize_tlabs,                                   "  Resize TLABs")                   \
  67                                                                                         \
  68   f(final_mark_gross,                               "Pause Final Mark (G)")             \
  69   f(final_mark,                                     "Pause Final Mark (N)")             \
  70                                                                                         \
  71   /* Per-thread timer block, should have "roots" counters in consistent order */        \
  72   f(update_roots,                                   "  Update Roots")                   \
  73   f(update_thread_roots,                            "    U: Thread Roots")              \
  74   f(update_code_roots,                              "    U: Code Cache Roots")          \
  75   f(update_universe_roots,                          "    U: Universe Roots")            \
  76   f(update_jni_roots,                               "    U: JNI Roots")                 \
  77   f(update_jvmti_weak_roots,                        "    U: JVMTI Weak Roots")          \
  78   f(update_jfr_weak_roots,                          "    U: JFR Weak Roots")            \
  79   f(update_jni_weak_roots,                          "    U: JNI Weak Roots")            \
  80   f(update_stringtable_roots,                       "    U: String Table Roots")        \
  81   f(update_resolved_method_table_roots,             "    U: Resolved Table Roots")      \
  82   f(update_vm_global_roots,                         "    U: VM Global Roots")           \
  83   f(update_vm_weak_roots,                           "    U: VM Weak Roots")             \

  84   f(update_synchronizer_roots,                      "    U: Synchronizer Roots")        \
  85   f(update_management_roots,                        "    U: Management Roots")          \
  86   f(update_system_dictionary_roots,                 "    U: System Dict Roots")         \
  87   f(update_cldg_roots,                              "    U: CLDG Roots")                \
  88   f(update_jvmti_roots,                             "    U: JVMTI Roots")               \
  89   f(update_string_dedup_table_roots,                "    U: Dedup Table Roots")         \
  90   f(update_string_dedup_queue_roots,                "    U: Dedup Queue Roots")         \
  91   f(update_finish_queues,                           "    U: Finish Queues")             \
  92                                                                                         \
  93   f(finish_queues,                                  "  Finish Queues")                  \
  94   f(termination,                                    "    Termination")                  \
  95   f(weakrefs,                                       "  Weak References")                \
  96   f(weakrefs_process,                               "    Process")                      \
  97   f(weakrefs_termination,                           "      Termination")                \
  98   f(purge,                                          "  System Purge")                   \
  99   f(purge_class_unload,                             "    Unload Classes")               \
 100   f(purge_par,                                      "    Parallel Cleanup")             \
 101   f(purge_cldg,                                     "    CLDG")                         \
 102   f(complete_liveness,                              "  Complete Liveness")              \
 103   f(prepare_evac,                                   "  Prepare Evacuation")             \
 104   f(recycle_regions,                                "  Recycle regions")                \
 105                                                                                         \
 106   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 107   f(init_evac,                                      "  Initial Evacuation")             \
 108   f(evac_thread_roots,                              "    E: Thread Roots")              \
 109   f(evac_code_roots,                                "    E: Code Cache Roots")          \
 110   f(evac_universe_roots,                            "    E: Universe Roots")            \
 111   f(evac_jni_roots,                                 "    E: JNI Roots")                 \
 112   f(evac_jvmti_weak_roots,                          "    E: JVMTI Weak Roots")          \
 113   f(evac_jfr_weak_roots,                            "    E: JFR Weak Roots")            \
 114   f(evac_jni_weak_roots,                            "    E: JNI Weak Roots")            \
 115   f(evac_stringtable_roots,                         "    E: String Table Roots")        \
 116   f(evac_resolved_method_table_roots,               "    E: Resolved Table Roots")      \
 117   f(evac_vm_global_roots,                           "    E: VM Global Roots")           \
 118   f(evac_vm_weak_roots,                             "    E: VM Weak Roots")             \

 119   f(evac_synchronizer_roots,                        "    E: Synchronizer Roots")        \
 120   f(evac_management_roots,                          "    E: Management Roots")          \
 121   f(evac_system_dictionary_roots,                   "    E: System Dict Roots")         \
 122   f(evac_cldg_roots,                                "    E: CLDG Roots")                \
 123   f(evac_jvmti_roots,                               "    E: JVMTI Roots")               \
 124   f(evac_string_dedup_table_roots,                  "    E: String Dedup Table Roots")  \
 125   f(evac_string_dedup_queue_roots,                  "    E: String Dedup Queue Roots")  \
 126   f(evac_finish_queues,                             "    E: Finish Queues")             \
 127                                                                                         \
 128   f(final_evac_gross,                               "Pause Final Evac (G)")             \
 129   f(final_evac,                                     "Pause Final Evac (N)")             \
 130                                                                                         \
 131   f(init_update_refs_gross,                         "Pause Init  Update Refs (G)")      \
 132   f(init_update_refs,                               "Pause Init  Update Refs (N)")      \
 133                                                                                         \
 134   f(final_update_refs_gross,                         "Pause Final Update Refs (G)")     \
 135   f(final_update_refs,                               "Pause Final Update Refs (N)")     \
 136   f(final_update_refs_finish_work,                   "  Finish Work")                   \
 137                                                                                         \
 138   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 139   f(final_update_refs_roots,                         "  Update Roots")                  \
 140   f(final_update_refs_thread_roots,                  "    UR: Thread Roots")            \
 141   f(final_update_refs_code_roots,                    "    UR: Code Cache Roots")        \
 142   f(final_update_refs_universe_roots,                "    UR: Universe Roots")          \
 143   f(final_update_refs_jni_roots,                     "    UR: JNI Roots")               \
 144   f(final_update_jvmti_weak_roots,                   "    UR: JVMTI Weak Roots")        \
 145   f(final_update_jfr_weak_roots,                     "    UR: JFR Weak Roots")          \
 146   f(final_update_jni_weak_roots,                     "    UR: JNI Weak Roots")          \
 147   f(final_update_stringtable_roots,                  "    UR: String Table Roots")      \
 148   f(final_update_resolved_method_table_roots,        "    UR: Resolved Table Roots")    \
 149   f(final_update_vm_global_roots,                    "    UR: VM Global Roots")         \
 150   f(final_update_vm_weak_roots,                      "    UR: VM Weak Roots")           \

 151   f(final_update_refs_synchronizer_roots,            "    UR: Synchronizer Roots")      \
 152   f(final_update_refs_management_roots,              "    UR: Management Roots")        \
 153   f(final_update_refs_system_dict_roots,             "    UR: System Dict Roots")       \
 154   f(final_update_refs_cldg_roots,                    "    UR: CLDG Roots")              \
 155   f(final_update_refs_jvmti_roots,                   "    UR: JVMTI Roots")             \
 156   f(final_update_refs_string_dedup_table_roots,      "    UR: Dedup Table Roots")       \
 157   f(final_update_refs_string_dedup_queue_roots,      "    UR: Dedup Queue Roots")       \
 158   f(final_update_refs_finish_queues,                 "    UR: Finish Queues")           \
 159                                                                                         \
 160   f(final_update_refs_recycle,                       "  Recycle")                       \
 161                                                                                         \
 162   f(degen_gc_gross,                                  "Pause Degenerated GC (G)")        \
 163   f(degen_gc,                                        "Pause Degenerated GC (N)")        \
 164                                                                                         \
 165   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 166   f(degen_gc_update_roots,                           "  Degen Update Roots")            \
 167   f(degen_gc_update_thread_roots,                    "    DU: Thread Roots")            \
 168   f(degen_gc_update_code_roots,                      "    DU: Code Cache Roots")        \
 169   f(degen_gc_update_universe_roots,                  "    DU: Universe Roots")          \
 170   f(degen_gc_update_jni_roots,                       "    DU: JNI Roots")               \
 171   f(degen_gc_update_jvmti_weak_roots,                "    DU: JVMTI Weak Roots")        \
 172   f(degen_gc_update_jfr_weak_roots,                  "    DU: JFR Weak Roots")          \
 173   f(degen_gc_update_jni_weak_roots,                  "    DU: JNI Weak Roots")          \
 174   f(degen_gc_update_stringtable_roots,               "    DU: String Table Roots")      \
 175   f(degen_gc_update_resolved_method_table_roots,     "    DU: Resolved Table Roots")    \
 176   f(degen_gc_update_vm_global_roots,                 "    DU: VM Global Roots")         \
 177   f(degen_gc_update_vm_weak_roots,                   "    DU: VM Weak Roots")           \

 178   f(degen_gc_update_synchronizer_roots,              "    DU: Synchronizer Roots")      \
 179   f(degen_gc_update_management_roots,                "    DU: Management Roots")        \
 180   f(degen_gc_update_system_dict_roots,               "    DU: System Dict Roots")       \
 181   f(degen_gc_update_cldg_roots,                      "    DU: CLDG Roots")              \
 182   f(degen_gc_update_jvmti_roots,                     "    DU: JVMTI Roots")             \
 183   f(degen_gc_update_string_dedup_table_roots,        "    DU: Dedup Table Roots")       \
 184   f(degen_gc_update_string_dedup_queue_roots,        "    DU: Dedup Queue Roots")       \
 185   f(degen_gc_update_finish_queues,                   "    DU: Finish Queues")           \
 186                                                                                         \
 187   f(init_traversal_gc_gross,                         "Pause Init Traversal (G)")        \
 188   f(init_traversal_gc,                               "Pause Init Traversal (N)")        \
 189   f(traversal_gc_prepare,                            "  Prepare")                       \
 190   f(traversal_gc_make_parsable,                      "    Make Parsable")               \
 191   f(traversal_gc_resize_tlabs,                       "    Resize TLABs")                \
 192                                                                                         \
 193   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 194   f(init_traversal_gc_work,                          "  Work")                          \
 195   f(init_traversal_gc_thread_roots,                  "    TI: Thread Roots")            \
 196   f(init_traversal_gc_code_roots,                    "    TI: Code Cache Roots")        \
 197   f(init_traversal_gc_universe_roots,                "    TI: Universe Roots")          \
 198   f(init_traversal_gc_jni_roots,                     "    TI: JNI Roots")               \
 199   f(init_traversal_gc_jvmti_weak_roots,              "    TI: JVMTI Weak Roots")        \
 200   f(init_traversal_gc_jfr_weak_roots,                "    TI: JFR Weak Roots")          \
 201   f(init_traversal_gc_jni_weak_roots,                "    TI: JNI Weak Roots")          \
 202   f(init_traversal_gc_stringtable_roots,             "    TI: String Table Roots")      \
 203   f(init_traversal_gc_resolved_method_table_roots,   "    TI: Resolved Table Roots")    \
 204   f(init_traversal_gc_vm_global_roots,               "    TI: VM Global Roots")         \
 205   f(init_traversal_gc_vm_weak_roots,                 "    TI: VM Weak Roots")           \

 206   f(init_traversal_gc_synchronizer_roots,            "    TI: Synchronizer Roots")      \
 207   f(init_traversal_gc_management_roots,              "    TI: Management Roots")        \
 208   f(init_traversal_gc_system_dict_roots,             "    TI: System Dict Roots")       \
 209   f(init_traversal_gc_cldg_roots,                    "    TI: CLDG Roots")              \
 210   f(init_traversal_gc_jvmti_roots,                   "    TI: JVMTI Roots")             \
 211   f(init_traversal_gc_string_dedup_table_roots,      "    TI: Dedup Table Roots")       \
 212   f(init_traversal_gc_string_dedup_queue_roots,      "    TI: Dedup Queue Roots")       \
 213   f(init_traversal_gc_finish_queues,                 "    TI: Finish Queues")           \
 214                                                                                         \
 215   f(final_traversal_gc_gross,                        "Pause Final Traversal (G)")       \
 216   f(final_traversal_gc,                              "Pause Final Traversal (N)")       \
 217                                                                                         \
 218   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 219   f(final_traversal_gc_work,                         "  Work")                          \
 220   f(final_traversal_gc_thread_roots,                 "    TF: Thread Roots")            \
 221   f(final_traversal_gc_code_roots,                   "    TF: Code Cache Roots")        \
 222   f(final_traversal_gc_universe_roots,               "    TF: Universe Roots")          \
 223   f(final_traversal_gc_jni_roots,                    "    TF: JNI Roots")               \
 224   f(final_traversal_gc_jvmti_weak_roots,             "    TF: JVMTI Weak Roots")        \
 225   f(final_traversal_gc_jfr_weak_roots,               "    TF: JFR Weak Roots")          \
 226   f(final_traversal_gc_jni_weak_roots,               "    TF: JNI Weak Roots")          \
 227   f(final_traversal_gc_stringtable_roots,            "    TF: String Table Roots")      \
 228   f(final_traversal_gc_resolved_method_table_roots,  "    TF: Resolved Table Roots")    \
 229   f(final_traversal_gc_vm_global_roots,              "    TF: VM Global Roots")         \
 230   f(final_traversal_gc_vm_weak_roots,                "    TF: VM Weak Roots")           \

 231   f(final_traversal_gc_synchronizer_roots,           "    TF: Synchronizer Roots")      \
 232   f(final_traversal_gc_management_roots,             "    TF: Management Roots")        \
 233   f(final_traversal_gc_system_dict_roots,            "    TF: System Dict Roots")       \
 234   f(final_traversal_gc_cldg_roots,                   "    TF: CLDG Roots")              \
 235   f(final_traversal_gc_jvmti_roots,                  "    TF: JVMTI Roots")             \
 236   f(final_traversal_gc_string_dedup_table_roots,     "    TF: Dedup Table Roots")       \
 237   f(final_traversal_gc_string_dedup_queue_roots,     "    TF: Dedup Queue Roots")       \
 238   f(final_traversal_gc_finish_queues,                "    TF: Finish Queues")           \
 239   f(final_traversal_gc_termination,                  "    TF:   Termination")           \
 240                                                                                         \
 241   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 242   f(final_traversal_update_roots,                       "  Update Roots")               \
 243   f(final_traversal_update_thread_roots,                "    TU: Thread Roots")         \
 244   f(final_traversal_update_code_roots,                  "    TU: Code Cache Roots")     \
 245   f(final_traversal_update_universe_roots,              "    TU: Universe Roots")       \
 246   f(final_traversal_update_jni_roots,                   "    TU: JNI Roots")            \
 247   f(final_traversal_update_jvmti_weak_roots,            "    TU: JVMTI Weak Roots")     \
 248   f(final_traversal_update_jfr_weak_roots,              "    TU: JFR Weak Roots")       \
 249   f(final_traversal_update_jni_weak_roots,              "    TU: JNI Weak Roots")       \
 250   f(final_traversal_update_stringtable_roots,           "    TU: String Table Roots")   \
 251   f(final_traversal_update_resolved_method_table_roots, "    TU: Resolved Table Roots") \
 252   f(final_traversal_update_vm_global_roots,             "    TU: VM Global Roots")      \
 253   f(final_traversal_update_vm_weak_roots,               "    TU: VM Weak Roots")        \

 254   f(final_traversal_update_synchronizer_roots,          "    TU: Synchronizer Roots")   \
 255   f(final_traversal_update_management_roots,            "    TU: Management Roots")     \
 256   f(final_traversal_update_system_dict_roots,           "    TU: System Dict Roots")    \
 257   f(final_traversal_update_cldg_roots,                  "    TU: CLDG Roots")           \
 258   f(final_traversal_update_jvmti_roots,                 "    TU: JVMTI Roots")          \
 259   f(final_traversal_update_string_dedup_table_roots,    "    TU: Dedup Table Roots")    \
 260   f(final_traversal_update_string_dedup_queue_roots,    "    TU: Dedup Queue Roots")    \
 261   f(final_traversal_update_finish_queues,               "    TU: Finish Queues")        \
 262                                                                                         \
 263   f(traversal_gc_cleanup,                            "  Cleanup")                       \
 264                                                                                         \
 265   f(full_gc_gross,                                   "Pause Full GC (G)")               \
 266   f(full_gc,                                         "Pause Full GC (N)")               \
 267   f(full_gc_heapdumps,                               "  Heap Dumps")                    \
 268   f(full_gc_prepare,                                 "  Prepare")                       \
 269                                                                                         \
 270   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 271   f(full_gc_roots,                                   "  Roots")                         \
 272   f(full_gc_thread_roots,                            "    F: Thread Roots")             \
 273   f(full_gc_code_roots,                              "    F: Code Cache Roots")         \
 274   f(full_gc_universe_roots,                          "    F: Universe Roots")           \
 275   f(full_gc_jni_roots,                               "    F: JNI Roots")                \
 276   f(full_gc_jvmti_weak_roots,                        "    F: JVMTI Weak Roots")         \
 277   f(full_gc_jfr_weak_roots,                          "    F: JFR Weak Roots")           \
 278   f(full_gc_jni_weak_roots,                          "    F: JNI Weak Roots")           \
 279   f(full_gc_stringtable_roots,                       "    F: String Table Roots")       \
 280   f(full_gc_resolved_method_table_roots,             "    F: Resolved Table Roots")     \
 281   f(full_gc_vm_global_roots,                         "    F: VM Global Roots")          \
 282   f(full_gc_vm_weak_roots,                           "    F: VM Weak Roots")            \

 283   f(full_gc_synchronizer_roots,                      "    F: Synchronizer Roots")       \
 284   f(full_gc_management_roots,                        "    F: Management Roots")         \
 285   f(full_gc_system_dictionary_roots,                 "    F: System Dict Roots")        \
 286   f(full_gc_cldg_roots,                              "    F: CLDG Roots")               \
 287   f(full_gc_jvmti_roots,                             "    F: JVMTI Roots")              \
 288   f(full_gc_string_dedup_table_roots,                "    F: Dedup Table Roots")        \
 289   f(full_gc_string_dedup_queue_roots,                "    F: Dedup Queue Roots")        \
 290   f(full_gc_finish_queues,                           "    F: Finish Queues")            \
 291                                                                                         \
 292   f(full_gc_mark,                                    "  Mark")                          \
 293   f(full_gc_mark_finish_queues,                      "    Finish Queues")               \
 294   f(full_gc_mark_termination,                        "      Termination")               \
 295   f(full_gc_weakrefs,                                "    Weak References")             \
 296   f(full_gc_weakrefs_process,                        "      Process")                   \
 297   f(full_gc_weakrefs_termination,                    "        Termination")             \
 298   f(full_gc_purge,                                   "    System Purge")                \
 299   f(full_gc_purge_class_unload,                      "      Unload Classes")            \
 300   f(full_gc_purge_par,                               "    Parallel Cleanup")            \
 301   f(full_gc_purge_cldg,                              "    CLDG")                        \
 302   f(full_gc_calculate_addresses,                     "  Calculate Addresses")           \


 324                                                                                         \
 325   f(conc_uncommit,                                   "Concurrent Uncommit")             \
 326                                                                                         \
 327   /* Unclassified */                                                                    \
 328   f(pause_other,                                     "Pause Other")                     \
 329   f(conc_other,                                      "Concurrent Other")                \
 330   // end
 331 
 332 #define SHENANDOAH_GC_PAR_PHASE_DO(f)                           \
 333   f(ThreadRoots,              "Thread Roots (ms):")              \
 334   f(CodeCacheRoots,           "CodeCache Roots (ms):")           \
 335   f(UniverseRoots,            "Universe Roots (ms):")            \
 336   f(JNIRoots,                 "JNI Handles Roots (ms):")         \
 337   f(JVMTIWeakRoots,           "JVMTI Weak Roots (ms):")          \
 338   f(JFRWeakRoots,             "JFR Weak Roots (ms):")            \
 339   f(JNIWeakRoots,             "JNI Weak Roots (ms):")            \
 340   f(StringTableRoots,         "StringTable Roots(ms):")          \
 341   f(ResolvedMethodTableRoots, "Resolved Table Roots(ms):")       \
 342   f(VMGlobalRoots,            "VM Global Roots(ms)")             \
 343   f(VMWeakRoots,              "VM Weak Roots(ms)")               \

 344   f(ObjectSynchronizerRoots,  "ObjectSynchronizer Roots (ms):")  \
 345   f(ManagementRoots,          "Management Roots (ms):")          \
 346   f(SystemDictionaryRoots,    "SystemDictionary Roots (ms):")    \
 347   f(CLDGRoots,                "CLDG Roots (ms):")                \
 348   f(JVMTIRoots,               "JVMTI Roots (ms):")               \
 349   f(StringDedupTableRoots,    "String Dedup Table Roots (ms):")  \
 350   f(StringDedupQueueRoots,    "String Dedup Queue Roots (ms):")  \
 351   f(FinishQueues,             "Finish Queues (ms):")             \
 352   // end
 353 
 354 class ShenandoahPhaseTimings : public CHeapObj<mtGC> {
 355 public:
 356 #define GC_PHASE_DECLARE_ENUM(type, title)   type,
 357 
 358   enum Phase {
 359     SHENANDOAH_GC_PHASE_DO(GC_PHASE_DECLARE_ENUM)
 360     _num_phases
 361   };
 362 
 363   // These are the subphases of GC phases (scan_roots, update_roots,




  37   f(total_pause_gross,                              "Total Pauses (G)")                 \
  38   f(total_pause,                                    "Total Pauses (N)")                 \
  39   f(init_mark_gross,                                "Pause Init Mark (G)")              \
  40   f(init_mark,                                      "Pause Init Mark (N)")              \
  41   f(make_parsable,                                  "  Make Parsable")                  \
  42   f(clear_liveness,                                 "  Clear Liveness")                 \
  43                                                                                         \
  44   /* Per-thread timer block, should have "roots" counters in consistent order */        \
  45   f(scan_roots,                                     "  Scan Roots")                     \
  46   f(scan_thread_roots,                              "    S: Thread Roots")              \
  47   f(scan_code_roots,                                "    S: Code Cache Roots")          \
  48   f(scan_universe_roots,                            "    S: Universe Roots")            \
  49   f(scan_jni_roots,                                 "    S: JNI Roots")                 \
  50   f(scan_jvmti_weak_roots,                          "    S: JVMTI Weak Roots")          \
  51   f(scan_jfr_weak_roots,                            "    S: JFR Weak Roots")            \
  52   f(scan_jni_weak_roots,                            "    S: JNI Weak Roots")            \
  53   f(scan_stringtable_roots,                         "    S: String Table Roots")        \
  54   f(scan_resolved_method_table_roots,               "    S: Resolved Table Roots")      \
  55   f(scan_vm_global_roots,                           "    S: VM Global Roots")           \
  56   f(scan_vm_weak_roots,                             "    S: VM Weak Roots")             \
  57   f(scan_nmethod_keepalive,                         "    S: NMethod Keepalive")         \
  58   f(scan_synchronizer_roots,                        "    S: Synchronizer Roots")        \
  59   f(scan_management_roots,                          "    S: Management Roots")          \
  60   f(scan_system_dictionary_roots,                   "    S: System Dict Roots")         \
  61   f(scan_cldg_roots,                                "    S: CLDG Roots")                \
  62   f(scan_jvmti_roots,                               "    S: JVMTI Roots")               \
  63   f(scan_string_dedup_table_roots,                  "    S: Dedup Table Roots")         \
  64   f(scan_string_dedup_queue_roots,                  "    S: Dedup Queue Roots")         \
  65   f(scan_finish_queues,                             "    S: Finish Queues" )            \
  66                                                                                         \
  67   f(resize_tlabs,                                   "  Resize TLABs")                   \
  68                                                                                         \
  69   f(final_mark_gross,                               "Pause Final Mark (G)")             \
  70   f(final_mark,                                     "Pause Final Mark (N)")             \
  71                                                                                         \
  72   /* Per-thread timer block, should have "roots" counters in consistent order */        \
  73   f(update_roots,                                   "  Update Roots")                   \
  74   f(update_thread_roots,                            "    U: Thread Roots")              \
  75   f(update_code_roots,                              "    U: Code Cache Roots")          \
  76   f(update_universe_roots,                          "    U: Universe Roots")            \
  77   f(update_jni_roots,                               "    U: JNI Roots")                 \
  78   f(update_jvmti_weak_roots,                        "    U: JVMTI Weak Roots")          \
  79   f(update_jfr_weak_roots,                          "    U: JFR Weak Roots")            \
  80   f(update_jni_weak_roots,                          "    U: JNI Weak Roots")            \
  81   f(update_stringtable_roots,                       "    U: String Table Roots")        \
  82   f(update_resolved_method_table_roots,             "    U: Resolved Table Roots")      \
  83   f(update_vm_global_roots,                         "    U: VM Global Roots")           \
  84   f(update_vm_weak_roots,                           "    U: VM Weak Roots")             \
  85   f(update_nmethod_keepalive,                       "    U: NMethod Keepalive")         \
  86   f(update_synchronizer_roots,                      "    U: Synchronizer Roots")        \
  87   f(update_management_roots,                        "    U: Management Roots")          \
  88   f(update_system_dictionary_roots,                 "    U: System Dict Roots")         \
  89   f(update_cldg_roots,                              "    U: CLDG Roots")                \
  90   f(update_jvmti_roots,                             "    U: JVMTI Roots")               \
  91   f(update_string_dedup_table_roots,                "    U: Dedup Table Roots")         \
  92   f(update_string_dedup_queue_roots,                "    U: Dedup Queue Roots")         \
  93   f(update_finish_queues,                           "    U: Finish Queues")             \
  94                                                                                         \
  95   f(finish_queues,                                  "  Finish Queues")                  \
  96   f(termination,                                    "    Termination")                  \
  97   f(weakrefs,                                       "  Weak References")                \
  98   f(weakrefs_process,                               "    Process")                      \
  99   f(weakrefs_termination,                           "      Termination")                \
 100   f(purge,                                          "  System Purge")                   \
 101   f(purge_class_unload,                             "    Unload Classes")               \
 102   f(purge_par,                                      "    Parallel Cleanup")             \
 103   f(purge_cldg,                                     "    CLDG")                         \
 104   f(complete_liveness,                              "  Complete Liveness")              \
 105   f(prepare_evac,                                   "  Prepare Evacuation")             \
 106   f(recycle_regions,                                "  Recycle regions")                \
 107                                                                                         \
 108   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 109   f(init_evac,                                      "  Initial Evacuation")             \
 110   f(evac_thread_roots,                              "    E: Thread Roots")              \
 111   f(evac_code_roots,                                "    E: Code Cache Roots")          \
 112   f(evac_universe_roots,                            "    E: Universe Roots")            \
 113   f(evac_jni_roots,                                 "    E: JNI Roots")                 \
 114   f(evac_jvmti_weak_roots,                          "    E: JVMTI Weak Roots")          \
 115   f(evac_jfr_weak_roots,                            "    E: JFR Weak Roots")            \
 116   f(evac_jni_weak_roots,                            "    E: JNI Weak Roots")            \
 117   f(evac_stringtable_roots,                         "    E: String Table Roots")        \
 118   f(evac_resolved_method_table_roots,               "    E: Resolved Table Roots")      \
 119   f(evac_vm_global_roots,                           "    E: VM Global Roots")           \
 120   f(evac_vm_weak_roots,                             "    E: VM Weak Roots")             \
 121   f(evac_nmethod_keepalive,                         "    E: NMethod Keepalive")         \
 122   f(evac_synchronizer_roots,                        "    E: Synchronizer Roots")        \
 123   f(evac_management_roots,                          "    E: Management Roots")          \
 124   f(evac_system_dictionary_roots,                   "    E: System Dict Roots")         \
 125   f(evac_cldg_roots,                                "    E: CLDG Roots")                \
 126   f(evac_jvmti_roots,                               "    E: JVMTI Roots")               \
 127   f(evac_string_dedup_table_roots,                  "    E: String Dedup Table Roots")  \
 128   f(evac_string_dedup_queue_roots,                  "    E: String Dedup Queue Roots")  \
 129   f(evac_finish_queues,                             "    E: Finish Queues")             \
 130                                                                                         \
 131   f(final_evac_gross,                               "Pause Final Evac (G)")             \
 132   f(final_evac,                                     "Pause Final Evac (N)")             \
 133                                                                                         \
 134   f(init_update_refs_gross,                         "Pause Init  Update Refs (G)")      \
 135   f(init_update_refs,                               "Pause Init  Update Refs (N)")      \
 136                                                                                         \
 137   f(final_update_refs_gross,                         "Pause Final Update Refs (G)")     \
 138   f(final_update_refs,                               "Pause Final Update Refs (N)")     \
 139   f(final_update_refs_finish_work,                   "  Finish Work")                   \
 140                                                                                         \
 141   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 142   f(final_update_refs_roots,                         "  Update Roots")                  \
 143   f(final_update_refs_thread_roots,                  "    UR: Thread Roots")            \
 144   f(final_update_refs_code_roots,                    "    UR: Code Cache Roots")        \
 145   f(final_update_refs_universe_roots,                "    UR: Universe Roots")          \
 146   f(final_update_refs_jni_roots,                     "    UR: JNI Roots")               \
 147   f(final_update_jvmti_weak_roots,                   "    UR: JVMTI Weak Roots")        \
 148   f(final_update_jfr_weak_roots,                     "    UR: JFR Weak Roots")          \
 149   f(final_update_jni_weak_roots,                     "    UR: JNI Weak Roots")          \
 150   f(final_update_stringtable_roots,                  "    UR: String Table Roots")      \
 151   f(final_update_resolved_method_table_roots,        "    UR: Resolved Table Roots")    \
 152   f(final_update_vm_global_roots,                    "    UR: VM Global Roots")         \
 153   f(final_update_vm_weak_roots,                      "    UR: VM Weak Roots")           \
 154   f(final_update_nmethod_keepalive,                  "    UR: NMethod Keepalive")       \
 155   f(final_update_refs_synchronizer_roots,            "    UR: Synchronizer Roots")      \
 156   f(final_update_refs_management_roots,              "    UR: Management Roots")        \
 157   f(final_update_refs_system_dict_roots,             "    UR: System Dict Roots")       \
 158   f(final_update_refs_cldg_roots,                    "    UR: CLDG Roots")              \
 159   f(final_update_refs_jvmti_roots,                   "    UR: JVMTI Roots")             \
 160   f(final_update_refs_string_dedup_table_roots,      "    UR: Dedup Table Roots")       \
 161   f(final_update_refs_string_dedup_queue_roots,      "    UR: Dedup Queue Roots")       \
 162   f(final_update_refs_finish_queues,                 "    UR: Finish Queues")           \
 163                                                                                         \
 164   f(final_update_refs_recycle,                       "  Recycle")                       \
 165                                                                                         \
 166   f(degen_gc_gross,                                  "Pause Degenerated GC (G)")        \
 167   f(degen_gc,                                        "Pause Degenerated GC (N)")        \
 168                                                                                         \
 169   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 170   f(degen_gc_update_roots,                           "  Degen Update Roots")            \
 171   f(degen_gc_update_thread_roots,                    "    DU: Thread Roots")            \
 172   f(degen_gc_update_code_roots,                      "    DU: Code Cache Roots")        \
 173   f(degen_gc_update_universe_roots,                  "    DU: Universe Roots")          \
 174   f(degen_gc_update_jni_roots,                       "    DU: JNI Roots")               \
 175   f(degen_gc_update_jvmti_weak_roots,                "    DU: JVMTI Weak Roots")        \
 176   f(degen_gc_update_jfr_weak_roots,                  "    DU: JFR Weak Roots")          \
 177   f(degen_gc_update_jni_weak_roots,                  "    DU: JNI Weak Roots")          \
 178   f(degen_gc_update_stringtable_roots,               "    DU: String Table Roots")      \
 179   f(degen_gc_update_resolved_method_table_roots,     "    DU: Resolved Table Roots")    \
 180   f(degen_gc_update_vm_global_roots,                 "    DU: VM Global Roots")         \
 181   f(degen_gc_update_vm_weak_roots,                   "    DU: VM Weak Roots")           \
 182   f(degen_gc_update_nmethod_keepalive,               "    DU: NMethod Keepalive")       \
 183   f(degen_gc_update_synchronizer_roots,              "    DU: Synchronizer Roots")      \
 184   f(degen_gc_update_management_roots,                "    DU: Management Roots")        \
 185   f(degen_gc_update_system_dict_roots,               "    DU: System Dict Roots")       \
 186   f(degen_gc_update_cldg_roots,                      "    DU: CLDG Roots")              \
 187   f(degen_gc_update_jvmti_roots,                     "    DU: JVMTI Roots")             \
 188   f(degen_gc_update_string_dedup_table_roots,        "    DU: Dedup Table Roots")       \
 189   f(degen_gc_update_string_dedup_queue_roots,        "    DU: Dedup Queue Roots")       \
 190   f(degen_gc_update_finish_queues,                   "    DU: Finish Queues")           \
 191                                                                                         \
 192   f(init_traversal_gc_gross,                         "Pause Init Traversal (G)")        \
 193   f(init_traversal_gc,                               "Pause Init Traversal (N)")        \
 194   f(traversal_gc_prepare,                            "  Prepare")                       \
 195   f(traversal_gc_make_parsable,                      "    Make Parsable")               \
 196   f(traversal_gc_resize_tlabs,                       "    Resize TLABs")                \
 197                                                                                         \
 198   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 199   f(init_traversal_gc_work,                          "  Work")                          \
 200   f(init_traversal_gc_thread_roots,                  "    TI: Thread Roots")            \
 201   f(init_traversal_gc_code_roots,                    "    TI: Code Cache Roots")        \
 202   f(init_traversal_gc_universe_roots,                "    TI: Universe Roots")          \
 203   f(init_traversal_gc_jni_roots,                     "    TI: JNI Roots")               \
 204   f(init_traversal_gc_jvmti_weak_roots,              "    TI: JVMTI Weak Roots")        \
 205   f(init_traversal_gc_jfr_weak_roots,                "    TI: JFR Weak Roots")          \
 206   f(init_traversal_gc_jni_weak_roots,                "    TI: JNI Weak Roots")          \
 207   f(init_traversal_gc_stringtable_roots,             "    TI: String Table Roots")      \
 208   f(init_traversal_gc_resolved_method_table_roots,   "    TI: Resolved Table Roots")    \
 209   f(init_traversal_gc_vm_global_roots,               "    TI: VM Global Roots")         \
 210   f(init_traversal_gc_vm_weak_roots,                 "    TI: VM Weak Roots")           \
 211   f(init_traversal_gc_nmethod_keepalive,             "    TI: NMethod Keepalive")       \
 212   f(init_traversal_gc_synchronizer_roots,            "    TI: Synchronizer Roots")      \
 213   f(init_traversal_gc_management_roots,              "    TI: Management Roots")        \
 214   f(init_traversal_gc_system_dict_roots,             "    TI: System Dict Roots")       \
 215   f(init_traversal_gc_cldg_roots,                    "    TI: CLDG Roots")              \
 216   f(init_traversal_gc_jvmti_roots,                   "    TI: JVMTI Roots")             \
 217   f(init_traversal_gc_string_dedup_table_roots,      "    TI: Dedup Table Roots")       \
 218   f(init_traversal_gc_string_dedup_queue_roots,      "    TI: Dedup Queue Roots")       \
 219   f(init_traversal_gc_finish_queues,                 "    TI: Finish Queues")           \
 220                                                                                         \
 221   f(final_traversal_gc_gross,                        "Pause Final Traversal (G)")       \
 222   f(final_traversal_gc,                              "Pause Final Traversal (N)")       \
 223                                                                                         \
 224   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 225   f(final_traversal_gc_work,                         "  Work")                          \
 226   f(final_traversal_gc_thread_roots,                 "    TF: Thread Roots")            \
 227   f(final_traversal_gc_code_roots,                   "    TF: Code Cache Roots")        \
 228   f(final_traversal_gc_universe_roots,               "    TF: Universe Roots")          \
 229   f(final_traversal_gc_jni_roots,                    "    TF: JNI Roots")               \
 230   f(final_traversal_gc_jvmti_weak_roots,             "    TF: JVMTI Weak Roots")        \
 231   f(final_traversal_gc_jfr_weak_roots,               "    TF: JFR Weak Roots")          \
 232   f(final_traversal_gc_jni_weak_roots,               "    TF: JNI Weak Roots")          \
 233   f(final_traversal_gc_stringtable_roots,            "    TF: String Table Roots")      \
 234   f(final_traversal_gc_resolved_method_table_roots,  "    TF: Resolved Table Roots")    \
 235   f(final_traversal_gc_vm_global_roots,              "    TF: VM Global Roots")         \
 236   f(final_traversal_gc_vm_weak_roots,                "    TF: VM Weak Roots")           \
 237   f(final_traversal_gc_nmethod_keepalive,            "    TF: NMethod Keepalive")       \
 238   f(final_traversal_gc_synchronizer_roots,           "    TF: Synchronizer Roots")      \
 239   f(final_traversal_gc_management_roots,             "    TF: Management Roots")        \
 240   f(final_traversal_gc_system_dict_roots,            "    TF: System Dict Roots")       \
 241   f(final_traversal_gc_cldg_roots,                   "    TF: CLDG Roots")              \
 242   f(final_traversal_gc_jvmti_roots,                  "    TF: JVMTI Roots")             \
 243   f(final_traversal_gc_string_dedup_table_roots,     "    TF: Dedup Table Roots")       \
 244   f(final_traversal_gc_string_dedup_queue_roots,     "    TF: Dedup Queue Roots")       \
 245   f(final_traversal_gc_finish_queues,                "    TF: Finish Queues")           \
 246   f(final_traversal_gc_termination,                  "    TF:   Termination")           \
 247                                                                                         \
 248   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 249   f(final_traversal_update_roots,                       "  Update Roots")               \
 250   f(final_traversal_update_thread_roots,                "    TU: Thread Roots")         \
 251   f(final_traversal_update_code_roots,                  "    TU: Code Cache Roots")     \
 252   f(final_traversal_update_universe_roots,              "    TU: Universe Roots")       \
 253   f(final_traversal_update_jni_roots,                   "    TU: JNI Roots")            \
 254   f(final_traversal_update_jvmti_weak_roots,            "    TU: JVMTI Weak Roots")     \
 255   f(final_traversal_update_jfr_weak_roots,              "    TU: JFR Weak Roots")       \
 256   f(final_traversal_update_jni_weak_roots,              "    TU: JNI Weak Roots")       \
 257   f(final_traversal_update_stringtable_roots,           "    TU: String Table Roots")   \
 258   f(final_traversal_update_resolved_method_table_roots, "    TU: Resolved Table Roots") \
 259   f(final_traversal_update_vm_global_roots,             "    TU: VM Global Roots")      \
 260   f(final_traversal_update_vm_weak_roots,               "    TU: VM Weak Roots")        \
 261   f(final_traversal_update_nmethod_keepalive,           "    TU: NMethod Keepalive")    \
 262   f(final_traversal_update_synchronizer_roots,          "    TU: Synchronizer Roots")   \
 263   f(final_traversal_update_management_roots,            "    TU: Management Roots")     \
 264   f(final_traversal_update_system_dict_roots,           "    TU: System Dict Roots")    \
 265   f(final_traversal_update_cldg_roots,                  "    TU: CLDG Roots")           \
 266   f(final_traversal_update_jvmti_roots,                 "    TU: JVMTI Roots")          \
 267   f(final_traversal_update_string_dedup_table_roots,    "    TU: Dedup Table Roots")    \
 268   f(final_traversal_update_string_dedup_queue_roots,    "    TU: Dedup Queue Roots")    \
 269   f(final_traversal_update_finish_queues,               "    TU: Finish Queues")        \
 270                                                                                         \
 271   f(traversal_gc_cleanup,                            "  Cleanup")                       \
 272                                                                                         \
 273   f(full_gc_gross,                                   "Pause Full GC (G)")               \
 274   f(full_gc,                                         "Pause Full GC (N)")               \
 275   f(full_gc_heapdumps,                               "  Heap Dumps")                    \
 276   f(full_gc_prepare,                                 "  Prepare")                       \
 277                                                                                         \
 278   /* Per-thread timer block, should have "roots" counters in consistent order */        \
 279   f(full_gc_roots,                                   "  Roots")                         \
 280   f(full_gc_thread_roots,                            "    F: Thread Roots")             \
 281   f(full_gc_code_roots,                              "    F: Code Cache Roots")         \
 282   f(full_gc_universe_roots,                          "    F: Universe Roots")           \
 283   f(full_gc_jni_roots,                               "    F: JNI Roots")                \
 284   f(full_gc_jvmti_weak_roots,                        "    F: JVMTI Weak Roots")         \
 285   f(full_gc_jfr_weak_roots,                          "    F: JFR Weak Roots")           \
 286   f(full_gc_jni_weak_roots,                          "    F: JNI Weak Roots")           \
 287   f(full_gc_stringtable_roots,                       "    F: String Table Roots")       \
 288   f(full_gc_resolved_method_table_roots,             "    F: Resolved Table Roots")     \
 289   f(full_gc_vm_global_roots,                         "    F: VM Global Roots")          \
 290   f(full_gc_vm_weak_roots,                           "    F: VM Weak Roots")            \
 291   f(full_gc_nmethod_keepalive,                       "    F: NMethod Keepalive")        \
 292   f(full_gc_synchronizer_roots,                      "    F: Synchronizer Roots")       \
 293   f(full_gc_management_roots,                        "    F: Management Roots")         \
 294   f(full_gc_system_dictionary_roots,                 "    F: System Dict Roots")        \
 295   f(full_gc_cldg_roots,                              "    F: CLDG Roots")               \
 296   f(full_gc_jvmti_roots,                             "    F: JVMTI Roots")              \
 297   f(full_gc_string_dedup_table_roots,                "    F: Dedup Table Roots")        \
 298   f(full_gc_string_dedup_queue_roots,                "    F: Dedup Queue Roots")        \
 299   f(full_gc_finish_queues,                           "    F: Finish Queues")            \
 300                                                                                         \
 301   f(full_gc_mark,                                    "  Mark")                          \
 302   f(full_gc_mark_finish_queues,                      "    Finish Queues")               \
 303   f(full_gc_mark_termination,                        "      Termination")               \
 304   f(full_gc_weakrefs,                                "    Weak References")             \
 305   f(full_gc_weakrefs_process,                        "      Process")                   \
 306   f(full_gc_weakrefs_termination,                    "        Termination")             \
 307   f(full_gc_purge,                                   "    System Purge")                \
 308   f(full_gc_purge_class_unload,                      "      Unload Classes")            \
 309   f(full_gc_purge_par,                               "    Parallel Cleanup")            \
 310   f(full_gc_purge_cldg,                              "    CLDG")                        \
 311   f(full_gc_calculate_addresses,                     "  Calculate Addresses")           \


 333                                                                                         \
 334   f(conc_uncommit,                                   "Concurrent Uncommit")             \
 335                                                                                         \
 336   /* Unclassified */                                                                    \
 337   f(pause_other,                                     "Pause Other")                     \
 338   f(conc_other,                                      "Concurrent Other")                \
 339   // end
 340 
 341 #define SHENANDOAH_GC_PAR_PHASE_DO(f)                           \
 342   f(ThreadRoots,              "Thread Roots (ms):")              \
 343   f(CodeCacheRoots,           "CodeCache Roots (ms):")           \
 344   f(UniverseRoots,            "Universe Roots (ms):")            \
 345   f(JNIRoots,                 "JNI Handles Roots (ms):")         \
 346   f(JVMTIWeakRoots,           "JVMTI Weak Roots (ms):")          \
 347   f(JFRWeakRoots,             "JFR Weak Roots (ms):")            \
 348   f(JNIWeakRoots,             "JNI Weak Roots (ms):")            \
 349   f(StringTableRoots,         "StringTable Roots(ms):")          \
 350   f(ResolvedMethodTableRoots, "Resolved Table Roots(ms):")       \
 351   f(VMGlobalRoots,            "VM Global Roots(ms)")             \
 352   f(VMWeakRoots,              "VM Weak Roots(ms)")               \
 353   f(NMethodKeepAliveRoots,    "NMethod Keepalive Roots(ms)")     \
 354   f(ObjectSynchronizerRoots,  "ObjectSynchronizer Roots (ms):")  \
 355   f(ManagementRoots,          "Management Roots (ms):")          \
 356   f(SystemDictionaryRoots,    "SystemDictionary Roots (ms):")    \
 357   f(CLDGRoots,                "CLDG Roots (ms):")                \
 358   f(JVMTIRoots,               "JVMTI Roots (ms):")               \
 359   f(StringDedupTableRoots,    "String Dedup Table Roots (ms):")  \
 360   f(StringDedupQueueRoots,    "String Dedup Queue Roots (ms):")  \
 361   f(FinishQueues,             "Finish Queues (ms):")             \
 362   // end
 363 
 364 class ShenandoahPhaseTimings : public CHeapObj<mtGC> {
 365 public:
 366 #define GC_PHASE_DECLARE_ENUM(type, title)   type,
 367 
 368   enum Phase {
 369     SHENANDOAH_GC_PHASE_DO(GC_PHASE_DECLARE_ENUM)
 370     _num_phases
 371   };
 372 
 373   // These are the subphases of GC phases (scan_roots, update_roots,


< prev index next >