diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/458-checker-instruction-simplification/src/Main.java | 4 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/build | 46 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/expected.txt | 0 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/info.txt | 2 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/run | 18 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/src/Main.java | 41 | ||||
| -rw-r--r-- | test/555-checker-regression-x86const/src/Unresolved.java | 18 | ||||
| -rw-r--r-- | test/565-checker-condition-liveness/src/Main.java | 18 |
8 files changed, 145 insertions, 2 deletions
diff --git a/test/458-checker-instruction-simplification/src/Main.java b/test/458-checker-instruction-simplification/src/Main.java index 3c8abeb841..2f80470cb3 100644 --- a/test/458-checker-instruction-simplification/src/Main.java +++ b/test/458-checker-instruction-simplification/src/Main.java @@ -1404,7 +1404,7 @@ public class Main { /// CHECK-START: int Main.floatConditionNotEqualOne(float) ssa_builder (after) /// CHECK: LessThanOrEqual - /// CHECK-START: int Main.floatConditionNotEqualOne(float) register (before) + /// CHECK-START: int Main.floatConditionNotEqualOne(float) instruction_simplifier_before_codegen (after) /// CHECK-DAG: <<Arg:f\d+>> ParameterValue /// CHECK-DAG: <<Const13:i\d+>> IntConstant 13 /// CHECK-DAG: <<Const54:i\d+>> IntConstant 54 @@ -1420,7 +1420,7 @@ public class Main { /// CHECK-START: int Main.doubleConditionEqualZero(double) ssa_builder (after) /// CHECK: LessThanOrEqual - /// CHECK-START: int Main.doubleConditionEqualZero(double) register (before) + /// CHECK-START: int Main.doubleConditionEqualZero(double) instruction_simplifier_before_codegen (after) /// CHECK-DAG: <<Arg:d\d+>> ParameterValue /// CHECK-DAG: <<Const13:i\d+>> IntConstant 13 /// CHECK-DAG: <<Const54:i\d+>> IntConstant 54 diff --git a/test/555-checker-regression-x86const/build b/test/555-checker-regression-x86const/build new file mode 100644 index 0000000000..09dcc363dd --- /dev/null +++ b/test/555-checker-regression-x86const/build @@ -0,0 +1,46 @@ +#!/bin/bash +# +# 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. + +# Stop if something fails. +set -e + +# We can't use src-ex testing infrastructure because src and src-ex are compiled +# with javac independetely and can't share code (without reflection). + +mkdir classes +${JAVAC} -d classes `find src -name '*.java'` + +mkdir classes-ex +mv classes/UnresolvedClass.class classes-ex + +if [ ${USE_JACK} = "true" ]; then + # Create .jack files from classes generated with javac. + ${JILL} classes --output classes.jack + ${JILL} classes-ex --output classes-ex.jack + + # Create DEX files from .jack files. + ${JACK} --import classes.jack --output-dex . + zip $TEST_NAME.jar classes.dex + ${JACK} --import classes-ex.jack --output-dex . + zip ${TEST_NAME}-ex.jar classes.dex +else + if [ ${NEED_DEX} = "true" ]; then + ${DX} -JXmx256m --debug --dex --dump-to=classes.lst --output=classes.dex --dump-width=1000 classes + zip $TEST_NAME.jar classes.dex + ${DX} -JXmx256m --debug --dex --dump-to=classes-ex.lst --output=classes.dex --dump-width=1000 classes-ex + zip ${TEST_NAME}-ex.jar classes.dex + fi +fi diff --git a/test/555-checker-regression-x86const/expected.txt b/test/555-checker-regression-x86const/expected.txt new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/test/555-checker-regression-x86const/expected.txt diff --git a/test/555-checker-regression-x86const/info.txt b/test/555-checker-regression-x86const/info.txt new file mode 100644 index 0000000000..c4037fa88f --- /dev/null +++ b/test/555-checker-regression-x86const/info.txt @@ -0,0 +1,2 @@ +Check that X86 FP constant-area handling handles intrinsics with CurrentMethod +on the call. diff --git a/test/555-checker-regression-x86const/run b/test/555-checker-regression-x86const/run new file mode 100644 index 0000000000..63fdb8c749 --- /dev/null +++ b/test/555-checker-regression-x86const/run @@ -0,0 +1,18 @@ +#!/bin/bash +# +# 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. + +# Use secondary switch to add secondary dex file to class path. +exec ${RUN} "${@}" --secondary diff --git a/test/555-checker-regression-x86const/src/Main.java b/test/555-checker-regression-x86const/src/Main.java new file mode 100644 index 0000000000..914cfde74f --- /dev/null +++ b/test/555-checker-regression-x86const/src/Main.java @@ -0,0 +1,41 @@ +/* + * Copyright (C) 2016 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 extends UnresolvedClass { + + /// CHECK-START: float Main.callAbs(float) register (before) + /// CHECK: <<CurrentMethod:[ij]\d+>> CurrentMethod + /// CHECK: <<ParamValue:f\d+>> ParameterValue + /// CHECK: InvokeStaticOrDirect [<<ParamValue>>,<<CurrentMethod>>] method_name:java.lang.Math.abs + static public float callAbs(float f) { + // An intrinsic invoke in a method that has unresolved references will still + // have a CurrentMethod as an argument. The X86 pc_relative_fixups_x86 pass + // must be able to handle Math.abs invokes that have a CurrentMethod, as both + // the CurrentMethod and the HX86LoadFromConstantTable (for the bitmask) + // expect to be in the 'SpecialInputIndex' input index. + return Math.abs(f); + } + + static public void main(String[] args) { + expectEquals(callAbs(-6.5f), 6.5f); + } + + public static void expectEquals(float expected, float result) { + if (expected != result) { + throw new Error("Expected: " + expected + ", found: " + result); + } + } +} diff --git a/test/555-checker-regression-x86const/src/Unresolved.java b/test/555-checker-regression-x86const/src/Unresolved.java new file mode 100644 index 0000000000..e98bdbf8fb --- /dev/null +++ b/test/555-checker-regression-x86const/src/Unresolved.java @@ -0,0 +1,18 @@ +/* + * Copyright (C) 2016 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 UnresolvedClass { +} diff --git a/test/565-checker-condition-liveness/src/Main.java b/test/565-checker-condition-liveness/src/Main.java index a811e5bb16..dc4cb76258 100644 --- a/test/565-checker-condition-liveness/src/Main.java +++ b/test/565-checker-condition-liveness/src/Main.java @@ -16,6 +16,24 @@ public class Main { + /// CHECK-START-X86: int Main.p(float) liveness (after) + /// CHECK: <<Arg:f\d+>> ParameterValue uses:[<<UseInput:\d+>>] + /// CHECK-DAG: <<Five:f\d+>> FloatConstant 5 uses:[<<UseInput>>] + /// CHECK-DAG: <<Zero:i\d+>> IntConstant 0 + /// CHECK-DAG: <<MinusOne:i\d+>> IntConstant -1 uses:[<<UseInput>>] + /// CHECK: <<Base:i\d+>> X86ComputeBaseMethodAddress uses:[<<UseInput>>] + /// CHECK-NEXT: <<Load:f\d+>> X86LoadFromConstantTable [<<Base>>,<<Five>>] + /// CHECK-NEXT: <<Cond:z\d+>> LessThanOrEqual [<<Arg>>,<<Load>>] + /// CHECK-NEXT: Select [<<Zero>>,<<MinusOne>>,<<Cond>>] liveness:<<LivSel:\d+>> + /// CHECK-EVAL: <<UseInput>> == <<LivSel>> + 1 + + public static int p(float arg) { + if (arg > 5.0f) { + return 0; + } + return -1; + } + /// CHECK-START: void Main.main(java.lang.String[]) liveness (after) /// CHECK: <<X:i\d+>> ArrayLength uses:[<<UseInput:\d+>>] /// CHECK: <<Y:i\d+>> StaticFieldGet uses:[<<UseInput>>] |