kerneltest/e32test/resmanus/d_resmanusbtrace.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 16:34:26 +0300
branchRCL_3
changeset 43 c1f20ce4abcf
permissions -rw-r--r--
Revision: 201035 Kit: 201035

// Copyright (c) 2010 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\resmanus\d_resmanusbtrace.cpp
// 
//

#include <kernel/kernel.h>
#include <drivers/resource.h>
#include <drivers/resourcecontrol.h>
#include <drivers/resmanus_trace.h>
#include <drivers/resourcecontrol_trace.h>
#include "d_resmanusbtraceconst.h"
#include "d_resmanusbtrace.h"

class DTestFactory : public DLogicalDevice
//
// Test LDD factory
//
	{
public:
	DTestFactory();
	virtual TInt Install(); 					//overriding pure virtual
	virtual void GetCaps(TDes8& aDes) const;	//overriding pure virtual
	virtual TInt Create(DLogicalChannelBase*& aChannel); 	//overriding pure virtual
	};

class DTest1 : public DLogicalChannelBase
//
// Test logical channel
//
	{
public:
	virtual ~DTest1();
protected:
	virtual TInt DoCreate(TInt aUnit, const TDesC8* anInfo, const TVersion& aVer);
	virtual TInt Request(TInt aReqNo, TAny* a1, TAny* a2);

private:
	TInt DoSendLog(TLogInfo* aInfo);
	TInt ClientHandle() { return KClientHandle; }
	};



DECLARE_STANDARD_LDD()
	{
	return new DTestFactory;
	}

//
// Constructor
//
DTestFactory::DTestFactory()
	{

	}

TInt DTestFactory::Create(DLogicalChannelBase*& aChannel)
	{
//
// Create new channel
//
	aChannel=new DTest1;
	return aChannel?KErrNone:KErrNoMemory;
	}

TInt DTestFactory::Install()
//
// Install the LDD - overriding pure virtual
//
	{
	return SetName(&KLddName);
	}

void DTestFactory::GetCaps(TDes8& /*aDes*/) const
//
// Get capabilities - overriding pure virtual
//
	{
	}

TInt DTest1::DoCreate(TInt /*aUnit*/, const TDesC8* /*aInfo*/, const TVersion& /*aVer*/)
//
// Create channel
//
	{
	return KErrNone;
	}

DTest1::~DTest1()
//
// Destructor
//
	{
	}

TInt DTest1::Request(TInt aReqNo, TAny* a1, TAny* /*a2*/)
	{

	// 'Control' functions...
	switch(aReqNo)
		{
		// DoControl
		case RLddTest1::ECONTROL_SENDLOG:
		    TLogInfo info;
			DoSendLog(&info);
			Kern::ThreadRawWrite(&Kern::CurrentThread(), a1, &info, sizeof(info));
			break;
		}

	return KErrNone;
	}
	
class TestResource 
    {
public:
    TestResource(const TDesC8& aName, TInt aDefaultLevel)
        {
        iName = (HBuf8*)&aName;
        iDefaultLevel = aDefaultLevel;
        }
    HBuf* iName;
    TInt iDefaultLevel;
    TInt iResourceId;
    };

struct TestClient
    {
    TDes8* iName;
    TInt iClientId;
    };

struct TestCallback
    {
    TInt iResourceId;
    TInt iClientId;
    };

struct TestNotification
    {
    TestCallback iCallback;
    };

class TestRequest
    {
public:
    TInt ResourceId() {return iResourceId;}
    TInt ClientId() {return iClientId;}
    TInt Level() {return iLevel;}
    TInt iResourceId;
    TInt iClientId;
    TInt iLevel;
    };

TInt DTest1::DoSendLog(TLogInfo* aInfo)
	{
	TInt r = KErrNoMemory;
	
	TInt iClient = (TInt) KClient;
	TBuf<80> Buffer;
	TDes8* iUserNameUsed = &Buffer;
	Buffer.Append(KCLIENTNAME);
	Kern::Printf("PRM_US_OPEN_CHANNEL_START_TRACE");
	PRM_US_OPEN_CHANNEL_START_TRACE
	
	Kern::Printf("PRM_US_OPEN_CHANNEL_END_TRACE %x", (TInt)ClientHandle());
	PRM_US_OPEN_CHANNEL_END_TRACE
	
	TUint8 stateRes[3] = {KStatsRes1, KStatsRes2, KStatsRes3};
	Kern::Printf("PRM_US_REGISTER_CLIENT_START_TRACE");
	PRM_US_REGISTER_CLIENT_START_TRACE

	Kern::Printf("PRM_US_REGISTER_CLIENT_END_TRACE");
	PRM_US_REGISTER_CLIENT_END_TRACE
	
	Kern::Printf("PRM_US_DEREGISTER_CLIENT_START_TRACE");
	PRM_US_DEREGISTER_CLIENT_START_TRACE
	
    Kern::Printf("PRM_US_DEREGISTER_CLIENT_END_TRACE");
	PRM_US_DEREGISTER_CLIENT_END_TRACE	
	
	TUint resourceId = KResourceId;
    Kern::Printf("PRM_US_GET_RESOURCE_STATE_START_TRACE");
	PRM_US_GET_RESOURCE_STATE_START_TRACE
	
	TUint aResourceId = KResourceId;
	TUint aLevel = KLevel;
	TUint aClient = KClient;
	TUint aResult = KResult;
    Kern::Printf("PRM_US_GET_RESOURCE_STATE_END_TRACE");
	PRM_US_GET_RESOURCE_STATE_END_TRACE
	
	TUint newState = KLevel;
    Kern::Printf("PRM_US_SET_RESOURCE_STATE_START_TRACE");
	PRM_US_SET_RESOURCE_STATE_START_TRACE
	
    Kern::Printf("PRM_US_SET_RESOURCE_STATE_END_TRACE");
	PRM_US_SET_RESOURCE_STATE_END_TRACE
	
	Kern::Printf("PRM_US_CANCEL_GET_RESOURCE_STATE_START_TRACE");
	PRM_US_CANCEL_GET_RESOURCE_STATE_START_TRACE
	
	Kern::Printf("PRM_US_CANCEL_GET_RESOURCE_STATE_END_TRACE");
	PRM_US_CANCEL_GET_RESOURCE_STATE_END_TRACE
	
	Kern::Printf("PRM_US_CANCEL_SET_RESOURCE_STATE_START_TRACE");
	PRM_US_CANCEL_SET_RESOURCE_STATE_START_TRACE
	
	Kern::Printf("PRM_US_CANCEL_SET_RESOURCE_STATE_END_TRACE");
	PRM_US_CANCEL_SET_RESOURCE_STATE_END_TRACE
	
	TPowerResourceInfoV01 ResourceInfo;
	TPowerResourceInfoV01* pResInfo = &ResourceInfo;
	TestResource Resource(KRESOURCENAME, KDefaultLevel);
	TestResource* pR = &Resource;
	pResInfo->iMinLevel = KMinLevel;
	pResInfo->iMaxLevel = KMaxLevel;
	pResInfo->iDefaultLevel = KDefaultLevel;
	TUint resCount = KResCount;
    Kern::Printf("PRM_REGISTER_RESOURCE_TRACE");
	PRM_REGISTER_RESOURCE_TRACE
	
	TUint aClientId = KClientId;
	TBuf8<80> ClientName(KCLIENTNAME);
	SPowerResourceClient ResourceClient;
	SPowerResourceClient* pC = &ResourceClient;
	pC->iName = &ClientName;
    Kern::Printf("PRM_CLIENT_REGISTER_TRACE");
	PRM_CLIENT_REGISTER_TRACE
	
    Kern::Printf("PRM_CLIENT_DEREGISTER_TRACE");
	PRM_CLIENT_DEREGISTER_TRACE
	
	TInt aNewState = KLevel;
	pC->iClientId = KClientId;
	Kern::Printf("PRM_CLIENT_CHANGE_STATE_START_TRACE");
	PRM_CLIENT_CHANGE_STATE_START_TRACE

	pC->iClientId = KClientId;
	Kern::Printf("PRM_CLIENT_CHANGE_STATE_END_TRACE");
	PRM_CLIENT_CHANGE_STATE_END_TRACE
	
	TestNotification aN;
	TestNotification* pN = &aN;
	pN->iCallback.iResourceId = KResourceId;
	
    Kern::Printf("PRM_POSTNOTIFICATION_REGISTER_TRACE");
	PRM_POSTNOTIFICATION_REGISTER_TRACE

    Kern::Printf("PRM_POSTNOTIFICATION_DEREGISTER_TRACE");
	PRM_POSTNOTIFICATION_DEREGISTER_TRACE
	
    Kern::Printf("PRM_POSTNOTIFICATION_SENT_TRACE");
	PRM_POSTNOTIFICATION_SENT_TRACE
	
	TestCallback* pCb = &(pN->iCallback);
	pCb->iClientId = KClientId;
    Kern::Printf("PRM_CALLBACK_COMPLETION_TRACE");
	PRM_CALLBACK_COMPLETION_TRACE
	
	TInt size = KSize;
	PRM_MEMORY_USAGE_TRACE
	
	TestRequest aRequest;
	aRequest.iClientId = KClientId;
	aRequest.iResourceId = KResourceId;
	
	TDesC8* iName = iUserNameUsed;
    Kern::Printf("PRM_PSL_RESOURCE_GET_STATE_START_TRACE");
	PRM_PSL_RESOURCE_GET_STATE_START_TRACE
	
    Kern::Printf("PRM_RESOURCE_GET_STATE_START_TRACE");
	PRM_RESOURCE_GET_STATE_START_TRACE
	
	TInt retVal = KRetVal;
	TInt iCurLevel = KLevel;
	TInt aState = KLevel;
    Kern::Printf("PRM_PSL_RESOURCE_GET_STATE_END_TRACE");
	PRM_PSL_RESOURCE_GET_STATE_END_TRACE
	
    Kern::Printf("PRM_RESOURCE_GET_STATE_END_TRACE");
	PRM_RESOURCE_GET_STATE_END_TRACE
	
    Kern::Printf("PRM_RESOURCE_CANCEL_LONGLATENCY_OPERATION_TRACE");
	PRM_RESOURCE_CANCEL_LONGLATENCY_OPERATION_TRACE
	
	aRequest.iLevel = KLevel;
    Kern::Printf("PRM_PSL_RESOURCE_CHANGE_STATE_START_TRACE");
	PRM_PSL_RESOURCE_CHANGE_STATE_START_TRACE
	
    Kern::Printf("PRM_PSL_RESOURCE_CHANGE_STATE_END_TRACE");
	PRM_PSL_RESOURCE_CHANGE_STATE_END_TRACE
	
	TInt iDefaultLevel = KDefaultLevel;
	TInt iFlags = KFlags;
	TInt iMinLevel = KMinLevel;
	TInt iMaxLevel = KMaxLevel;
	TInt aReason = KErrNoMemory;
    Kern::Printf("PRM_PSL_RESOURCE_CREATE_TRACE");
	PRM_PSL_RESOURCE_CREATE_TRACE
	
    Kern::Printf("PRM_BOOTING_TRACE");
	PRM_BOOTING_TRACE
	
	TestResource* aPDRes = &Resource;
	aPDRes->iResourceId = KResourceId;
	TestClient Client;
	TestClient* aClientPtr = &Client;
	aClientPtr->iName = &ClientName;
	aClientPtr->iClientId = KClientId;
    Kern::Printf("PRM_REGISTER_STATIC_RESOURCE_WITH_DEPENDENCY_TRACE");
	PRM_REGISTER_STATIC_RESOURCE_WITH_DEPENDENCY_TRACE

	TestResource* pDR = &Resource;
	TInt level = KLevel;
    Kern::Printf("PRM_REGISTER_DYNAMIC_RESOURCE_TRACE");
	PRM_REGISTER_DYNAMIC_RESOURCE_TRACE
	
    Kern::Printf("PRM_DEREGISTER_DYNAMIC_RESOURCE_TRACE");
	PRM_DEREGISTER_DYNAMIC_RESOURCE_TRACE
	
	TestResource* pR1 = &Resource;
	TestResource* pR2 = &Resource;
    Kern::Printf("PRM_REGISTER_RESOURCE_DEPENDENCY_TRACE");
	PRM_REGISTER_RESOURCE_DEPENDENCY_TRACE
	
	TestResource* pDR1 = &Resource;
	TestResource* pDR2 = &Resource;
    Kern::Printf("PRM_DEREGISTER_RESOURCE_DEPENDENCY_TRACE");
	PRM_DEREGISTER_RESOURCE_DEPENDENCY_TRACE
	
	aInfo->iPR = &Resource;
	aInfo->iPC = &ResourceClient;
	aInfo->iPN = pN;
	aInfo->iPCb = pCb;
	aInfo->iPClient = &Client;
	aInfo->iPCallback = &(pN->iCallback);
	
	return KErrNone;
	}