1232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain/* 2232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * Copyright (C) 2014 The Android Open Source Project 3232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * 4232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * Licensed under the Apache License, Version 2.0 (the "License"); 5232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * you may not use this file except in compliance with the License. 6232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * You may obtain a copy of the License at 7232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * 8232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * http://www.apache.org/licenses/LICENSE-2.0 9232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * 10232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * Unless required by applicable law or agreed to in writing, software 11232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * distributed under the License is distributed on an "AS IS" BASIS, 12232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * See the License for the specific language governing permissions and 14232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain * limitations under the License. 15232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain */ 16232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain 17232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain// Note that $opt$ is a marker for the optimizing compiler to ensure 18232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain// it does compile the method. 19232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillainpublic class Main { 20232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain 21232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain public static void assertFloatEquals(float expected, float result) { 22232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain if (expected != result) { 23232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain throw new Error("Expected: " + expected + ", found: " + result); 24232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain } 25232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain } 26232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain 27232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain public static void main(String[] args) { 28232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain // Generate, compile and check long-to-float Dex instructions. 29232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain longToFloat(); 30232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain } 31232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain 32232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain private static void longToFloat() { 33232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain // The result for this test case is slightly less accurate on ARM, 34232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain // due to the implementation of long-to-float type conversions for 35232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain // this architecture (both in Quick and Optimizing). 36232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain assertFloatEquals(Float.intBitsToFloat(-555858671), $opt$LongToFloat(-8008112895877447681L)); 37232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain } 38232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain 39232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain // This method produces a long-to-float Dex instruction. 40232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain static float $opt$LongToFloat(long a) { return (float)a; } 41232ade0b9401404ad4b61b1003551b58b96195a8Roland Levillain} 42