Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/optimizer/J9CFGSimplifier.hpp
6000 views
1
/*******************************************************************************
2
* Copyright (c) 2019, 2019 IBM Corp. and others
3
*
4
* This program and the accompanying materials are made available under
5
* the terms of the Eclipse Public License 2.0 which accompanies this
6
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
7
* or the Apache License, Version 2.0 which accompanies this distribution and
8
* is available at https://www.apache.org/licenses/LICENSE-2.0.
9
*
10
* This Source Code may also be made available under the following
11
* Secondary Licenses when the conditions for such availability set
12
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
13
* General Public License, version 2 with the GNU Classpath
14
* Exception [1] and GNU General Public License, version 2 with the
15
* OpenJDK Assembly Exception [2].
16
*
17
* [1] https://www.gnu.org/software/classpath/license.html
18
* [2] http://openjdk.java.net/legal/assembly-exception.html
19
*
20
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
21
*******************************************************************************/
22
23
#ifndef J9_CFGSIMPLIFIER_INCL
24
#define J9_CFGSIMPLIFIER_INCL
25
26
#include "optimizer/OMRCFGSimplifier.hpp"
27
28
namespace J9
29
{
30
31
// Performs local common subexpression elimination within
32
// a basic block.
33
//
34
35
class CFGSimplifier : public OMR::CFGSimplifier
36
{
37
public:
38
39
CFGSimplifier(TR::OptimizationManager *manager) : OMR::CFGSimplifier(manager)
40
{}
41
42
protected:
43
/**
44
* \brief
45
* This virtual function calls individual routines to try to match different `if` control flow structures
46
* for simplification.
47
*
48
* \parm needToDuplicateTree
49
* Boolean to indicate whether or not to duplicate node.
50
*
51
* \return Boolean that indicates whether tranformation is performed based on a matched pattern
52
*/
53
virtual bool simplifyIfPatterns(bool needToDuplicateTree);
54
55
/**
56
* \brief
57
* This function tries to match an `ifacmpeq/ifacmpne` of NULL node with a throw of an NPE exception
58
* for the unresolved case and replace with a NULLCHK node
59
*
60
* \parm needToDuplicateTree
61
* Boolean to indicate whether or not to duplicate node.
62
*
63
* \return Boolean that indicates true if tranformation is performed based on a matched pattern.
64
*/
65
bool simplifyUnresolvedRequireNonNull(bool needToDuplicateTree);
66
67
/**
68
* \brief
69
* This function tries to match an `ifacmpeq/ifacmpne` of NULL node with a throw of an NPE exception
70
* for the resolved case and replace with a NULLCHK node
71
*
72
* \parm needToDuplicateTree
73
* Boolean to indicate whether or not to duplicate node.
74
*
75
* \return Boolean that indicates true if tranformation is performed based on a matched pattern.
76
*/
77
bool simplifyResolvedRequireNonNull(bool needToDuplicateTree);
78
79
};
80
81
}
82
83
#endif
84
85