// Copyright (c) 1996-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
// e32test\math\t_gcc64.cpp
// From UP_GCC.CPP, for emulating UP_GCC in T_R64.CPP tests
//
//
#include <e32def.h>
#include <e32def_private.h>
#include "t_math.h"
LOCAL_C void MathException(TInt aErrType)
//
// Decides on type of maths exception according to error and raises exception.
// DOES NOT CONVERT TO SPECIAL IF RETURNS
// Added by AnnW, December 1996
//
{
TExcType excType=EExcGeneral;
switch (aErrType)
{
case KErrArgument: // error due to invalid operation
excType=EExcFloatInvalidOperation;
break;
case KErrDivideByZero:
excType=EExcFloatDivideByZero;
break;
case KErrOverflow:
excType=EExcFloatOverflow;
break;
case KErrUnderflow:
excType=EExcFloatUnderflow;
break;
/*
// also errors due to inexact result
case KErrInexact: // const not defined yet
excType=EExcFloatInexact;
break;
*/
default:
// Unknown error
User::Panic(_L("USER-Math"),EMathUnknownError);
}
RThread thread;
thread.RaiseException(excType);
}
GLDEF_C TReal64 __adddf3(TReal64 a1,TReal64 a2)
//
// Add two doubles
//
{
TRealX x1=a1;
TRealX x2=a2;
TRealX res;
TReal64 trg;
x1.Add(res,x2);
TInt ret=res.GetTReal(trg);
if (ret!=KErrNone)
MathException(ret);
return(trg);
}
GLDEF_C TReal64 __subdf3(TReal64 a1,TReal64 a2)
//
// Subtract two doubles
//
{
TRealX x1=a1;
TRealX x2=a2;
TRealX res;
TReal64 trg;
x1.Sub(res,x2);
TInt ret=res.GetTReal(trg);
if (ret!=KErrNone)
MathException(ret);
return(trg);
}
GLDEF_C TReal64 __muldf3(TReal64 a1,TReal64 a2)
//
// Multiply two doubles
//
{
TRealX x1=a1;
TRealX x2=a2;
TRealX res;
TReal64 trg;
TInt ret=x1.Mult(res,x2);
if (ret==KErrNone)
ret=res.GetTReal(trg);
if (ret!=KErrNone)
MathException(ret);
return((TReal64)res);
}
GLDEF_C TReal64 __divdf3(TReal64 a1,TReal64 a2)
//
// Divide two doubles
//
{
TRealX x1=a1;
TRealX x2=a2;
TRealX res;
TReal64 trg;
TInt ret=x1.Div(res,x2);
if (ret==KErrNone)
ret=res.GetTReal(trg);
if (ret!=KErrNone)
MathException(ret);
return((TReal64)res);
}