1 /*
  2  * Copyright (c) 1998, 2023, Oracle and/or its affiliates. All rights reserved.
  3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  4  *
  5  * This code is free software; you can redistribute it and/or modify it
  6  * under the terms of the GNU General Public License version 2 only, as
  7  * published by the Free Software Foundation.
  8  *
  9  * This code is distributed in the hope that it will be useful, but WITHOUT
 10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 12  * version 2 for more details (a copy is included in the LICENSE file that
 13  * accompanied this code).
 14  *
 15  * You should have received a copy of the GNU General Public License version
 16  * 2 along with this work; if not, write to the Free Software Foundation,
 17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 18  *
 19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 20  * or visit www.oracle.com if you need additional information or have any
 21  * questions.
 22  *
 23  */
 24 
 25 #include "precompiled.hpp"
 26 #include "ci/ciInlineKlass.hpp"
 27 #include "ci/ciSymbols.hpp"
 28 #include "compiler/compileLog.hpp"
 29 #include "oops/flatArrayKlass.hpp"
 30 #include "oops/objArrayKlass.hpp"
 31 #include "opto/addnode.hpp"
 32 #include "opto/castnode.hpp"
 33 #include "opto/inlinetypenode.hpp"
 34 #include "opto/memnode.hpp"
 35 #include "opto/mulnode.hpp"
 36 #include "opto/parse.hpp"
 37 #include "opto/rootnode.hpp"
 38 #include "opto/runtime.hpp"
 39 #include "runtime/sharedRuntime.hpp"
 40 
 41 //------------------------------make_dtrace_method_entry_exit ----------------
 42 // Dtrace -- record entry or exit of a method if compiled with dtrace support
 43 void GraphKit::make_dtrace_method_entry_exit(ciMethod* method, bool is_entry) {
 44   const TypeFunc *call_type    = OptoRuntime::dtrace_method_entry_exit_Type();
 45   address         call_address = is_entry ? CAST_FROM_FN_PTR(address, SharedRuntime::dtrace_method_entry) :
 46                                             CAST_FROM_FN_PTR(address, SharedRuntime::dtrace_method_exit);
 47   const char     *call_name    = is_entry ? "dtrace_method_entry" : "dtrace_method_exit";
 48 
 49   // Get base of thread-local storage area
 50   Node* thread = _gvn.transform( new ThreadLocalNode() );
 51 
 52   // Get method
 53   const TypePtr* method_type = TypeMetadataPtr::make(method);
 54   Node *method_node = _gvn.transform(ConNode::make(method_type));
 55 
 56   kill_dead_locals();
 57 
 58   // For some reason, this call reads only raw memory.
 59   const TypePtr* raw_adr_type = TypeRawPtr::BOTTOM;
 60   make_runtime_call(RC_LEAF | RC_NARROW_MEM,
 61                     call_type, call_address,
 62                     call_name, raw_adr_type,
 63                     thread, method_node);
 64 }
 65 
 66 
 67 //=============================================================================
 68 //------------------------------do_checkcast-----------------------------------
 69 void Parse::do_checkcast() {
 70   bool will_link;
 71   ciKlass* klass = iter().get_klass(will_link);
 72   Node *obj = peek();
 73 
 74   // Throw uncommon trap if class is not loaded or the value we are casting
 75   // _from_ is not loaded, and value is not null.  If the value _is_ null,
 76   // then the checkcast does nothing.
 77   const TypeOopPtr *tp = _gvn.type(obj)->isa_oopptr();
 78   if (!will_link || (tp && !tp->is_loaded())) {
 79     if (C->log() != nullptr) {
 80       if (!will_link) {
 81         C->log()->elem("assert_null reason='checkcast' klass='%d'",
 82                        C->log()->identify(klass));
 83       }
 84       if (tp && !tp->is_loaded()) {
 85         // %%% Cannot happen?
 86         ciKlass* klass = tp->unloaded_klass();
 87         C->log()->elem("assert_null reason='checkcast source' klass='%d'",
 88                        C->log()->identify(klass));
 89       }
 90     }
 91     null_assert(obj);
 92     assert( stopped() || _gvn.type(peek())->higher_equal(TypePtr::NULL_PTR), "what's left behind is null" );
 93     return;
 94   }
 95 
 96   Node* res = gen_checkcast(obj, makecon(TypeKlassPtr::make(klass, Type::trust_interfaces)));
 97   if (stopped()) {
 98     return;
 99   }
100 
101   // Pop from stack AFTER gen_checkcast because it can uncommon trap and
102   // the debug info has to be correct.
103   pop();
104   push(res);
105 }
106 
107 
108 //------------------------------do_instanceof----------------------------------
109 void Parse::do_instanceof() {
110   if (stopped())  return;
111   // We would like to return false if class is not loaded, emitting a
112   // dependency, but Java requires instanceof to load its operand.
113 
114   // Throw uncommon trap if class is not loaded
115   bool will_link;
116   ciKlass* klass = iter().get_klass(will_link);
117 
118   if (!will_link) {
119     if (C->log() != nullptr) {
120       C->log()->elem("assert_null reason='instanceof' klass='%d'",
121                      C->log()->identify(klass));
122     }
123     null_assert(peek());
124     assert( stopped() || _gvn.type(peek())->higher_equal(TypePtr::NULL_PTR), "what's left behind is null" );
125     if (!stopped()) {
126       // The object is now known to be null.
127       // Shortcut the effect of gen_instanceof and return "false" directly.
128       pop();                   // pop the null
129       push(_gvn.intcon(0));    // push false answer
130     }
131     return;
132   }
133 
134   // Push the bool result back on stack
135   Node* res = gen_instanceof(peek(), makecon(TypeKlassPtr::make(klass, Type::trust_interfaces)), true);
136 
137   // Pop from stack AFTER gen_instanceof because it can uncommon trap.
138   pop();
139   push(res);
140 }
141 
142 //------------------------------array_store_check------------------------------
143 // pull array from stack and check that the store is valid
144 Node* Parse::array_store_check(Node*& adr, const Type*& elemtype) {
145   // Shorthand access to array store elements without popping them.
146   Node *obj = peek(0);
147   Node *idx = peek(1);
148   Node *ary = peek(2);
149 
150   if (_gvn.type(obj) == TypePtr::NULL_PTR) {
151     // There's never a type check on null values.
152     // This cutout lets us avoid the uncommon_trap(Reason_array_check)
153     // below, which turns into a performance liability if the
154     // gen_checkcast folds up completely.
155     if (_gvn.type(ary)->is_aryptr()->is_null_free()) {
156       null_check(obj);
157     }
158     return obj;
159   }
160 
161   // Extract the array klass type
162   Node* array_klass = load_object_klass(ary);
163   // Get the array klass
164   const TypeKlassPtr* tak = _gvn.type(array_klass)->is_klassptr();
165 
166   // The type of array_klass is usually INexact array-of-oop.  Heroically
167   // cast array_klass to EXACT array and uncommon-trap if the cast fails.
168   // Make constant out of the inexact array klass, but use it only if the cast
169   // succeeds.
170   bool always_see_exact_class = false;
171   if (MonomorphicArrayCheck && !tak->klass_is_exact()) {
172     // Make a constant out of the inexact array klass
173     const TypeKlassPtr* extak = nullptr;
174     const TypeOopPtr* ary_t = _gvn.type(ary)->is_oopptr();
175     ciKlass* ary_spec = ary_t->speculative_type();
176     Deoptimization::DeoptReason reason = Deoptimization::Reason_none;
177     // Try to cast the array to an exact type from profile data. First
178     // check the speculative type.
179     if (ary_spec != nullptr && !too_many_traps(Deoptimization::Reason_speculate_class_check)) {
180       extak = TypeKlassPtr::make(ary_spec);
181       reason = Deoptimization::Reason_speculate_class_check;
182     } else if (UseArrayLoadStoreProfile) {
183       // No speculative type: check profile data at this bci.
184       reason = Deoptimization::Reason_class_check;
185       if (!too_many_traps(reason)) {
186         ciKlass* array_type = nullptr;
187         ciKlass* element_type = nullptr;
188         ProfilePtrKind element_ptr = ProfileMaybeNull;
189         bool flat_array = true;
190         bool null_free_array = true;
191         method()->array_access_profiled_type(bci(), array_type, element_type, element_ptr, flat_array, null_free_array);
192         if (array_type != nullptr) {
193           extak = TypeKlassPtr::make(array_type);
194         }
195       }
196     } else if (!too_many_traps(Deoptimization::Reason_array_check) && tak != TypeInstKlassPtr::OBJECT) {
197       // If the compiler has determined that the type of array 'ary' (represented
198       // by 'array_klass') is java/lang/Object, the compiler must not assume that
199       // the array 'ary' is monomorphic.
200       //
201       // If 'ary' were of type java/lang/Object, this arraystore would have to fail,
202       // because it is not possible to perform a arraystore into an object that is not
203       // a "proper" array.
204       //
205       // Therefore, let's obtain at runtime the type of 'ary' and check if we can still
206       // successfully perform the store.
207       //
208       // The implementation reasons for the condition are the following:
209       //
210       // java/lang/Object is the superclass of all arrays, but it is represented by the VM
211       // as an InstanceKlass. The checks generated by gen_checkcast() (see below) expect
212       // 'array_klass' to be ObjArrayKlass, which can result in invalid memory accesses.
213       //
214       // See issue JDK-8057622 for details.
215       extak = tak->cast_to_exactness(true);
216       reason = Deoptimization::Reason_array_check;
217     }
218     if (extak != nullptr && extak->exact_klass(true) != nullptr) {
219       Node* con = makecon(extak);
220       Node* cmp = _gvn.transform(new CmpPNode(array_klass, con));
221       Node* bol = _gvn.transform(new BoolNode(cmp, BoolTest::eq));
222       // Only do it if the check does not always pass/fail
223       if (!bol->is_Con()) {
224         always_see_exact_class = true;
225         { BuildCutout unless(this, bol, PROB_MAX);
226           uncommon_trap(reason,
227                         Deoptimization::Action_maybe_recompile,
228                         extak->exact_klass());
229         }
230         // Cast array klass to exactness
231         replace_in_map(array_klass, con);
232         array_klass = con;
233         Node* cast = _gvn.transform(new CheckCastPPNode(control(), ary, extak->as_instance_type()));
234         replace_in_map(ary, cast);
235         ary = cast;
236 
237         // Recompute element type and address
238         const TypeAryPtr* arytype = _gvn.type(ary)->is_aryptr();
239         elemtype = arytype->elem();
240         adr = array_element_address(ary, idx, T_OBJECT, arytype->size(), control());
241 
242         CompileLog* log = C->log();
243         if (log != nullptr) {
244           log->elem("cast_up reason='monomorphic_array' from='%d' to='(exact)'",
245                     log->identify(extak->exact_klass()));
246         }
247       }
248     }
249   }
250 
251   // Come here for polymorphic array klasses
252 
253   // Extract the array element class
254   int element_klass_offset = in_bytes(ArrayKlass::element_klass_offset());
255 
256   Node *p2 = basic_plus_adr(array_klass, array_klass, element_klass_offset);
257   // We are allowed to use the constant type only if cast succeeded. If always_see_exact_class is true,
258   // we must set a control edge from the IfTrue node created by the uncommon_trap above to the
259   // LoadKlassNode.
260   Node* a_e_klass = _gvn.transform(LoadKlassNode::make(_gvn, always_see_exact_class ? control() : nullptr,
261                                                        immutable_memory(), p2, tak));
262 
263   // If we statically know that this is an inline type array, use precise element klass for checkcast
264   const TypeAryPtr* arytype = _gvn.type(ary)->is_aryptr();
265   const TypePtr* elem_ptr = elemtype->make_ptr();
266   bool null_free;
267   if (elem_ptr->is_inlinetypeptr()) {
268     // We statically know that this is an inline type array, use precise klass ptr
269     null_free = arytype->is_flat() || !elem_ptr->maybe_null();
270     a_e_klass = makecon(TypeKlassPtr::make(elemtype->inline_klass()));
271   } else {
272     // TODO: Should move to TypeAry::is_null_free() with JDK-8345681
273     TypePtr::PTR ptr = elem_ptr->ptr();
274     null_free = ((ptr == TypePtr::NotNull) || (ptr == TypePtr::AnyNull));
275 #ifdef ASSERT
276     // If the element type is exact, the array can be null-free (i.e. the element type is NotNull) if:
277     //   - The elements are inline types
278     //   - The array is from an autobox cache.
279     // If the element type is inexact, it could represent multiple null-free arrays. Since autobox cache arrays
280     // are local to very few cache classes and are only used in the valueOf() methods, they are always exact and are not
281     // merged or hidden behind super types. Therefore, an inexact null-free array always represents some kind of
282     // inline type array - either of an abstract value class or Object.
283     if (null_free) {
284       ciKlass* klass = elem_ptr->is_instptr()->instance_klass();
285       if (klass->exact_klass()) {
286         assert(elem_ptr->is_inlinetypeptr() || arytype->is_autobox_cache(), "elements must be inline type or autobox cache");
287       } else {
288         assert(!arytype->is_autobox_cache() && elem_ptr->can_be_inline_type() &&
289                (klass->is_java_lang_Object() || klass->is_abstract()), "cannot have inexact non-inline type elements");
290       }
291     }
292 #endif // ASSERT
293   }
294 
295   // Check (the hard way) and throw if not a subklass.
296   return gen_checkcast(obj, a_e_klass, nullptr, null_free);
297 }
298 
299 
300 //------------------------------do_new-----------------------------------------
301 void Parse::do_new() {
302   kill_dead_locals();
303 
304   bool will_link;
305   ciInstanceKlass* klass = iter().get_klass(will_link)->as_instance_klass();
306   assert(will_link, "_new: typeflow responsibility");
307 
308   // Should throw an InstantiationError?
309   if (klass->is_abstract() || klass->is_interface() ||
310       klass->name() == ciSymbols::java_lang_Class() ||
311       iter().is_unresolved_klass()) {
312     uncommon_trap(Deoptimization::Reason_unhandled,
313                   Deoptimization::Action_none,
314                   klass);
315     return;
316   }
317 
318   if (C->needs_clinit_barrier(klass, method())) {
319     clinit_barrier(klass, method());
320     if (stopped())  return;
321   }
322 
323   if (klass->is_inlinetype()) {
324     push(InlineTypeNode::make_default(_gvn, klass->as_inline_klass(), /* is_larval */ true));
325     return;
326   }
327 
328   Node* kls = makecon(TypeKlassPtr::make(klass));
329   Node* obj = new_instance(kls);
330 
331   // Push resultant oop onto stack
332   push(obj);
333 
334   // Keep track of whether opportunities exist for StringBuilder
335   // optimizations.
336   if (OptimizeStringConcat &&
337       (klass == C->env()->StringBuilder_klass() ||
338        klass == C->env()->StringBuffer_klass())) {
339     C->set_has_stringbuilder(true);
340   }
341 
342   // Keep track of boxed values for EliminateAutoBox optimizations.
343   if (C->eliminate_boxing() && klass->is_box_klass()) {
344     C->set_has_boxed_value(true);
345   }
346 }
347 
348 #ifndef PRODUCT
349 //------------------------------dump_map_adr_mem-------------------------------
350 // Debug dump of the mapping from address types to MergeMemNode indices.
351 void Parse::dump_map_adr_mem() const {
352   tty->print_cr("--- Mapping from address types to memory Nodes ---");
353   MergeMemNode *mem = map() == nullptr ? nullptr : (map()->memory()->is_MergeMem() ?
354                                       map()->memory()->as_MergeMem() : nullptr);
355   for (uint i = 0; i < (uint)C->num_alias_types(); i++) {
356     C->alias_type(i)->print_on(tty);
357     tty->print("\t");
358     // Node mapping, if any
359     if (mem && i < mem->req() && mem->in(i) && mem->in(i) != mem->empty_memory()) {
360       mem->in(i)->dump();
361     } else {
362       tty->cr();
363     }
364   }
365 }
366 
367 #endif