diff -r 000000000000 -r 96e5fb8b040d kernel/eka/memmodel/epoc/moving/mmu.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/kernel/eka/memmodel/epoc/moving/mmu.cpp Thu Dec 17 09:24:54 2009 +0200 @@ -0,0 +1,97 @@ +// Copyright (c) 1998-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: +// e32\memmodel\epoc\moving\mmu.cpp +// +// + +#include "memmodel.h" + +/******************************************************************************* + * "Independent" MMU code + *******************************************************************************/ + +void Mmu::Panic(TPanic aPanic) + { + Kern::Fault("MMU",aPanic); + } + +void Mmu::Init1() + { + __KTRACE_OPT2(KBOOT,KMMU,Kern::Printf("Mmu::Init1")); + __ASSERT_ALWAYS(TheRomHeader().iUserDataAddress==iDllDataBase+iMaxDllDataSize,Panic(ERomUserDataAddressInvalid)); + __ASSERT_ALWAYS((TheRomHeader().iTotalUserDataSize&iPageMask)==0,Panic(ERomUserDataSizeInvalid)); + __ASSERT_ALWAYS(::RomHeaderAddress==iRomLinearBase,Panic(ERomLinearAddressInvalid)); + MmuBase::Init1(); + } + +void Mmu::DoInit2() + { + __KTRACE_OPT2(KBOOT,KMMU,Kern::Printf("Mmu::DoInit2")); + MM::DllDataAllocator=TBitMapAllocator::New(iMaxDllDataSize>>iPageShift, ETrue); + __ASSERT_ALWAYS(MM::DllDataAllocator,Panic(EDllDataAllocatorCreateFailed)); + TInt rom_dll_pages=TheRomHeader().iTotalUserDataSize>>iPageShift; + __KTRACE_OPT2(KBOOT,KMMU,Kern::Printf("DllDataAllocator @ %08x, %d ROM DLL Data Pages", MM::DllDataAllocator, rom_dll_pages)); + if (rom_dll_pages) + MM::DllDataAllocator->Alloc(0, rom_dll_pages); // low bit numbers represent high addresses + } + +//#ifndef __MMU_MACHINE_CODED__ +TInt Mmu::PageTableId(TLinAddr aAddr) + { + NKern::LockSystem(); + TInt id = GetPageTableId(aAddr); + NKern::UnlockSystem(); + return id; + } +//#endif + +void Mmu::AssignPageTable(TInt aId, TInt aUsage, TAny* aObject, TLinAddr aAddr, TPde aPdePerm) + { + __KTRACE_OPT(KMMU,Kern::Printf("Mmu::AssignPageTable id=%d, u=%08x, obj=%08x, addr=%08x, perm=%08x", + aId, aUsage, aObject, aAddr, aPdePerm)); + NKern::LockSystem(); + SPageTableInfo& pti=PtInfo(aId); + switch (aUsage) + { +// case SPageTableInfo::EChunk: +// { +// DMemModelChunk* pC=(DMemModelChunk*)aObject; +// TUint32 ccp=K::CompressKHeapPtr(pC); +// TUint32 offset=(aAddr-TLinAddr(pC->iBase))>>iChunkShift; +// pti.SetChunk(ccp,offset); +// break; +// } +// case SPageTableInfo::EHwChunk: +// break; + case SPageTableInfo::EGlobal: + pti.SetGlobal(aAddr>>iChunkShift); + break; + default: + Panic(EAssignPageTableInvalidUsage); + } + DoAssignPageTable(aId, aAddr, aPdePerm); + NKern::UnlockSystem(); + } + +TInt Mmu::UnassignPageTable(TLinAddr aAddr) + { + __KTRACE_OPT(KMMU,Kern::Printf("Mmu::UnassignPageTable addr=%08x", aAddr)); + NKern::LockSystem(); + TInt id=GetPageTableId(aAddr); + if (id>=0) + DoUnassignPageTable(aAddr); + NKern::UnlockSystem(); + return id; + } +