Skip to content
This repository has been archived by the owner on Aug 16, 2023. It is now read-only.

Commit

Permalink
[GR-30029] Merge tag 'jdk8u292-b09'.
Browse files Browse the repository at this point in the history
PullRequest: graal-jvmci-8/387
  • Loading branch information
marwan-hallaoui committed Apr 5, 2021
2 parents c2a68aa + cda83f6 commit 4b256af
Show file tree
Hide file tree
Showing 7 changed files with 96 additions and 21 deletions.
2 changes: 2 additions & 0 deletions .hgtags
Original file line number Diff line number Diff line change
Expand Up @@ -1412,3 +1412,5 @@ d7c102fe9c4736bca65b25da69093d84da141e65 jdk8u292-b00
16bc2fd11c4c62b01473221b1b6b892a63723e18 jdk8u292-b04
a435c913c8ce30f0487d05cfec1d9be3fcc57f10 jdk8u292-b05
a5795acea81480d6377dbc5256d82e2f25cd7394 jdk8u292-b06
f206e4bfcef993ce5a75ed54612f045ca047abd3 jdk8u292-b07
85c5bc8157df45d7351c388f18ab65297b5bdd01 jdk8u292-b08
2 changes: 1 addition & 1 deletion ci.jsonnet
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@

OpenJDK:: {
local jdk_version = "8u292",
local jdk_build = "07",
local jdk_build = "09",

name+: "-openjdk",
downloads+: {
Expand Down
2 changes: 2 additions & 0 deletions src/cpu/aarch64/vm/c1_FrameMap_aarch64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,8 @@ LIR_Opr FrameMap::map_to_opr(BasicType type, VMRegPair* reg, bool) {
opr = as_oop_opr(reg);
} else if (type == T_METADATA) {
opr = as_metadata_opr(reg);
} else if (type == T_ADDRESS) {
opr = as_address_opr(reg);
} else {
opr = as_opr(reg);
}
Expand Down
4 changes: 2 additions & 2 deletions src/cpu/aarch64/vm/c1_LIRAssembler_aarch64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -791,7 +791,7 @@ void LIR_Assembler::reg2stack(LIR_Opr src, LIR_Opr dest, BasicType type, bool po
if (type == T_ARRAY || type == T_OBJECT) {
__ str(src->as_register(), frame_map()->address_for_slot(dest->single_stack_ix()));
__ verify_oop(src->as_register());
} else if (type == T_METADATA || type == T_DOUBLE) {
} else if (type == T_METADATA || type == T_DOUBLE || type == T_ADDRESS) {
__ str(src->as_register(), frame_map()->address_for_slot(dest->single_stack_ix()));
} else {
__ strw(src->as_register(), frame_map()->address_for_slot(dest->single_stack_ix()));
Expand Down Expand Up @@ -904,7 +904,7 @@ void LIR_Assembler::stack2reg(LIR_Opr src, LIR_Opr dest, BasicType type) {
if (type == T_ARRAY || type == T_OBJECT) {
__ ldr(dest->as_register(), frame_map()->address_for_slot(src->single_stack_ix()));
__ verify_oop(dest->as_register());
} else if (type == T_METADATA) {
} else if (type == T_METADATA || type == T_ADDRESS) {
__ ldr(dest->as_register(), frame_map()->address_for_slot(src->single_stack_ix()));
} else {
__ ldrw(dest->as_register(), frame_map()->address_for_slot(src->single_stack_ix()));
Expand Down
42 changes: 26 additions & 16 deletions src/share/vm/opto/mathexactnode.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2013, 2018, Oracle and/or its affiliates. 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
Expand Down Expand Up @@ -117,23 +117,33 @@ bool OverflowSubLNode::will_overflow(jlong v1, jlong v2) const {
return SubHelper<OverflowSubLNode>::will_overflow(v1, v2);
}

bool OverflowMulLNode::will_overflow(jlong val1, jlong val2) const {
jlong result = val1 * val2;
jlong ax = (val1 < 0 ? -val1 : val1);
jlong ay = (val2 < 0 ? -val2 : val2);

bool overflow = false;
if ((ax | ay) & CONST64(0xFFFFFFFF00000000)) {
// potential overflow if any bit in upper 32 bits are set
if ((val1 == min_jlong && val2 == -1) || (val2 == min_jlong && val1 == -1)) {
// -1 * Long.MIN_VALUE will overflow
overflow = true;
} else if (val2 != 0 && (result / val2 != val1)) {
overflow = true;
}
bool OverflowMulLNode::is_overflow(jlong val1, jlong val2) {
// x * { 0, 1 } will never overflow. Even for x = min_jlong
if (val1 == 0 || val2 == 0 || val1 == 1 || val2 == 1) {
return false;
}

// x * min_jlong for x not in { 0, 1 } overflows
// even -1 as -1 * min_jlong is an overflow
if (val1 == min_jlong || val2 == min_jlong) {
return true;
}

return overflow;
// if (x * y) / y == x there is no overflow
//
// the multiplication here is done as unsigned to avoid undefined behaviour which
// can be used by the compiler to assume that the check further down (result / val2 != val1)
// is always false and breaks the overflow check
julong v1 = (julong) val1;
julong v2 = (julong) val2;
julong tmp = v1 * v2;
jlong result = (jlong) tmp;

if (result / val2 != val1) {
return true;
}

return false;
}

bool OverflowAddINode::can_overflow(const Type* t1, const Type* t2) const {
Expand Down
6 changes: 4 additions & 2 deletions src/share/vm/opto/mathexactnode.hpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2013, 2018, Oracle and/or its affiliates. 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
Expand Down Expand Up @@ -129,8 +129,10 @@ class OverflowMulLNode : public OverflowLNode {
OverflowMulLNode(Node* in1, Node* in2) : OverflowLNode(in1, in2) {}
virtual int Opcode() const;

virtual bool will_overflow(jlong v1, jlong v2) const;
virtual bool will_overflow(jlong v1, jlong v2) const { return is_overflow(v1, v2); }
virtual bool can_overflow(const Type* t1, const Type* t2) const;

static bool is_overflow(jlong v1, jlong v2);
};

#endif
Expand Down
59 changes: 59 additions & 0 deletions test/compiler/intrinsics/mathexact/LongMulOverflowTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
/*
* Copyright (c) 2018, Oracle and/or its affiliates. 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 8191915
* @summary Regression test for multiplyExact intrinsic
* @compile LongMulOverflowTest.java
* @run main/othervm -Xcomp -XX:-TieredCompilation LongMulOverflowTest
*/

public class LongMulOverflowTest {
public static void main(String[] args) {
LongMulOverflowTest test = new LongMulOverflowTest();
for (int i = 0; i < 10; ++i) {
try {
test.runTest();
throw new RuntimeException("Error, runTest() did not overflow!");
} catch (ArithmeticException e) {
// success
}

try {
test.runTestOverflow();
throw new RuntimeException("Error, runTestOverflow() did not overflow!");
} catch (ArithmeticException e) {
// success
}
}
}

public void runTest() {
java.lang.Math.multiplyExact(Long.MIN_VALUE, 7);
}

public void runTestOverflow() {
java.lang.Math.multiplyExact((Long.MAX_VALUE / 2) + 1, 2);
}
}

0 comments on commit 4b256af

Please sign in to comment.