cbsref/csyrefplugins/csy27010/src/PortC32Interface.cpp
author hgs
Mon, 09 Aug 2010 17:35:42 +0100
changeset 58 980b3d0c4069
parent 44 8b72faa1200f
permissions -rw-r--r--
201027_10
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     1
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     2
// * Copyright 2004 Neusoft America Inc.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     3
// * All rights reserved.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     4
// * This component and the accompanying materials are made available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     5
// * under the terms of the Eclipse Public License v1.0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     6
// * which accompanies this distribution, and is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     7
// * at the URL "http://www.eclipse.org/legal/epl-v10.html".
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     8
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     9
// * Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    10
// * Keith Collins (Neusoft America Inc.)  original software development and additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    11
// * Thomas Gahagen (Neusoft America Inc.)  additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    12
// * Zhen Yuan (Neusoft America Inc.)  additional code and modifications.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    13
// *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    14
// * Description:  This file contains the implementation for the CPortC32Interface class.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// *               This class contains methods which are invoked by C32 when the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
// *               associated client RComm public API is invoked. These methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
// *               are used to create, configure, read, write, and close logical
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
// *               serial ports. Instances of this class are created by the CSY's
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
// *               Port Factory.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
// PortC32Interface.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
/** @file PortC32Interface.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
#include <cdbcols.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
#include "PortC32Interface.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
#include "Portfactory.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
#include "Mux0710Protocol.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
#include "CsyMsgBufBPFrame.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
#include "ChannelMgrCmdData.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
#include "CommFrameReaderAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
#include "CsyDebugLogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
#include "CsyGlobals.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
#include "CommFrameWriterAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
CPortC32Interface* CPortC32Interface::NewL(CPortFactory& aPortFactory, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
										   CPortFactory::TC32PortInfo& aPortInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
 * This method uses two phase construction and the cleanup stack to create
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
 * an instance of class CPortC32Interface.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
 * @param aPortFactory - Reference to the port factory
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
 * @param aPortInfo - Reference to the port information
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
 * @return Pointer to the created instance
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
	_LOG_L4C1( "CPortC32Interface::NewL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
	CPortC32Interface* self = new(ELeave) CPortC32Interface(aPortFactory, aPortInfo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
	TCleanupItem closeSelf(CPortFactory::CloseObject, self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
	CleanupStack::PushL(closeSelf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
	CleanupStack::Pop(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
CPortC32Interface::~CPortC32Interface()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
 * Destructor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
	_LOG_L4C1( ">>CPortC32Interface::~CPortC32Interface");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
	// let port factory know we are deleted
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
	iPortFactory.RemoveC32Port(this);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
	CompleteOutstandingRequest();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
	iMuxChannel->Close(this);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
	if (iReadBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
		_LOG_L3C1("Delete read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
		delete iReadBuf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
	_LOG_L4C1( "<<CPortC32Interface::~CPortC32Interface");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
CPortC32Interface::CPortC32Interface(CPortFactory& aPortFactory,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
									 CPortFactory::TC32PortInfo& aPortInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
 * Constructor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
 * @param aPortFactory - Reference to the port factory
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
 * @param aPortInfo - Reference to the port information
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
: CPortC32InterfaceBase(aPortFactory, aPortInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
	{}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
void CPortC32Interface::ConstructL(void)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
 * Safe constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
	_LOG_L4C1( "CPortC32Interface::ConstructL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
	CPortC32InterfaceBase::ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
/********************************************************************************/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
/*               Start of utility methods for CPortC32InterfaceBase                 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
/********************************************************************************/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
TInt CPortC32Interface::QueryReceiveBuffer(TInt& aLength) const
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
 * Called by C32 when the client queries the size of the receive buffer,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
 * which returns the number of receive characters available to be read by
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
 * the C32 client RComm instance.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
 * @param aLength - Reference to client's buffer length variable
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
 * @return KErrNone
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	_LOG_L4C2( "CPortC32Interface::QueryReceiveBuffer [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
	aLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
	if (iReadBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
		aLength = iReadBuf->iMsg.Length();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
		_LOG_L4C2("iReadBuf aLength=%d", aLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	else if (!iFramesWaitingToBeReadList.IsEmpty())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
		CCsyMsgBufBpFrame* frame = iFramesWaitingToBeReadList.First();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
		if ((frame)&&(frame->iMsg.Length() >= (KAdvOptionHeaderSize + KChecksumSize)))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
#ifdef _27010ADVANCEOPTION
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
			aLength = frame->iMsg.Length() - (KAdvOptionHeaderSize + KChecksumSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
#else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
			aLength = frame->iMsg.Length() - (KBasicOptionHeaderSize + KChecksumSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
			_LOG_L4C2("iFramesWaitingToBeReadList aLength=%d", aLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
	return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
void CPortC32Interface::ResetBuffers(TUint aFlags)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
 * Called by C32 when the client requests to reset the buffers,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
 * by removing all receive and/or transmit messages according to
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
 * the specified flags.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
 * @param aFlags Indicate which buffers (receive and/or transmit) should be reset
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
	_LOG_L4C2(">>CPortC32Interface::ResetBuffers [aFlags=%d]", aFlags);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
	_LOG_L4C2("[port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
	if (aFlags & KCommResetRx)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
		_LOG_L4C1("Removing all messages intended for the C32 client");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
		RemoveWaitingAllFrames();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
	if (aFlags & KCommResetTx)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
		_LOG_L4C1("Removing all messages intended for the modem");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
		GetMuxChannel()->WriteCancel();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
	_LOG_L4C1("<<CPortC32Interface::ResetBuffers");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
void CPortC32Interface::SendFrameToClient(CCsyMsgBufBpFrame* aFrame)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
 * This method is called by a CSY Channel object when it has a single
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
 * frame to send to a C32 client RComm object.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
 * @param aFrame - Pointer to message to send to client
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
	_LOG_L4C2( "CPortC32Interface::SendFrameToClient [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
	if (aFrame)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
		// check if queue is empty
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
		TBool trigger = iFramesWaitingToBeReadList.IsEmpty();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
		iFramesWaitingToBeReadList.AddLast(*aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
		if (trigger)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
			_LOG_L4C1("No packets already waiting");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
			if (iIsReadInProgress)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
				_LOG_L4C1("A read is outstanding");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
				ReadFromBufOrQueue();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
		// inform client new data is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
		SetDataAvailable();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
	else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
		//MAF __ASSERT_DEBUG(EFalse, PANIC(KPanicIllegalState));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
TBool CPortC32Interface::ReadFromBufOrQueue()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
 * This method is called to read from buffer or the frame list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
 * It will read as much as possible.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
 * @return ETrue if complete the read request
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
	_LOG_L4C2( ">>CPortC32Interface::ReadFromBufOrQueue [port=%d]",GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
	TBool completedTheReadRequest = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
	TInt err = KErrGeneral;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
	TBool cont;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
	do
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
		cont = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
		if(iReadBuf==NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
			//Read data from the frame list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
			if (!iFramesWaitingToBeReadList.IsEmpty())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
				_LOG_L4C1("Set to first item");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
				iReadBuf = iFramesWaitingToBeReadList.First();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
				if (iReadBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
					_LOG_L4C1("iReadBuf not null");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
					// remove msg buf from client list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
					iFramesWaitingToBeReadList.Remove(*iReadBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
					// subtract checksum field
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
					TInt frameLength = iReadBuf->iMsg.Length();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
					_LOG_L4C2("New read buffer frameLength=%d",frameLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
					if (frameLength >= KBasicOptionHeaderSize)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
						iReadBuf->iMsg.SetLength(frameLength - KChecksumSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
						// remove leading header ints from frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
#ifdef _27010ADVANCEOPTION
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
						iReadBuf->iMsg.Delete(0, KAdvOptionHeaderSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
#else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
						iReadBuf->iMsg.Delete(0, KBasicOptionHeaderSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
					else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
						_LOG_L4C1("Incorrect frame size - freeing read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
						iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(iReadBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
						iReadBuf = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
		if (iReadBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
			TInt length = -1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
			if (iClientLength - iPos < iReadBuf->iMsg.Length())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
				length = iClientLength - iPos;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
				_LOG_L4C2("length = %d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
			if (iConfig.iTerminatorCount > 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
				_LOG_L4C2("iTerminatorCount = %d",iConfig.iTerminatorCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
				// First find terminator
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
				TInt terminatorLoc = -1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
				TInt loc;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
				for (TInt i=0; i< iConfig.iTerminatorCount;i++)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
					loc = iReadBuf->iMsg.LocateF(iConfig.iTerminator[i]);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
					if (loc > KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
						if (terminatorLoc == KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
							{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
							terminatorLoc = loc;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
							}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
						else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
							{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
							terminatorLoc = Min(loc,terminatorLoc);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
							}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
				if (terminatorLoc>KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
					if (length > KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
						length = Min(terminatorLoc + 1,length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
					else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
						length = terminatorLoc + 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
				_LOG_L4C2("length = %d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
			_LOG_L4C2("Read buf length %d",iReadBuf->iMsg.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
			if ((iReadBuf->iMsg.Length() >= length) && (length > -1))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
				_LOG_L2C2("complete partial read: # %d ", length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
				iPartialReadBuf.Copy(&iReadBuf->iMsg[0], length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
				iReadBuf->iMsg.Delete(0, length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
				err = IPCWrite(iClientBuffer, iPartialReadBuf, iPos); 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
				if (err)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
					_LOG_L1C2("** IPCWrite Error %d **",err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
				CompleteReadRequest(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
				err = KErrGeneral;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
				completedTheReadRequest = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
				iPos = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
				if (iReadBuf->iMsg.Length()==0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
					_LOG_L4C1("All data used - freeing read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
					iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(iReadBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
					iReadBuf = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
				err = IPCWrite(iClientBuffer, iReadBuf->iMsg, iPos);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
				if (err)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
					_LOG_L1C2("** IPCWrite Error %d **",err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
				_LOG_L4C3( "Read: iPos = %d, add %d bytes", iPos, iReadBuf->iMsg.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
				//try read next frame in the list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
				cont = ETrue; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
				iPos += iReadBuf->iMsg.Length();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
				_LOG_L4C1("Freeing read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
				iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(iReadBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
				iReadBuf = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
	while (cont);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
	if (iPos>0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
		if (iOneOrMore)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
			CompleteReadRequest(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
			iPos = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
			completedTheReadRequest = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
		else 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
			//normal read and have not filled the buffer yet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
			_LOG_L4C3( "Not filled buffer yet iPos = %d, iClientLength = %d", iPos, iClientLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
	_LOG_L4C2( "<<CPortC32Interface::ReadFromBufOrQueue [completedTheReadRequest=%d]",completedTheReadRequest);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
	return completedTheReadRequest;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
	}