kerneltest/f32test/ext/t_logext.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 23 Dec 2009 11:43:31 +0000
changeset 4 56f325a607ea
parent 0 a41df078684a
permissions -rw-r--r--
Revision: 200951 Kit: 200951

// Copyright (c) 2002-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:
// f32test\ext\logext.cpp
// extension that records/prints out accesses to each function and length of reads and writes
// 
//

#include <f32fsys.h>

struct TAccessLength
	{
	TInt iless512;
	TInt i512;
	TInt imore512;
	};

class CLoggerExtProxyDrive : public CBaseExtProxyDrive
	{
public:
	static CLoggerExtProxyDrive* NewL(CProxyDrive* aProxyDrive, CMountCB* aMount);
	~CLoggerExtProxyDrive();
public:
	virtual TInt Initialise();
	virtual TInt Dismounted();
	virtual TInt Enlarge(TInt aLength);
	virtual TInt ReduceSize(TInt aPos, TInt aLength);
	virtual TInt Read(TInt64 aPos,TInt aLength,const TAny* aTrg,TInt aThreadHandle,TInt anOffset);
	virtual TInt Read(TInt64 aPos,TInt aLength,TDes8& aTrg);
	virtual TInt Write(TInt64 aPos,TInt aLength,const TAny* aSrc,TInt aThreadHandle,TInt anOffset);
	virtual TInt Write(TInt64 aPos,const TDesC8& aSrc);
	virtual TInt Caps(TDes8& anInfo);
	virtual TInt Format(TFormatInfo& anInfo);
	virtual TInt GetInterface(TInt aInterfaceId,TAny*& aInterface,TAny* aInput);
private:
	CLoggerExtProxyDrive(CProxyDrive* aProxyDrive, CMountCB* aMount);
private:
	TInt iInitialise;
	TInt iDismounted;
	TInt iEnlarge;
	TInt iReduceSize;
	TInt iReadThread;
	TAccessLength iReadThreadLength;
	TInt iRead;
	TAccessLength iReadLength;
	TInt iWriteThread;
	TAccessLength iWriteThreadLength;
	TInt iWrite;
	TAccessLength iWriteLength;
	TInt iCaps;
	TInt iFormat;
	};

class CLoggerProxyDriveFactory : public CProxyDriveFactory
	{
public:
	CLoggerProxyDriveFactory();
	virtual TInt Install();			
	virtual CProxyDrive* NewProxyDriveL(CProxyDrive* aProxy,CMountCB* aMount);
	};



LOCAL_C void LogLength(TAccessLength& aAccess,TInt aLength)
//
//
//
	{
	if(aLength<512)
		{
		aAccess.iless512++;
		}
	else if(aLength==512)
		{
		aAccess.i512++;
		}
	else
		aAccess.imore512++;
	}

LOCAL_C void PrintLength(TAccessLength& aAccess)
//
//
//
	{
	RDebug::Print(_L("\t<512 = %d"),aAccess.iless512);
	RDebug::Print(_L("\t 512 = %d"),aAccess.i512);
	RDebug::Print(_L("\t>512 = %d"),aAccess.imore512);
	}


CLoggerExtProxyDrive* CLoggerExtProxyDrive::NewL(CProxyDrive* aProxyDrive, CMountCB* aMount)
//
//
//
	{
	CLoggerExtProxyDrive* temp=new(ELeave) CLoggerExtProxyDrive(aProxyDrive,aMount);
	return(temp);
	}


CLoggerExtProxyDrive::CLoggerExtProxyDrive(CProxyDrive* aProxyDrive, CMountCB* aMount):CBaseExtProxyDrive(aProxyDrive,aMount)
	{
	RDebug::Print(_L("CLoggerExtProxyDrive::CLoggerExtProxyDrive"));
	}

CLoggerExtProxyDrive::~CLoggerExtProxyDrive()
//
//
//
	{
	// print out the figures obtained
	RDebug::Print(_L("Initialise = %d"),iInitialise);
	RDebug::Print(_L("Dismounted = %d"),iDismounted);
	RDebug::Print(_L("Enlarge = %d"),iEnlarge);
	RDebug::Print(_L("ReduceSize = %d"),iReduceSize);
	RDebug::Print(_L("Read Thread = %d"),iReadThread);
	if(iReadThread)
		PrintLength(iReadThreadLength);
	RDebug::Print(_L("Read = %d"),iRead);
	if(iRead)
		PrintLength(iReadLength);
	RDebug::Print(_L("Write Thread = %d"),iWriteThread);
	if(iWriteThread)
		PrintLength(iWriteThreadLength);
	RDebug::Print(_L("Write = %d"),iWrite);
	if(iWrite)
		PrintLength(iWriteLength);
	RDebug::Print(_L("Caps = %d"),iCaps);
	RDebug::Print(_L("Format = %d"),iFormat);
	}

TInt CLoggerExtProxyDrive::Initialise()
//
//
//
	{
	RDebug::Print(_L("CLoggerExtProxyDrive::Initialise()"));
	++iInitialise;
	return(CBaseExtProxyDrive::Initialise());
	}

TInt CLoggerExtProxyDrive::Dismounted()
//
//
//
	{
	RDebug::Print(_L("CLoggerExtProxyDrive::Dismounted()"));
	++iDismounted;
	return(CBaseExtProxyDrive::Dismounted());
	}

TInt CLoggerExtProxyDrive::Enlarge(TInt aLength)
//
//
//
	{
	++iEnlarge;
	return(CBaseExtProxyDrive::Enlarge(aLength));
	}


TInt CLoggerExtProxyDrive::ReduceSize(TInt aPos, TInt aLength)
//
//
//
	{
	++iReduceSize;
	return(CBaseExtProxyDrive::ReduceSize(aPos,aLength));
	}

TInt CLoggerExtProxyDrive::Read(TInt64 aPos,TInt aLength,const TAny* aTrg,TInt aThreadHandle,TInt anOffset)
//
//
//
	{
	++iReadThread;
	LogLength(iReadThreadLength,aLength);
	return(CBaseExtProxyDrive::Read(aPos,aLength,aTrg,aThreadHandle,anOffset));
	}

TInt CLoggerExtProxyDrive::Read(TInt64 aPos,TInt aLength,TDes8& aTrg)
//
//
//
	{
	++iRead;
	LogLength(iReadLength,aLength);
	return(CBaseExtProxyDrive::Read(aPos,aLength,aTrg));
	}

TInt CLoggerExtProxyDrive::Write(TInt64 aPos,TInt aLength,const TAny* aSrc,TInt aThreadHandle,TInt anOffset)
//
//
//
	{
	++iWriteThread;
	LogLength(iWriteThreadLength,aLength);
	return(CBaseExtProxyDrive::Write(aPos,aLength,aSrc,aThreadHandle,anOffset));
	}

TInt CLoggerExtProxyDrive::Write(TInt64 aPos,const TDesC8& aSrc)
//
//
//
	{
	++iWrite;
	LogLength(iWriteLength,aSrc.Length());
	return(CBaseExtProxyDrive::Write(aPos,aSrc));
	}

TInt CLoggerExtProxyDrive::Caps(TDes8& anInfo)
//
//
//
	{
	++iCaps;
	return(CBaseExtProxyDrive::Caps(anInfo));
	}

TInt CLoggerExtProxyDrive::Format(TFormatInfo& anInfo)
//
//
//
	{
	++iFormat;
	return(CBaseExtProxyDrive::Format(anInfo));
	}


TInt CLoggerExtProxyDrive::GetInterface(TInt aInterfaceId,TAny*& aInterface,TAny* aInput)
	{
	switch(aInterfaceId)
		{
		// file caching supported, so pass query on to next extension
		case ELocalBufferSupport:
			return CBaseExtProxyDrive::LocalBufferSupport();

		default:
			return CBaseExtProxyDrive::GetInterface(aInterfaceId, aInterface, aInput);
		}
	}

CLoggerProxyDriveFactory::CLoggerProxyDriveFactory()
//
//
//
	{
	RDebug::Print(_L("CLoggerProxyDriveFactory::CLoggerProxyDriveFactory"));
	}

TInt CLoggerProxyDriveFactory::Install()
//
//
//
	{
	_LIT(KLoggerName,"Logger");
	return(SetName(&KLoggerName));
	}


CProxyDrive* CLoggerProxyDriveFactory::NewProxyDriveL(CProxyDrive* aProxy,CMountCB* aMount)
//
//
//
	{
	return(CLoggerExtProxyDrive::NewL(aProxy,aMount));
	}

extern "C" {

EXPORT_C CProxyDriveFactory* CreateFileSystem()
//
// Create a new file system
//
	{
	return(new CLoggerProxyDriveFactory());
	}
}