kerneltest/e32test/bench/t_ctxsw3.cpp
author John Imhofe
Mon, 19 Oct 2009 15:55:17 +0100
changeset 0 a41df078684a
permissions -rw-r--r--
Convert Kernelhwsrv package from SFL to EPL kernel\eka\compsupp is subject to the ARM EABI LICENSE userlibandfileserver\fatfilenameconversionplugins\unicodeTables is subject to the Unicode license kernel\eka\kernel\zlib is subject to the zlib license

// Copyright (c) 1997-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_ctxsw3.cpp
// Overview:
// Benchmark the inter-thread context switching. 
// API Information:
// RThread, RRSemaphore.
// Details:
// - Create a semaphore.
// - Create a thread (thread1) with a handle to the Semaphore and 
// priority EPriorityLess. Verify the successful creation.
// - Create another thread (thread2) with a handle to the Semaphore 
// and priority EPriorityMuchLess. Verify the successful creation.
// - thread1 counts the number of times the semaphore count is decremented.
// - thread2 counts the number of times the semaphore count is incremented.
// - Display the number of times the semaphore is signalled per second.
// Platforms/Drives/Compatibility:
// All.
// Assumptions/Requirement/Pre-requisites:
// Failures and causes:
// Base Port information:
// 
//

#include <e32test.h>

RTest test(_L("T_CTXSW3"));

LOCAL_D TInt Count;

LOCAL_D RSemaphore StartSem;

LOCAL_C TInt Thread1(TAny* aSemaphore)
	{
	RSemaphore s;
	s.SetHandle((TInt)aSemaphore);
	StartSem.Wait();
	FOREVER
		{
		s.Wait();
		Count++;
		}
	}

LOCAL_C TInt Thread2(TAny* aSemaphore)
	{
	RSemaphore s;
	s.SetHandle((TInt)aSemaphore);
	StartSem.Wait();
	FOREVER
		{
		s.Signal();
		Count++;
		}
	}

const TInt KHeapSize=4096;

GLDEF_C TInt E32Main()
	{
	test.Title();
	test.Start(_L("Timing inter-thread context switches..."));

	TInt r=StartSem.CreateLocal(0);
	test(r==KErrNone);

	RSemaphore sem;
	r=sem.CreateLocal(0);
	test(r==KErrNone);
	RThread t1,t2;
	r=t1.Create(_L("Thread1"),Thread1,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)sem.Handle());
	test(r==KErrNone);
	t1.SetPriority(EPriorityLess);
	r=t2.Create(_L("Thread2"),Thread2,KDefaultStackSize,KHeapSize,KHeapSize,(TAny*)sem.Handle());
	test(r==KErrNone);
	t2.SetPriority(EPriorityMuchLess);

	TRequestStatus s1,s2;
	t1.Logon(s1);
	t2.Logon(s2);
	t1.Resume();
	t2.Resume();

	Count=0;
	User::After(20000);
	StartSem.Signal(2);
	User::After(2000000);
	TInt count=Count;

	t2.Kill(0);
	User::WaitForRequest(s2);
	t1.Kill(0);
	User::WaitForRequest(s1);
	t2.Close();
	t1.Close();
	sem.Close();

	test.Printf(_L("%d per second\n"),count/2);

	test.End();
	return 0;
	}