kernel/eka/compsupp/rvct2_1/sftfpini.cpp
author mikek
Fri, 02 Jul 2010 09:53:45 +0100
branchGCC_SURGE
changeset 190 0d42d469e749
parent 0 a41df078684a
permissions -rw-r--r--
1) Swapping to c++ instead of assembly implementations of several kernel APIs to avoid calling probably broken implementations of __EH_FRAME_?? macros 2) Commenting out otherwise unavoidable calls to __EH_FRAME_?? macros in uc_exe.cia. This is a temporary hack. Both changes to see if they get past an early kernel panic in the Syborg ROM from the current build: EH ERROR: no exception descriptor for address 0x801eb277 Thread efile.exe::Main Panic USER-EXEC 3

// Copyright (c) 2002-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 "ARM EABI LICENCE.txt"
// which accompanies this distribution, and is available
// in kernel/eka/compsupp.
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
//

#include <e32std.h>
#include <e32std_private.h>

// support functions for ARM supplied softvfp compiler-helper functions

extern "C" {

//void __rt_fp_status_register_cleanup(TAny * aReg)
//	{
//	delete aReg;
//	}

// set up the fp status register 
EXPORT_C  void _fp_init(void) 
	{
	TUint32 * aReg = (TUint32 *)User::AllocZ(sizeof(TUint32));
	if (aReg) 
		{
		Dll::SetTls(aReg /*, __rt_fp_status_register_cleanup*/);
		}
	else
		{
		// This will force us to try again if we actually get an FP 
		// exception later.
		Dll::SetTls(0 /*, __rt_fp_status_register_cleanup*/);
		}
	}
  
EXPORT_C TAny * __rt_fp_status_addr(void) 
	{ 
	//return &__fp_status_register; 
	TAny* aTls = Dll::Tls();
	if (aTls)
		return aTls;
	// we obviously failed to set it up before. Try again, so we can
	// at least try to error meaningfully
	TUint32* aReg = (TUint32*)User::AllocZ(sizeof(TUint32));
	_LIT(KFpGeneralPanic, "FP Emulator");
	if (aReg) 
		{
		TInt r = Dll::SetTls(aReg /*, __rt_fp_status_register_cleanup*/);
		if (r==KErrNone)
			return aReg;
		// if we get here we really in trouble. Just Panic.
		User::Panic(KFpGeneralPanic, KErrGeneral);
		}
	else
		{
		// If we get here, we're toast anyway....
		User::Panic(KFpGeneralPanic, KErrNoMemory);
		}
	return 0;
	}
}