graphicstest/graphicstestharness/src/t_simloadutils.cpp
author William Roberts <williamr@symbian.org>
Fri, 16 Jul 2010 18:15:12 +0100
changeset 117 cc566ae45bab
parent 36 01a6848ebfd7
child 160 969102054596
permissions -rw-r--r--
Add wstfxconst.h file, to satisfy missing dependencies - Bug 3283

// 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 "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:
//

/**
 @file
 @test
*/

#include <e32math.h>
#include <e32debug.h>
#include <cinidata.h>
#include "t_simload.h"
#include "t_simloadutils.h"

EXPORT_C TBool CTSimLoadAppUtils::IsStaticLoadL()
	{
	CIniData * iniData = CIniData::NewL(KSimLoadConfigFile);
	CleanupStack::PushL(iniData);

	TPtrC value;
	User::LeaveIfError(iniData->FindVar(KDefaultSectionName, KConfigSimLoadType(), value));
	HBufC* simLoadType = value.Alloc();

	CleanupStack::PopAndDestroy(iniData);

	TBool ret = EFalse;

	if (simLoadType!=NULL && simLoadType->Des().Compare(_L("KSimLoadStatic")) == KErrNone)
		{
		ret = ETrue;
		}
	else
		{
		if (simLoadType!=NULL && simLoadType->Des().Compare(_L("KSimLoadSpiked")) != KErrNone)
			{
			User::Leave(KErrAbort);
			}
		}

	return ret;
	}

EXPORT_C TInt CTSimLoadAppUtils::SimLoadL()
	{
	CIniData * iniData = CIniData::NewL(KSimLoadConfigFile);
	CleanupStack::PushL(iniData);

	TInt ret;
	User::LeaveIfError(iniData->FindVar(KDefaultSectionName, KConfigSimLoadValue(), ret));
	CleanupStack::PopAndDestroy(iniData);
	return ret;
	}

EXPORT_C void CTSimLoadAppUtils::SimulateStaticLoadL(TInt aLoadPercentage, TInt aDelay)
	{
	if (aLoadPercentage>=0)
		{
		// assuming the figure read in was '%' calculate the loop count
		// required to achieve the simulated load required
		const TInt mySimLoad = CalculateSimLoadL(aLoadPercentage);

		TInt internalDelay = aDelay;

		if (aLoadPercentage==0)
			{
			// set delay to large number, so that simload process is still
			// running at end of test, and therefore not cause issue with
			// TEF execution determining the test has failed because
			// the sim load app is not running at end of test.
			internalDelay = 30000000; // 30s
			}

		SimulateTestLoad(mySimLoad, internalDelay);
		}
	}

EXPORT_C void CTSimLoadAppUtils::SimulateSpikedLoad()
	{
	SimulateTestLoad(1500000, 100000);
	}

void CTSimLoadAppUtils::SimulateTestLoad(TInt aSimLoad, TInt aDelay)
	{
	FOREVER
		{
		for (TInt i = 0; i <= aSimLoad; i++)
			{
			//Load the CPU by forcing it to execute the NOP The load value
			//is dependant upon the value of aSimLoad and the load type (either
			//static or spiked) by the ratio of aSimload to aDelay
			//Tuned to work with the H4 only
			#if !defined(__WINS__) && !defined(__X86GCC__)
			asm{nop;};
			#endif
			}

		User::After(aDelay);
		}
	}

TInt CTSimLoadAppUtils::CalculateSimLoadL(TInt aPercentage)
	{
	TInt32 calculatedLoad = 0;

	if (aPercentage>0)
		{
		// based on measurements performed using Symbian Sample Profiler
		// .../base/e32utils/analyse/profiler.rtf
		// and then utilising curve fit (http://www.ebicom.net/~dhyams/cftp.htm)
		// the following formula was determined to best calculate the load
		// based on a required percentage
		// simload = a + b*aPercentage + c*aPercentage^2 + d*aPercentage^3 + e*aPercentage^4
		const TReal a = 92600;
		const TReal b = -32000;
		const TReal c = 4700;
		const TReal d = -114;
		const TReal e = 0.91;
		TReal tempValue = a + (b*aPercentage) + (c*aPercentage*aPercentage)
		                    + (d*aPercentage*aPercentage*aPercentage)
		                    + (e*aPercentage*aPercentage*aPercentage*aPercentage);
		User::LeaveIfError(Math::Int(calculatedLoad, tempValue));
		}

	return calculatedLoad;
	}