cbsref/csyrefplugins/csy27010/src/PortC32InterfaceIp.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
/** @file PortC32InterfaceIp.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
 * This file contains the implementation for the CPortC32InterfaceIp class.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
 * This class contains methods which are invoked by C32 when the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
 * associated client RComm public API is invoked. These methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
 * are used to create, configure, read, write, and close logical
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
 * serial ports. Instances of this class are created by the CSY's
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
 * Port Factory.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
#include <cdbcols.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
#include "PortC32InterfaceIp.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
#include "Portfactory.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
#include "Mux0710Protocol.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
#include "CsyMsgBufBPFrame.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
#include "ChannelMgrCmdData.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
#include "CommFrameReaderAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
#include "CsyDebugLogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
#include "CsyGlobals.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
#include "CommFrameWriterAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
CPortC32InterfaceIp* CPortC32InterfaceIp::NewL(CPortFactory& aPortFactory, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
										   CPortFactory::TC32PortInfo& aPortInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
 * This method uses two phase construction and the cleanup stack to create
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
 * an instance of class CPortC32InterfaceIp.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
 * @param aPortFactory - Reference to the port factory
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
 * @param aPortInfo - Reference to the port information
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
 * @return Pointer to the created instance
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
	_LOG_L4C1("CPortC32InterfaceIp::NewL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
	CPortC32InterfaceIp* self =
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
		new(ELeave) CPortC32InterfaceIp(aPortFactory, aPortInfo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
	TCleanupItem closeSelf(CPortFactory::CloseObject, self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
	CleanupStack::PushL(closeSelf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
	CleanupStack::Pop(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
	return (self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
CPortC32InterfaceIp::~CPortC32InterfaceIp()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
 * Destructor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
	_LOG_L4C1(">>CPortC32InterfaceIp::~CPortC32InterfaceIp");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
	_LOG_L3C1("Remove port from the port factory");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
	// let port factory know we are deleted
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
	iPortFactory.RemoveC32Port(this);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
	CompleteOutstandingRequest();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
	_LOG_L3C1("Release any packets going to the C32 client");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
	// remove all frames to do with the most recent IP packet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
	CCsyMsgBufBpFrame* ipPacketFrame = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
	iFramesReceivedForIpPacketIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
	while ((ipPacketFrame = iFramesReceivedForIpPacketIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
		iFramesReceivedForIpPacket.Remove(*ipPacketFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
		delete ipPacketFrame;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
	_LOG_L4C1("<<CPortC32InterfaceIp::~CPortC32InterfaceIp");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
CPortC32InterfaceIp::CPortC32InterfaceIp(CPortFactory& aPortFactory,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
									 CPortFactory::TC32PortInfo& aPortInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
 * Constructor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
 * @param aPortFactory - Reference to the port factory
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
 * @param aPortInfo - Reference to the port information
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
: CPortC32InterfaceBase(aPortFactory, aPortInfo),
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
   iFramesReceivedForIpPacket(_FOFF(CCsyMsgBufBpFrame, iMsgLink)),
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
   iFramesReceivedForIpPacketIter(iFramesReceivedForIpPacket)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
	{}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
void CPortC32InterfaceIp::ConstructL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
 * Safe constructor
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
	_LOG_L4C1(">>CPortC32InterfaceIp::ConstructL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
	CPortC32InterfaceBase::ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	_LOG_L4C1("<<CPortC32InterfaceIp::ConstructL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
/********************************************************************************/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
/*               Start of utility methods for CPortC32InterfaceBase             */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
/********************************************************************************/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
TInt CPortC32InterfaceIp::QueryReceiveBuffer(TInt& aLength) const
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
 * Called by C32 when the client queries the size of the receive buffer,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
 * which returns the number of receive characters available to be read by
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
 * the C32 client RComm instance.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
 * @param aLength - Reference to client's buffer length variable
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
 * @return KErrNone
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
	_LOG_L4C2("CPortC32InterfaceIp::QueryReceiveBuffer [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
	aLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
	// MAF
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
	return KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
void CPortC32InterfaceIp::ResetBuffers(TUint aFlags)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
 * Called by C32 when the client requests to reset the buffers,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
 * by removing all receive and/or transmit messages according to
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
 * the specified flags.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
 * @param aFlags Indicate which buffers (receive and/or transmit) should be reset
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
	_LOG_L4C3(">>CPortC32InterfaceIp::ResetBuffers [aFlags=%d,port=%d]",
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
		aFlags,GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
	if (aFlags & KCommResetRx)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
		_LOG_L4C1("Removing all messages intended for the C32 client");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
		RemoveWaitingAllFrames();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
		// remove all frames to do with the most recent IP packet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
		CCsyMsgBufBpFrame* ipPacketFrame = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
		iFramesReceivedForIpPacketIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
		while ((ipPacketFrame = iFramesReceivedForIpPacketIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
			iFramesReceivedForIpPacket.Remove(*ipPacketFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
			delete ipPacketFrame;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
	if (aFlags & KCommResetTx)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
		_LOG_L4C1("Removing all messages intended for the modem");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
		GetMuxChannel()->WriteCancel();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
	_LOG_L4C1("<<CPortC32InterfaceIp::ResetBuffers");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
void CPortC32InterfaceIp::PlaceIpPacketFramesOntoFreeList()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
 * Place all frames to do with recent IP packet onto free list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
	_LOG_L4C2(">>CPortC32InterfaceIp::PlaceIpPacketFramesOntoFreeList [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
	CCsyMsgBufBpFrame* frame = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
	iFramesReceivedForIpPacketIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
	while ((frame = iFramesReceivedForIpPacketIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
		iFramesReceivedForIpPacket.Remove(*frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
		iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
	iCurrentIpPacketLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
	_LOG_L4C1("<<CPortC32InterfaceIp::PlaceIpPacketFramesOntoFreeList");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
void CPortC32InterfaceIp::PlaceIpPacketFramesOntoReadList()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
 * Place all frames to do with recent IP packet onto read list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
	_LOG_L4C2(">>CPortC32InterfaceIp::PlaceIpPacketFramesOntoReadList [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
	CCsyMsgBufBpFrame* frame = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
	iFramesReceivedForIpPacketIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
	while ((frame = iFramesReceivedForIpPacketIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
		iFramesReceivedForIpPacket.Remove(*frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
		iFramesWaitingToBeReadList.AddLast(*frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
	iCurrentIpPacketLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
	iNumberOfPacketsWaiting++;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
	_LOG_L4C2("iNumberOfPacketsWaiting=%d",iNumberOfPacketsWaiting);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
	if (iNumberOfPacketsWaiting == KMaxPacketsOutstandingForC32Client)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
		_LOG_L2C1("Client appears to be slow at reading");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
		_LOG_L2C3("iNumberOfPacketsWaiting %d > KMaxPacketsOutstandingForC32Client %d)",
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
			iNumberOfPacketsWaiting,KMaxPacketsOutstandingForC32Client);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
		iMuxChannel->SetCsyToModemFlowControl(EFlowControlOn);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
	_LOG_L4C1("<<CPortC32InterfaceIp::PlaceIpPacketFramesOntoReadList");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
void CPortC32InterfaceIp::SendFrameToClient(CCsyMsgBufBpFrame* aFrame)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
 * This method is called by a CSY Channel object when it has a single
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
 * frame to send to a C32 client RComm object.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
 * @param aFrame - Pointer to message to send to client
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
	_LOG_L4C2(">>CPortC32InterfaceIp::SendFrameToClient [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
	if (aFrame)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
		// frame validation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
		if (aFrame->iMsg.Length() <= KAdvOptionNumOfNonDataOctets)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
			_LOG_L1C1("** Does not appear to be a valid frame - disregarding **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
			// Place received frames on the empty list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
			iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
			PlaceIpPacketFramesOntoFreeList();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
			_LOG_L4C1("<<CPortC32InterfaceIp::SendFrameToClient - bad frame");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
			return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
		TUint8 framePosition = aFrame->GetType4FrameSequence();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
		_LOG_L4C2("framePosition = 0x%02x",framePosition);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
		// read buffer validation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
		if (iFramesReceivedForIpPacket.IsEmpty())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
			// There is no read buffer allocated for this frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
			switch (framePosition)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
			case KSingleFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
			case KStartMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
				_LOG_L4C1("Starting new IP frame list");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
				iCurrentIpPacketLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
			case KEndMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
			case KMiddleMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
			default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
				// assumption here is that because no read buffer is allocated then
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
				// there cannot have been a valid start frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
				_LOG_L1C1("** Missed start of packet - disregarding **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
				// Place received frame on the empty list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
				iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
				_LOG_L4C1("<<CPortC32InterfaceIp::SendFrameToClient - no start");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
				return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
		else if ((framePosition == KSingleFrame)||(framePosition == KStartMultiFrame))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
			// There's been a comms error and an end packet has been lost
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
			_LOG_L1C1("** Unexpected Start/Single frame - disregarded previous frames **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
			// Place received frames on the empty list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
			PlaceIpPacketFramesOntoFreeList();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
			// Continue processing this frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
			_LOG_L4C1("Starting new IP frame list");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
			iCurrentIpPacketLength = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
		// If have got to here then IP frame list exists
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
		TInt length = aFrame->iMsg.Length() - KAdvOptionNumOfNonDataOctets;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
		_LOG_L4C2("length=%d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
		// length validation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
		if ((iCurrentIpPacketLength + length) > KMaxIpPacketSize)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
			// The length of the data in the new frame would exceed that available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
			// in the read buffer.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
			_LOG_L1C3("** iCurrentIpPacketLength + length %d exceeds max size %d **",
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
				(iCurrentIpPacketLength + length),KMaxIpPacketSize);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
			// Place received frames on the empty list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
			iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
			PlaceIpPacketFramesOntoFreeList();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
			_LOG_L4C1("<<CPortC32InterfaceIp::SendFrameToClient - frame sized exceeded");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
			return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
		// If have got to here IP frame list exists and length is valid
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
		iCurrentIpPacketLength += length;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
		TBool addReadBufferToClientList = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
		switch (framePosition)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
		// Single frame	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
		case KSingleFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
			_LOG_L4C1("Only frame");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
			iFramesReceivedForIpPacket.AddFirst(*aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
			addReadBufferToClientList = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
		// Multiframe
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
		case KStartMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
			_LOG_L4C1("Start multiframe");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
			iFramesReceivedForIpPacket.AddFirst(*aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
		case KMiddleMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
			_LOG_L4C1("Middle multiframe");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
			iFramesReceivedForIpPacket.AddLast(*aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
		case KEndMultiFrame:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
			_LOG_L4C1("Last multiframe");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
			iFramesReceivedForIpPacket.AddLast(*aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
			addReadBufferToClientList = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
		// Unknown
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
			_LOG_L1C2("** Unknown framePosition %d - ignoring **",
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
				framePosition);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
			// Place received frame on the empty list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
			iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(aFrame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
			PlaceIpPacketFramesOntoFreeList();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
			_LOG_L4C1("<<CPortC32InterfaceIp::SendFrameToClient - unknown frame pos");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
			return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
		if (addReadBufferToClientList)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
			// Give iFramesWaitingToBeReadList ownership of the frames making up the IP Packet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
			_LOG_L4C1("Transfer frames to client msg list");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
			// check if queue is empty
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   369
			TBool trigger = iFramesWaitingToBeReadList.IsEmpty();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   370
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   371
			PlaceIpPacketFramesOntoReadList();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   372
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   373
			if (trigger)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   374
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   375
				_LOG_L4C1("No packets already waiting");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   376
				if (iIsReadInProgress)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   377
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   378
					_LOG_L4C1("A read is outstanding");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   379
					ReadFromBufOrQueue();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   380
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   381
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   382
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   383
			// inform client new data is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   384
			SetDataAvailable();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   385
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   386
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   387
	else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   388
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   389
		_LOG_L1C1("** aFrame is null **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   390
		// MAF __ASSERT_DEBUG(EFalse, PANIC(KPanicIllegalState));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   391
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   392
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   393
	_LOG_L4C1("<<CPortC32InterfaceIp::SendFrameToClient");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   394
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   395
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   396
TBool CPortC32InterfaceIp::CreateIpPacketFromFrames()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   397
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   398
 * We assume that all validation has been done during SendFrameToClient so only valid
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   399
 * data exists on the iFramesWaitingToBeReadList frame list.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   400
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   401
 * @return ETrue if packet retrieved successfully
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   402
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   403
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   404
	_LOG_L4C2(">>CPortC32InterfaceIp::CreateIpPacketFromFrames [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   405
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   406
	iIpPacket.Zero();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   407
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   408
	TUint8	framePosition = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   409
	TInt	length = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   410
	TBool	packetRetrieved = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   411
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   412
	// Remove all frames to do with the same IP Packet from waiting to be read list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   413
	CCsyMsgBufBpFrame* frame = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   414
	iFramesWaitingToBeReadIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   415
	while ((frame = iFramesWaitingToBeReadIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   416
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   417
		iFramesWaitingToBeReadList.Remove(*frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   418
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   419
		framePosition = frame->GetType4FrameSequence();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   420
		_LOG_L4C2("framePosition = 0x%02x",framePosition);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   421
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   422
		length = frame->iMsg.Length() - KAdvOptionNumOfNonDataOctets;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   423
		_LOG_L4C2("length=%d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   424
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   425
		iIpPacket.Append(&frame->iMsg[KAdvOptionType4StartOfMessageData], length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   426
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   427
		iPortFactory.GetMux0710Protocol()->AddFrameFreeQ(frame);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   428
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   429
		if ((framePosition == KSingleFrame)||(framePosition == KEndMultiFrame))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   430
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   431
			_LOG_L4C1("retrieved packet");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   432
			packetRetrieved = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   433
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   434
			if (iNumberOfPacketsWaiting == KMaxPacketsOutstandingForC32Client)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   435
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   436
				_LOG_L2C1("Client appears to be reading again");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   437
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   438
				// Assume it is okay to set FC to Off even in low free frame
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   439
				// condition since just freed a frame.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   440
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   441
				iMuxChannel->SetCsyToModemFlowControl(EFlowControlOff);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   442
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   443
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   444
			iNumberOfPacketsWaiting--;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   445
			_LOG_L4C2("iNumberOfPacketsWaiting=%d",iNumberOfPacketsWaiting);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   446
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   447
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   448
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   449
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   450
	_LOG_L4C2("<<CPortC32InterfaceIp::CreateIpPacketFromFrames [packetRetrieved=%d]",packetRetrieved);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   451
	return packetRetrieved;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   452
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   453
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   454
TBool CPortC32InterfaceIp::ReadFromBufOrQueue()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   455
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   456
 * This method is called to read from buffer or the frame list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   457
 * It will read as much as possible.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   458
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   459
 * @return ETrue if complete the read request
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   460
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   461
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   462
	_LOG_L4C2(">>CPortC32InterfaceIp::ReadFromBufOrQueue [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   463
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   464
	TBool completedRead = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   465
	TInt ret = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   466
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   467
	_LOG_L4C2("iOneOrMore=%d",iOneOrMore);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   468
	_LOG_L4C2("iClientLength=%d",iClientLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   469
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   470
	while ((CreateIpPacketFromFrames())&&(!ret))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   471
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   472
		TInt ipPacketLength = iIpPacket.Length();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   473
		TInt length = -1; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   474
		if (iClientLength - iPos < ipPacketLength)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   475
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   476
			length = iClientLength - iPos;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   477
			_LOG_L4C2("length remaining = %d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   478
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   479
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   480
		if ((length > -1) && (ipPacketLength >= length))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   481
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   482
			// MAF should partial reads be allowed?
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   483
			_LOG_L2C1("Partial read?");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   484
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   485
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   486
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   487
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   488
			_LOG_L4C3("read buf %d >= length %d ", ipPacketLength, length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   489
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   490
			ret = IPCWrite(iClientBuffer, iIpPacket, iPos);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   491
			if (ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   492
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   493
				_LOG_L1C2("** IPCWrite Error %d **",ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   494
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   495
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   496
			_LOG_L4C3("Read: iPos = %d, add %d bytes", iPos, ipPacketLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   497
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   498
			iPos += ipPacketLength;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   499
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   500
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   501
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   502
	if (iPos>0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   503
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   504
		if (iOneOrMore)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   505
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   506
			CompleteReadRequest(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   507
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   508
			iPos = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   509
			completedRead = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   510
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   511
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   512
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   513
			//normal read? and have not filled the buffer yet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   514
			_LOG_L4C3( "Not filled buffer yet iPos = %d, iClientLength = %d", iPos, iClientLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   515
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   516
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   517
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   518
	_LOG_L4C2("<<CPortC32InterfaceIp::ReadFromBufOrQueue [completedRead=%d]", completedRead);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   519
	return completedRead;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   520
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   521
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   522
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   523
/***
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   524
TBool CPortC32InterfaceIp::ReadFromBufOrQueue()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   525
**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   526
 * This method is called to read from buffer or the frame list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   527
 * It will read as much as possible.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   528
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   529
 * @return ETrue if complete the read request
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   530
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   531
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   532
	_LOG_L4C2(">>CPortC32InterfaceIp::ReadFromBufOrQueue [port=%d]", GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   533
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   534
	TBool completedRead = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   535
	TInt err = KErrGeneral;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   536
	TBool cont;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   537
	do
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   538
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   539
		cont = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   540
		if(iQueuedIpPacket == NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   541
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   542
			//Read data from the frame list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   543
			if (!iMsgToClientList.IsEmpty())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   544
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   545
				_LOG_L4C1("Set to first item");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   546
				iQueuedIpPacket = iMsgToClientList.First();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   547
				if (iQueuedIpPacket)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   548
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   549
					_LOG_L4C1("iQueuedIpPacket not null");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   550
					// remove msg buf from client list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   551
					iMsgToClientList.Remove(*iQueuedIpPacket);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   552
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   553
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   554
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   555
		if (iQueuedIpPacket)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   556
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   557
			TInt length = KErrNotFound; // <- yeaks!
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   558
			if (iClientLength - iPos < iQueuedIpPacket->iMsg.Length())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   559
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   560
				length = iClientLength - iPos;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   561
				_LOG_L4C2("length remaining = %d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   562
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   563
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   564
			if (iConfig.iTerminatorCount > 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   565
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   566
				_LOG_L4C2("iTerminatorCount = %d",iConfig.iTerminatorCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   567
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   568
				// First find terminator
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   569
				TInt terminatorLoc = KErrNotFound; // <- yeaks!
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   570
				TInt loc;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   571
				for (TInt i = 0; i < iConfig.iTerminatorCount; i++)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   572
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   573
					loc = iQueuedIpPacket->iMsg.LocateF(iConfig.iTerminator[i]);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   574
					if (loc > KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   575
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   576
						if (terminatorLoc == KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   577
							{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   578
							terminatorLoc = loc;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   579
							}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   580
						else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   581
							{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   582
							terminatorLoc = Min(loc,terminatorLoc);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   583
							}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   584
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   585
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   586
				if (terminatorLoc > KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   587
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   588
					if (length > KErrNotFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   589
						length = Min(terminatorLoc + 1,length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   590
					else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   591
						length = terminatorLoc + 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   592
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   593
				_LOG_L4C2("length = %d",length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   594
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   595
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   596
			_LOG_L4C2("Read buf length %d",iQueuedIpPacket->iMsg.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   597
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   598
			if ((iQueuedIpPacket->iMsg.Length() >= length) && (length > KErrNotFound))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   599
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   600
				LOGTEXT2(__DEBUGLEVELMAJOR__,"complete partial read: # %d ", length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   601
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   602
				iPartialReadBuf.Copy(&iQueuedIpPacket->iMsg[0], length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   603
				iQueuedIpPacket->iMsg.Delete(0, length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   604
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   605
				err = IPCWrite(iClientBuffer, iPartialReadBuf, iPos); 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   606
				if (err)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   607
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   608
					_LOG_L1C2("** IPCWrite Error %d **",err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   609
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   610
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   611
				CompleteReadRequest(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   612
				err = KErrGeneral;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   613
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   614
				completedRead = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   615
				iPos = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   616
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   617
				if (iQueuedIpPacket->iMsg.Length() == 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   618
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   619
					_LOG_L4C1("All data used - freeing read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   620
					AddToFreeC32BufferQ(iQueuedIpPacket);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   621
					iQueuedIpPacket = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   622
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   623
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   624
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   625
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   626
				LOGTEXT3(__DEBUGLEVELMAJOR__,"read buf %d >= length %d ", iQueuedIpPacket->iMsg.Length(), length);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   627
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   628
				err = IPCWrite(iClientBuffer, iQueuedIpPacket->iMsg, iPos);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   629
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   630
				_LOG_L4C3("Read: iPos = %d, add %d bytes", iPos, iQueuedIpPacket->iMsg.Length());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   631
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   632
				cont = ETrue; //try read next frame in the list
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   633
				iPos = iPos + iQueuedIpPacket->iMsg.Length();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   634
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   635
				_LOG_L4C1("Freeing read buffer");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   636
				AddToFreeC32BufferQ(iQueuedIpPacket);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   637
				iQueuedIpPacket = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   638
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   639
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   640
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   641
	while (cont);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   642
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   643
	if (iPos>0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   644
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   645
		if (iOneOrMore)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   646
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   647
			if (err)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   648
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   649
				_LOG_L1C2("** IPCWrite Error %d **",err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   650
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   651
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   652
			CompleteReadRequest(err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   653
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   654
			iPos = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   655
			completedRead = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   656
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   657
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   658
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   659
			//normal read and have not filled the buffer yet
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   660
			_LOG_L4C3( "Not filled buffer yet iPos = %d, iClientLength = %d", iPos, iClientLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   661
			//iToClientMsgQAo->IssueNotificationRequest();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   662
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   663
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   664
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   665
	_LOG_L4C2("<<CPortC32InterfaceIp::ReadFromBufOrQueue [ret=%d]",completedRead);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   666
	return completedRead;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   667
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   668
***/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   669
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   670