emulator/emulatorbsp/specific/winscomm.h
author William Roberts <williamr@symbian.org>
Mon, 08 Mar 2010 21:44:28 +0000
branchCompilerCompatibility
changeset 5 991e374445d0
parent 0 cec860690d41
permissions -rw-r--r--
Create CompilerCompatibility branch

// 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 "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:
// wins/specific/winscomm.h
// 
//

#ifndef __M32COMM_H__
#define __M32COMM_H__
#include <platform.h>
//#include <kpower.h>
#include <d32comm.h>
#include <e32ver.h>
//
const TInt KCommsMajorVersionNumber=1;
const TInt KCommsMinorVersionNumber=1;
const TInt KCommsBuildVersionNumber=KE32BuildVersionNumber;

//
enum TStopMode {EStopNormal,EStopPwrDown,EStopEmergency};
//
//
class DChannelComm;
class DComm : public DBase
	{
public:
	virtual TInt Start() =0;
	virtual void Stop(TStopMode aMode) =0;
	virtual void Break(TBool aState) =0;
	virtual void Write(DThread*,TAny*,TInt) = 0;
	virtual void Read(DThread*,TAny*,TInt) = 0;
	virtual void NotifySignals(DThread*, TInt) = 0;
	virtual void NotifyDataAvailable() = 0;
	virtual TUint Signals() const =0;
	virtual void SetSignals(TUint aSetMask,TUint aClearMask) =0;
	virtual TInt ValidateConfig(const TCommConfigV01 &aConfig) const =0;
	virtual void Configure(TCommConfigV01 &aConfig) =0;
	virtual void Caps(TDes8 &aCaps) const =0;
	virtual void CheckConfig(TCommConfigV01& aConfig)=0;
	virtual TDfcQue* DfcQ(TInt aUnit)=0;
	inline void SetCurrent(TInt aCurrent);
	inline TBool Transmitting();
	virtual TInt RxCount() =0;
	virtual void ResetBuffers(TBool) = 0;
	virtual TInt SetRxBufferSize(TInt aSize) = 0;
	virtual TInt RxBufferSize() =0;
	virtual TDes8* RxBuffer() =0;
	virtual TBool AreAnyPending() = 0;
	virtual void ReadCancel() = 0;
	virtual void WriteCancel() = 0;
	virtual void SignalChangeCancel() = 0;
	virtual inline TBool LineFail() =0;

public:
	DChannelComm *iLdd;
	TBool iTransmitting;
	TUint8 * iInBufPtr;
	TUint8 * iOutBufPtr;
	};


class DDeviceComm : public DLogicalDevice
	{
public:
	DDeviceComm();
	virtual TInt Install();
	virtual void GetCaps(TDes8 &aDes) const;
	virtual TInt Create(DLogicalChannelBase*& aChannel);
	};

//class DCommPowerHandler;
class DChannelComm : public DLogicalChannel
	{
public:
	enum TState {EOpen,EActive,EClosed};
	enum TRequest {ERx=1, ETx=2, ESigChg=4, ERxDA=8, EBreak=16, EAll=0xff};

	DChannelComm();
	~DChannelComm();
	inline void SetStatus(TState aStatus);
	TInt TurnaroundSet(TUint aNewTurnaroundMilliSeconds);
	TBool TurnaroundStopTimer();
	TInt TurnaroundClear();
	static void TurnaroundStartDfc(TAny* aSelf);
	void TurnaroundStartDfcImplementation(TBool inIsr);
	static void TurnaroundTimeout(TAny* aSelf);
	void TurnaroundTimeoutImplementation(void);

protected:
	virtual TInt DoCreate(TInt aUnit, const TDesC8* aInfo, const TVersion& aVer);
	virtual void HandleMsg(TMessageBase* aMsg);
	void DoCancel(TInt aMask);
	TInt DoControl(TInt aId, TAny* a1, TAny* a2);
	TInt DoRequest(TInt aId, TRequestStatus* aStatus, TAny* a1, TAny* a2);
	void Start();
	void Shutdown();
	void BreakOn();
	void BreakOff();
	void ResetBuffers(TBool aResetTx);
	void DoCompleteRx();
	void DoCompleteTx();
	void DoSignalNotify();
	void DoRxDataAvailable();
	void Complete(TInt aMask, TInt aReason);
	inline void CompleteRead()	{ iRxCompleteDfc.Add(); }
	inline void CompleteWrite() { iTxCompleteDfc.Add(); }
protected:
	inline void Write(DThread* aT, TAny* aP, TInt aL) {((DComm*)iPdd)->Write(aT, aP,aL);}
	inline void Read(DThread* aT, TAny* aP, TInt aL) {((DComm*)iPdd)->Read(aT, aP,aL);}
	inline void NotifySignals(DThread* aThread, TInt aMask) {((DComm*)iPdd)->NotifySignals(aThread, aMask);}
	inline void NotifyDataAvailable() {((DComm*)iPdd)->NotifyDataAvailable(); }
	inline TInt PddStart();
	inline void Stop(TStopMode aMode);
	inline void PddBreak(TBool aState);
	inline TUint Signals() const;
	inline void SetSignals(TUint aSetMask,TUint aClearMask);
	inline TInt ValidateConfig(const TCommConfigV01 &aConfig) const;
	inline void PddConfigure(TCommConfigV01 &aConfig);
	inline void PddCaps(TDes8 &aCaps) const;
	inline void PddCheckConfig(TCommConfigV01& aConfig);
	inline TBool Transmitting();
	inline TInt BufferSize();
	inline void ReadCancel();
	inline void WriteCancel();
	inline void SignalChangeCancel();

	static void FinishBreakDfc(TAny* aSelf);
	void QueueFinishBreakDfc();
	static void FinishBreak(TAny* aSelf);
	void FinishBreakImplementation(TInt aBreakError);
private:
//	static void PowerUpDfc(TAny* aPtr);
//	static void PowerDownDfc(TAny* aPtr);
	static void CompleteRxDfc(TAny* aPtr);
	static void CompleteTxDfc(TAny* aPtr);
	static void SignalNotifyDfc(TAny* aPtr);
	static void RxDataAvailableDfc(TAny* aPtr);
	inline TInt RxCount();
	inline TInt RxBufferSize();
	inline TDes8* RxBuffer();
	inline TInt SetRxBufferSize(TInt aSize);
	inline TBool AreAnyPending() const;
//	void UpdateSignals();
	void UpdateAndProcessSignals();
	void InitiateRead(TAny* aRxDes, TInt aLength);
	void InitiateWrite(TAny* aTxDes, TInt aLength);
	void InitiateNotifySignals(TAny* aResult, TInt aMask);
	void NotifyReadDataAvailable();
//	TUint FailSignals(TUint aHandshake);
//	TUint HoldSignals(TUint aHandshake);
//	TUint FlowControlSignals(TUint aHandshake);
//	TUint AutoSignals(TUint aHandshake);
	TInt SetConfig(TCommConfigV01& aConfig);
//	void CheckOutputHeld();
//	void ReleaseBuffers();
	inline TBool LineFail();

	// Min Turnaround time between Rx and Tx
	TUint		iTurnaroundMicroSeconds;		// delay after a receive before transmission in us
	TUint		iTurnaroundMinMilliSeconds;		// delay after a receive before transmission in ms
	TUint       iTurnaroundTimerStartTime;      // stores the start time of the turnaround timer.
	TUint8      iTurnaroundTimerStartTimeValid; // stores turnaround timer status 0 after boot, 1 if the timestamp is valid, and 2 if invalid
	TUint8		iTurnaroundTimerRunning;		// a receive has started the timer
	TUint8		iTurnaroundTransmitDelayed;		// a transmission is held until time elapses after a receive
	TUint8		iSpare;
	NTimer		iTurnaroundTimer;				// used to delay transmission after a receive
	TDfc		iTurnaroundDfc;					// used in interrupt space, to trigger a call in user space

	TAny*		iTurnaroundTxDesPtr;			// client descriptor awaiting transmission
	TInt		iTurnaroundTxDesLength;			// initial size of tx descriptor

	// Breaks
	TTickLink iBreakTimer;
	TDfc		 iBreakDfc;
	TRequestStatus* iBreakStatus;
	TInt		iBreakTimeMicroSeconds;
	TBool 	iTurnaroundBreakDelayed;
	TAny*		iBreakDelayedTxDesPtr;			// client descriptor awaiting transmission
	TInt		iBreakDelayedTxDesLength;			// initial size of tx descriptor
	TBool		iBreakDelayedTx;
public:
	// Port configuration
	TCommConfigV01 iConfig;

	// General items
	DThread* iClient;
	TAny* iClientDestPtr;
//	DCommPowerHandler* iPowerHandler;
//	TDfc iPowerUpDfc;
//	TDfc iPowerDownDfc;
//	TUint32 iPowerDownMask;
	TState iStatus;
	TDfc iRxCompleteDfc;
	TDfc iTxCompleteDfc;
	TDfc iRxDataAvailableDfc;
	TDfc iSigNotifyDfc;
	TUint iFlags;				//
	TUint iSignals;				// State of handshake lines
//	TUint iFailSignals;			// 1 bit means line low causes line fail error
//	TUint iHoldSignals;			// 1 bit means line low halts TX
//	TUint iFlowControlSignals;	// 1 bit means signal is used for RX flow control
//	TUint iAutoSignals;			// 1 bit means signal is high when channel is open
	TBool iShutdown;			// ETrue means device is being closed
	TBool iMsgHeld;				// ETrue means a message has been held up waiting power on

	// RX client related items
	TInt iRxError;
	TRequestStatus* iRxStatus;


	// TX client related items
	TInt iTxError;
	TRequestStatus* iTxStatus;

	// DataAvailable client related items
	TInt iRxDAError;
	TRequestStatus* iRxDAStatus;

	// Signal change notification
	TInt iSignalError;
	TRequestStatus* iSignalStatus;	
	TUint* iClientSignalResultPtr;	//ptr to uint in client address space
	TUint iSignalResult;			//holds result of the signal (in Symbian OS values)
	};

//class DCommPowerHandler : public DPowerHandler
//	{
//public:
//	DCommPowerHandler(DChannelComm* aChannel);
//	virtual TInt DoPowerUp();
//	virtual void DoPowerDown(TUint32 aPowerDownMask);
//	virtual void DoEmergencyPowerDown();
//public:
//	DChannelComm* iChannel;
//	};

#include "winscomm.inl"

#endif