kerneltest/e32test/demandpaging/t_dpcmn.cpp
author Adrian Taylor <adrian@macrobug.com>
Tue, 10 Nov 2009 20:10:34 +0000
changeset 1 cb3e90eb7d89
parent 0 a41df078684a
permissions -rw-r--r--
Improving comments on panics generated by CActive::SetActive. Patch slightly altered based on comments by John Imhofe.

// Copyright (c) 2008-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:
// e32test\demandpaging\t_dpcmn.cpp
// 
//

#include <e32test.h>
#include <dptest.h>
#include <e32hal.h>
#include <u32exec.h>
#include <e32svr.h>
#include <e32panic.h>
#include "u32std.h"

TInt gPageSize;
TBool gPagingSupported = EFalse;
TBool gRomPagingSupported = EFalse;
TBool gCodePagingSupported = EFalse;
TBool gDataPagingSupported = EFalse;
TInt gDataPagingPolicy;
TBool gProcessPaged;

TBool gGlobalNoPaging = EFalse;		
TBool gGlobalAlwaysPage = EFalse;
TBool gGlobalDefaultUnpaged = EFalse;	
TBool gGlobalDefaultPage = EFalse;

// Size of paging cache in pages
TUint gMinCacheSize = 0;
TUint gMaxCacheSize = 0;
TUint gCurrentCacheSize = 0;

RChunk gChunk;

//
// GetGlobalPolicies
//
// Determine the global dapaging policies as specified at rombuild time
//
TInt GetGlobalPolicies()
	{
	// Determine which types of paging are supported
	TUint32 attrs = DPTest::Attributes();

	gRomPagingSupported = (attrs & DPTest::ERomPaging) != 0;
	gCodePagingSupported = (attrs & DPTest::ECodePaging) != 0;
	gDataPagingSupported = (attrs & DPTest::EDataPaging) != 0;
	gPagingSupported = gRomPagingSupported || gCodePagingSupported || gDataPagingSupported;
	
	if (gRomPagingSupported)
		RDebug::Printf("Rom paging supported");
	if (gCodePagingSupported)
		RDebug::Printf("Code paging supported");
	if (gDataPagingSupported)
		RDebug::Printf("Data paging supported");	
	
	// Determine the data paging attributes
	TInt kernelFlags = UserSvr::HalFunction(EHalGroupKernel, EKernelHalConfigFlags, 0, 0);
	if (kernelFlags < 0)
		return kernelFlags;
	
	gDataPagingPolicy = kernelFlags & EKernelConfigDataPagingPolicyMask;
	if (gDataPagingPolicy == EKernelConfigDataPagingPolicyNoPaging)
		{
		RDebug::Printf("Global NO PAGING policy is set");
		gGlobalNoPaging = ETrue;
		}
	if (gDataPagingPolicy == EKernelConfigDataPagingPolicyAlwaysPage)
		{
		RDebug::Printf("Global ALWAYS PAGE policy is set");
		gGlobalAlwaysPage = ETrue;
		}
	if (gDataPagingPolicy == EKernelConfigDataPagingPolicyDefaultUnpaged)
		{
		RDebug::Printf("Global DEFAULT UNPAGED policy is set");
		gGlobalDefaultUnpaged = ETrue;
		}
	if (gDataPagingPolicy == EKernelConfigDataPagingPolicyDefaultPaged)
		{
		RDebug::Printf("Global DEFAULT PAGED policy is set");
		gGlobalDefaultPage = ETrue;
		}

	// Determine this process' data paging attribute
	RProcess process;	// Default to point to current process.
	gProcessPaged = process.DefaultDataPaged();
	RDebug::Printf(gProcessPaged ? "This process is paged" : "This process is not paged");

	// Get page size
	TInt r = UserHal::PageSizeInBytes(gPageSize);
	if (r != KErrNone)
		return r;

	if (gPagingSupported)
		{
		TUint minSize;
		TUint maxSize;
		TUint currentSize;
		r = DPTest::CacheSize(minSize, maxSize, currentSize);
		if (r != KErrNone)
			return r;

		gMinCacheSize = minSize / gPageSize;
		gMaxCacheSize = maxSize / gPageSize;
		gCurrentCacheSize = currentSize / gPageSize;
		RDebug::Printf("Cache size (pages): min == %d, max == %d, current == %d",
					   gMinCacheSize, gMaxCacheSize, gCurrentCacheSize);
		}
	
	return r;
	}

//
// IsDataPagingSupported
//
// Determine whether data paging is supported
//
TBool IsDataPagingSupported()
	{
	return gDataPagingSupported;
	}

//
// UpdatePaged
//
// Update whether the expected paged status based on the global paging policy.
//
void UpdatePaged(TBool& aPaged)
	{
	if (gGlobalNoPaging)
		aPaged = EFalse;
	if (gGlobalAlwaysPage)
		aPaged = ETrue;
	if (!gDataPagingSupported)
		aPaged = EFalse;
	}


// 
// TestThreadExit
//
// Resume the specified thread and verify the exit reason.
//
TInt TestThreadExit(RThread& aThread, TExitType aExitType, TInt aExitReason)
	{
	// Disable JIT debugging.
	TBool justInTime=User::JustInTime();
	User::SetJustInTime(EFalse);

	TRequestStatus status;
	aThread.Logon(status); 
	aThread.Resume();
	User::WaitForRequest(status);
	if (aExitType != aThread.ExitType())
		return KErrGeneral;

	if (aExitReason != status.Int())
		return KErrGeneral;
	
	if (aExitReason != aThread.ExitReason())
		return KErrGeneral;


	if (aExitType == EExitPanic)
		{
		if (aThread.ExitCategory()!=_L("USER"))
			{
			return KErrGeneral;
			}
		}
			
	CLOSE_AND_WAIT(aThread);

	// Put JIT debugging back to previous status.
	User::SetJustInTime(justInTime);
	return KErrNone;
	}