cbsref/csyrefplugins/csy27010/src/PortFactory.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 class CPortFactory.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// *               This class is used to create C32 port interface instances.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
// PortFactory.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
/** @file PortFactory.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
/*! \mainpage CSY 27.010 Documentation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
 * \section intro Introduction
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
 * This CSY has been designed and implemented by TapRoot Systems.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
 * This CSY is part of the TapRoot Systems Communications Platform (CommP)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
 * product family for Symbian OS. Please contact TapRoot Systems for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
 * information on CommP.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
 * A CSY is a specialized type of DLL that implements API interfaces
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
 * required by the C32 Serial Communications Server. "CSY" is the file
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
 * name extension used by CSY modules as in "ecuart.csy", which is the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
 * name of Symbian's generic CSY for non-multiplexed serial ports.  
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
 * TapRoot Systems 27.010 CSY (gsm0701.csy) is compatible with the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
 * 3GPP 27.010 v5.0.0 specification.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
 * The CSY has been designed and tested with the Intel Lubbock application
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
 * processor, TI Condat baseband processor and Symbian OS 8.0a.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
 * The CSY is not guaranteed to work with other AP's, BP's or Symbian OS versions.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
 * The CSY has been integrated with Symbian OS supplied TSY and NIF IP.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
 * The CSY is not guaranteed to work with other TSY's and NIF's.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
 * \section feat Features
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
 * The CSY supports the 27.010 Basic Option. The 3GPP 27.010 specification 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
 * is derived from the GSM 07.10 specification. 3GPP 27.010 defines a mechanism
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
 * whereby multiple commands and data streams can be carried over the same
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
 * physical link. This specification defines a multiplexing protocol between
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
 * a Terminal Equipment (TE) and a Mobile Station (MS) allowing multiple 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
 * simultaneous sessions over a single start-stop, framed, serial link. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
 * Each session (channel) can carry different types of data including voice,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
 * fax, data, SMS, CBS, phonebook maintenance, battery status, GPRS, USSD, etc.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
 * The multiplexer has three operating options, basic, advanced without error
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
 * recovery and advanced with error recovery. CSY 27.010 supports the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
 * basic option. The basic option is recommended on highly reliable links. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
 * Advanced options are not supported by the CSY. The characteristics of the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
 * basic option are:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
 * <li> Length indicator used instead of the HDLC transparency mechanism
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
 * <li> Different flag octet from that used by HDLC
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
 * <li> Cannot be used on links that use XON/XOFF flow control
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
 * <li> May have longer recovery procedure from loss of synchronization
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
 * Each channel between the TE and MS is called a Data Link Connection (DLC).
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
 * A special DLC called "control channel" is used to exchange management 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
 * information (e.g. parameter negotiation), power saving control information,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
 * testing, flow control, close down, etc. between the TE and MS.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
 * The multiplexer is activated with the 3GPP 27.007 AT+CMUX command.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
 * <p>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
 * \section install Installation
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
 * Refer to the readme.txt file for installation and build instructions.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
 * <br>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
 * Please contact TapRoot Systems for information on product updates and
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
 * additional support.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
/** @file PortFactory.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
 * This file contains the implementation for the class CPortFactory.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
 * This class is used to create C32 port interface instances.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
#include <cs_port.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
#include <f32file.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
#include <commsdattypesv1_1.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
#include <commsdat_partner.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
using namespace CommsDat;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
#include "Portfactory.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
#include "CsyGlobals.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
#include "Mux0710Protocol.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
#include "ChannelMgrCtrl.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
#include "ChannelMgrCmdData.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
#include "PortC32InterfaceBase.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
#include "PortC32Interface.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
#include "PortC32InterfaceIp.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
#include "CommFrameWriterAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
#include "CommFrameReaderAo.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
#include "CsyDebugLogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
CPortFactory* CPortFactory::NewL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
 * This method uses two phase construction and the cleanup stack to create
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
 * an instance of class CPortFactory. This method is invoked when the user
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
 * invokes the C32 comm server's LoadCommModule() method to load the CSY.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
 * Note that multiple instances of CPortFactory can be created by C32,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
 * so no memory allocation or objects should be created when the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
 * port factory is first created.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
 * @return Pointer to the created instance of CPortFactory
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_L4C1("CPortFactory::NewL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
	CPortFactory* self = new(ELeave) CPortFactory;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
	TCleanupItem closeSelf(CPortFactory::CloseObject, self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
	CleanupStack::PushL(closeSelf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
	CleanupStack::Pop(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
	return (self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
CPortFactory::CPortFactory()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
: iPortC32InterfaceList(_FOFF(CPortC32Interface, iLink)),
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
  iPortC32InterfaceIter(iPortC32InterfaceList),
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
  iDataChannelList(_FOFF(CChannelMgrCmdData, iLink)),
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
  iDataChannelIter(iDataChannelList)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
 * Constructor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
	_LOG_L4C1("CPortFactory::CPortFactory");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
CPortFactory::~CPortFactory()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
 * Destructor. Delete all objects and memory created/allocated by this class.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
	_LOG_L4C1(">>CPortFactory::~CPortFactory");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
	// check if the CSY's objects have been created 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
	// C32 creates a new instance of the port factory each time a client
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
	// loads the CSY. The C32 recognizes a redundant CSerial name and promptly
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
	// destroys the redundant CSY.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
	if (iMuxObjectsCreated)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
		// client channels
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
		CChannelMgrCmdData* anyChannel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
		iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
		while ((anyChannel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
			iDataChannelList.Remove(*anyChannel);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
			delete anyChannel;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
		// control channel
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
		delete iChannelCtrl;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
		delete iCommWriterAo;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
		delete iCommReaderAo;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
		delete iMux0710Protocol;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
		// may not be necessary ???
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
		// MAF /\ what does this comment mean
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
		// delete any remaining C32 port objects that were not closed by the client
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
		CPortC32InterfaceBase* port = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
		iPortC32InterfaceIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
		while ((port = iPortC32InterfaceIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
			delete port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
		iCommPort.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
	//iMuxObjectsCreated = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
	_LOG_L4C1("<<CPortFactory::~CPortFactory");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
	_LOG_L3C1(" ");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
void CPortFactory::ConstructL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
 * 2nd-phase construction. Registers the CSY Name with C32.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
	_LOG_L4C1("CPortFactory::ConstructL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
#ifdef _DEBUG
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
	TInt usedCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
	TInt freeCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
	usedCellCount = User::CountAllocCells(freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
	_LOG_L4C3("Cell Counts Used = %d   Free = %d", usedCellCount, freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
	// inform C32 of the CSY name
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
	TName name(KCSY_Gsm0710ServerName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
	TInt retVal1 = SetName(&name);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
	if (retVal1 != KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
		_LOG_L1C3("** Failed to set CSY:%S in C32. Err: %d **", &name, retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
		User::Leave(retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
	iVersion = TVersion(KCSY_Gsm0710MinorVersionNumber,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
						KCSY_Gsm0710MajorVersionNumber,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
						KCSY_Gsm0710BuildVersionNumber);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
void CPortFactory::CreateCsyObjectsL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
 * This method is called to create the CSY objects for the multiplexing channels,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
 * message queues, i/o interface, etc.  This method should be called when the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
 * 1st client request to create a port is received by the CSY via NewPortL().
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
	_LOG_L4C1(">>CPortFactory::CreateCsyObjectsL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
	// set flag
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
	iMuxObjectsCreated = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
	iOpenPortFailed = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
	// load physical device drivers for serial port(s)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
#ifdef __WINS__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
	// 1st make sure the file server is running
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
	RFs fileServer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
	User::LeaveIfError(fileServer.Connect());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
	fileServer.Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
	_LIT(KPDDName, "ECDRV");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
	TInt retVal1 = User::LoadPhysicalDevice(KPDDName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
	if ((retVal1 != KErrNone) && (retVal1 != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
		User::Leave(retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
#else  // target
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
	TBuf<20> commPddName;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
	TInt retVal1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
	commPddName.Copy(KCsyDefaultPDDNameComm1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
	retVal1 = User::LoadPhysicalDevice(commPddName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
	if ((retVal1 != KErrNone) && (retVal1 != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
		User::Leave(retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
	// only load 2nd PDD if debugging is enabled 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
#ifdef __DEBUGSERIALPORT__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
	commPddName.Copy(KCsyDefaultPDDNameComm2);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
	retVal1 = User::LoadPhysicalDevice(commPddName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
	if ((retVal1 != KErrNone) && (retVal1 != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
		User::Leave(retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
#endif //__DEBUGSERIALPORT__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
#endif  //__WINS__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
	// load logical device driver for serial ports
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
	_LIT(KLDDName, "ECOMM");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
	retVal1 = User::LoadLogicalDevice(KLDDName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
	if ((retVal1 != KErrNone) && (retVal1 != KErrAlreadyExists))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
		User::Leave(retVal1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
	ConfigurePhysicalCommPortL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
	// create 27.010 framer and comm i/o objects
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
	iMux0710Protocol = CMux0710Protocol::NewL(*this);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
	iCommWriterAo    = CCommFrameWriterAo::NewL(this, iMux0710Protocol);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
	iMux0710Protocol->SetCommWriter(iCommWriterAo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
	iCommReaderAo    = CCommFrameReaderAo::NewL(this, iMux0710Protocol);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
	iCommReaderAo->Read();  // start it
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
	// create the Multiplexer Control Channel
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
	iChannelCtrl = CChannelMgrCtrl::NewL(*this, *iMux0710Protocol);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
	// create All Multiplexer Channels	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
	for (TUint8 i=1; i < KCsyDefaultMaxDLCChannels; i++)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
		CChannelMgrCmdData* channelMgrCmd =
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
			CChannelMgrCmdData::NewL(i, *this, *iMux0710Protocol);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
		iDataChannelList.AddLast(*channelMgrCmd);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
	// switch to multiplexer mode
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
	iMux0710Protocol->SwitchToMuxMode();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
#ifdef _DEBUG
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
	TInt usedCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
	TInt freeCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
	usedCellCount = User::CountAllocCells(freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
	_LOG_L4C3("Cell Counts Used = %d   Free = %d", usedCellCount, freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
	_LOG_L4C1("<<CPortFactory::CreateCsyObjectsL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
void CPortFactory::CloseObject(TAny* aObject)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
 * Utility to close objects created by the port factory. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
 * Used during construction with the cleanup stack.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
 * @param aObject - The CObject to close.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
 * @return void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
	reinterpret_cast<CObject*>(aObject)->Close();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
CPort* CPortFactory::NewPortL(const TUint aUnit)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
 * This method is called by C32 when a port is opened via RComm::Open().
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
 * An instance of the CSY's class CPortC32Interface is created.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
 * The instance is assigned a channel manager and then is added to
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
 * the list of C32 port interface objects.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
 * @param aUnit - Numeric portion of the port identifier
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
 * @return Pointer to the created C32 port interface object
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
	_LOG_L4C2(">>CPortFactory::NewPortL [aUnit=%d]", aUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
	TC32PortInfo portInfo;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
	portInfo.iClientType = GetClientType(aUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
	portInfo.iPortNumber = aUnit;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
	// check if port number is valid and translates to a client type
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
	if (portInfo.iClientType == EC32ClientUndefined)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
		_LOG_L4C1("<<CPortFactory::NewPortL - ** Unknown client **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
		return NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
	// check if this is the 1st port to be opened
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
	if (!iMuxObjectsCreated)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
		_LOG_L4C1("first port to be opened");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
		CreateCsyObjectsL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
	else if (iChannelCtrl->GetChannelReady() == EFalse)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
		_LOG_L4C1("CSY objects already exist");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
		// switch to multiplexer mode
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
		iMux0710Protocol->SwitchToMuxMode();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
	// first make sure control channel is already connected
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
	iChannelCtrl->WaitForChannelReady();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
	if (! iOpenPortFailed)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
		// create a new C32 Interface Port based on port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
		CPortC32InterfaceBase* port = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
		if (portInfo.iClientType == EC32ClientIpNif)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
			_LOG_L4C1("Raw IP port");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
 			port = CPortC32InterfaceIp::NewL(*this, portInfo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
 			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
			_LOG_L4C1("Normal port");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
 			port = CPortC32Interface::NewL(*this, portInfo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   369
 			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   370
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   371
		CleanupStack::PushL(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   372
		CChannelMgrCmdData* channel = FindChannelMgr(aUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   373
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   374
		if (channel == NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   375
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   376
			_LOG_L2C1("** channel is null, delete interface **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   377
			CleanupStack::PopAndDestroy(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   378
			User::Leave(KErrNotFound);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   379
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   380
		TName name;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   381
		name.Format(_L("%d"), aUnit);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   382
		port->SetName(&name);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   383
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   384
		// channel->Open() will add this port to it's port list, and connect channel if needed
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   385
		// Make sure that during channel init we do not tx/rx through channel
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   386
		channel->Open(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   387
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   388
		iNumOfOpenPorts++;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   389
		_LOG_L4C2("No. of ports = %d",iNumOfOpenPorts);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   390
 		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   391
		port->SetMuxChannel(channel);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   392
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   393
		channel->WaitForChannelReady();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   394
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   395
		//Need to wait for the channel to be ready. How to wait for something without blocking whole thread?
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   396
		// add it to list of ports
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   397
		iPortC32InterfaceList.AddLast(*port);	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   398
		CleanupStack::Pop(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   399
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   400
#ifdef _DEBUG
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   401
		TInt usedCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   402
		TInt freeCellCount;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   403
		usedCellCount = User::CountAllocCells(freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   404
		_LOG_L4C3("Cell Counts Used = %d   Free = %d", usedCellCount, freeCellCount);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   405
#endif
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   406
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   407
		_LOG_L4C2("<<CPortFactory::NewPortL [port=%d]", port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   408
		return port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   409
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   410
	else //iPortOpenFailed == ETrue
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   411
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   412
		_LOG_L4C1("<<CPortFactory::NewPortL [port=NULL]");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   413
		User::Leave(KErrTimedOut);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   414
		return NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   415
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   416
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   417
 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   418
void CPortFactory::Info(TSerialInfo& aSerialInfo)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   419
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   420
 * Called by C32 to identify the CSY module.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   421
 * @param aSerialInfo - Reference holder for information to be populated by the function.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   422
 * @return void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   423
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   424
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   425
	_LOG_L4C1("CPortFactory::Info");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   426
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   427
	aSerialInfo.iDescription	= KCSY_Description;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   428
	aSerialInfo.iName			= KCSY_Gsm0710ServerName;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   429
	aSerialInfo.iLowUnit		= KCSY_Gsm0710LowUnit;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   430
	aSerialInfo.iHighUnit		= KCSY_Gsm0710HighUnit;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   431
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   432
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   433
CPortFactory::TC32ClientType CPortFactory::GetClientType(TInt aC32PortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   434
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   435
 * Returns the ClientType for the specified C32 port number.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   436
 * @param aC32PortNum -  C32 port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   437
 * @return Client type - TSY or NIF
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   438
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   439
	{ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   440
	_LOG_L4C2("CPortFactory::GetClientType [aC32PortNum=%d]", aC32PortNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   441
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   442
	if (aC32PortNum >= KCOMMP_IP_NIF_OFFSET)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   443
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   444
		_LOG_L4C1("Raw Ip");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   445
		return CPortFactory::EC32ClientIpNif;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   446
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   447
	else if (aC32PortNum == KCOMMP_CSD_PPP_NUMBER)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   448
		{ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   449
		_LOG_L4C1("Csd PPP");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   450
		return CPortFactory::EC32ClientNif;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   451
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   452
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   453
	_LOG_L4C1("Tsy");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   454
	return CPortFactory::EC32ClientTsy;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   455
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   456
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   457
CPortC32InterfaceBase* CPortFactory::FindPortC32Interface(const TUint8 aDlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   458
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   459
 * This method returns a pointer to the C32 port interface object 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   460
 * that is associated with the specified DLC number.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   461
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   462
 * @param aDlcNum - DLC number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   463
 * @return Pointer to C32 port interface object or NULL if not found
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   464
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   465
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   466
	_LOG_L4C2(">>CPortFactory::FindPortC32Interface [aDlcNum=%d]", aDlcNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   467
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   468
	CPortC32InterfaceBase* port = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   469
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   470
	CChannelMgrCmdData* anyChannel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   471
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   472
	while ((anyChannel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   473
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   474
		if (anyChannel->GetDlcNumber() == aDlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   475
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   476
			_LOG_L4C1("AT channel");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   477
			port = anyChannel->GetC32Port();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   478
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   479
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   480
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   481
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   482
	_LOG_L4C2("<<CPortFactory::FindPortC32Interface [port=0x%x]",port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   483
	return port;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   484
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   485
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   486
CChannelMgrCmdData* CPortFactory::FindChannelMgr(const TUint aC32PortNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   487
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   488
 * This method is only called when a port is created.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   489
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   490
 * @param aC32PortNum - C32 port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   491
 * @return Pointer to the channel manager object or NULL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   492
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   493
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   494
	_LOG_L4C2(">>CPortFactory::FindChannelMgr [aC32PortNum=%d]", aC32PortNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   495
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   496
	TUint dlcNum = ++iLastDlcNum;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   497
	_LOG_L4C2("iLastDlcNum: %d", iLastDlcNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   498
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   499
	//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   500
	// MAF Horrible
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   501
	// This just counts through the array of channel pointers
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   502
	// and returns a pointer when the count gets to the correct value.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   503
	// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   504
	// We should be able to use an array here and directly access it using
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   505
	// the dlc number!?!?
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   506
	//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   507
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   508
	TUint count  = 1;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   509
	CChannelMgrCmdData* anyChannelCmd;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   510
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   511
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   512
	while ((anyChannelCmd = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   513
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   514
		if (count == dlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   515
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   516
			_LOG_L4C2("<<CPortFactory::FindChannelMgr() - found, count %d",count);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   517
			return anyChannelCmd;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   518
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   519
		count++;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   520
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   521
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   522
	_LOG_L4C1("<<CPortFactory::FindChannelMgr() - *** NOT FOUND ***");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   523
	return NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   524
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   525
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   526
CChannelMgrCmdData* CPortFactory::FindChannelMgrByDlcNum(const TUint8 aDlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   527
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   528
 * This method returns a pointer to the channel manager object 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   529
 * that has the specified  DLC number.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   530
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   531
 * @param aDlcNum -  DLC number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   532
 * @return Pointer to the channel manager object or NULL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   533
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   534
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   535
	_LOG_L4C2(">>CPortFactory::FindChannelMgrByDlcNum [aDlcNum=%d]", aDlcNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   536
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   537
    CChannelMgrCmdData* channel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   538
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   539
	while ((channel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   540
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   541
		if (channel->GetDlcNumber() == aDlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   542
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   543
			_LOG_L4C1("AT channel");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   544
			return channel;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   545
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   546
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   547
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   548
	_LOG_L2C1("<<CPortFactory::FindChannelMgrByDlcNum() - NOT FOUND");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   549
	return NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   550
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   551
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   552
TInt CPortFactory::ConfigurePhysicalCommPortL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   553
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   554
 * This method is used to configure the specified physical comm port.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   555
 * The parameters are read from CommDb or supplied by C32.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   556
 * @param aPhysPortNum - Physical port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   557
 * @return KErrorNone or KErrAccessDenied.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   558
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   559
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   560
	_LOG_L4C1(">>CPortFactory::ConfigurePhysicalCommPortL");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   561
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   562
	// create a package pointer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   563
	TPckgBuf<TCommConfigV01> newCfg;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   564
	TInt ret, len;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   565
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   566
	// get the modem table	- Get port settings from CommDB.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   567
	CMDBSession* db = CMDBSession::NewL(KCDLatestVersion);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   568
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   569
	CleanupStack::PushL(db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   570
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   571
	TUint32 modemId = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   572
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   573
	// We are using the same modem as TSY
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   574
	// Accessing the ModemPhoneServicesSMS field in the Global Settings Table
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   575
	CMDBField<TUint32>* globalSettingsField = new(ELeave) CMDBField<TUint32>(KCDTIdModemPhoneServicesSMS);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   576
	CleanupStack::PushL(globalSettingsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   577
	globalSettingsField->SetRecordId(1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   578
	globalSettingsField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   579
	modemId = *globalSettingsField;	// The field value gives the record id in the Modem Bearer Table.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   580
	CleanupStack::PopAndDestroy(globalSettingsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   581
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   582
	_LOG_L4C2("Accessing modem entry %d in the modem table", modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   583
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   584
	TUint32 rate;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   585
	TUint32 dataBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   586
	TUint32 stopBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   587
	TUint32 parity;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   588
	TUint32 handshake;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   589
	TPckgBuf<TCommConfigV01> config;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   590
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   591
	TUint port = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   592
	TBuf<KCommsDbSvrMaxFieldLength> controlPort;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   593
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   594
	// Accessing the ControlChannelPort Name from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   595
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   596
	CMDBField<TDesC>* portField = new(ELeave) CMDBField<TDesC>(KCDTIdControlChannelPortName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   597
	CleanupStack::PushL(portField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   598
	portField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   599
	portField->SetMaxLengthL(KMaxTextLength);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   600
	portField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   601
	controlPort = *portField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   602
	CleanupStack::PopAndDestroy(portField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   603
	// Diagnostics - control port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   604
	if (controlPort.Length())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   605
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   606
		TBuf8<16> portName;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   607
		portName.Copy(controlPort.Left(16));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   608
		_LOG_L4C2("Control port(MODEM_CONTROL_CHANNEL_PORT_NAME) '%S'",
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   609
			&portName);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   610
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   611
		// Get number of port out of the port descriptor.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   612
		_LIT(KDoubleColon, "::");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   613
		TInt len = controlPort.Find(KDoubleColon);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   614
		if (len < KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   615
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   616
			_LOG_L1C1("** finding :: in control port failed **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   617
			User::Leave(KErrGeneral);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   618
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   619
		TUint numPos = len + KDoubleColon.iTypeLength;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   620
		TPtrC numPtr(&controlPort[numPos], controlPort.Length() - numPos);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   621
		TLex lexer(numPtr);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   622
		TInt ret = lexer.Val(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   623
		if (ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   624
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   625
			_LOG_L1C1("** lexing to get port number failed **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   626
			User::Leave(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   627
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   628
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   629
	else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   630
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   631
		_LOG_L1C1("** Control port not set in commDb **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   632
		User::Leave(KErrGeneral);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   633
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   634
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   635
	// Accessing the Rate from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   636
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   637
	CMDBField<TUint32>* rateField = new(ELeave) CMDBField<TUint32>(KCDTIdRate);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   638
	CleanupStack::PushL(rateField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   639
	rateField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   640
	rateField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   641
	rate = *rateField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   642
	CleanupStack::PopAndDestroy(rateField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   643
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   644
	// Accessing the DataBits from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   645
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   646
	CMDBField<TUint32>* dataBitsField = new(ELeave) CMDBField<TUint32>(KCDTIdDataBits);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   647
	CleanupStack::PushL(dataBitsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   648
	dataBitsField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   649
	dataBitsField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   650
	dataBits = *dataBitsField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   651
	CleanupStack::PopAndDestroy(dataBitsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   652
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   653
	// Accessing the StopBits from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   654
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   655
	CMDBField<TUint32>* stopBitsField = new(ELeave) CMDBField<TUint32>(KCDTIdStopBits);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   656
	CleanupStack::PushL(stopBitsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   657
	stopBitsField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   658
	stopBitsField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   659
	stopBits = *stopBitsField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   660
	CleanupStack::PopAndDestroy(stopBitsField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   661
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   662
	// Accessing the Parity from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   663
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   664
	CMDBField<TUint32>* parityField = new(ELeave) CMDBField<TUint32>(KCDTIdParity);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   665
	CleanupStack::PushL(parityField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   666
	parityField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   667
	parityField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   668
	parity = *parityField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   669
	CleanupStack::PopAndDestroy(parityField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   670
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   671
	// Accessing the HandShake from the ModemBearer Table in the record number 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   672
	//corresponding to modemId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   673
	CMDBField<TUint32>* handshakeField = new(ELeave) CMDBField<TUint32>(KCDTIdHandshaking);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   674
	CleanupStack::PushL(handshakeField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   675
	handshakeField->SetRecordId(modemId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   676
	handshakeField->LoadL(*db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   677
	handshake = *handshakeField;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   678
	CleanupStack::PopAndDestroy(handshakeField);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   679
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   680
	config().iRate		  = (TBps)rate;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   681
	config().iDataBits    = (TDataBits)dataBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   682
	config().iStopBits    = (TStopBits)stopBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   683
	config().iParity      = (TParity)parity;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   684
	config().iHandshake   = (TUint)handshake;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   685
	config().iParityError = KConfigParityErrorIgnore;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   686
	config().iFifo        = static_cast<TUint>(EFifoEnable);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   687
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   688
	newCfg.Copy(config);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   689
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   690
	ret = iCommPort.Open(port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   691
	if (ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   692
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   693
		_LOG_L1C3("** Failed CommPort.Open(%d) ret=%d **", port,ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   694
		User::Leave(ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   695
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   696
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   697
	// Configure the port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   698
	len = iCommPort.ReceiveBufferLength();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   699
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   700
	if (len < KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   701
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   702
		_LOG_L1C2("** Leave: CommPort.ReceiveBufferLength() len=%d **", len);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   703
		User::Leave(KErrGeneral);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   704
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   705
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   706
	// Increase the receive buffer to make sure we can operate as slowly as we 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   707
	// can without filling up the LDD's receive buffer with incoming signals 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   708
	len *= KCSY_ReceiveBufferSizeIncreaseFactor; 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   709
	ret = iCommPort.SetReceiveBufferLength(len);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   710
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   711
	TCommConfig cbuf;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   712
	TCommConfigV01 &cfg = cbuf();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   713
	iCommPort.Config(cbuf);					// Get the Configuration Parameters
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   714
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   715
	cfg.iRate        = newCfg().iRate;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   716
	cfg.iDataBits    = newCfg().iDataBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   717
	cfg.iStopBits    = newCfg().iStopBits;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   718
	cfg.iParity      = newCfg().iParity;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   719
	cfg.iHandshake   = newCfg().iHandshake;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   720
	cfg.iParityError = newCfg().iParityError;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   721
	cfg.iFifo        = newCfg().iFifo;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   722
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   723
	_LOG_L4C2("  Set Phys Port Config for Port %d", port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   724
	_LOG_L4C2("    Rate = 0x%x", cfg.iRate);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   725
	_LOG_L4C2("    DataBits = 0x%x", cfg.iDataBits);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   726
	_LOG_L4C2("    Stop Bits = 0x%x", cfg.iStopBits);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   727
	_LOG_L4C2("    Parity = 0x%x", cfg.iParity);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   728
	_LOG_L4C2("    Handshake = 0x%x", cfg.iHandshake);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   729
	_LOG_L4C2("    Parity Error = 0x%x", cfg.iParityError);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   730
	_LOG_L4C2("    Fifo = 0x%x", cfg.iFifo);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   731
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   732
	ret = iCommPort.SetConfig(cbuf);		// Set the Configuration Parameters
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   733
	if (ret)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   734
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   735
		_LOG_L1C2("** CommPort.SetConfig ret=%d **", ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   736
		User::Leave(KErrNotSupported);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   737
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   738
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   739
	// Clean up the stack
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   740
	CleanupStack::PopAndDestroy(db);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   741
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   742
	_LOG_L4C2("<<CPortFactory::ConfigurePhysicalCommPortL [ret=%d]", ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   743
	return ret;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   744
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   745
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   746
void CPortFactory::ConnectControlChannel()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   747
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   748
 * This method is called to connect the 27.010 control channel,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   749
 * which is DLC 0.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   750
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   751
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   752
	_LOG_L4C1("CPortFactory::ConnectControlChannel");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   753
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   754
	TInt ret = 	iChannelCtrl->Connect();	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   755
	if (ret != KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   756
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   757
		_LOG_L4C2(("<<CCPortFactory::ConnectControlChannel ret=%d"),ret);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   758
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   759
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   760
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   761
void CPortFactory::DisconnectControlChannel()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   762
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   763
 * This method is called to set the 27.010 control channel to the "disconnect" state.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   764
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   765
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   766
	_LOG_L4C1("CPortFactory::DisconnectAllChannels");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   767
	iChannelCtrl->Disconnect();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   768
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   769
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   770
void CPortFactory::ChannelCtrlDoCancel()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   771
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   772
 * This method is called when the port has been opened and the max number of retries has been reached.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   773
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   774
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   775
	_LOG_L4C1(">>CPortFactory::ChannelCtrlDoCancel");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   776
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   777
	iOpenPortFailed = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   778
	iChannelCtrl->NotifyChannelReady();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   779
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   780
	_LOG_L4C1("<<CPortFactory::ChannelCtrlDoCancel");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   781
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   782
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   783
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   784
void CPortFactory::RemoveC32Port(CPortC32InterfaceBase* aPort)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   785
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   786
 * This method removes the specified C32 port object from the
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   787
 * port factory's list of current/open C32 port objects.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   788
 * This will allow another client to open that port.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   789
 * @param aPort - Pointer to C32 port object
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   790
 * @return void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   791
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   792
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   793
	_LOG_L4C2(">>CPortFactory::RemoveC32Port [aPort=%d]", aPort->GetPortNumber());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   794
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   795
	CPortC32InterfaceBase* port = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   796
	iPortC32InterfaceIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   797
	while ((port = iPortC32InterfaceIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   798
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   799
		if (port == aPort)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   800
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   801
			iPortC32InterfaceList.Remove(*port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   802
			_LOG_L4C1("<<CPortFactory::RemoveC32Port - okay");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   803
			return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   804
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   805
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   806
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   807
	// MAF this is a bad condition
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   808
	_LOG_L4C1("<<CPortFactory::RemoveC32Port ** Not Removed? **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   809
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   810
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   811
void CPortFactory::ConnectIpNifPort(const TUint8 aDlcNum)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   812
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   813
 * This method connects the port interface object
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   814
 * in the CSY that are used for a data interface to a NIF.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   815
 * @param void
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   816
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   817
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   818
	_LOG_L4C2("CPortFactory::ConnectIpNifPort [aDlcNum=%d]",aDlcNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   819
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   820
	CPortC32InterfaceBase* port = FindPortC32Interface(aDlcNum);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   821
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   822
	if (port)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   823
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   824
		CChannelMgrCmdData* iMuxChannel = port->GetMuxChannel();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   825
		if (iMuxChannel)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   826
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   827
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   828
			TInt err = iMuxChannel->Connect();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   829
			if (err != KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   830
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   831
				_LOG_L1C2("iMuxChannel->Connect() error =%d",err);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   832
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   833
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   834
		else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   835
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   836
			// MAF assert here
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   837
			_LOG_L1C2("** Could not find channel for port [0x%x] **",port);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   838
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   839
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   840
	else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   841
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   842
		// MAF assert here
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   843
		_LOG_L1C1("** Could not find port for dlcnumber **");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   844
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   845
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   846
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   847
TBool CPortFactory::FindDlcToEnable()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   848
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   849
 * We have resources again. Find a dlc that has had its flow control
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   850
 * set and re-enable.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   851
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   852
 * @return ETrue if there are still dlcs that are stopped due to flow control.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   853
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   854
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   855
	_LOG_L4C1(">>CPortFactory::FindDlcToEnable");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   856
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   857
	TInt numberOfStopped = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   858
	TBool dlcsStillToEnable = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   859
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   860
    CChannelMgrCmdData* channel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   861
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   862
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   863
	while ((channel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   864
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   865
		if (channel->CsyToModemFlowControl() == EFlowControlOn)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   866
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   867
			numberOfStopped++;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   868
			if (numberOfStopped == 1)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   869
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   870
				_LOG_L4C1("Found a dlc to re-enable");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   871
				if (channel->SetCsyToModemFlowControl(EFlowControlOff))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   872
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   873
					_LOG_L4C1("Re-enable failed");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   874
					dlcsStillToEnable = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   875
					break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   876
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   877
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   878
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   879
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   880
				_LOG_L4C1("Other dlc still to re-enable");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   881
				dlcsStillToEnable = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   882
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   883
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   884
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   885
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   886
	_LOG_L4C2("<<CPortFactory::FindDlcToEnable numberOfStopped=%d",numberOfStopped);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   887
	return dlcsStillToEnable;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   888
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   889
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   890
void CPortFactory::FindActiveDataDlcToStop()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   891
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   892
 * MAF come up with a better algorithm. Currently this scans sequentially for a data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   893
 * DLC to stop.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   894
 * Check the data dlcs to see if one of them can be stopped
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   895
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   896
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   897
	_LOG_L4C1(">>CPortFactory::FindActiveDataDlcToStop");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   898
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   899
    CChannelMgrCmdData* channel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   900
	CPortC32InterfaceBase* port = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   901
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   902
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   903
	while ((channel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   904
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   905
		port = channel->GetC32Port();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   906
		if ((port)&&(port->GetClientType() == EC32ClientIpNif))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   907
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   908
			if (channel->CsyToModemFlowControl() == EFlowControlOff)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   909
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   910
				_LOG_L4C1("Found a data dlc to stop");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   911
				if (channel->SetCsyToModemFlowControl(EFlowControlOn))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   912
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   913
					_LOG_L4C1("Failed to stop dlc");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   914
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   915
				else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   916
					break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   917
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   918
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   919
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   920
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   921
	_LOG_L4C1("<<CPortFactory::FindActiveDataDlcToStop");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   922
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   923
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   924
void CPortFactory::StopAnyDlc()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   925
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   926
 * Time for drastic action - enforce flow control on any DLC (except ctrl).
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   927
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   928
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   929
	_LOG_L4C1(">>CPortFactory::StopAnyDlc");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   930
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   931
    CChannelMgrCmdData* channel = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   932
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   933
	iDataChannelIter.SetToFirst();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   934
	while ((channel = iDataChannelIter++) != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   935
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   936
		if (channel->CsyToModemFlowControl() == EFlowControlOff)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   937
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   938
			_LOG_L4C1("Found a dlc to stop");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   939
			if (channel->SetCsyToModemFlowControl(EFlowControlOn))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   940
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   941
				_LOG_L4C1("Failed to stop dlc");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   942
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   943
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   944
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   945
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   946
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   947
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   948
	_LOG_L4C1("<<CPortFactory::StopAnyDlc");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   949
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   950
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   951
TBool CPortFactory::DecrementNumOfOpenPorts()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   952
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   953
 * Used to decrement the number of open ports and disconnect if number = 0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   954
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   955
 * aReturn returns EFalse if Num of Ports is 0; ETrue otherwise
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   956
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   957
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   958
	if (iNumOfOpenPorts==0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   959
		return EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   960
	else if (--iNumOfOpenPorts == 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   961
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   962
		_LOG_L4C1("******* DISCONNECT ALL *********");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   963
		DisconnectControlChannel();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   964
		iLastDlcNum = 0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   965
		return EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   966
		}	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   967
	return ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   968
}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   969
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   970
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   971
TSecurityPolicy CPortFactory::PortPlatSecCapability(TUint /*aPort*/) const
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   972
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   973
 * This method returns the capabilities required to open the given port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   974
 * This 27.010 CSY requires the same capabilities for all port numbers
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   975
 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   976
 * @param aPort - The port number to check against
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   977
 * @return TSecurityPolicy - containing the required capabilities to use this CSY
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   978
 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   979
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   980
	return TSecurityPolicy(ECapabilityNetworkServices, ECapabilityNetworkControl, ECapabilityReadUserData, ECapabilityWriteUserData);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   981
}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   982