2013-09-27 08:39:19 +02:00
|
|
|
/*
|
2019-01-10 15:13:51 -05:00
|
|
|
* Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved.
|
2013-09-27 08:39:19 +02:00
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-01-10 15:13:51 -05:00
|
|
|
#ifndef SHARE_OPTO_MATHEXACTNODE_HPP
|
|
|
|
#define SHARE_OPTO_MATHEXACTNODE_HPP
|
2013-09-27 08:39:19 +02:00
|
|
|
|
|
|
|
#include "opto/multnode.hpp"
|
|
|
|
#include "opto/node.hpp"
|
2014-01-23 12:08:28 +01:00
|
|
|
#include "opto/addnode.hpp"
|
2013-10-11 12:06:14 +02:00
|
|
|
#include "opto/subnode.hpp"
|
2013-09-27 08:39:19 +02:00
|
|
|
#include "opto/type.hpp"
|
|
|
|
|
|
|
|
class PhaseGVN;
|
|
|
|
class PhaseTransform;
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowNode : public CmpNode {
|
2013-09-27 08:39:19 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
OverflowNode(Node* in1, Node* in2) : CmpNode(in1, in2) {}
|
2013-09-27 08:39:19 +02:00
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
virtual uint ideal_reg() const { return Op_RegFlags; }
|
|
|
|
virtual const Type* sub(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowINode : public OverflowNode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef TypeInt TypeClass;
|
2013-09-27 08:39:19 +02:00
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
OverflowINode(Node* in1, Node* in2) : OverflowNode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual Node* Ideal(PhaseGVN* phase, bool can_reshape);
|
2016-01-12 12:55:09 +01:00
|
|
|
virtual const Type* Value(PhaseGVN* phase) const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jint v1, jint v2) const = 0;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const = 0;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
class OverflowLNode : public OverflowNode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef TypeLong TypeClass;
|
|
|
|
|
|
|
|
OverflowLNode(Node* in1, Node* in2) : OverflowNode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual Node* Ideal(PhaseGVN* phase, bool can_reshape);
|
2016-01-12 12:55:09 +01:00
|
|
|
virtual const Type* Value(PhaseGVN* phase) const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jlong v1, jlong v2) const = 0;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const = 0;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowAddINode : public OverflowINode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef AddINode MathOp;
|
|
|
|
|
|
|
|
OverflowAddINode(Node* in1, Node* in2) : OverflowINode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual int Opcode() const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jint v1, jint v2) const;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowSubINode : public OverflowINode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef SubINode MathOp;
|
|
|
|
|
|
|
|
OverflowSubINode(Node* in1, Node* in2) : OverflowINode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual int Opcode() const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jint v1, jint v2) const;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowMulINode : public OverflowINode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef MulINode MathOp;
|
|
|
|
|
|
|
|
OverflowMulINode(Node* in1, Node* in2) : OverflowINode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual int Opcode() const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jint v1, jint v2) const;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowAddLNode : public OverflowLNode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef AddLNode MathOp;
|
|
|
|
|
|
|
|
OverflowAddLNode(Node* in1, Node* in2) : OverflowLNode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual int Opcode() const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jlong v1, jlong v2) const;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowSubLNode : public OverflowLNode {
|
2013-10-18 10:41:56 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef SubLNode MathOp;
|
|
|
|
|
|
|
|
OverflowSubLNode(Node* in1, Node* in2) : OverflowLNode(in1, in2) {}
|
2013-10-18 10:41:56 +02:00
|
|
|
virtual int Opcode() const;
|
2014-01-23 12:08:28 +01:00
|
|
|
|
|
|
|
virtual bool will_overflow(jlong v1, jlong v2) const;
|
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2013-10-18 10:41:56 +02:00
|
|
|
};
|
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
class OverflowMulLNode : public OverflowLNode {
|
2013-09-27 08:39:19 +02:00
|
|
|
public:
|
2014-01-23 12:08:28 +01:00
|
|
|
typedef MulLNode MathOp;
|
2013-09-27 08:39:19 +02:00
|
|
|
|
2014-01-23 12:08:28 +01:00
|
|
|
OverflowMulLNode(Node* in1, Node* in2) : OverflowLNode(in1, in2) {}
|
2013-09-27 08:39:19 +02:00
|
|
|
virtual int Opcode() const;
|
|
|
|
|
2018-01-18 19:21:11 +01:00
|
|
|
virtual bool will_overflow(jlong v1, jlong v2) const { return is_overflow(v1, v2); }
|
2014-01-23 12:08:28 +01:00
|
|
|
virtual bool can_overflow(const Type* t1, const Type* t2) const;
|
2018-01-18 19:21:11 +01:00
|
|
|
|
|
|
|
static bool is_overflow(jlong v1, jlong v2);
|
2014-01-23 12:08:28 +01:00
|
|
|
};
|
2013-09-27 08:39:19 +02:00
|
|
|
|
2019-01-10 15:13:51 -05:00
|
|
|
#endif // SHARE_OPTO_MATHEXACTNODE_HPP
|