Skip to content
This repository has been archived by the owner on Jul 17, 2024. It is now read-only.
/ jdk22u Public archive

Commit

Permalink
8328822: C2: "negative trip count?" assert failure in profile predica…
Browse files Browse the repository at this point in the history
…te code

Backport-of: 2ceeb6c00135310b7bdabacb92d26d81de525240
  • Loading branch information
shipilev committed May 7, 2024
1 parent beb06e1 commit e77a047
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/hotspot/share/opto/loopPredicate.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -956,7 +956,7 @@ bool PhaseIdealLoop::loop_predication_should_follow_branches(IdealLoopTree* loop
CountedLoopNode* cl = head->as_CountedLoop();
if (cl->phi() != nullptr) {
const TypeInt* t = _igvn.type(cl->phi())->is_int();
float worst_case_trip_cnt = ((float)t->_hi - t->_lo) / ABS(cl->stride_con());
float worst_case_trip_cnt = ((float)t->_hi - t->_lo) / ABS((float)cl->stride_con());
if (worst_case_trip_cnt < loop_trip_cnt) {
loop_trip_cnt = worst_case_trip_cnt;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
/*
* Copyright (c) 2024, 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 8328822
* @summary C2: "negative trip count?" assert failure in profile predicate code
* @run main/othervm -XX:-BackgroundCompilation TestCountedLoopMinJintStride
*/

import java.util.Objects;

public class TestCountedLoopMinJintStride {
public static void main(String[] args) {
for (int i = 0; i < 20_000; i++) {
test1(Integer.MAX_VALUE-1, Integer.MAX_VALUE, 0);
testHelper1(100, -1, Integer.MAX_VALUE, 0);
test2(Integer.MAX_VALUE-1, Integer.MAX_VALUE, 0);
testHelper2(100, -1, Integer.MAX_VALUE, 0);
}
}

private static void test1(int stop, int range, int start) {
testHelper1(stop, Integer.MIN_VALUE, range, start);
}

private static void testHelper1(int stop, int stride, int range, int start) {
for (int i = stop; i >= start; i += stride) {
Objects.checkIndex(i, range);
}
}

private static void test2(int stop, int range, int start) {
testHelper1(stop, Integer.MIN_VALUE, range, start);
}

private static void testHelper2(int stop, int stride, int range, int start) {
for (int i = stop; i >= start; i += stride) {
if (i < 0 || i >= range) {
throw new RuntimeException("out of bounds");
}
}
}
}

1 comment on commit e77a047

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.