📄 fp_math.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 + -