diff options
| author | 2015-04-21 16:09:29 +0000 | |
|---|---|---|
| committer | 2015-04-21 16:09:30 +0000 | |
| commit | 4bb014fd8e0aa45b012d56bc4813f18fa295d2b0 (patch) | |
| tree | ba5fa5beef6e2c4a91ec5bbe7b0ed81b168b4958 /test | |
| parent | d677de20906067061f262bdd434536a02e7f0dd0 (diff) | |
| parent | 232ade0b9401404ad4b61b1003551b58b96195a8 (diff) | |
Merge "Revert "Revert "Optimizing: Fix long-to-fp conversion on x86."""
Diffstat (limited to 'test')
| -rw-r--r-- | test/477-long-to-float-conversion-precision/expected.txt | 0 | ||||
| -rw-r--r-- | test/477-long-to-float-conversion-precision/info.txt | 1 | ||||
| -rw-r--r-- | test/477-long-to-float-conversion-precision/src/Main.java | 41 | ||||
| -rw-r--r-- | test/Android.run-test.mk | 13 |
4 files changed, 55 insertions, 0 deletions
diff --git a/test/477-long-to-float-conversion-precision/expected.txt b/test/477-long-to-float-conversion-precision/expected.txt new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/test/477-long-to-float-conversion-precision/expected.txt diff --git a/test/477-long-to-float-conversion-precision/info.txt b/test/477-long-to-float-conversion-precision/info.txt new file mode 100644 index 0000000000..d9d41d70ba --- /dev/null +++ b/test/477-long-to-float-conversion-precision/info.txt @@ -0,0 +1 @@ +Tests for type conversions precision. diff --git a/test/477-long-to-float-conversion-precision/src/Main.java b/test/477-long-to-float-conversion-precision/src/Main.java new file mode 100644 index 0000000000..bc17053e20 --- /dev/null +++ b/test/477-long-to-float-conversion-precision/src/Main.java @@ -0,0 +1,41 @@ +/* + * Copyright (C) 2014 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. + */ + +// Note that $opt$ is a marker for the optimizing compiler to ensure +// it does compile the method. +public class Main { + + public static void assertFloatEquals(float expected, float result) { + if (expected != result) { + throw new Error("Expected: " + expected + ", found: " + result); + } + } + + public static void main(String[] args) { + // Generate, compile and check long-to-float Dex instructions. + longToFloat(); + } + + private static void longToFloat() { + // The result for this test case is slightly less accurate on ARM, + // due to the implementation of long-to-float type conversions for + // this architecture (both in Quick and Optimizing). + assertFloatEquals(Float.intBitsToFloat(-555858671), $opt$LongToFloat(-8008112895877447681L)); + } + + // This method produces a long-to-float Dex instruction. + static float $opt$LongToFloat(long a) { return (float)a; } +} diff --git a/test/Android.run-test.mk b/test/Android.run-test.mk index 39afc6785b..731c040027 100644 --- a/test/Android.run-test.mk +++ b/test/Android.run-test.mk @@ -335,6 +335,19 @@ endif TEST_ART_BROKEN_DEFAULT_RUN_TESTS := +# Known broken tests for Quick's and Optimizing's ARM back ends. +TEST_ART_BROKEN_ARM_RUN_TESTS := 477-long-to-float-conversion-precision # b/20413424 + +ifeq ($(TARGET_ARCH),arm) + ifneq (,$(filter 32,$(ALL_ADDRESS_SIZES))) + ART_TEST_KNOWN_BROKEN += $(call all-run-test-names,target,$(RUN_TYPES),$(PREBUILD_TYPES), \ + $(COMPILER_TYPES),$(RELOCATE_TYPES),$(TRACE_TYPES),$(GC_TYPES),$(JNI_TYPES), \ + $(IMAGE_TYPES),$(PICTEST_TYPES),$(DEBUGGABLE_TYPES),$(TEST_ART_BROKEN_ARM_RUN_TESTS),32) + endif +endif + +TEST_ART_BROKEN_ARM_RUN_TESTS := + # Known broken tests for the arm64 optimizing compiler backend. TEST_ART_BROKEN_OPTIMIZING_ARM64_RUN_TESTS := |