os/kernelhwsrv/kernel/eka/memmodel/epoc/direct/arm/xkernel.cpp
changeset 0 bde4ae8d615e
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/os/kernelhwsrv/kernel/eka/memmodel/epoc/direct/arm/xkernel.cpp	Fri Jun 15 03:10:57 2012 +0200
     1.3 @@ -0,0 +1,88 @@
     1.4 +// Copyright (c) 1994-2009 Nokia Corporation and/or its subsidiary(-ies).
     1.5 +// All rights reserved.
     1.6 +// This component and the accompanying materials are made available
     1.7 +// under the terms of the License "Eclipse Public License v1.0"
     1.8 +// which accompanies this distribution, and is available
     1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
    1.10 +//
    1.11 +// Initial Contributors:
    1.12 +// Nokia Corporation - initial contribution.
    1.13 +//
    1.14 +// Contributors:
    1.15 +//
    1.16 +// Description:
    1.17 +// e32\memmodel\epoc\direct\arm\xkernel.cpp
    1.18 +// 
    1.19 +//
    1.20 +
    1.21 +#include "arm_mem.h"
    1.22 +
    1.23 +/********************************************
    1.24 + * Thread
    1.25 + ********************************************/
    1.26 +
    1.27 +TInt DArmPlatThread::SetupContext(SThreadCreateInfo& anInfo)
    1.28 +	{
    1.29 +#ifndef __SMP__
    1.30 +	if(iThreadType==EThreadUser)
    1.31 +		iNThread.iSpare3 /*iUserContextType*/ = NThread::EContextUndefined;
    1.32 +#endif
    1.33 +	return KErrNone;
    1.34 +	}
    1.35 +
    1.36 +DArmPlatProcess::DArmPlatProcess()
    1.37 +	{}
    1.38 +
    1.39 +DArmPlatProcess::~DArmPlatProcess()
    1.40 +	{
    1.41 +	__KTRACE_OPT(KMMU,Kern::Printf("DArmPlatProcess destruct"));
    1.42 +	DMemModelProcess::Destruct();
    1.43 +	}
    1.44 +
    1.45 +TBool Exc::IsMagic(TLinAddr /*anAddress*/)
    1.46 +//
    1.47 +// Return TRUE if anAddress is a 'magic' exception handling instruction
    1.48 +//
    1.49 +	{
    1.50 +	return EFalse;
    1.51 +	}
    1.52 +
    1.53 +void DThread::IpcExcHandler(TExcTrap* aTrap, DThread* aThread, TAny* aContext)
    1.54 +	{
    1.55 +	aThread->iIpcClient = 0;
    1.56 +	TIpcExcTrap& xt=*(TIpcExcTrap*)aTrap;
    1.57 +	TArmExcInfo& info=*(TArmExcInfo*)aContext;
    1.58 +	if (info.iExcCode==EArmExceptionDataAbort)
    1.59 +		{
    1.60 +		TUint32 opcode = *(TUint32*)info.iR15;		// faulting instruction
    1.61 +		if (opcode>=0xf0000000)
    1.62 +			return;									// not a load/store so fault the kernel
    1.63 +		TUint32 opc1 = (opcode>>25)&7;
    1.64 +		TBool load;
    1.65 +		if ( (opc1==2) || (opc1==4) || (opc1==3 && !(opcode&0x10)) )
    1.66 +			load=opcode & 0x00100000;				// bit 20=1 for load, 0 for store
    1.67 +		else if (opc1==0)
    1.68 +			{
    1.69 +			TUint32 opc2 = (opcode>>4)&0xf;
    1.70 +			if (opc2==0x0b)
    1.71 +				load=opcode & 0x00100000;			// bit 20=1 for load, 0 for store
    1.72 +			else if ((opc2&0x0d)==0x0d)
    1.73 +				{
    1.74 +				if (opcode&0x00100000)
    1.75 +					load=ETrue;						// LDRSB/LDRSH
    1.76 +				else
    1.77 +					load=(opcode&0x20)^0x20;		// LDRD/STRD, bit5=1 for STRD, 0 for LDRD
    1.78 +				}
    1.79 +			else
    1.80 +				return;								// not a load/store so fault the kernel
    1.81 +			}
    1.82 +		else
    1.83 +			return;									// not a load/store so fault the kernel
    1.84 +
    1.85 +		if ((load && !xt.iDir) || (!load && xt.iDir))
    1.86 +			xt.Exception(KErrBadDescriptor);	// problem accessing remote address - 'leave' so an error code will be returned
    1.87 +		NKern::UnlockSystem();			// else assume problem accessing local address - return and panic current thread as usual
    1.88 +		}
    1.89 +	// otherwise return and fault kernel
    1.90 +	}
    1.91 +