kerneltest/e32test/realtime/t_latncy.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) 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\realtime\t_latncy.cpp
// 
//

#include <e32test.h>
#include <e32svr.h>

LOCAL_D RTest test(_L("Latency"));
LOCAL_D CConsoleBase* console=NULL;

struct SLatencyValues
	{
	TUint iAddress;
	TUint iLatencies;
	TUint iThreadIds;
	TUint iSwi;
	};

struct SMaxLatencyValues
	{
	TInt iMaxIntLatency;
	TUint iMaxIntLatencyRetAddr;
	TInt iMaxThreadLatency;
	TUint iMaxThreadLatencyRetAddr;
	};

extern void GetLatencyValues(TInt, TInt&, SLatencyValues*);

inline TInt* NullTIntPtr()	// to allow generation of a NULL reference without the compiler complaining
	{ return 0; }

void GetMaxLatencyValues(SMaxLatencyValues& a)
	{
	GetLatencyValues(2,*NullTIntPtr(),(SLatencyValues*)&a);
	}

LOCAL_C void DumpValues(TInt aCount, SLatencyValues* aValues)
	{
	TInt i;
	for (i=0; i<aCount; i++)
		{
		SLatencyValues v=aValues[i];
		TInt addr=v.iAddress;
		TInt iticks=v.iLatencies>>16;
		TInt tticks=v.iLatencies & 0xffff;
		TInt ius=(iticks*125+124)>>6;
		TInt tus=(tticks*125+124)>>6;
//		TInt oldtid=v.iThreadIds & 0xffff;
//		TInt newtid=v.iThreadIds >> 16;
		TInt swi=v.iSwi;
		RDebug::Print(_L("%08x %4d %4d %08x %08x"),addr,ius,tus,v.iThreadIds,swi);
		}
	}

LOCAL_C void DisplayMaxLatencyValues()
	{
	SMaxLatencyValues v;
	GetMaxLatencyValues(v);
	TInt ius=(v.iMaxIntLatency*125+124)>>6;
	TInt tus=(v.iMaxThreadLatency*125+124)>>6;
	console->Printf(_L("Interrupt: %4dus return address %08x\n"),ius,v.iMaxIntLatencyRetAddr);
	console->Printf(_L("Thread:    %4dus return address %08x\n"),tus,v.iMaxThreadLatencyRetAddr);
	}

GLDEF_C TInt E32Main()
	{
	TInt c;
	SLatencyValues* pV=new SLatencyValues[28672];

	test.Title();
	console=test.Console();
	if (!pV)
		User::Panic(_L("OOM"),0);

	TBool exit=EFalse;
	while(!exit)
		{
		TKeyCode k=test.Getch();
		switch(k)
			{
			case '0':
				console->Printf(_L("Getting Latency Values\n"));
				GetLatencyValues(0,c,pV);
				DumpValues(c,pV);
				break;
			case '1':
				console->Printf(_L("Clearing Latency Values\n"));
				GetLatencyValues(1,c,pV);
				break;
			case '2':
				DisplayMaxLatencyValues();
				break;
			case 'x':
			case 'X':
				exit=ETrue;
				break;
			default:
				break;
			}
		}

	test.End();
	return 0;
	}