Skip to content

Commit ec13364

Browse files
committed
8343067: C2: revisit constant-offset AddP chains after successful input idealizations
Reviewed-by: kvn, vlivanov
1 parent 5ca6698 commit ec13364

File tree

3 files changed

+73
-3
lines changed

3 files changed

+73
-3
lines changed

src/hotspot/share/opto/phaseX.cpp

Lines changed: 11 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@
2727
#include "gc/shared/c2/barrierSetC2.hpp"
2828
#include "memory/allocation.inline.hpp"
2929
#include "memory/resourceArea.hpp"
30+
#include "opto/addnode.hpp"
3031
#include "opto/block.hpp"
3132
#include "opto/callnode.hpp"
3233
#include "opto/castnode.hpp"
@@ -1634,12 +1635,19 @@ void PhaseIterGVN::add_users_of_use_to_worklist(Node* n, Node* use, Unique_Node_
16341635
}
16351636
}
16361637
}
1637-
// If changed AddP inputs, check Stores for loop invariant
1638-
if( use_op == Op_AddP ) {
1638+
// If changed AddP inputs:
1639+
// - check Stores for loop invariant, and
1640+
// - if the changed input is the offset, check constant-offset AddP users for
1641+
// address expression flattening.
1642+
if (use_op == Op_AddP) {
1643+
bool offset_changed = n == use->in(AddPNode::Offset);
16391644
for (DUIterator_Fast i2max, i2 = use->fast_outs(i2max); i2 < i2max; i2++) {
16401645
Node* u = use->fast_out(i2);
1641-
if (u->is_Mem())
1646+
if (u->is_Mem()) {
16421647
worklist.push(u);
1648+
} else if (offset_changed && u->is_AddP() && u->in(AddPNode::Offset)->is_Con()) {
1649+
worklist.push(u);
1650+
}
16431651
}
16441652
}
16451653
// If changed initialization activity, check dependent Stores
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
/*
2+
* Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation.
8+
*
9+
* This code is distributed in the hope that it will be useful, but WITHOUT
10+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12+
* version 2 for more details (a copy is included in the LICENSE file that
13+
* accompanied this code).
14+
*
15+
* You should have received a copy of the GNU General Public License version
16+
* 2 along with this work; if not, write to the Free Software Foundation,
17+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18+
*
19+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20+
* or visit www.oracle.com if you need additional information or have any
21+
* questions.
22+
*/
23+
package compiler.c2.irTests.igvn;
24+
25+
import compiler.lib.ir_framework.*;
26+
27+
/*
28+
* @test
29+
* @bug 8343067
30+
* @requires os.simpleArch == "x64" | os.simpleArch == "aarch64"
31+
* @requires vm.compiler2.enabled
32+
* @summary Test that chains of AddP nodes with constant offsets are idealized
33+
* when their offset input changes.
34+
* @library /test/lib /
35+
* @run driver compiler.c2.irTests.igvn.TestCombineAddPWithConstantOffsets
36+
*/
37+
public class TestCombineAddPWithConstantOffsets {
38+
39+
public static void main(String[] args) {
40+
TestFramework.run();
41+
}
42+
43+
@Test
44+
@IR(applyIfPlatform = {"x64", "true"}, failOn = {IRNode.ADD_P_OF, ".*"})
45+
@IR(applyIfPlatform = {"aarch64", "true"}, failOn = {IRNode.ADD_P_OF, "reg_imm"})
46+
static void testCombineAddPWithConstantOffsets(int[] arr) {
47+
for (long i = 6; i < 14; i++) {
48+
arr[(int)i] = 1;
49+
}
50+
}
51+
52+
@Run(test = {"testCombineAddPWithConstantOffsets"})
53+
public void runTests() {
54+
testCombineAddPWithConstantOffsets(new int[14]);
55+
}
56+
}

test/hotspot/jtreg/compiler/lib/ir_framework/IRNode.java

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -279,6 +279,12 @@ public class IRNode {
279279
superWordNodes(ADD_REDUCTION_VL, "AddReductionVL");
280280
}
281281

282+
public static final String ADD_P_OF = COMPOSITE_PREFIX + "ADD_P_OF" + POSTFIX;
283+
static {
284+
String regex = START + "addP_" + IS_REPLACED + MID + ".*" + END;
285+
machOnly(ADD_P_OF, regex);
286+
}
287+
282288
public static final String ALLOC = PREFIX + "ALLOC" + POSTFIX;
283289
static {
284290
String optoRegex = "(.*precise .*\\R((.*(?i:mov|mv|xorl|nop|spill).*|\\s*)\\R)*.*(?i:call,static).*wrapper for: C2 Runtime new_instance" + END;

0 commit comments

Comments
 (0)