kerneltest/e32test/earlyextension/d_testearlyextension.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 09:24:54 +0200
changeset 43 96e5fb8b040d
permissions -rw-r--r--
Revision: 200951 Kit: 200951

// Copyright (c) 2007-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\earlyextension\d_testearlyextension.cpp
// 
//

#include <kernel/kernel.h>
#include "d_testearlyextension.h"
#include "earlyextension.h"

_LIT(KTestEarlyExtName, "D_TESTEARLYEXTENSION.LDD");

/** Factory class */
class DTestEarlyExtLddFactory : public DLogicalDevice
	{
public:
	DTestEarlyExtLddFactory();
	virtual TInt Install();
	virtual void GetCaps(TDes8 &aDes) const;
	virtual TInt Create(DLogicalChannelBase*& aChannel);
	static TTimeK* iTimeArray; //Pointer to store the time stamps.
	};

/** Logical channel */
class DTestEarlyExtension : public DLogicalChannelBase
	{
public:
	DTestEarlyExtension();
	~DTestEarlyExtension();
protected:
	virtual TInt DoCreate(TInt aUnit, const TDesC8* anInfo, const TVersion& aVer);
	virtual TInt Request(TInt aReqNo, TAny* a1, TAny* a2);
	virtual TInt RequestUserHandle(DThread* aThread, TOwnerType aType);
private:
	DThread* iClient;
	};

TTimeK* DTestEarlyExtLddFactory::iTimeArray = NULL;

/** Factory class */
DTestEarlyExtLddFactory::DTestEarlyExtLddFactory()
	{
    iParseMask=0;
    iUnitsMask=0;
	}

/** Entry point for this driver */
DECLARE_EXTENSION_WITH_PRIORITY(LATE_EXTENSION_PRIORITY)
	{
	// - In extension init1 create and installing ldd factory
	// - Allocating space for 2 array of time stamps
	// - Calling early extension export to get the time stamp stored during its entry point
	// - Taking another time stamp and storing.
	DTestEarlyExtLddFactory* device = new DTestEarlyExtLddFactory;
	if(!device)
		return KErrNoMemory;
	device->iTimeArray = (TTimeK*)new(TTimeK[2]);
	if(!device->iTimeArray)
		{
		Kern::Printf("Memory not allocated");
		delete device;
		return KErrNoMemory;
		}
	TInt r = Kern::InstallLogicalDevice(device);
	if(r == KErrNone)
		{
		TTimeK temp;
		TestEarlyExtension::GetTimeStamp(temp);
		device->iTimeArray[0] = temp;
		device->iTimeArray[1] = Kern::SystemTime();
		}
	return r;
	}

DECLARE_EXTENSION_LDD()
	{
	return new DTestEarlyExtLddFactory;
	}
/** Second stage constuctor */
TInt DTestEarlyExtLddFactory::Install()
	{
    return(SetName(&KTestEarlyExtName));
	}

/** Device capabilities */
void DTestEarlyExtLddFactory::GetCaps(TDes8& aDes)const
	{
	}

/** Create logical channel, only open of one channel is allowed at a time */
TInt DTestEarlyExtLddFactory::Create(DLogicalChannelBase*& aChannel)
	{
    if (iOpenChannels != 0) //A Channel is already open
		return KErrInUse;
    aChannel = new DTestEarlyExtension;
    if(!aChannel)
		return KErrNoMemory;
    return KErrNone;
	}

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

/** Constructor of Logical channel */
DTestEarlyExtension::DTestEarlyExtension()
	{
	iClient = &Kern::CurrentThread();
	((DObject*)iClient)->Open();;
	}

/** Destructor */
DTestEarlyExtension::~DTestEarlyExtension()
	{
	// Close our reference on the client thread
	Kern::SafeClose((DObject*&)iClient,NULL);
	}

/** Handle user side requests */
TInt DTestEarlyExtension::Request(TInt aReqNo, TAny* a1, TAny* a2)
	{
	switch(aReqNo)
		{
		case (RLddEarlyExtensionTest::EGET_SYSTEM_TIME_STAMPS):
			{ //Get time stamps
			kumemput(a1, &(((DTestEarlyExtLddFactory*)iDevice)->iTimeArray[0]), sizeof(Int64));
			kumemput(a2, &(((DTestEarlyExtLddFactory*)iDevice)->iTimeArray[1]), sizeof(Int64));
			return KErrNone;
			}
		}
	return KErrNotSupported;
	}

/** Restricting handle duplication */
TInt DTestEarlyExtension::RequestUserHandle(DThread* aThread, TOwnerType aType)
	{
	if (aType!=EOwnerThread || aThread!=iClient)
		return KErrAccessDenied;
	return KErrNone;
	}