52 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
| /*
 | |
|  * Copyright (C) 2012 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.
 | |
|  */
 | |
| 
 | |
| #include "math_entrypoints.h"
 | |
| 
 | |
| #include "entrypoint_utils-inl.h"
 | |
| 
 | |
| namespace art {
 | |
| 
 | |
| extern "C" double art_l2d(int64_t l) {
 | |
|   return static_cast<double>(l);
 | |
| }
 | |
| 
 | |
| extern "C" float art_l2f(int64_t l) {
 | |
|   return static_cast<float>(l);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Float/double conversion requires clamping to min and max of integer form.  If
 | |
|  * target doesn't support this normally, use these.
 | |
|  */
 | |
| extern "C" int64_t art_d2l(double d) {
 | |
|   return art_float_to_integral<int64_t, double>(d);
 | |
| }
 | |
| 
 | |
| extern "C" int64_t art_f2l(float f) {
 | |
|   return art_float_to_integral<int64_t, float>(f);
 | |
| }
 | |
| 
 | |
| extern "C" int32_t art_d2i(double d) {
 | |
|   return art_float_to_integral<int32_t, double>(d);
 | |
| }
 | |
| 
 | |
| extern "C" int32_t art_f2i(float f) {
 | |
|   return art_float_to_integral<int32_t, float>(f);
 | |
| }
 | |
| 
 | |
| }  // namespace art
 |