ART: Don't duplicate null/int/long constants when inlining
Change-Id: I7e6a3393fcbbcf76b4ba2000915ba6bbbfb7c70e
diff --git a/compiler/optimizing/nodes.cc b/compiler/optimizing/nodes.cc
index d8a8554..c1e2351 100644
--- a/compiler/optimizing/nodes.cc
+++ b/compiler/optimizing/nodes.cc
@@ -971,7 +971,14 @@
int parameter_index = 0;
for (HInstructionIterator it(entry_block_->GetInstructions()); !it.Done(); it.Advance()) {
HInstruction* current = it.Current();
- if (current->IsConstant()) {
+ if (current->IsNullConstant()) {
+ current->ReplaceWith(outer_graph->GetNullConstant());
+ } else if (current->IsIntConstant()) {
+ current->ReplaceWith(outer_graph->GetIntConstant(current->AsIntConstant()->GetValue()));
+ } else if (current->IsLongConstant()) {
+ current->ReplaceWith(outer_graph->GetLongConstant(current->AsLongConstant()->GetValue()));
+ } else if (current->IsFloatConstant() || current->IsDoubleConstant()) {
+ // TODO: Don't duplicate floating-point constants.
current->MoveBefore(outer_graph->GetEntryBlock()->GetLastInstruction());
} else if (current->IsParameterValue()) {
current->ReplaceWith(invoke->InputAt(parameter_index++));
diff --git a/test/473-checker-inliner-constants/expected.txt b/test/473-checker-inliner-constants/expected.txt
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/test/473-checker-inliner-constants/expected.txt
diff --git a/test/473-checker-inliner-constants/info.txt b/test/473-checker-inliner-constants/info.txt
new file mode 100644
index 0000000..e8e1ffb
--- /dev/null
+++ b/test/473-checker-inliner-constants/info.txt
@@ -0,0 +1 @@
+Test whether inliner deduplicates constants.
\ No newline at end of file
diff --git a/test/473-checker-inliner-constants/src/Main.java b/test/473-checker-inliner-constants/src/Main.java
new file mode 100644
index 0000000..79d89b0
--- /dev/null
+++ b/test/473-checker-inliner-constants/src/Main.java
@@ -0,0 +1,76 @@
+/*
+* Copyright (C) 2015 The Android Open Source Project
+*
+* Licensed under the Apache License, Version 2.0 (the "License");
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/licenses/LICENSE-2.0
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an "AS IS" BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*/
+
+public class Main {
+
+ // CHECK-START: java.lang.Object Main.InlineNullConstant() inliner (before)
+ // CHECK: NullConstant
+ // CHECK-NOT: NullConstant
+
+ // CHECK-START: java.lang.Object Main.InlineNullConstant() inliner (after)
+ // CHECK: NullConstant
+ // CHECK-NOT: NullConstant
+
+ public static Object returnNullConstant(Object x) {
+ return null;
+ }
+
+ public static Object InlineNullConstant() {
+ return returnNullConstant(null);
+ }
+
+ // CHECK-START: int Main.InlineIntConstant() inliner (before)
+ // CHECK: IntConstant 42
+ // CHECK-NOT: IntConstant 42
+
+ // CHECK-START: int Main.InlineIntConstant() inliner (after)
+ // CHECK: IntConstant 42
+ // CHECK-NOT: IntConstant 42
+
+ public static int returnIntConstant(int x) {
+ return 42;
+ }
+
+ public static int InlineIntConstant() {
+ return returnIntConstant(42);
+ }
+
+ // CHECK-START: long Main.InlineLongConstant() inliner (before)
+ // CHECK: LongConstant 42
+ // CHECK-NOT: LongConstant 42
+
+ // CHECK-START: long Main.InlineLongConstant() inliner (after)
+ // CHECK: LongConstant 42
+ // CHECK-NOT: LongConstant 42
+
+ public static long returnLongConstant(long x) {
+ return 42L;
+ }
+
+ public static long InlineLongConstant() {
+ return returnLongConstant(42L);
+ }
+
+ public static void main(String[] args) {
+ if (InlineNullConstant() != null) {
+ throw new Error("Expected null");
+ } else if (InlineIntConstant() != 42) {
+ throw new Error("Expected int 42");
+ } else if (InlineLongConstant() != 42L) {
+ throw new Error("Expected long 42");
+ }
+ }
+}