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