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");
+    }
+  }
+}