⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fp_math.h

📁 java 1.1 gemini 08_16
💻 H
字号:
/*****************************************************************************
*  Copyright Statement:
*  --------------------
*  This software is protected by Copyright and the information contained
*  herein is confidential. The software may not be copied and the information
*  contained herein may not be used or disclosed except with the written
*  permission of MediaTek Inc. (C) 2005
*
*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
*
*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. 
*
*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
*
*****************************************************************************/

/*******************************************************************************
 * Filename:
 * ---------
 *  fp_math.h
 *
 * Project:
 * --------
 *  MAUI
 *
 * Description:
 * ------------
 *  
 *
 * Author:
 * -------
 *  
 *
 *==============================================================================
 * 				HISTORY
 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!! 
 *------------------------------------------------------------------------------
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 * removed!
 * removed!
 * removed!
 *
 *------------------------------------------------------------------------------
 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!! 
 *==============================================================================
 *******************************************************************************/


/*
 * Copyright ?2003 Sun Microsystems, Inc. All rights reserved.
 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 *
 */

/*=========================================================================
 * SYSTEM:    KVM
 * SUBSYSTEM: Floating point operations for CLDC 1.1
 * FILE:      fp_math.h
 * OVERVIEW:  This file provides definitions that are needed for
 *            supporting the Math library functions defined in
 *            CLDC Specification 1.1.
 * AUTHOR:    Kinsley Wong
 *=======================================================================*/

/*=========================================================================
 * Include files
 *=======================================================================*/

/*=========================================================================
 * Definitions and declarations
 *=======================================================================*/

/* Macros for NaN (Not-A-Number) and Infinity for floats and doubles */
#ifndef __MTK_TARGET__ 
#define D_POS_INFINITY    								(0x7FF0000000000000)
#define D_NEG_INFINITY    								(0xFFF0000000000000)
#define D_L_POS_NAN       								(0x7FF0000000000001)
#define D_H_POS_NAN       								(0x7FFFFFFFFFFFFFFF)
#define D_L_NEG_NAN       								(0xFFF0000000000001)
#define D_H_NEG_NAN       								(0xFFFFFFFFFFFFFFFF)
#define MAX_LONG          								(0x7FFFFFFFFFFFFFFF)
#define MIN_LONG          								(0x8000000000000000)
#define MAX_LONG          								(0x7FFFFFFFFFFFFFFF)
#define MIN_LONG          								(0x8000000000000000)
#else
#define D_POS_INFINITY    								(0x7FF0000000000000ll)
#define D_NEG_INFINITY    								(0xFFF0000000000000ll)
#define D_L_POS_NAN       								(0x7FF0000000000001ll)
#define D_H_POS_NAN       								(0x7FFFFFFFFFFFFFFFll)
#define D_L_NEG_NAN       								(0xFFF0000000000001ll)
#define D_H_NEG_NAN       								(0xFFFFFFFFFFFFFFFFll)
#define MAX_LONG          								(0x7FFFFFFFFFFFFFFFull)
#define MIN_LONG          								(0x8000000000000000ull)
#endif /* !__MTK_TARGET__  */

#define F_POS_INFINITY    								0x7F800000
#define F_NEG_INFINITY    								0xFF800000
#define F_L_POS_NAN       								0x7F800001
#define F_H_POS_NAN       								0x7FFFFFFF
#define F_L_NEG_NAN       								0xFF800001
#define F_H_NEG_NAN       								0xFFFFFFFF

/* MAX and MIN values for INT and LONG */
#define MAX_INT           								0x7FFFFFFF
#define MIN_INT           								0x80000000

/*=========================================================================
 * Function prototype for initializing floating point arithmetic
 *=======================================================================*/
void InitializeFloatingPoint(void);

/*=========================================================================
 * Function prototypes for the internal library routines that we use
 *=======================================================================*/

double __kernel_sin(double x, double y, int iy);
double __kernel_cos(double x, double y);
double __kernel_tan(double x, double y, int iy);
int    __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, const int *ipio2);

double __ieee754_sqrt(double x);
int    __ieee754_rem_pio2(double x, double *y);

double JFP_lib_copysign(double x, double y);
double JFP_lib_fabs(double x);
double JFP_lib_scalbn(double x, int n);

double JFP_lib_sin(double x);
double JFP_lib_cos(double x);
double JFP_lib_tan(double x);
double JFP_lib_floor(double x);
double JFP_lib_ceil(double x);
double JFP_lib_sqrt(double x);

/*=========================================================================
 * Function prototypes for the some floating point operations
 * that are needed for fixing strictfp problems on x86 CPUs.
 *=======================================================================*/

void JFP_lib_dmul_x86(double lvalue, double rvalue);
void JFP_lib_ddiv_x86(double lvalue, double rvalue);
void JFP_lib_fcmpl_x86(float lvalue, float rvalue);
void JFP_lib_fcmpg_x86(float lvalue, float rvalue);
void JFP_lib_dcmpl_x86(double lvalue, double rvalue);
void JFP_lib_dcmpg_x86(double lvalue, double rvalue);
void JFP_lib_frem_x86(float lvalue, float rvalue);
void JFP_lib_drem_x86(double lvalue, double rvalue);

/*=========================================================================
 * Native function prototypes for CLDC 1.1 functions
 *=======================================================================*/

void Java_java_lang_Float_intBitsToFloat(void);
void Java_java_lang_Float_floatToIntBits(void);

void Java_java_lang_Double_longBitsToDouble(void);
void Java_java_lang_Double_doubleToLongBits(void);

void Java_java_lang_Math_ceil(void);
void Java_java_lang_Math_floor(void);

void Java_java_lang_Math_sqrt(void);

void Java_java_lang_Math_sin(void);
void Java_java_lang_Math_cos(void);
void Java_java_lang_Math_tan(void);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -