git: 0d0710f366ca - main - java/openjdk17: Update to 17.0.5

From: Greg Lewis <glewis_at_FreeBSD.org>
Date: Sat, 29 Oct 2022 22:21:29 UTC
The branch main has been updated by glewis:

URL: https://cgit.FreeBSD.org/ports/commit/?id=0d0710f366caad489a8c985d704cf42ff12bf7f6

commit 0d0710f366caad489a8c985d704cf42ff12bf7f6
Author:     Greg Lewis <glewis@FreeBSD.org>
AuthorDate: 2022-10-29 22:21:06 +0000
Commit:     Greg Lewis <glewis@FreeBSD.org>
CommitDate: 2022-10-29 22:21:06 +0000

    java/openjdk17: Update to 17.0.5
---
 java/openjdk17/Makefile        |   3 +-
 java/openjdk17/distinfo        |   6 +-
 java/openjdk17/files/patch-4-1 | 544 -----------------------------------------
 3 files changed, 4 insertions(+), 549 deletions(-)

diff --git a/java/openjdk17/Makefile b/java/openjdk17/Makefile
index 416ec0ad2c3c..dc972f6436ab 100644
--- a/java/openjdk17/Makefile
+++ b/java/openjdk17/Makefile
@@ -1,7 +1,6 @@
 PORTNAME=	openjdk
 DISTVERSIONPREFIX=	jdk-
 DISTVERSION=	${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_PATCH_VERSION}+${JDK_BUILD_NUMBER}-${BSD_JDK_VERSION}
-PORTREVISION=	1
 CATEGORIES=	java devel
 PKGNAMESUFFIX?=	${JDK_MAJOR_VERSION}
 
@@ -63,7 +62,7 @@ NOPRECIOUSMAKEVARS=	yes
 
 JDK_MAJOR_VERSION=	17
 JDK_MINOR_VERSION=	0
-JDK_PATCH_VERSION=	4
+JDK_PATCH_VERSION=	5
 JDK_BUILD_NUMBER=	8
 BSD_JDK_VERSION=	1
 
diff --git a/java/openjdk17/distinfo b/java/openjdk17/distinfo
index bc0fbc26b21e..7cf8a893a5a4 100644
--- a/java/openjdk17/distinfo
+++ b/java/openjdk17/distinfo
@@ -1,3 +1,3 @@
-TIMESTAMP = 1659416748
-SHA256 (battleblow-jdk17u-jdk-17.0.4+8-1_GH0.tar.gz) = 3de3785971cd7764952f0f8f51055efd22fc295ad3b7640a1e83f64487612475
-SIZE (battleblow-jdk17u-jdk-17.0.4+8-1_GH0.tar.gz) = 105007565
+TIMESTAMP = 1667065422
+SHA256 (battleblow-jdk17u-jdk-17.0.5+8-1_GH0.tar.gz) = 53397f1c66eed40ade118843af45313b69f1486d6d5ea70cf28a4d0227699308
+SIZE (battleblow-jdk17u-jdk-17.0.5+8-1_GH0.tar.gz) = 105179758
diff --git a/java/openjdk17/files/patch-4-1 b/java/openjdk17/files/patch-4-1
deleted file mode 100644
index 0ac6e1c3565f..000000000000
--- a/java/openjdk17/files/patch-4-1
+++ /dev/null
@@ -1,544 +0,0 @@
---- .jcheck/conf
-+++ .jcheck/conf
-@@ -1,7 +1,7 @@
- [general]
- project=jdk-updates
- jbs=JDK
--version=17.0.4
-+version=17.0.4.1
- 
- [checks]
- error=author,committer,reviewers,merge,issues,executable,symlink,message,hg-tag,whitespace,problemlists
---- make/conf/version-numbers.conf
-+++ make/conf/version-numbers.conf
-@@ -29,11 +29,11 @@
- DEFAULT_VERSION_FEATURE=17
- DEFAULT_VERSION_INTERIM=0
- DEFAULT_VERSION_UPDATE=4
--DEFAULT_VERSION_PATCH=0
-+DEFAULT_VERSION_PATCH=1
- DEFAULT_VERSION_EXTRA1=0
- DEFAULT_VERSION_EXTRA2=0
- DEFAULT_VERSION_EXTRA3=0
--DEFAULT_VERSION_DATE=2022-07-19
-+DEFAULT_VERSION_DATE=2022-08-12
- DEFAULT_VERSION_CLASSFILE_MAJOR=61  # "`$EXPR $DEFAULT_VERSION_FEATURE + 44`"
- DEFAULT_VERSION_CLASSFILE_MINOR=0
- DEFAULT_VERSION_DOCS_API_SINCE=11
---- src/hotspot/share/opto/callnode.cpp
-+++ src/hotspot/share/opto/callnode.cpp
-@@ -1654,7 +1654,6 @@ AllocateNode::AllocateNode(Compile* C, const TypeFunc *atype,
-   init_req( KlassNode          , klass_node);
-   init_req( InitialTest        , initial_test);
-   init_req( ALength            , topnode);
--  init_req( ValidLengthTest    , topnode);
-   C->add_macro_node(this);
- }
- 
-@@ -1687,6 +1686,54 @@ Node *AllocateNode::make_ideal_mark(PhaseGVN *phase, Node* obj, Node* control, N
-   return mark_node;
- }
- 
-+//=============================================================================
-+Node* AllocateArrayNode::Ideal(PhaseGVN *phase, bool can_reshape) {
-+  if (remove_dead_region(phase, can_reshape))  return this;
-+  // Don't bother trying to transform a dead node
-+  if (in(0) && in(0)->is_top())  return NULL;
-+
-+  const Type* type = phase->type(Ideal_length());
-+  if (type->isa_int() && type->is_int()->_hi < 0) {
-+    if (can_reshape) {
-+      PhaseIterGVN *igvn = phase->is_IterGVN();
-+      // Unreachable fall through path (negative array length),
-+      // the allocation can only throw so disconnect it.
-+      Node* proj = proj_out_or_null(TypeFunc::Control);
-+      Node* catchproj = NULL;
-+      if (proj != NULL) {
-+        for (DUIterator_Fast imax, i = proj->fast_outs(imax); i < imax; i++) {
-+          Node *cn = proj->fast_out(i);
-+          if (cn->is_Catch()) {
-+            catchproj = cn->as_Multi()->proj_out_or_null(CatchProjNode::fall_through_index);
-+            break;
-+          }
-+        }
-+      }
-+      if (catchproj != NULL && catchproj->outcnt() > 0 &&
-+          (catchproj->outcnt() > 1 ||
-+           catchproj->unique_out()->Opcode() != Op_Halt)) {
-+        assert(catchproj->is_CatchProj(), "must be a CatchProjNode");
-+        Node* nproj = catchproj->clone();
-+        igvn->register_new_node_with_optimizer(nproj);
-+
-+        Node *frame = new ParmNode( phase->C->start(), TypeFunc::FramePtr );
-+        frame = phase->transform(frame);
-+        // Halt & Catch Fire
-+        Node* halt = new HaltNode(nproj, frame, "unexpected negative array length");
-+        phase->C->root()->add_req(halt);
-+        phase->transform(halt);
-+
-+        igvn->replace_node(catchproj, phase->C->top());
-+        return this;
-+      }
-+    } else {
-+      // Can't correct it during regular GVN so register for IGVN
-+      phase->C->record_for_igvn(this);
-+    }
-+  }
-+  return NULL;
-+}
-+
- // Retrieve the length from the AllocateArrayNode. Narrow the type with a
- // CastII, if appropriate.  If we are not allowed to create new nodes, and
- // a CastII is appropriate, return NULL.
---- src/hotspot/share/opto/callnode.hpp
-+++ src/hotspot/share/opto/callnode.hpp
-@@ -913,7 +913,6 @@ public:
-     KlassNode,                        // type (maybe dynamic) of the obj.
-     InitialTest,                      // slow-path test (may be constant)
-     ALength,                          // array length (or TOP if none)
--    ValidLengthTest,
-     ParmLimit
-   };
- 
-@@ -923,7 +922,6 @@ public:
-     fields[KlassNode]   = TypeInstPtr::NOTNULL;
-     fields[InitialTest] = TypeInt::BOOL;
-     fields[ALength]     = t;  // length (can be a bad length)
--    fields[ValidLengthTest] = TypeInt::BOOL;
- 
-     const TypeTuple *domain = TypeTuple::make(ParmLimit, fields);
- 
-@@ -1018,16 +1016,18 @@ public:
- //
- class AllocateArrayNode : public AllocateNode {
- public:
--  AllocateArrayNode(Compile* C, const TypeFunc* atype, Node* ctrl, Node* mem, Node* abio, Node* size, Node* klass_node,
--                    Node* initial_test, Node* count_val, Node* valid_length_test)
-+  AllocateArrayNode(Compile* C, const TypeFunc *atype, Node *ctrl, Node *mem, Node *abio,
-+                    Node* size, Node* klass_node, Node* initial_test,
-+                    Node* count_val
-+                    )
-     : AllocateNode(C, atype, ctrl, mem, abio, size, klass_node,
-                    initial_test)
-   {
-     init_class_id(Class_AllocateArray);
-     set_req(AllocateNode::ALength,        count_val);
--    set_req(AllocateNode::ValidLengthTest, valid_length_test);
-   }
-   virtual int Opcode() const;
-+  virtual Node *Ideal(PhaseGVN *phase, bool can_reshape);
- 
-   // Dig the length operand out of a array allocation site.
-   Node* Ideal_length() {
---- src/hotspot/share/opto/cfgnode.cpp
-+++ src/hotspot/share/opto/cfgnode.cpp
-@@ -2631,17 +2631,6 @@ const Type* CatchNode::Value(PhaseGVN* phase) const {
-       // Rethrows always throw exceptions, never return
-       if (call->entry_point() == OptoRuntime::rethrow_stub()) {
-         f[CatchProjNode::fall_through_index] = Type::TOP;
--      } else if (call->is_AllocateArray()) {
--        Node* klass_node = call->in(AllocateNode::KlassNode);
--        Node* length = call->in(AllocateNode::ALength);
--        const Type* length_type = phase->type(length);
--        const Type* klass_type = phase->type(klass_node);
--        Node* valid_length_test = call->in(AllocateNode::ValidLengthTest);
--        const Type* valid_length_test_t = phase->type(valid_length_test);
--        if (length_type == Type::TOP || klass_type == Type::TOP || valid_length_test_t == Type::TOP ||
--            valid_length_test_t->is_int()->is_con(0)) {
--          f[CatchProjNode::fall_through_index] = Type::TOP;
--        }
-       } else if( call->req() > TypeFunc::Parms ) {
-         const Type *arg0 = phase->type( call->in(TypeFunc::Parms) );
-         // Check for null receiver to virtual or interface calls
---- src/hotspot/share/opto/compile.cpp
-+++ src/hotspot/share/opto/compile.cpp
-@@ -3740,7 +3740,7 @@ bool Compile::final_graph_reshaping() {
-       // 'fall-thru' path, so expected kids is 1 less.
-       if (n->is_PCTable() && n->in(0) && n->in(0)->in(0)) {
-         if (n->in(0)->in(0)->is_Call()) {
--          CallNode* call = n->in(0)->in(0)->as_Call();
-+          CallNode *call = n->in(0)->in(0)->as_Call();
-           if (call->entry_point() == OptoRuntime::rethrow_stub()) {
-             required_outcnt--;      // Rethrow always has 1 less kid
-           } else if (call->req() > TypeFunc::Parms &&
-@@ -3749,25 +3749,22 @@ bool Compile::final_graph_reshaping() {
-             // detected that the virtual call will always result in a null
-             // pointer exception. The fall-through projection of this CatchNode
-             // will not be populated.
--            Node* arg0 = call->in(TypeFunc::Parms);
-+            Node *arg0 = call->in(TypeFunc::Parms);
-             if (arg0->is_Type() &&
-                 arg0->as_Type()->type()->higher_equal(TypePtr::NULL_PTR)) {
-               required_outcnt--;
-             }
--          } else if (call->entry_point() == OptoRuntime::new_array_Java() ||
--                     call->entry_point() == OptoRuntime::new_array_nozero_Java()) {
--            // Check for illegal array length. In such case, the optimizer has
-+          } else if (call->entry_point() == OptoRuntime::new_array_Java() &&
-+                     call->req() > TypeFunc::Parms+1 &&
-+                     call->is_CallStaticJava()) {
-+            // Check for negative array length. In such case, the optimizer has
-             // detected that the allocation attempt will always result in an
-             // exception. There is no fall-through projection of this CatchNode .
--            assert(call->is_CallStaticJava(), "static call expected");
--            assert(call->req() == call->jvms()->endoff() + 1, "missing extra input");
--            Node* valid_length_test = call->in(call->req()-1);
--            call->del_req(call->req()-1);
--            if (valid_length_test->find_int_con(1) == 0) {
-+            Node *arg1 = call->in(TypeFunc::Parms+1);
-+            if (arg1->is_Type() &&
-+                arg1->as_Type()->type()->join(TypeInt::POS)->empty()) {
-               required_outcnt--;
-             }
--            assert(n->outcnt() == required_outcnt, "malformed control flow");
--            continue;
-           }
-         }
-       }
-@@ -3776,14 +3773,6 @@ bool Compile::final_graph_reshaping() {
-         record_method_not_compilable("malformed control flow");
-         return true;            // Not all targets reachable!
-       }
--    } else if (n->is_PCTable() && n->in(0) && n->in(0)->in(0) && n->in(0)->in(0)->is_Call()) {
--      CallNode* call = n->in(0)->in(0)->as_Call();
--      if (call->entry_point() == OptoRuntime::new_array_Java() ||
--          call->entry_point() == OptoRuntime::new_array_nozero_Java()) {
--        assert(call->is_CallStaticJava(), "static call expected");
--        assert(call->req() == call->jvms()->endoff() + 1, "missing extra input");
--        call->del_req(call->req()-1); // valid length test useless now
--      }
-     }
-     // Check that I actually visited all kids.  Unreached kids
-     // must be infinite loops.
---- src/hotspot/share/opto/graphKit.cpp
-+++ src/hotspot/share/opto/graphKit.cpp
-@@ -2744,9 +2744,7 @@ void GraphKit::make_slow_call_ex(Node* call, ciInstanceKlass* ex_klass, bool sep
-   // Make a catch node with just two handlers:  fall-through and catch-all
-   Node* i_o  = _gvn.transform( new ProjNode(call, TypeFunc::I_O, separate_io_proj) );
-   Node* catc = _gvn.transform( new CatchNode(control(), i_o, 2) );
--  Node* norm = new CatchProjNode(catc, CatchProjNode::fall_through_index, CatchProjNode::no_handler_bci);
--  _gvn.set_type_bottom(norm);
--  C->record_for_igvn(norm);
-+  Node* norm = _gvn.transform( new CatchProjNode(catc, CatchProjNode::fall_through_index, CatchProjNode::no_handler_bci) );
-   Node* excp = _gvn.transform( new CatchProjNode(catc, CatchProjNode::catch_all_index,    CatchProjNode::no_handler_bci) );
- 
-   { PreserveJVMState pjvms(this);
-@@ -3985,28 +3983,20 @@ Node* GraphKit::new_array(Node* klass_node,     // array klass (maybe variable)
-     initial_slow_test = initial_slow_test->as_Bool()->as_int_value(&_gvn);
-   }
- 
--  const TypeOopPtr* ary_type = _gvn.type(klass_node)->is_klassptr()->as_instance_type();
--  Node* valid_length_test = _gvn.intcon(1);
--  if (ary_type->klass()->is_array_klass()) {
--    BasicType bt = ary_type->klass()->as_array_klass()->element_type()->basic_type();
--    jint max = TypeAryPtr::max_array_length(bt);
--    Node* valid_length_cmp  = _gvn.transform(new CmpUNode(length, intcon(max)));
--    valid_length_test = _gvn.transform(new BoolNode(valid_length_cmp, BoolTest::le));
--  }
--
-   // Create the AllocateArrayNode and its result projections
-   AllocateArrayNode* alloc
-     = new AllocateArrayNode(C, AllocateArrayNode::alloc_type(TypeInt::INT),
-                             control(), mem, i_o(),
-                             size, klass_node,
-                             initial_slow_test,
--                            length, valid_length_test);
-+                            length);
- 
-   // Cast to correct type.  Note that the klass_node may be constant or not,
-   // and in the latter case the actual array type will be inexact also.
-   // (This happens via a non-constant argument to inline_native_newArray.)
-   // In any case, the value of klass_node provides the desired array type.
-   const TypeInt* length_type = _gvn.find_int_type(length);
-+  const TypeOopPtr* ary_type = _gvn.type(klass_node)->is_klassptr()->as_instance_type();
-   if (ary_type->isa_aryptr() && length_type != NULL) {
-     // Try to get a better type than POS for the size
-     ary_type = ary_type->is_aryptr()->cast_to_size(length_type);
---- src/hotspot/share/opto/macro.cpp
-+++ src/hotspot/share/opto/macro.cpp
-@@ -1208,8 +1208,7 @@ void PhaseMacroExpand::expand_allocate_common(
-             AllocateNode* alloc, // allocation node to be expanded
-             Node* length,  // array length for an array allocation
-             const TypeFunc* slow_call_type, // Type of slow call
--            address slow_call_address,  // Address of slow call
--            Node* valid_length_test // whether length is valid or not
-+            address slow_call_address  // Address of slow call
-     )
- {
-   Node* ctrl = alloc->in(TypeFunc::Control);
-@@ -1395,12 +1394,6 @@ void PhaseMacroExpand::expand_allocate_common(
-   // Copy debug information and adjust JVMState information, then replace
-   // allocate node with the call
-   call->copy_call_debug_info(&_igvn, alloc);
--  // For array allocations, copy the valid length check to the call node so Compile::final_graph_reshaping() can verify
--  // that the call has the expected number of CatchProj nodes (in case the allocation always fails and the fallthrough
--  // path dies).
--  if (valid_length_test != NULL) {
--    call->add_req(valid_length_test);
--  }
-   if (expand_fast_path) {
-     call->set_cnt(PROB_UNLIKELY_MAG(4));  // Same effect as RC_UNCOMMON.
-   } else {
-@@ -1882,12 +1875,11 @@ Node* PhaseMacroExpand::prefetch_allocation(Node* i_o, Node*& needgc_false,
- void PhaseMacroExpand::expand_allocate(AllocateNode *alloc) {
-   expand_allocate_common(alloc, NULL,
-                          OptoRuntime::new_instance_Type(),
--                         OptoRuntime::new_instance_Java(), NULL);
-+                         OptoRuntime::new_instance_Java());
- }
- 
- void PhaseMacroExpand::expand_allocate_array(AllocateArrayNode *alloc) {
-   Node* length = alloc->in(AllocateNode::ALength);
--  Node* valid_length_test = alloc->in(AllocateNode::ValidLengthTest);
-   InitializeNode* init = alloc->initialization();
-   Node* klass_node = alloc->in(AllocateNode::KlassNode);
-   ciKlass* k = _igvn.type(klass_node)->is_klassptr()->klass();
-@@ -1902,7 +1894,7 @@ void PhaseMacroExpand::expand_allocate_array(AllocateArrayNode *alloc) {
-   }
-   expand_allocate_common(alloc, length,
-                          OptoRuntime::new_array_Type(),
--                         slow_call_address, valid_length_test);
-+                         slow_call_address);
- }
- 
- //-------------------mark_eliminated_box----------------------------------
---- src/hotspot/share/opto/macro.hpp
-+++ src/hotspot/share/opto/macro.hpp
-@@ -92,8 +92,8 @@ private:
-   void expand_allocate_common(AllocateNode* alloc,
-                               Node* length,
-                               const TypeFunc* slow_call_type,
--                              address slow_call_address,
--                              Node* valid_length_test);
-+                              address slow_call_address);
-+  void yank_initalize_node(InitializeNode* node);
-   void yank_alloc_node(AllocateNode* alloc);
-   Node *value_from_mem(Node *mem, Node *ctl, BasicType ft, const Type *ftype, const TypeOopPtr *adr_t, AllocateNode *alloc);
-   Node *value_from_mem_phi(Node *mem, BasicType ft, const Type *ftype, const TypeOopPtr *adr_t, AllocateNode *alloc, Node_Stack *value_phis, int level);
---- src/hotspot/share/opto/split_if.cpp
-+++ src/hotspot/share/opto/split_if.cpp
-@@ -128,8 +128,8 @@ bool PhaseIdealLoop::split_up( Node *n, Node *blk1, Node *blk2 ) {
-               }
-             } else {
-               // We might see an Opaque1 from a loop limit check here
--              assert(use->is_If() || use->is_CMove() || use->Opcode() == Op_Opaque1 || use->is_AllocateArray(), "unexpected node type");
--              Node *use_c = (use->is_If() || use->is_AllocateArray()) ? use->in(0) : get_ctrl(use);
-+              assert(use->is_If() || use->is_CMove() || use->Opcode() == Op_Opaque1, "unexpected node type");
-+              Node *use_c = use->is_If() ? use->in(0) : get_ctrl(use);
-               if (use_c == blk1 || use_c == blk2) {
-                 assert(use->is_CMove(), "unexpected node type");
-                 continue;
-@@ -166,15 +166,14 @@ bool PhaseIdealLoop::split_up( Node *n, Node *blk1, Node *blk2 ) {
-                 --j;
-               } else {
-                 // We might see an Opaque1 from a loop limit check here
--                assert(u->is_If() || u->is_CMove() || u->Opcode() == Op_Opaque1 || u->is_AllocateArray(), "unexpected node type");
--                assert(u->is_AllocateArray() || u->in(1) == bol, "");
--                assert(!u->is_AllocateArray() || u->in(AllocateNode::ValidLengthTest) == bol, "wrong input to AllocateArray");
-+                assert(u->is_If() || u->is_CMove() || u->Opcode() == Op_Opaque1, "unexpected node type");
-+                assert(u->in(1) == bol, "");
-                 // Get control block of either the CMove or the If input
--                Node *u_ctrl = (u->is_If() || u->is_AllocateArray()) ? u->in(0) : get_ctrl(u);
-+                Node *u_ctrl = u->is_If() ? u->in(0) : get_ctrl(u);
-                 assert((u_ctrl != blk1 && u_ctrl != blk2) || u->is_CMove(), "won't converge");
-                 Node *x = bol->clone();
-                 register_new_node(x, u_ctrl);
--                _igvn.replace_input_of(u, u->is_AllocateArray() ? AllocateNode::ValidLengthTest : 1, x);
-+                _igvn.replace_input_of(u, 1, x);
-                 --j;
-               }
-             }
---- test/hotspot/jtreg/compiler/allocation/TestAllocArrayAfterAllocNoUse.java
-+++ /dev/null
-@@ -1,52 +0,0 @@
--/*
-- * Copyright (c) 2022, Red Hat, Inc. 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.
-- *
-- * This code is distributed in the hope that it will be useful, but WITHOUT
-- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-- * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
-- * version 2 for more details (a copy is included in the LICENSE file that
-- * accompanied this code).
-- *
-- * You should have received a copy of the GNU General Public License version
-- * 2 along with this work; if not, write to the Free Software Foundation,
-- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
-- *
-- * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
-- * or visit www.oracle.com if you need additional information or have any
-- * questions.
-- */
--
--/**
-- * @test
-- * @bug 8279125
-- * @summary fatal error: no reachable node should have no use
-- * @requires vm.flavor == "server"
-- *
-- * @run main/othervm -XX:-BackgroundCompilation -XX:-DoEscapeAnalysis TestAllocArrayAfterAllocNoUse
-- *
-- */
--
--public class TestAllocArrayAfterAllocNoUse {
--    private static Object field;
--
--    public static void main(String[] args) {
--        for (int i = 0; i < 20_000; i++) {
--            test();
--        }
--    }
--
--    private static void test() {
--        try {
--            final TestAllocArrayAfterAllocNoUse o = new TestAllocArrayAfterAllocNoUse();
--        } catch (Exception e) {
--            final int[] array = new int[100];
--            field = array;
--        }
--
--    }
--}
---- test/hotspot/jtreg/compiler/allocation/TestCCPAllocateArray.java
-+++ /dev/null
-@@ -1,53 +0,0 @@
--/*
-- * Copyright (c) 2022, Red Hat, Inc. 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.
-- *
-- * This code is distributed in the hope that it will be useful, but WITHOUT
-- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-- * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
-- * version 2 for more details (a copy is included in the LICENSE file that
-- * accompanied this code).
-- *
-- * You should have received a copy of the GNU General Public License version
-- * 2 along with this work; if not, write to the Free Software Foundation,
-- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
-- *
-- * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
-- * or visit www.oracle.com if you need additional information or have any
-- * questions.
-- */
--
--/**
-- * @test
-- * @bug 8279062
-- * @summary C2: assert(t->meet(t0) == t) failed: Not monotonic after JDK-8278413
-- *
-- * @run main/othervm -XX:-BackgroundCompilation TestCCPAllocateArray
-- *
-- */
--
--public class TestCCPAllocateArray {
--    public static void main(String[] args) {
--        for (int i = 0; i < 20_000; i++) {
--            try {
--                test();
--            } catch (OutOfMemoryError e) {
--            }
--            length(42);
--        }
--    }
--
--    private static int[] test() {
--        int i = 2;
--        for (; i < 4; i *= 2);
--        return new int[length(i)];
--    }
--
--    private static int length(int i) {
--        return i == 4 ? Integer.MAX_VALUE : 0;
--    }
--}
---- test/hotspot/jtreg/compiler/allocation/TestFailedAllocationBadGraph.java
-+++ /dev/null
-@@ -1,80 +0,0 @@
--/*
-- * Copyright (c) 2022, Red Hat, Inc. 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.
-- *
-- * This code is distributed in the hope that it will be useful, but WITHOUT
-- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-- * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
-- * version 2 for more details (a copy is included in the LICENSE file that
-- * accompanied this code).
-- *
-- * You should have received a copy of the GNU General Public License version
-- * 2 along with this work; if not, write to the Free Software Foundation,
-- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
-- *
-- * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
-- * or visit www.oracle.com if you need additional information or have any
-- * questions.
-- */
--
--/*
-- * @test
-- * bug 8279219
-- * @summary C2 crash when allocating array of size too large
-- * @requires vm.compiler2.enabled
-- * @library /test/lib /
-- * @build sun.hotspot.WhiteBox
-- * @run driver jdk.test.lib.helpers.ClassFileInstaller sun.hotspot.WhiteBox
-- * @run main/othervm -ea -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:-BackgroundCompilation TestFailedAllocationBadGraph
-- */
--
--import sun.hotspot.WhiteBox;
--import java.lang.reflect.Method;
--import compiler.whitebox.CompilerWhiteBoxTest;
--
--public class TestFailedAllocationBadGraph {
--    private static final WhiteBox WHITE_BOX = WhiteBox.getWhiteBox();
--
--    private static long[] array;
--    private static int field;
--    private static volatile int barrier;
--
--    public static void main(String[] args) throws Exception {
--        run("test1");
--        run("test2");
--    }
--
--    private static void run(String method) throws Exception {
--        Method m = TestFailedAllocationBadGraph.class.getDeclaredMethod(method);
--        WHITE_BOX.enqueueMethodForCompilation(m, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION);
--        if (!WHITE_BOX.isMethodCompiled(m) || WHITE_BOX.getMethodCompilationLevel(m) != CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION) {
--            throw new RuntimeException("should still be compiled");
--        }
--    }
--
--    private static int test1() {
--        int length = Integer.MAX_VALUE;
--        try {
--            array = new long[length];
--        } catch (OutOfMemoryError outOfMemoryError) {
--            barrier = 0x42;
--            length = field;
--        }
--        return length;
--    }
--
--    private static int test2() {
--        int length = -1;
--        try {
--            array = new long[length];
--        } catch (OutOfMemoryError outOfMemoryError) {
--            barrier = 0x42;
--            length = field;
--        }
--        return length;
--    }
--}