< prev index next >

src/hotspot/share/opto/compile.cpp

Print this page
@@ -566,14 +566,19 @@
      BREAKPOINT;
    }
  
    if( PrintOpto ) {
      if (is_osr_compilation()) {
-       tty->print("[OSR]%3d", _compile_id);
-     } else {
-       tty->print("%3d", _compile_id);
+       tty->print("[OSR]");
+     } else if (env()->task()->is_precompile()) {
+       if (for_preload()) {
+         tty->print("[PRE]");
+       } else {
+         tty->print("[AOT]");
+       }
      }
+     tty->print("%3d", _compile_id);
    }
  #endif
  }
  
  #ifndef PRODUCT

@@ -605,11 +610,12 @@
    NoSafepointVerifier nsv;
    ttyLocker ttyl;
    if (xtty != nullptr) {
      xtty->head("ideal compile_id='%d'%s compile_phase='%s'",
                 compile_id(),
-                is_osr_compilation() ? " compile_kind='osr'" : "",
+                is_osr_compilation() ? " compile_kind='osr'" :
+                (for_preload() ? " compile_kind='AP'" : ""),
                 phase_name);
    }
  
    tty->print("%s", ss.as_string());
  

@@ -649,10 +655,11 @@
  #ifndef PRODUCT
        _igv_idx(0),
        _trace_opto_output(directive->TraceOptoOutputOption),
  #endif
        _clinit_barrier_on_entry(false),
+       _has_clinit_barriers(false),
        _stress_seed(0),
        _comp_arena(mtCompiler, Arena::Tag::tag_comp),
        _barrier_set_state(BarrierSet::barrier_set()->barrier_set_c2()->create_barrier_state(comp_arena())),
        _env(ci_env),
        _directive(directive),

@@ -923,10 +930,11 @@
  #ifndef PRODUCT
        _igv_idx(0),
        _trace_opto_output(directive->TraceOptoOutputOption),
  #endif
        _clinit_barrier_on_entry(false),
+       _has_clinit_barriers(false),
        _stress_seed(0),
        _comp_arena(mtCompiler, Arena::Tag::tag_comp),
        _barrier_set_state(BarrierSet::barrier_set()->barrier_set_c2()->create_barrier_state(comp_arena())),
        _env(ci_env),
        _directive(directive),

@@ -1095,12 +1103,16 @@
    set_use_cmove(UseCMoveUnconditionally /* || do_vector_loop()*/); //TODO: consider do_vector_loop() mandate use_cmove unconditionally
    NOT_PRODUCT(if (use_cmove() && Verbose && has_method()) {tty->print("Compile::Init: use CMove without profitability tests for method %s\n",  method()->name()->as_quoted_ascii());})
  
    _max_node_limit = _directive->MaxNodeLimitOption;
  
-   if (VM_Version::supports_fast_class_init_checks() && has_method() && !is_osr_compilation() && method()->needs_clinit_barrier()) {
+   if (VM_Version::supports_fast_class_init_checks() && has_method() && !is_osr_compilation() &&
+       (method()->needs_clinit_barrier() || (do_clinit_barriers() && method()->is_static()))) {
      set_clinit_barrier_on_entry(true);
+     if (do_clinit_barriers()) {
+       set_has_clinit_barriers(true); // Entry clinit barrier is in prolog code.
+     }
    }
    if (debug_info()->recording_non_safepoints()) {
      set_node_note_array(new(comp_arena()) GrowableArray<Node_Notes*>
                          (comp_arena(), 8, 0, nullptr));
      set_default_node_notes(Node_Notes::make(this));

@@ -4170,10 +4182,17 @@
  // Report if there are too many traps at the current method and bci.
  // Return true if there was a trap, and/or PerMethodTrapLimit is exceeded.
  bool Compile::too_many_traps(ciMethod* method,
                               int bci,
                               Deoptimization::DeoptReason reason) {
+   if (method->has_trap_at(bci)) {
+     return true;
+   }
+   if (PreloadReduceTraps && for_preload()) {
+     // Preload code should not have traps, if possible.
+     return true;
+   }
    ciMethodData* md = method->method_data();
    if (md->is_empty()) {
      // Assume the trap has not occurred, or that it occurred only
      // because of a transient condition during start-up in the interpreter.
      return false;

@@ -4195,10 +4214,14 @@
  }
  
  // Less-accurate variant which does not require a method and bci.
  bool Compile::too_many_traps(Deoptimization::DeoptReason reason,
                               ciMethodData* logmd) {
+   if (PreloadReduceTraps && for_preload()) {
+     // Preload code should not have traps, if possible.
+     return true;
+   }
    if (trap_count(reason) >= Deoptimization::per_method_trap_limit(reason)) {
      // Too many traps globally.
      // Note that we use cumulative trap_count, not just md->trap_count.
      if (log()) {
        int mcount = (logmd == nullptr)? -1: (int)logmd->trap_count(reason);

@@ -4284,14 +4307,14 @@
  bool Compile::needs_clinit_barrier(ciField* field, ciMethod* accessing_method) {
    return field->is_static() && needs_clinit_barrier(field->holder(), accessing_method);
  }
  
  bool Compile::needs_clinit_barrier(ciInstanceKlass* holder, ciMethod* accessing_method) {
-   if (holder->is_initialized()) {
+   if (holder->is_initialized() && !do_clinit_barriers()) {
      return false;
    }
-   if (holder->is_being_initialized()) {
+   if (holder->is_being_initialized() || do_clinit_barriers()) {
      if (accessing_method->holder() == holder) {
        // Access inside a class. The barrier can be elided when access happens in <clinit>,
        // <init>, or a static method. In all those cases, there was an initialization
        // barrier on the holder klass passed.
        if (accessing_method->is_static_initializer() ||
< prev index next >