kerneltest/e32test/bench/t_kernbm.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 26 Jan 2010 13:13:38 +0200
changeset 13 46fffbe7b5a7
parent 9 96e5fb8b040d
permissions -rw-r--r--
Revision: 201004 Kit: 201004

// Copyright (c) 1995-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\bench\t_kernbm.cpp
// Overview:
// Benchmark the performance of some kernel functions including RTimer
// and RThread. Calculation time required for creation & closing of
// timer objects, suspension of threads, handling kernel messages, and 
// the number of threads created and stopped within a fixed time period.
// API Information:
// RTimer, RThread.
// Details:
// - Calculate and display the time required to create and close 1000 
// thread-relative timer objects.
// - Count and print the time taken to suspend the thread for 100000 times.
// - Count and display the time consumed for 100000 kernel messages.
// - Get and print the number of threads created and stopped within a 
// specified timeframe, verify the ExitType, and ExitReason of the threads.
// Platforms/Drives/Compatibility:
// All.
// Assumptions/Requirement/Pre-requisites:
// Failures and causes:
// Base Port information:
// 
//

#include <e32test.h>

#define	TIMECOUNT()	User::NTickCount()
#define TIMEDIFFMS(i,f)	(f-i)

LOCAL_D RTest test(_L("T_KERNBM"));
volatile TInt Count;
volatile TBool Stop;

#ifdef __EPOC32__
extern void DummyKernMsg();
#else
void DummyKernMsg()
	{}
#endif

LOCAL_C TInt ThreadFunction(TAny*)
	{
	User::WaitForAnyRequest();
	return 0;
	}

TInt TestThread(TAny*)
	{
	return 0;
	}

TInt TestThreadCreate(TAny*)
	{
	RThread t;
	t.SetPriority(EPriorityAbsoluteVeryLow);
	while (!Stop)
		{
		t.Create(KNullDesC,TestThread,4096,NULL,NULL);
		t.Resume();
		t.Close();
		++Count;
		}
	return 0;
	}

GLDEF_C TInt E32Main()
	{
	test.Title();
	test.Start(_L("Start...\n"));

	RTimer t;
	TInt i;
	TInt r;
	TUint32 c1=TIMECOUNT();
	for (i=0; i<1000; i++)
		{
		r=t.CreateLocal();
		if (r!=KErrNone)
			test(0);
		t.Close();
		}
	TUint32 c2=TIMECOUNT();
	test.Printf(_L("Create and close 1000 timers takes %d ms\n"),TIMEDIFFMS(c1,c2));

	RThread thrd;
	r=thrd.Create(_L("DodgyThread"),ThreadFunction,4096,1024,8192,NULL);
	test(r==KErrNone);
	test.Printf(_L("DodgyThread created\n"));
	thrd.SetPriority(EPriorityMore);
	thrd.Resume();
	test.Printf(_L("DodgyThread resumed\n"));
	c1=TIMECOUNT();
	for (i=0; i<100000; i++)
		{
		thrd.Suspend();
		}
	c2=TIMECOUNT();
	test.Printf(_L("Suspend 100000 times takes %d ms\n"),TIMEDIFFMS(c1,c2));
	thrd.Kill(0);
	thrd.Close();
	test.Printf(_L("DodgyThread killed\n"));

	c1=TIMECOUNT();
	for (i=0; i<100000; i++)
		{
		DummyKernMsg();
		}
	c2=TIMECOUNT();
	test.Printf(_L("100000 kernel messages take %d ms\n"),TIMEDIFFMS(c1,c2));

	test.Next(_L("Create thread test"));
	r=thrd.Create(_L("Creator"),TestThreadCreate,4096,NULL,NULL);
	test(r==KErrNone);
	thrd.SetPriority(EPriorityLess);
	RThread().SetPriority(EPriorityMuchMore);
	TRequestStatus s;
	thrd.Logon(s);
	thrd.Resume();
	Count=0;
	Stop=EFalse;
	c1=TIMECOUNT();
	User::After(1000000);
	Stop=ETrue;
	User::WaitForRequest(s);
	c2=TIMECOUNT();
	test(thrd.ExitType()==EExitKill);
	test(thrd.ExitReason()==0);
	thrd.Close();
	test.Printf(_L("%d threads created and stopped in %dms\n"),Count,TIMEDIFFMS(c1,c2));

	test.End();
	return 0;
	}