kernel/eka/memmodel/epoc/flexible/mmu/mcleanup.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) 2007-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:
//

#include <plat_priv.h>
#include "mm.h"
#include "mmu.h"

#include "mcleanup.h"


//
// TMemoryCleanup
//

static TDfc CleanupDfc(TMemoryCleanup::Cleanup, NULL, 2);

static TMemoryCleanup* CleanupList = 0;

#ifdef __SMP__
static TSpinLock CleanupLock(TSpinLock::EOrderEventHandlerList);
#endif

void TMemoryCleanup::Init2()
	{
	CleanupDfc.SetDfcQ(K::SvMsgQ);
	}


void TMemoryCleanup::Add(TMemoryCleanupCallback aCallback, TAny* aArg)
	{
	__SPIN_LOCK_IRQ(CleanupLock);
	if(iCallback)
		{
		// already queued...
		__NK_ASSERT_DEBUG(iCallback==aCallback);
		__SPIN_UNLOCK_IRQ(CleanupLock);
		}
	else
		{
		iCallback = aCallback;
		iArg = aArg;
		iNext = CleanupList;
		CleanupList = this;
		__SPIN_UNLOCK_IRQ(CleanupLock);
		CleanupDfc.Enque();
		}
	}


void TMemoryCleanup::Cleanup(TAny* /*aDummy*/)
	{
	for(;;)
		{
		__SPIN_LOCK_IRQ(CleanupLock);
		TMemoryCleanup* c = CleanupList;
		if(!c)
			{
			__SPIN_UNLOCK_IRQ(CleanupLock);
			return;
			}

		CleanupList = c->iNext;
		TMemoryCleanupCallback fn = c->iCallback;
		TAny* arg = c->iArg;
		c->iCallback = 0;
		__SPIN_UNLOCK_IRQ(CleanupLock);
		(*fn)(arg);
		}
	}