kerneltest/e32test/power/d_lddpowerseqtest.cpp
changeset 0 a41df078684a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/e32test/power/d_lddpowerseqtest.cpp	Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,280 @@
+// Copyright (c) 2006-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\power\d_lddpowerseqtest.cpp
+// LDD for testing the power up and down sequence
+// 
+//
+
+#include <kernel/kernel.h>
+#include <kernel/kpower.h>
+#include "d_lddpowerseqtest.h"
+
+
+_LIT(KLitPower1,"PowerSeqTest1");
+_LIT(KLitPower2,"PowerSeqTest2");
+
+//
+// Variables to store asynchronous status request and time count user variables address.
+//
+TRequestStatus *aStatus_up1;
+TRequestStatus *aStatus_up2;
+TRequestStatus *aStatus_down1;
+TRequestStatus *aStatus_down2;
+TUint *time_power1down;
+TUint *time_power2down;
+TUint *time_power1up;
+TUint *time_power2up;
+TUint sleepTime;
+
+
+class DTest1;
+//
+// Power handler1
+//
+class DTest1PowerHandler : public DPowerHandler
+	{
+public:
+	DTest1PowerHandler();
+
+	void PowerUp();
+	void PowerDown(TPowerState);
+	};
+
+//
+// Power handler2
+//
+class DTest2PowerHandler : public DPowerHandler
+	{
+public:
+	DTest2PowerHandler();
+	void PowerUp();
+	void PowerDown(TPowerState);
+	};
+
+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);
+	DTest1PowerHandler power1;
+	DTest2PowerHandler power2;
+	};
+
+
+
+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
+//
+	{
+	//try to remove a handler that hasn't been added yet - should not cause any problems
+	power1.Remove();
+	//Add power handlers
+	power2.Add();
+	power1.Add();
+	return KErrNone;
+	}
+
+DTest1::~DTest1()
+//
+// Destructor
+//
+	{
+	power1.Remove();
+	power2.Remove();
+	//try to remove a handler twice - should not cause any problems
+	power2.Remove();
+	}
+
+TInt DTest1::Request(TInt aReqNo, TAny* a1, TAny* a2)
+	{
+//
+// Store status requests and time stamp variable for each power up and power down
+//
+
+	if(aReqNo<0)
+		{
+		// 'Request' functions...
+		TRequestStatus* s = (TRequestStatus*)a1;
+		TAny* args[2];
+		kumemget32(args,a2,sizeof(args)); // get user side arguments
+
+		switch(~aReqNo)
+			{
+			case RLddTest1::EPOWERDOWN_POWER1:
+				aStatus_down1 = s;
+				time_power1down = (TUint*)args[0];
+				break;
+
+			case RLddTest1::EPOWERDOWN_POWER2:
+				aStatus_down2 = s;
+				time_power2down = (TUint*)args[0];
+				break;
+
+			case RLddTest1::EPOWERUP_POWER1:
+				aStatus_up1 = s;
+				time_power1up = (TUint*)args[0];
+				break;
+
+			case RLddTest1::EPOWERUP_POWER2:
+				aStatus_up2 = s;
+				time_power2up = (TUint*)args[0];
+				break;
+			}
+		}
+	else
+		{
+		// 'Control' functions...
+		switch(aReqNo)
+			{
+			// DoControl
+			case RLddTest1::ESET_SLEEPTIME:
+				sleepTime = (TUint)a1;
+				break;
+			}
+		}
+
+	return KErrNone;
+	}
+
+DTest1PowerHandler::DTest1PowerHandler():DPowerHandler(KLitPower1)
+	{
+//
+// Power handler1 constructor
+//
+	}
+
+DTest2PowerHandler::DTest2PowerHandler():DPowerHandler(KLitPower2)
+	{
+//
+// Power handler2 constructor
+//
+	}
+
+
+void DTest1PowerHandler::PowerUp()
+	{
+//
+// Sleep for sometime to get different tick counts for comparision.
+// Copy the tick count to user variable and complete the request
+//
+	NKern::Sleep(sleepTime);
+
+	TUint temp = NKern::TickCount();
+	kumemput(time_power1up, (const TUint *)&temp, sizeof(temp));
+
+	Kern::RequestComplete(aStatus_up1, KErrNone);
+
+	PowerUpDone();
+
+	}
+
+void DTest2PowerHandler::PowerUp()
+	{
+//
+// Copy the tick count to user variable and complete the request
+//
+
+	TUint temp = NKern::TickCount();
+	kumemput(time_power2up, (const TUint *)&temp, sizeof(temp));
+
+	Kern::RequestComplete(aStatus_up2, KErrNone);
+
+	PowerUpDone();
+	}
+
+void DTest1PowerHandler::PowerDown(TPowerState /*aState*/)
+	{
+//
+// Copy the tick count to user variable and complete the request
+//
+
+	TUint temp = NKern::TickCount();
+	kumemput(time_power1down, (const TUint *)&temp, sizeof(temp));
+
+	Kern::RequestComplete(aStatus_down1, KErrNone);
+
+	PowerDownDone();
+	}
+
+void DTest2PowerHandler::PowerDown(TPowerState /*aState*/)
+	{
+//
+// Sleep for sometime to get different tick counts for comparision.
+// Copy the tick count to user variable and complete the request
+//
+
+	NKern::Sleep(sleepTime);
+
+	TUint temp = NKern::TickCount();
+	kumemput(time_power2down, (const TUint *)&temp, sizeof(temp));
+
+	Kern::RequestComplete(aStatus_down2, KErrNone);
+
+	PowerDownDone();
+	}