diff options
author | David Brazdil <dbrazdil@google.com> | 2015-06-18 12:40:01 +0100 |
---|---|---|
committer | David Brazdil <dbrazdil@google.com> | 2015-06-19 09:49:23 +0100 |
commit | dd3c7d2d6124ceb346b4ed9aa7115f75fc6d3f9f (patch) | |
tree | 705982e99c6a071b0337b63658cf071a8a212c2a /test | |
parent | 122349a7672da6636ca94aded7f2d3642f9962e3 (diff) | |
download | art-dd3c7d2d6124ceb346b4ed9aa7115f75fc6d3f9f.zip art-dd3c7d2d6124ceb346b4ed9aa7115f75fc6d3f9f.tar.gz art-dd3c7d2d6124ceb346b4ed9aa7115f75fc6d3f9f.tar.bz2 |
ART: Remove old DCHECK that trips Baseline
Codegen verified that the entry block always falls through to the next
block. While this is the case with Optimizing, it doesn't hold for
Baseline but it doesn't need to since codegen handles it fine.
Bug:21913514
Change-Id: I751ef227e6cf103af3e7fc35fca4b01c663385a1
(cherry picked from commit 015c7e63604c038e866d7af3850c557403cddc8b)
Diffstat (limited to 'test')
-rw-r--r-- | test/504-regression-baseline-entry/expected.txt | 0 | ||||
-rw-r--r-- | test/504-regression-baseline-entry/info.txt | 2 | ||||
-rw-r--r-- | test/504-regression-baseline-entry/smali/Test.smali | 30 | ||||
-rw-r--r-- | test/504-regression-baseline-entry/src/Main.java | 33 |
4 files changed, 65 insertions, 0 deletions
diff --git a/test/504-regression-baseline-entry/expected.txt b/test/504-regression-baseline-entry/expected.txt new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/test/504-regression-baseline-entry/expected.txt diff --git a/test/504-regression-baseline-entry/info.txt b/test/504-regression-baseline-entry/info.txt new file mode 100644 index 0000000..26cc9ce --- /dev/null +++ b/test/504-regression-baseline-entry/info.txt @@ -0,0 +1,2 @@ +Regression test for the baseline compiler which required the entry block to fall +through to the next block.
\ No newline at end of file diff --git a/test/504-regression-baseline-entry/smali/Test.smali b/test/504-regression-baseline-entry/smali/Test.smali new file mode 100644 index 0000000..06412e7 --- /dev/null +++ b/test/504-regression-baseline-entry/smali/Test.smali @@ -0,0 +1,30 @@ +# +# 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. + +.class public LTest; + +.super Ljava/lang/Object; + +.method public static SingleGotoStart()I + .registers 1 + goto :second + + :first + return v0 + + :second + const/4 v0, 0x5 + goto :first +.end method diff --git a/test/504-regression-baseline-entry/src/Main.java b/test/504-regression-baseline-entry/src/Main.java new file mode 100644 index 0000000..2c9df28 --- /dev/null +++ b/test/504-regression-baseline-entry/src/Main.java @@ -0,0 +1,33 @@ +/* + * 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. + */ + +import java.lang.reflect.Method; +import java.lang.reflect.Type; + +public class Main { + + // Workaround for b/18051191. + class InnerClass {} + + public static void main(String args[]) throws Exception { + Class<?> c = Class.forName("Test"); + Method m = c.getMethod("SingleGotoStart", (Class[]) null); + Integer result = (Integer) m.invoke(null); + if (result != 5) { + throw new Error("Expected 5, got " + result); + } + } +} |