summaryrefslogtreecommitdiffstats
path: root/test/479-regression-implicit-null-check
diff options
context:
space:
mode:
authorCalin Juravle <calin@google.com>2015-04-21 22:08:51 +0100
committerCalin Juravle <calin@google.com>2015-04-22 11:40:25 +0100
commit641547a5f18ca2ea54469cceadcfef64f132e5e0 (patch)
tree441e325fc9bea377c549101756d9e8dc68f95779 /test/479-regression-implicit-null-check
parent296c6cc2e5e90a81bdfc5f5486eae6b64d80e595 (diff)
downloadart-641547a5f18ca2ea54469cceadcfef64f132e5e0.zip
art-641547a5f18ca2ea54469cceadcfef64f132e5e0.tar.gz
art-641547a5f18ca2ea54469cceadcfef64f132e5e0.tar.bz2
[optimizing] Fix a bug in moving the null check to the user.
When taking the decision to move a null check to the user we did not verify if the next instruction checks the same object. Change-Id: I2f4533a4bb18aa4b0b6d5e419f37dcccd60354d2
Diffstat (limited to 'test/479-regression-implicit-null-check')
-rw-r--r--test/479-regression-implicit-null-check/expected.txt0
-rw-r--r--test/479-regression-implicit-null-check/info.txt2
-rw-r--r--test/479-regression-implicit-null-check/src/Main.java50
3 files changed, 52 insertions, 0 deletions
diff --git a/test/479-regression-implicit-null-check/expected.txt b/test/479-regression-implicit-null-check/expected.txt
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/test/479-regression-implicit-null-check/expected.txt
diff --git a/test/479-regression-implicit-null-check/info.txt b/test/479-regression-implicit-null-check/info.txt
new file mode 100644
index 0000000..0bfca8c
--- /dev/null
+++ b/test/479-regression-implicit-null-check/info.txt
@@ -0,0 +1,2 @@
+Tests a regression in which we moved the null check to an instruction which
+checked a different object. This lead to valid null checks being elided.
diff --git a/test/479-regression-implicit-null-check/src/Main.java b/test/479-regression-implicit-null-check/src/Main.java
new file mode 100644
index 0000000..6b6f2e4
--- /dev/null
+++ b/test/479-regression-implicit-null-check/src/Main.java
@@ -0,0 +1,50 @@
+/*
+* 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 {
+ public int x = 0;
+
+ public Main(Main c) {
+ // After inlining the graph will look like:
+ // NullCheck c
+ // InstanceFieldGet c
+ // InstanceFieldSet this 3
+ // The dead code will eliminate the InstanceFieldGet and we'll end up with:
+ // NullCheck c
+ // InstanceFieldSet this 3
+ // At codegen, when verifying if we can move the null check to the user,
+ // we should check that we actually have the same user (not only that the
+ // next instruction can do implicit null checks).
+ // In this case we should generate code for the NullCheck since the next
+ // instruction checks a different object.
+ c.willBeInlined();
+ x = 3;
+ }
+
+ private int willBeInlined() {
+ return x;
+ }
+
+ public static void main(String[] args) {
+ try {
+ new Main(null);
+ throw new RuntimeException("Failed to throw NullPointerException");
+ } catch (NullPointerException e) {
+ // expected
+ }
+ }
+}