os/kernelhwsrv/kernel/eka/memmodel/epoc/direct/x86/xkernel.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 1994-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// e32\memmodel\epoc\direct\x86\xkernel.cpp
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include <x86_mem.h>
sl@0
    19
sl@0
    20
/********************************************
sl@0
    21
 * Thread
sl@0
    22
 ********************************************/
sl@0
    23
sl@0
    24
TInt DX86PlatThread::SetupContext(SThreadCreateInfo& anInfo)
sl@0
    25
	{
sl@0
    26
	return KErrNone;
sl@0
    27
	}
sl@0
    28
sl@0
    29
DX86PlatProcess::DX86PlatProcess()
sl@0
    30
	{}
sl@0
    31
sl@0
    32
DX86PlatProcess::~DX86PlatProcess()
sl@0
    33
	{
sl@0
    34
	__KTRACE_OPT(KMMU,Kern::Printf("DX86PlatProcess destruct"));
sl@0
    35
	DMemModelProcess::Destruct();
sl@0
    36
	}
sl@0
    37
sl@0
    38
TBool Exc::IsMagic(TLinAddr /*anAddress*/)
sl@0
    39
//
sl@0
    40
// Return TRUE if anAddress is a 'magic' exception handling instruction
sl@0
    41
//
sl@0
    42
	{
sl@0
    43
	return EFalse;
sl@0
    44
	}
sl@0
    45
sl@0
    46
void DThread::IpcExcHandler(TExcTrap* aTrap, DThread* aThread, TAny* aContext)
sl@0
    47
	{
sl@0
    48
	aThread->iIpcClient = 0;
sl@0
    49
	TIpcExcTrap& xt=*(TIpcExcTrap*)aTrap;
sl@0
    50
	TX86ExcInfo& info=*(TX86ExcInfo*)aContext;
sl@0
    51
	if (info.iExcId==EX86VectorPageFault)
sl@0
    52
		{
sl@0
    53
		TLinAddr va=(TLinAddr)info.iFaultAddress;
sl@0
    54
		if (va>=xt.iRemoteBase && (va-xt.iRemoteBase)<xt.iSize)
sl@0
    55
			xt.Exception(KErrBadDescriptor);	// problem accessing remote address - 'leave' so an error code will be returned
sl@0
    56
		if (xt.iLocalBase && va>=xt.iLocalBase && (va-xt.iLocalBase)<xt.iSize)
sl@0
    57
			NKern::UnlockSystem();		// problem accessing local address - return and panic current thread as usual
sl@0
    58
		}
sl@0
    59
	// otherwise return and fault kernel
sl@0
    60
	}
sl@0
    61