kerneltest/e32test/examples/convert1/convert1_dev.h
author Tom Cosgrove <tom.cosgrove@nokia.com>
Fri, 28 May 2010 16:26:05 +0100
branchRCL_3
changeset 29 743008598095
parent 0 a41df078684a
permissions -rw-r--r--
Fix for bug 2283 (RVCT 4.0 support is missing from PDK 3.0.h) Have multiple extension sections in the bld.inf, one for each version of the compiler. The RVCT version building the tools will build the runtime libraries for its version, but make sure we extract all the other versions from zip archives. Also add the archive for RVCT4.

// Copyright (c) 2005-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:
// Shared Chunks in its implementation.
// 
//

/**
 @file Kernel side interfaces to example data converter device driver which uses
 @publishedPartner
 @prototype 9.1
*/

#ifndef __CONVERT1_DEV_H__
#define __CONVERT1_DEV_H__

/**
  Logical Device (factory class) for 'Convert1'
*/
class DConvert1Factory : public DLogicalDevice
	{
public:
	DConvert1Factory();
	~DConvert1Factory();
	//	Inherited from DLogicalDevice
	virtual TInt Install();
	virtual void GetCaps(TDes8& aDes) const;
	virtual TInt Create(DLogicalChannelBase*& aChannel);
	// Resource handling methods
	TInt ClaimResource(TInt& aResourceId);
	void ReleaseResource(TInt aResourceId);
private:
	NFastMutex iResourceMutex;	/**< Mutex to protect access to iResourceFlags */
	TUint iResourceFlags;		/**< Bitfield of flags representing device resources available for use.
								     I.e. iResourceFlags&(1<<resourceId) is true if resource 'resourceId' is free. */
	};

/**
  Class representing a buffer of data
*/
class DChunkBuffer
	{
public:
	DChunkBuffer();
	~DChunkBuffer();
	TInt Create(TInt aSize);
	void Destroy();
	TInt SetMaxSize(TInt aMaxSize);
	TInt Open(TAny* aAddress, TInt aSize, TBool aWrite=EFalse);
	TInt Open(TInt aChunkHandle, TInt aOffset, TInt aSize, TBool aWrite=EFalse);
	void Close();
	TInt Copy(TAny* aAddress, TInt aSize);
private:
	TInt SetPhysicalAddresses(TInt aSize);
public:
	DChunk* iChunk;				/**< The chunk which contains the buffer */
	TInt iChunkOffset;			/**< Offset, in bytes, of buffer start within the chunk */
	TInt iMaxSize;				/**< Maximum size of buffer n bytes */
	TLinAddr iChunkBase;		/**< Linear address in kernel process for the start of the chunk  */
	TUint32 iChunkMapAttr;		/**< MMU mapping attributes for chunk */
	TPhysAddr iPhysicalAddress;	/**< Physical address of buffer. KPhysAddrInvalid if buffer not physically contiguous */
	TPhysAddr* iPhysicalPages;	/**< List of physical addresses for buffer pages. 0 if buffer is physically contiguous */
	};

/**
  Logical Channel class for 'Convert1'
*/
class DConvert1Channel : public DLogicalChannelBase
	{
public:
	DConvert1Channel(DConvert1Factory* aFactory);
	virtual ~DConvert1Channel();
	//	Inherited from DObject
	virtual TInt RequestUserHandle(DThread* aThread, TOwnerType aType);
	// Inherited from DLogicalChannelBase
	virtual TInt DoCreate(TInt aUnit, const TDesC8* anInfo, const TVersion& aVer);
	virtual TInt Request(TInt aReqNo, TAny* a1, TAny* a2);
private:
	// Panic reasons
	enum TPanic
		{
		ERequestFromWrongThread=1,
		ERequestAlreadyPending
		};
	// Implementation for the differnt kinds of messages sent through RBusLogicalChannel
	TInt DoControl(TInt aFunction, TAny* a1, TAny* a2);
	TInt DoRequest(TInt aNotReqNo, TAny* a1, TAny* a2);
	TInt DoCancel(TUint aMask);
	// Methods for configuration
	TInt GetConfig(TDes8* aConfigBuf);
	TInt SetConfig(const TDesC8* aConfigBuf,RConvert1::TBufferInfo* aBufferInfo);
	// Methods for capturing images
	void ConvertDes(const TDesC8* aSrc,TRequestStatus* aRequestStatus);
	void ConvertChunk(const RConvert1::TConvertArgs* aSrcArgs,TRequestStatus* aRequestStatus);
	void ConvertInChunk(TInt aSize,TRequestStatus* aRequestStatus);
	void ConvertCancel();
	void ConvertComplete(TInt aResult);
	static void ConvertDfcTrampoline(TAny* aSelf);
	void ConvertDfc();
	// Methods which program the convert hardware
	void DoConvertStart(TInt aOffset,TInt aSize);
	void DoConvertCancel();
private:
	DConvert1Factory* iFactory;	/**< Pointer to device driver factory object */
	TInt iResourceId;			/**< The id of the device hardware resource owned by this channel */

	NFastMutex iConvertMutex;	/**< Mutex to protect access to driver state */

	DChunkBuffer* iSource;		/**< Buffer containing the converter's input data */
	DChunkBuffer iInBuffer;		/**< Buffer into which client supplied data can be copied */
	DChunkBuffer iOutBuffer;	/**< Buffer containing the converter's output data */
	DChunkBuffer iClientBuffer;	/**< Buffer representing client supplied chunk data */

	DThread* iClient;			/**< The single client thread for this channel */
	TRequestStatus* iConvertRequestStatus;	/**< The request status for client ConvertImage request */

	RConvert1::TConfig iConfig;	/**< The driver configuration information */

	NTimer iConvertTimer;		/**< Timer used to emulate image capture hardware */
	};

#endif