mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-26 19:16:41 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			37 lines
		
	
	
	
		
			905 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			905 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* clang-format off */
 | |
| /*===-- powisf2.cpp - Implement __powisf2 ---------------------------------===
 | |
|  *
 | |
|  *                    The LLVM Compiler Infrastructure
 | |
|  *
 | |
|  * This file is dual licensed under the MIT and the University of Illinois Open
 | |
|  * Source Licenses. See LICENSE.TXT for details.
 | |
|  *
 | |
|  * ===----------------------------------------------------------------------===
 | |
|  *
 | |
|  * This file implements __powisf2 for the compiler_rt library.
 | |
|  *
 | |
|  * ===----------------------------------------------------------------------===
 | |
|  */
 | |
| 
 | |
| STATIC_YOINK("huge_compiler_rt_license");
 | |
| 
 | |
| #include "third_party/compiler_rt/int_lib.h"
 | |
| 
 | |
| /* Returns: a ^ b */
 | |
| 
 | |
| COMPILER_RT_ABI float
 | |
| __powisf2(float a, si_int b)
 | |
| {
 | |
|     const int recip = b < 0;
 | |
|     float r = 1;
 | |
|     while (1)
 | |
|     {
 | |
|         if (b & 1)
 | |
|             r *= a;
 | |
|         b /= 2;
 | |
|         if (b == 0)
 | |
|             break;
 | |
|         a *= a;
 | |
|     }
 | |
|     return recip ? 1/r : r;
 | |
| }
 |