adaptationlayer/modematadaptation/modematcontroller_exe/src/cmodematsrv.cpp
author mikaruus
Tue, 19 Oct 2010 13:16:20 +0300
changeset 9 8486d82aef45
parent 8 6295dc2169f3
permissions -rw-r--r--
modemadaptation release 2010wk40
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     1
/*
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     3
* All rights reserved.
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     4
* This component and the accompanying materials are made available
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     6
* which accompanies this distribution, and is available
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     8
*
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
     9
* Initial Contributors:
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    11
*
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    12
* Contributors:
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    13
* 
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    14
* Description: 
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    15
*
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    16
*/
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    17
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    18
#include <pn_const.h>
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    19
#include <iscnokiadefinitions.h>
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    20
#include "cmodematsrv.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    21
#include "modematclientsrv.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    22
#include "modematsecpolicy.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    23
#include "cmodematsession.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    24
#include "cmodemathandler.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    25
#include "modemattrace.h"
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    26
#include "catmessage.h"
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    27
#include "cmodematpipecontroller.h"
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    28
#include "OstTraceDefinitions.h"
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    29
#ifdef OST_TRACE_COMPILER_IN_USE
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    30
#include "cmodematsrvTraces.h"
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    31
#endif
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    32
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    33
_LIT8( KCursor, ">" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    34
_LIT8( KOkResponse, "OK" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    35
_LIT8( KErrorResponse, "ERROR" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    36
_LIT8( KOkResponseNoVerbose, "0" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    37
_LIT8( KErrorResponseNoVerbose, "4" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    38
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    39
_LIT8( KAtv, "ATV" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    40
_LIT8( KAtv1, "ATV1" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    41
_LIT8( KAtv0, "ATV0" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    42
_LIT8( KAtq, "ATQ" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    43
_LIT8( KAtq1, "ATQ1" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    44
_LIT8( KAtq0, "ATQ0" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    45
_LIT8( KAte, "ATE" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    46
_LIT8( KAte1, "ATE1" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    47
_LIT8( KAte0, "ATE0" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    48
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    49
_LIT8( KCmgs, "+CMGS" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    50
_LIT8( KCmgc, "+CMGC" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    51
_LIT8( KCmgsQuery, "+CMGS=?" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    52
_LIT8( KCmgcQuery, "+CMGC=?" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    53
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    54
// Carriage return needs to be checked from ATS3, or the following AT&V
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    55
// fails, because its not yet informed to upper layers.
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    56
_LIT8( KAts3, "ATS3=" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    57
const TUint8 KDefaultCarriageChar( 0xd );  // 13
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    58
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    59
const TUint8 KOff( 0x00 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    60
const TUint8 KOn( 0x01 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    61
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    62
const TInt KEchoOn( 1 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    63
const TInt KEchoOff( 2 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    64
const TInt KVerboseOn( 3 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    65
const TInt KVerboseOff( 4 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    66
const TInt KQuietOn( 5 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    67
const TInt KQuietOff( 6 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    68
const TInt KReplyTypeEditorStart( 1 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    69
const TInt KReplyTypeEditorEnd( 2 );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    70
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    71
CModemAtSrv::CModemAtSrv( TInt aPriority ) :
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
    72
    CPolicyServer( aPriority, KSrvPolicy ),
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
    73
    iHandler(NULL),
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    74
    iEcho( KOn ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    75
    iEchoNotified( KInitialValue ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    76
    iEchoQueryIsOngoing( EFalse ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    77
    iVerbose( KOff ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    78
    iVerboseNotified( KInitialValue ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    79
    iVerboseQueryIsOngoing( EFalse ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    80
    iQuiet( KOff ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    81
    iQuietNotified( KInitialValue ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    82
    iQuietQueryIsOngoing( EFalse ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    83
    iCarriageReturn( KDefaultCarriageChar ),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    84
    iCarriageReturnFound( EFalse )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    85
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    86
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_CMODEMATSRV, "CModemAtSrv::CModemAtSrv" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    87
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    88
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    89
CModemAtSrv::~CModemAtSrv()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    90
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
    91
    OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_CMODEMATSRV, "CModemAtSrv::~CModemAtSrv" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    92
    C_TRACE (( _L(">>CModemAtSrv::~CModemAtSrv()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    93
    iAtMessageArray.ResetAndDestroy();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    94
    iAtMessageArray.Close();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    95
    C_TRACE (( _L("<<CModemAtSrv::~CModemAtSrv()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    96
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    97
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    98
CModemAtSrv* CModemAtSrv::NewLC()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
    99
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   100
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_NEWLC, "CModemAtSrv::NewLC" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   101
    CModemAtSrv* self = new (ELeave) CModemAtSrv( EPriorityNormal );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   102
    CleanupStack::PushL( self );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   103
    self->ConstructL();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   104
    self->StartL( KATExtSrvName );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   105
    RThread().SetPriority( EPriorityNormal );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   106
    return self;
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   107
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   108
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   109
void CModemAtSrv::RemovePipe( CModemAtHandler* aHandler )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   110
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   111
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_REMOVEPIPE, "CModemAtSrv::RemovePipe" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   112
    C_TRACE((_L("CModemAtSrv::RemovePipe()") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   113
    ASSERT_PANIC_ALWAYS( NULL != aHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   114
    aHandler->RemovePipe();
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   115
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   116
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   117
void CModemAtSrv::ClientClosed( CModemAtSession* aSession )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   118
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   119
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_CLIENTCLOSED, "CModemAtSrv::ClientClosed" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   120
    C_TRACE (( _L(">>CModemAtSrv::ClientClosed()") ));
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   121
    TInt index = iSessions.Find( aSession );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   122
    if( index >= 0 )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   123
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   124
        OstTrace1( TRACE_NORMAL, DUP1_CMODEMATSRV_CLIENTCLOSED, "CModemAtSrv::ClientClosed - Removing session;iSessions[index]->GetPluginType()=%d", iSessions[index]->GetPluginType() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   125
        C_TRACE((_L("Removing session (plugin type %d)"), iSessions[index]->GetPluginType() ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   126
        iSessions.Remove( index );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   127
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   128
        if( ECommonPlugin == aSession->GetPluginType() )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   129
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   130
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_CLIENTCLOSED, "CModemAtSrv::ClientClosed - Disconnecting ISI message handler" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   131
            C_TRACE((_L("Disconnecting ISI message handler ") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   132
            aSession->GetHandler()->Disconnect();
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   133
            }
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   134
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   135
        for( int i = 0; i < iDteInfo.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   136
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   137
            if( aSession == iDteInfo[i].iSession )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   138
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   139
                OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_CLIENTCLOSED, "CModemAtSrv::ClientClosed - removing dte info" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   140
                C_TRACE((_T("CModemAtSrv::ClientClosed() removing dte info") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   141
                iDteInfo.Remove( i );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   142
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   143
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   144
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   145
        TBool pluginsFound( EFalse );       
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   146
        for( int i = 0; i < iSessions.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   147
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   148
            if( 0 == iSessions[i]->GetName().Compare( aSession->GetName() ) )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   149
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   150
                pluginsFound = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   151
                break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   152
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   153
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   154
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   155
        if( !pluginsFound &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   156
            iHandler != aSession->GetHandler() )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   157
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   158
            OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_CLIENTCLOSED, "CModemAtSrv::ClientClosed - Deleting handler" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   159
            C_TRACE((_L("Deleting handler") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   160
            iFreeChannels.Append( aSession->GetHandler()->GetChannelId() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   161
            delete aSession->GetHandler();
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   162
            }
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   163
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   164
        C_TRACE((_T("<<CModemAtSrv::ClientClosed()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   165
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   166
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   167
 
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   168
CSession2* CModemAtSrv::NewSessionL( const TVersion& aVersion,
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   169
                                   const RMessage2& /*aMessage*/ ) const
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   170
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   171
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_NEWSESSIONL, "CModemAtSrv::NewSessionL" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   172
    C_TRACE (( _T("CModemAtSrv::NewSessionL()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   173
    CModemAtSrv& thisServer = const_cast<CModemAtSrv&>( *this );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   174
    CModemAtSession* session = CModemAtSession::NewL( thisServer, aVersion );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   175
    CleanupStack::PushL( session );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   176
    thisServer.iSessions.AppendL( session );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   177
    CleanupStack::Pop( session );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   178
    return session;
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   179
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   180
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   181
void CModemAtSrv::ConstructL()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   182
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   183
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_CONSTRUCTL, "CModemAtSrv::ConstructL" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   184
    C_TRACE (( _T("CModemAtSrv::ConstructL()") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   185
    iHandler = CModemAtHandler::NewL( *this, EIscNokiaAtController );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   186
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   187
    iFreeChannels.Append( EIscNokiaAtController2 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   188
    iFreeChannels.Append( EIscNokiaAtController3 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   189
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   190
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   191
void CModemAtSrv::HandleSignalInd( const TUint8 aDteId, const TInt aCompleteCode )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   192
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   193
    C_TRACE((_T("CModemAtSrv::HandleSignalInd aDteId = %d sessions = %d, code = %d"), aDteId, iSessions.Count(), aCompleteCode ));
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   194
    for( TInt i = 0; i < iSessions.Count(); i++ )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   195
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   196
        if( iSessions[i]->GetDteId() == aDteId && iSessions[i]->IsSignalIndReqActive() )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   197
            {
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   198
            C_TRACE (( _T("CModemAtSrv::HandleSignalInd() session found") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   199
            iSessions[i]->SignalIndReceived( aCompleteCode );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   200
            }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   201
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   202
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   203
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   204
void CModemAtSrv::HandleUnsolicitedData( const TUint8 aDteId, const TDesC8& aData )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   205
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   206
    OstTraceExt2( TRACE_NORMAL, CMODEMATSRV_HANDLEUNSOLICITEDDATA, "CModemAtSrv::HandleUnsolicitedData;aDteId=%d;iSessions.Count()=%d", aDteId, iSessions.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   207
    C_TRACE ((_T("CModemAtSrv::HandleUnsolicitedData aDteId = %d sessions = %d"), aDteId, iSessions.Count() ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   208
    TBool unsolicitedDataHandled( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   209
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   210
    _LIT8( KNoCarrier, "NO CARRIER" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   211
    if( aData.Find( KNoCarrier ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   212
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   213
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_HANDLEUNSOLICITEDDATA, "CModemAtSrv::HandleUnsolicitedData - NO CARRIER -> COMMAND MODE" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   214
        C_TRACE(_L("NO CARRIER -> COMMAND MODE"));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   215
        HandleCommandModeChange( aDteId, ECommandMode );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   216
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   217
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   218
    for( TInt i = 0; i < iSessions.Count(); i++ )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   219
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   220
        if( ( iSessions[i]->GetDteId() == aDteId || aDteId == KUnsolicitedDataDteId )&&
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   221
            iSessions[i]->IsUnsolicitedDataReqActive() &&
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   222
            iSessions[i]->GetPluginType() == EATExtPlugin )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   223
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   224
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_HANDLEUNSOLICITEDDATA, "CModemAtSrv::HandleUnsolicitedData - session found" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   225
            C_TRACE (( _T("CModemAtSrv::HandleUnsolicitedData() session found") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   226
            iSessions[i]->UnsolicitedData( aData );
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   227
            unsolicitedDataHandled = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   228
            return;
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   229
            }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   230
        }
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   231
    if( ! unsolicitedDataHandled )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   232
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   233
        OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_HANDLEUNSOLICITEDDATA, "CModemAtSrv::HandleUnsolicitedData - request is not active yet so save message to the server" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   234
        C_TRACE (( _T("CModemAtSrv::HandleSignalInd() request is not active yet so save message to the server") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   235
        
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   236
        // Note: If call is received with unsolicited "RING", it will not be sent, because request is not active in data mode.
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   237
        // After that "NO CARRIER" will copy over the "RING", and it will be sent, when returning to command mode.
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   238
        iTemporaryUnsolicitedData = aData;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   239
        }
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   240
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   241
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   242
TBool CModemAtSrv::IsUnsolicitedDataInBuffer()
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   243
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   244
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_ISUNSOLICITEDDATAINBUFFER, "CModemAtSrv::IsUnsolicitedDataInBuffer;%d", (TInt) iTemporaryUnsolicitedData.Length() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   245
    C_TRACE ((_T("CModemAtSrv::IsUnsolicitedDataInBuffer %d"), (TInt) iTemporaryUnsolicitedData.Length() ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   246
    if( iTemporaryUnsolicitedData.Length() > 0)
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   247
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   248
        return ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   249
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   250
    else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   251
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   252
        return EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   253
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   254
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   255
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   256
void CModemAtSrv::ResetUnsolicitedDataInBuffer()
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   257
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   258
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_RESETUNSOLICITEDDATAINBUFFER, "CModemAtSrv::ResetUnsolicitedDataInBuffer" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   259
    C_TRACE (( _T("CModemAtSrv::ResetUnsolicitedDataInBuffer()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   260
    iTemporaryUnsolicitedData.Zero();
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   261
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   262
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   263
void CModemAtSrv::GetUnsolicitedDataInBuffer( TDes8& aData )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   264
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   265
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_GETUNSOLICITEDDATAINBUFFER, "CModemAtSrv::GetUnsolicitedDataInBuffer" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   266
    C_TRACE (( _T("CModemAtSrv::GetUnsolicitedDataInBuffer()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   267
    aData.Copy( iTemporaryUnsolicitedData );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   268
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   269
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   270
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   271
void CModemAtSrv::HandleCommandModeChange( TUint8 aDteId, TCommandMode aMode )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   272
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   273
    OstTraceExt2( TRACE_NORMAL, CMODEMATSRV_HANDLECOMMANDMODECHANGE, "CModemAtSrv::HandleCommandModeChange;iSessions.Count()=%d;aMode=%d", iSessions.Count(), (TInt)aMode );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   274
    C_TRACE ((_T("CModemAtSrv::HandleCommandModeChange sessions = %d mode = %d"), iSessions.Count(), (TInt) aMode ));
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   275
    for( TInt i = 0; i < iSessions.Count(); i++ )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   276
        {
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   277
        if( iSessions[i]->IsCommandModeReqActive() &&
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   278
            ECommonPlugin == iSessions[i]->GetPluginType() &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   279
            aDteId == iSessions[i]->GetDteId() )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   280
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   281
            OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_HANDLECOMMANDMODECHANGE, "CModemAtSrv::HandleCommandModeChange - session found" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   282
            C_TRACE (( _T("CModemAtSrv::HandleCommandModeChange() session found") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   283
            iSessions[i]->CommandModeChanged( aMode );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   284
            }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   285
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   286
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   287
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   288
void CModemAtSrv::HandleIntermediateDataInd( const TUint8 aDteId,
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   289
    const TATPluginInterface aPluginType,
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   290
    const TDesC8& aResponse,
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   291
    const TUint8 aCommand )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   292
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   293
    OstTraceExt2( TRACE_NORMAL, CMODEMATSRV_HANDLEINTERMEDIATEDATAIND, "CModemAtSrv::HandleIntermediateDataInd;aDteId=%d;iSessions.Count()=%d", aDteId, iSessions.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   294
    C_TRACE ((_T("CModemAtSrv::HandleIntermediateDataInd aDteId = %d sessions = %d "), aDteId, iSessions.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   295
    C_TRACE ((_T("plugintype = %d command = %d"), (TInt)aPluginType, aCommand ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   296
    
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   297
    if ( iAtMessageArray.Count() > 0 )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   298
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   299
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_HANDLEINTERMEDIATEDATAIND, "CModemAtSrv::HandleIntermediateDataInd - iAtMessageArray[0]->ReceiveATResponse Intermediate data" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   300
        C_TRACE((_L("iAtMessageArray[0]->ReceiveATResponse Intermediate data")));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   301
        iAtMessageArray[0]->ReceiveATResponse( aResponse, EFalse, KErrNone );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   302
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   303
    else
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   304
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   305
        OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_HANDLEINTERMEDIATEDATAIND, "CModemAtSrv::HandleIntermediateDataInd - INTERMEDIATE DATA received but no request active" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   306
        C_TRACE ((_T("CModemAtSrv::HandleIntermediateDataInd INTERMEDIATE DATA received but no request active") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   307
        HandleUnsolicitedData( aDteId, aResponse);
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   308
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   309
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   310
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   311
void CModemAtSrv::HandleATResponse( 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   312
    const TUint8 aDteId, 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   313
    CModemAtHandler* aHandler,
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   314
    const TDesC8& aResponse, 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   315
    const TUint8 aCommand )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   316
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   317
    OstTraceExt2( TRACE_NORMAL, CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse;aDteId=%d;iSessions.Count()=%d", aDteId, iSessions.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   318
    C_TRACE ((_T(">>CModemAtSrv::HandleATResponse aDteId = %d sessions = %d "), aDteId, iSessions.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   319
    C_TRACE ((_T("CModemAtSrv::HandleATResponse command = %d"), aCommand ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   320
    TRACE_ASSERT( NULL != aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   321
    TInt completeCode( KErrNone );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   322
    if( IsTextMessageMode( aHandler ) )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   323
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   324
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Text message mode is on" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   325
        C_TRACE(_L("Text message mode is on"));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   326
        if( aResponse.Find( KCursor ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   327
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   328
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - detected during text message mode" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   329
            C_TRACE(_L("> detected during text message mode"));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   330
            completeCode = KReplyTypeEditorStart; // replace later with EReplyTypeEditorStart
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   331
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   332
        else if( aResponse.Find( KOkResponse ) != KErrNotFound ||
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   333
        	  aResponse.Find( KErrorResponse ) != KErrNotFound ||
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   334
        	  aResponse.Find( KOkResponseNoVerbose ) != KErrNotFound ||
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   335
        	  aResponse.Find( KErrorResponseNoVerbose ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   336
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   337
            OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Response detected after text message mode" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   338
            C_TRACE(_L("Response detected after text message mode"));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   339
            aHandler->SetTextMessageMode( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   340
            completeCode = KReplyTypeEditorEnd; // replace later with EReplyTypeEditorEnd
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   341
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   342
        if( completeCode == KErrNone )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   343
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   344
            OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Response detected after text message mode (quiet mode)" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   345
            C_TRACE(_L("Response detected after text message mode (quiet mode)"));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   346
            aHandler->SetTextMessageMode( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   347
            completeCode = KReplyTypeEditorEnd;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   348
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   349
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   350
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   351
    if( iEchoQueryIsOngoing )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   352
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   353
        OstTraceExt2( TRACE_NORMAL, DUP5_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Echo query ongoing.;iEcho=%d;iEchoNitified=%d", iEcho, iEchoNotified );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   354
        C_TRACE((_L("Echo query ongoing. current: %d, notified %d"), iEcho, iEchoNotified ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   355
        if( iEcho == KOff && iEchoNotified != KOff )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   356
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   357
            OstTrace0( TRACE_NORMAL, DUP7_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Echo off, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   358
            C_TRACE(_L("Echo off, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   359
            HandleSignalInd( aDteId, KEchoOff );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   360
            iEchoNotified = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   361
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   362
        else if( iEcho == KOn && iEchoNotified != KOn )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   363
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   364
            OstTrace0( TRACE_NORMAL, DUP8_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Echo on, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   365
            C_TRACE(_L("Echo on, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   366
            HandleSignalInd( aDteId, KEchoOn );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   367
            iEchoNotified = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   368
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   369
        iEchoQueryIsOngoing = EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   370
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   371
    else if( iVerboseQueryIsOngoing )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   372
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   373
        OstTraceExt2( TRACE_NORMAL, DUP9_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Verbose query ongoing.;iVerbose=%d;iVerboseNotified=%d", iVerbose, iVerboseNotified );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   374
        C_TRACE((_L("Verbose query ongoing. current: %d, notified %d"), iVerbose, iVerboseNotified ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   375
        if( iVerbose == KOff && iVerboseNotified != KOff )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   376
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   377
            OstTrace0( TRACE_NORMAL, DUP10_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Verbose off received, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   378
            C_TRACE(_L("Verbose off received, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   379
            HandleSignalInd( aDteId, KVerboseOff );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   380
            iVerboseNotified = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   381
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   382
        else if( iVerbose == KOn && iVerboseNotified != KOn )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   383
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   384
            OstTrace0( TRACE_NORMAL, DUP11_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Verbose on received, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   385
            C_TRACE(_L("Verbose on received, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   386
            HandleSignalInd( aDteId, KVerboseOn );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   387
            iVerboseNotified = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   388
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   389
        iVerboseQueryIsOngoing = EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   390
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   391
    else if( iQuietQueryIsOngoing )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   392
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   393
        OstTraceExt2( TRACE_NORMAL, DUP12_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Quiet query ongoing.;iQuiet=%d;iQuietNotified=%d", iQuiet, iQuietNotified );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   394
        C_TRACE((_L("Quiet query ongoing. current: %d, notified %d"), iQuiet, iQuietNotified ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   395
        if( iQuiet == KOff && iQuietNotified != KOff )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   396
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   397
            OstTrace0( TRACE_NORMAL, DUP13_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Quiet off, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   398
            C_TRACE(_L("Quiet off, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   399
            HandleSignalInd( aDteId, KQuietOff );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   400
            iQuietNotified = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   401
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   402
        else if( iQuiet == KOn && iQuietNotified != KOn )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   403
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   404
            OstTrace0( TRACE_NORMAL, DUP14_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Quiet on, notify common plug-in." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   405
            C_TRACE(_L("Quiet on, notify common plug-in."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   406
            HandleSignalInd( aDteId, KQuietOn );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   407
            iQuietNotified = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   408
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   409
        iQuietQueryIsOngoing = EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   410
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   411
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   412
    if ( iAtMessageArray.Count() > 0 )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   413
        {
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   414
        CAtMessage* tmp = iAtMessageArray[0];
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   415
        OstTrace1( TRACE_NORMAL, DUP15_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - iAtMessageArray[0]->ReceiveATResponse;tmp=%x", tmp );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   416
        C_TRACE((_L("iAtMessageArray[0]->ReceiveATResponse 0x%x"), tmp ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   417
        tmp->ReceiveATResponse( aResponse, ETrue, completeCode );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   418
        OstTrace0( TRACE_NORMAL, DUP16_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - Remove the first message in Fifo" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   419
        C_TRACE((_L("CModemAtSrv::HandleATResponse Remove the first message in Fifo")));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   420
        RemoveFirstFromSendFifo();
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   421
        OstTrace0( TRACE_NORMAL, DUP17_CMODEMATSRV_HANDLEATRESPONSE, "CModemAtSrv::HandleATResponse - SendNextFromFifo" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   422
        C_TRACE((_L("CModemAtSrv::HandleATResponse SendNextFromFifo")));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   423
        SendNextFromFifo();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   424
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   425
    else
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   426
        {
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   427
        HandleUnsolicitedData( aDteId, aResponse);
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   428
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   429
    C_TRACE ((_T("<<CModemAtSrv::HandleATResponse()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   430
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   431
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   432
TInt CModemAtSrv::ConnectToModemL( CModemAtSession* aSession, TATPluginInterface aPluginType ) 
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   433
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   434
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL;aSession=%x", aSession );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   435
    C_TRACE ((_T(">>CModemAtSrv::ConnectToModem 0x%x"), aSession));
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   436
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   437
    OstTraceExt2( TRACE_NORMAL, DUP1_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL;iSessions.Count()=%d;aPluginType=%d", iSessions.Count(), (TInt)aPluginType );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   438
    C_TRACE(( _L("session count: %d, type: %d"), iSessions.Count(), (TInt) aPluginType ));
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   439
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   440
    if( aPluginType == ECommonPlugin )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   441
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   442
        OstTrace1( TRACE_NORMAL, DUP2_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Common plug-in connecting;aSession=%x", aSession );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   443
        C_TRACE ((_T("Common plug-in connecting")));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   444
        C_TRACE ((_T("<<CModemAtSrv::ConnectToModem session: 0x%x"), aSession));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   445
        
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   446
        if( KMaxDteCount >= GetDteCount() )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   447
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   448
            TBool handlerAttached( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   449
            for( TInt i = 0; i < iSessions.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   450
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   451
                if( iHandler == iSessions[i]->GetHandler() )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   452
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   453
                    handlerAttached = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   454
                    break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   455
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   456
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   457
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   458
            TUint8 devId( 0 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   459
            TUint8 objId( 0 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   460
            TBool dteFound( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   461
            OstTrace1( TRACE_NORMAL, DUP3_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL;iDteInfo.Count()=%d", iDteInfo.Count() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   462
            C_TRACE ((_T("iDteInfo.Count(): %d"), iDteInfo.Count()));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   463
            for( TInt j = 0; j < iDteInfo.Count(); j++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   464
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   465
                if( NULL == iDteInfo[j].iSession )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   466
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   467
                    dteFound = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   468
                    CModemAtHandler* handler( NULL );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   469
                    devId = iDteInfo[j].iDevId;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   470
                    objId = iDteInfo[j].iObjId;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   471
                    if( handlerAttached )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   472
                        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   473
                        OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Creating new handler" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   474
                        C_TRACE ((_T("Creating new handler")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   475
                        TUint8 channelId( 0 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   476
                        if( KErrNone == GetFreeChannelId( channelId ) )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   477
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   478
                            handler = CModemAtHandler::NewL(
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   479
                                *this,
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   480
                                channelId );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   481
                            iDteInfo[j].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   482
                            aSession->SetHandler( handler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   483
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   484
                        else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   485
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   486
                            TRACE_ASSERT_ALWAYS;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   487
                            aSession->ModemConnected( KErrGeneral );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   488
                            OstTrace0( TRACE_NORMAL, DUP14_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL No free channel id" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   489
                            C_TRACE ((_T("No free channel id")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   490
                            return KErrGeneral;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   491
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   492
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   493
                    else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   494
                        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   495
                        OstTrace0( TRACE_NORMAL, DUP5_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Using already created handler" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   496
                        C_TRACE ((_T("Using already created handler")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   497
                        iDteInfo[j].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   498
                        aSession->SetHandler( iHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   499
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   500
                    break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   501
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   502
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   503
            if( dteFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   504
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   505
                return aSession->GetHandler()->Connect( devId, objId );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   506
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   507
            else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   508
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   509
                OstTrace0( TRACE_NORMAL, DUP6_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - No dte info found. Possibly PNS_NAME_ADD_IND not received -> creating default pipe." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   510
                C_TRACE ((_T("No dte info found. Possibly PNS_NAME_ADD_IND not received -> creating default pipe.")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   511
                
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   512
                CModemAtHandler* handler( NULL );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   513
                
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   514
                TUint KInitialDpObjId( 0x2f );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   515
                TUint dataportObjectid( KInitialDpObjId );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   516
                TBool found( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   517
                    
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   518
                if( !handlerAttached )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   519
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   520
                    OstTrace0( TRACE_NORMAL, DUP7_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Using already created handler" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   521
                    C_TRACE ((_T("Using already created handler")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   522
                    aSession->SetHandler( iHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   523
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   524
                    OstTrace0( TRACE_NORMAL, DUP8_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Calling GetDataportObjectId()" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   525
                    C_TRACE ((_T("Calling GetDataportObjectId()")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   526
                    aSession->GetHandler()->GetDataportObjectId( dataportObjectid );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   527
                    
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   528
                    OstTrace0( TRACE_NORMAL, DUP9_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Calling AddDevice()" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   529
                    C_TRACE ((_T("Calling AddDevice()")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   530
                    AddDevice( THIS_DEVICE, (TUint8)dataportObjectid );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   531
                    
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   532
                    OstTrace0( TRACE_NORMAL, DUP10_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Set session to this device" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   533
                    C_TRACE ((_T("Set session to this device")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   534
                    for( TInt j = 0; j < iDteInfo.Count(); j++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   535
                        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   536
                        if( NULL == iDteInfo[j].iSession ) // if iSession is NULL, the device handler is not attached
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   537
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   538
                            OstTrace0( TRACE_NORMAL, DUP11_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Device session found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   539
                            C_TRACE ((_T("Device session found")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   540
                            iDteInfo[j].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   541
                            found = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   542
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   543
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   544
                    if( !found )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   545
                        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   546
                        OstTrace0( TRACE_NORMAL, DUP12_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Device session not found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   547
                        C_TRACE ((_T("Device session not found")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   548
                        if( iDteInfo.Count() == 1 )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   549
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   550
                            OstTrace0( TRACE_NORMAL, DUP13_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Set session to first device" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   551
                            C_TRACE ((_T("Set session to first device")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   552
                            iDteInfo[0].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   553
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   554
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   555
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   556
                else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   557
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   558
                    // NOTE: It might be possible to have second device attached and then no pipe has been created
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   559
                    // before this, EIscNokiaDataport2 has been used with first device. Now we need use
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   560
                    // EIscNokiaDataport4. EIscNokiaDataport5 is not currently supported without PNS_NAME_ADD_IND.
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   561
                    TUint8 channelId( 0 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   562
                    if( KErrNone == GetFreeChannelId( channelId ) )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   563
                        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   564
                        C_TRACE ((_T("Creating new handler")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   565
                        handler = CModemAtHandler::NewL(
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   566
                            *this,
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   567
                            channelId );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   568
                        OstTrace0( TRACE_NORMAL, DUP15_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Using just created handler" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   569
                        C_TRACE ((_T("Using just created handler")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   570
                        aSession->SetHandler( handler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   571
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   572
                        OstTrace0( TRACE_NORMAL, DUP16_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Calling GetDataportObjectId()" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   573
                        C_TRACE ((_T("Calling GetDataportObjectId()")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   574
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   575
                        // Get dataport 4 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   576
                        aSession->GetHandler()->GetSecondaryDataportObjectId( dataportObjectid );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   577
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   578
                        OstTrace0( TRACE_NORMAL, DUP17_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Calling AddDevice()" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   579
                        C_TRACE ((_T("Calling AddDevice()")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   580
                        AddDevice( THIS_DEVICE, (TUint8)dataportObjectid );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   581
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   582
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   583
                        OstTrace0( TRACE_NORMAL, DUP18_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Set session to the second device" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   584
                        C_TRACE ((_T("Set session to the second device")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   585
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   586
                        for( TInt j = 0; j < iDteInfo.Count(); j++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   587
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   588
                            if( NULL == iDteInfo[j].iSession )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   589
                                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   590
                                OstTrace0( TRACE_NORMAL, DUP19_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Device session found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   591
                                C_TRACE ((_T("Device session found")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   592
                                iDteInfo[j].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   593
                                found = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   594
                                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   595
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   596
                        if( !found )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   597
                            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   598
                            OstTrace0( TRACE_NORMAL, DUP20_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Device 2 session not found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   599
                            C_TRACE ((_T("Device 2 session not found")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   600
                            if( iDteInfo.Count() == 2 )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   601
                                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   602
                                OstTrace0( TRACE_NORMAL, DUP21_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Set session to second device" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   603
                                C_TRACE ((_T("Set session to second device")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   604
                                iDteInfo[1].iSession = aSession;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   605
                                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   606
                            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   607
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   608
                    else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   609
                        {	
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   610
                        TRACE_ASSERT_ALWAYS;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   611
                        aSession->ModemConnected( KErrGeneral );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   612
                        OstTrace0( TRACE_NORMAL, DUP26_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL No free channel id" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   613
                        C_TRACE ((_T("No free channel id")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   614
                        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   615
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   616
                if( found )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   617
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   618
                    OstTrace0( TRACE_NORMAL, DUP22_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Calling Connect( THIS_DEVICE, dataportObjectid )" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   619
                    C_TRACE ((_T("Calling Connect( THIS_DEVICE, dataportObjectid )")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   620
                    return aSession->GetHandler()->Connect( THIS_DEVICE, dataportObjectid );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   621
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   622
                else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   623
                    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   624
                    C_TRACE ((_T("no dte info found, connect failed")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   625
                    OstTrace0( TRACE_NORMAL, DUP27_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL no dte info found, connect failed" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   626
                    aSession->ModemConnected( KErrGeneral );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   627
                    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   628
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   629
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   630
        else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   631
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   632
            OstTrace0( TRACE_NORMAL, DUP23_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Too many connections, connect failed" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   633
            C_TRACE ((_T("Too many connections, connect failed")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   634
            aSession->ModemConnected( KErrGeneral );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   635
            }
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   636
        }
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   637
    else
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   638
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   639
        OstTrace0( TRACE_NORMAL, DUP24_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL - Atext plug-in connecting" );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   640
        C_TRACE ((_T("Atext plug-in connecting")));
5
8ccc39f9d787 New release based on our 2010wk02 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 0
diff changeset
   641
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   642
        for( TInt i = 0; i < iSessions.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   643
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   644
            if( ECommonPlugin == iSessions[i]->GetPluginType() &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   645
                0 == iSessions[i]->GetName().Compare( aSession->GetName() ) )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   646
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   647
                aSession->SetDteId( iSessions[i]->GetDteId() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   648
                aSession->SetHandler( iSessions[i]->GetHandler() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   649
                break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   650
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   651
            }
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   652
        aSession->ModemConnected( KErrNone );
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   653
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   654
        OstTrace1( TRACE_NORMAL, DUP25_CMODEMATSRV_CONNECTTOMODEML, "CModemAtSrv::ConnectToModemL;aSession=%x", aSession );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   655
        C_TRACE ((_T("<<CModemAtSrv::ConnectToModem 0x%x"), aSession));
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   656
        }
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   657
    return KErrNone;
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   658
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   659
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   660
void CModemAtSrv::AddToSendFifo( const TATPluginInterface aPluginType, CAtMessage* aMessage )
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   661
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   662
    OstTraceExt2( TRACE_NORMAL, CMODEMATSRV_ADDTOSENDFIFO, "CModemAtSrv::AddToSendFifo;aPluginType=%d;aMessage=%p", (TInt)aPluginType, aMessage );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   663
    C_TRACE (( _T("CModemAtSrv::AddToSendFifo( aPluginType: %d, aMessage: 0x%x)"), (TInt)aPluginType, aMessage));
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   664
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   665
    iAtMessageArray.Append( aMessage ); // only one AT command at the time in modem
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   666
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   667
    if( iAtMessageArray.Count() == 1 ) //if empty Fifo send immediately
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   668
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   669
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_ADDTOSENDFIFO, "CModemAtSrv::AddToSendFifo - Sending message immediately" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   670
        C_TRACE((_L("Sending message immediately")));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   671
        CModemAtSession* session = aMessage->GetSession();
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   672
        if( session )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   673
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   674
            CModemAtHandler* handler( session->GetHandler() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   675
            PeekAtCommand( handler, aMessage->GetBuffer() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   676
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   677
            handler->SendATCommand( 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   678
                aPluginType,
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   679
                aMessage->GetMessageType(),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   680
                aMessage->GetBuffer() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   681
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   682
        else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   683
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   684
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_ADDTOSENDFIFO, "CModemAtSrv::AddToSendFifo - Session NULL" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   685
            C_TRACE((_L("Session NULL")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   686
            TRACE_ASSERT_ALWAYS;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   687
            }
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   688
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   689
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   690
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   691
void CModemAtSrv::RemoveFirstFromSendFifo()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   692
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   693
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo;iAtMessageArray.Count()=%d", iAtMessageArray.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   694
    C_TRACE(( _T("CModemAtSrv::RemoveFirstFromSendFifo iAtMessageArray.Count = %d"), iAtMessageArray.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   695
    if( iAtMessageArray.Count( ) > 0 )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   696
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   697
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo - 1" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   698
        C_TRACE (( _T("CModemAtSrv::RemoveFirstFromSendFifo 1") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   699
        CAtMessage* msg = iAtMessageArray[0];
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   700
        OstTrace1( TRACE_NORMAL, DUP2_CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo - 2;msg=%x", msg );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   701
        C_TRACE (( _T("CModemAtSrv::RemoveFirstFromSendFifo 2 0x%x"), msg ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   702
        iAtMessageArray.Remove(0);
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   703
        if( msg )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   704
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   705
            OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo - 3" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   706
            C_TRACE (( _T("CModemAtSrv::RemoveFirstFromSendFifo 3") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   707
            delete msg;
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   708
            }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   709
        else
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   710
            {
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   711
            TRACE_ASSERT_ALWAYS;
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   712
            }
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   713
        OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo - 4" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   714
        C_TRACE (( _T("CModemAtSrv::RemoveFirstFromSendFifo 4") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   715
        }
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   716
    OstTrace0( TRACE_NORMAL, DUP5_CMODEMATSRV_REMOVEFIRSTFROMSENDFIFO, "CModemAtSrv::RemoveFirstFromSendFifo - 5" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   717
    C_TRACE (( _T("CModemAtSrv::RemoveFirstFromSendFifo 5") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   718
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   719
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   720
void CModemAtSrv::SendNextFromFifo()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   721
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   722
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_SENDNEXTFROMFIFO, "CModemAtSrv::SendNextFromFifo - fifo message count;iAtMessageArray.Count()=%d", iAtMessageArray.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   723
    C_TRACE ((_T("CModemAtSrv::SendNextFromFifo fifo has %d message(s)"), iAtMessageArray.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   724
    
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   725
    TPtr8 ptr( 0, 0 );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   726
    if( iAtMessageArray.Count() > 0 )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   727
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   728
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_SENDNEXTFROMFIFO, "CModemAtSrv::SendNextFromFifo - Messages in buffer... Sending message" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   729
        C_TRACE((_L("Messages in buffer... Sending message")));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   730
        ptr.Set( iAtMessageArray[0]->GetBuffer() );
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   731
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   732
        CModemAtHandler* handler( iAtMessageArray[0]->GetSession()->GetHandler() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   733
        if( handler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   734
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   735
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_SENDNEXTFROMFIFO, "CModemAtSrv::SendNextFromFifo - iHandler->SendATCommand()" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   736
            C_TRACE (( _T("iHandler->SendATCommand()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   737
            PeekAtCommand( handler, ptr );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   738
            handler->SendATCommand( 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   739
                iAtMessageArray[0]->GetSession()->GetPluginType(),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   740
                iAtMessageArray[0]->GetMessageType(),
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   741
                ptr );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   742
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   743
        else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   744
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   745
            OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_SENDNEXTFROMFIFO, "CModemAtSrv::SendNextFromFifo - Handler NULL" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   746
            C_TRACE((_L("Handler NULL")));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   747
            TRACE_ASSERT_ALWAYS;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   748
            }   
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   749
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   750
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   751
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   752
void CModemAtSrv::CancelFifoRequests( const CModemAtSession* aSession )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   753
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   754
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests;iAtMessageArray.Count()=%d", iAtMessageArray.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   755
    C_TRACE((_T(">>CModemAtSrv::CancelFifoRequests count: %d"), iAtMessageArray.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   756
    TInt messageCount = iAtMessageArray.Count();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   757
    for( TInt i = 0; i < messageCount; i++ )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   758
        {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   759
        OstTrace1( TRACE_NORMAL, DUP1_CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests - ;i=%d", i );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   760
        C_TRACE((_T("CancelFifoRequests %d"), i ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   761
        CAtMessage* msg = iAtMessageArray[ i ];
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   762
        if( msg )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   763
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   764
            OstTrace1( TRACE_NORMAL, DUP2_CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests - Found Request:;msg=%x", msg );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   765
            C_TRACE((_T("Found Request: 0x%x"),msg ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   766
            if( msg->GetSession() == aSession)
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   767
                {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   768
                OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests - canceling request" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   769
                C_TRACE((_T("CancelFifoRequests - canceling request") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   770
                msg->CancelRequest();
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   771
                OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests - delete msg" );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   772
                C_TRACE (( _T("CModemAtSrv::CancelFifoRequest delete msg") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   773
                delete msg;
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   774
                }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   775
            }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   776
        }
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   777
    OstTrace1( TRACE_NORMAL, DUP5_CMODEMATSRV_CANCELFIFOREQUESTS, "CModemAtSrv::CancelFifoRequests - iAtMessageArray.Remove;messageCount=%d", messageCount );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   778
    C_TRACE (( _T("CModemAtSrv::CancelFifoRequest iAtMessageArray.Remove %d messages"), messageCount ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   779
    for( TInt j = 0; j < messageCount && iAtMessageArray.Count() > 0; j++ )
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   780
        {
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   781
        iAtMessageArray.Remove( 0 );
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   782
        }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   783
    C_TRACE(( _T("<<CModemAtSrv::CancelFifoRequests()") ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   784
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   785
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   786
TInt CModemAtSrv::SessionCount()
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   787
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   788
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_SESSIONCOUNT, "CModemAtSrv::SessionCount;iSessions.Count()=%d", iSessions.Count() );
0
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   789
    C_TRACE(( _T("CModemAtSrv::SessionCount() %d"), iSessions.Count() ));
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   790
    return iSessions.Count();
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   791
    }
63b37f68c1ce First Contribution. Vanilla as it came from Nokia
<dalarub>
parents:
diff changeset
   792
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   793
void CModemAtSrv::SetDteIdAndConnect( const TUint8 aDteId, const TInt aConnectionError ) 
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   794
    {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   795
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_SETDTEIDANDCONNECT, "CModemAtSrv::SetDteIdAndConnect;aDteId=%d", aDteId );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   796
    C_TRACE(( _T("CModemAtSrv::SetDteIdAndConnect( %d )"), aDteId ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   797
    OstTrace1( TRACE_NORMAL, DUP1_CMODEMATSRV_SETDTEIDANDCONNECT, "CModemAtSrv::SetDteIdAndConnect;iSessions.Count()=%d", iSessions.Count() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   798
    C_TRACE ((_T("sessions = %d"), iSessions.Count() ));
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   799
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   800
    for( TInt i = 0; i < iSessions.Count(); i++ )
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   801
        {
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   802
        if( iSessions[i]->IsConnectReqActive() )
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   803
            {
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   804
            OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_SETDTEIDANDCONNECT, "CModemAtSrv::SetDteIdAndConnect - set sessions to connected" );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   805
            C_TRACE (( _T("set sessions to connected") ));
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   806
            iSessions[i]->SetDteId( aDteId );
8
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   807
            iSessions[i]->ModemConnected( aConnectionError );
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   808
            }
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   809
        }
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   810
    }
6295dc2169f3 New release based on our 2010wk15 release
mikaruus <mika.a.ruuskanen@nokia.com>
parents: 5
diff changeset
   811
9
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   812
TBool CModemAtSrv::IsPipeInDataMode( CModemAtHandler* aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   813
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   814
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_ISPIPEINDATAMODE, "CModemAtSrv::IsPipeInDataMode;aHandler=%x", aHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   815
    C_TRACE(( _T("CModemAtSrv::IsPipeInDataMode() handler: 0x%x"), aHandler ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   816
    TRACE_ASSERT( NULL != aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   817
    return aHandler->IsPipeInDataMode();
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   818
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   819
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   820
TBool CModemAtSrv::IsTextMessageMode( CModemAtHandler* aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   821
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   822
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_ISTEXTMESSAGEMODE, "CModemAtSrv::IsTextMessageMode;aHandler=%x", aHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   823
    C_TRACE(( _T("CModemAtSrv::IsTextMessageMode() handler: 0x%x"), aHandler ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   824
    TRACE_ASSERT( NULL != aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   825
    return aHandler->IsTextMessageMode();
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   826
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   827
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   828
void CModemAtSrv::PeekAtCommand( CModemAtHandler* aHandler, TDes8& aCmd )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   829
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   830
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand;aHandler=%x", aHandler );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   831
    C_TRACE(( _T("CModemAtSrv::PeekAtCommand() handler: 0x%x"), aHandler ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   832
    TRACE_ASSERT( NULL != aHandler )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   833
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   834
    if( ( aCmd.Find( KCmgs ) != KErrNotFound || 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   835
    	  aCmd.Find( KCmgc ) != KErrNotFound ) &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   836
    	  aCmd.Find( KCmgsQuery ) == KErrNotFound &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   837
    	  aCmd.Find( KCmgcQuery ) == KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   838
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   839
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - +CMGS or +CMGC detected. The indications after this will be ignored." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   840
        C_TRACE(_L("+CMGS or +CMGC detected. The indications after this will be ignored."));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   841
        aHandler->SetTextMessageMode( ETrue );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   842
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   843
    // no else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   844
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   845
    if( aCmd.Find( KAtv1 ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   846
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   847
        OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATV1 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   848
        C_TRACE(( _T("ATV1 received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   849
        iVerbose = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   850
        iVerboseQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   851
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   852
    else if( aCmd.Find( KAtv0 ) != KErrNotFound || 
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   853
    	  aCmd.Find( KAtv ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   854
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   855
        OstTrace0( TRACE_NORMAL, DUP3_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATV0 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   856
        C_TRACE(( _T("ATV(0) received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   857
        iVerbose = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   858
        iVerboseQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   859
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   860
    else if( aCmd.Find( KAtq1 ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   861
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   862
        OstTrace0( TRACE_NORMAL, DUP4_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATQ1 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   863
        C_TRACE(( _T("ATQ1 received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   864
        iQuiet = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   865
        iQuietQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   866
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   867
    else if( aCmd.Find( KAtq0 ) != KErrNotFound ||
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   868
    	  aCmd.Find( KAtq ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   869
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   870
        OstTrace0( TRACE_NORMAL, DUP5_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATQ0 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   871
        C_TRACE(( _T("ATQ(0) received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   872
        iQuiet = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   873
        iQuietQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   874
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   875
    else if( aCmd.Find( KAte1 ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   876
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   877
        OstTrace0( TRACE_NORMAL, DUP6_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATE1 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   878
        C_TRACE(( _T("ATE(1) received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   879
        iEcho = KOn;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   880
        iEchoQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   881
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   882
    else if( aCmd.Find( KAte0 ) != KErrNotFound ||
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   883
    	  aCmd.Find( KAte ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   884
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   885
        OstTrace0( TRACE_NORMAL, DUP7_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATE0 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   886
        C_TRACE(( _T("ATE(0) received") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   887
        iEcho = KOff;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   888
        iEchoQueryIsOngoing = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   889
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   890
    else if( aCmd.Find( KAts3 ) != KErrNotFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   891
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   892
        OstTrace0( TRACE_NORMAL, DUP8_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATS3 received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   893
        C_TRACE(( _T("ATS3= received, saving it for the next profile query") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   894
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   895
        TInt valueLength = aCmd.Length() - KAts3().Length() - 1;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   896
		OstTrace1( TRACE_NORMAL, DUP9_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand;valueLength=%d", valueLength );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   897
		OstTrace1( TRACE_NORMAL, DUP10_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand;KAts3Length=%d", KAts3().Length() );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   898
        C_TRACE(( _T("Reading %d char's starting from %d."), valueLength, KAts3().Length() ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   899
        if( valueLength > 0 )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   900
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   901
            TLex8 lex( aCmd.Mid( KAts3().Length(), valueLength ) );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   902
            TInt value;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   903
            if( lex.Val(value) == KErrNone )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   904
                {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   905
                C_TRACE(( _T("iCarriageReturn 0x%x "), value ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   906
                iCarriageReturn = (TUint8)value;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   907
                iCarriageReturnFound = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   908
                }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   909
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   910
        // no else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   911
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   912
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   913
    if( aCmd.Find( KAts3 ) == KErrNotFound &&
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   914
    	  iCarriageReturnFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   915
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   916
        OstTrace0( TRACE_NORMAL, DUP11_CMODEMATSRV_PEEKATCOMMAND, "CModemAtSrv::PeekAtCommand - ATE=? received" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   917
        C_TRACE(( _T("ATS3 has set the carriage return, using it once for profile query that will notify it to upper layers") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   918
        aCmd.Copy( aCmd.Mid( 0, aCmd.Length() - 1 ) );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   919
        aCmd.Append( iCarriageReturn );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   920
        iCarriageReturnFound = EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   921
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   922
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   923
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   924
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   925
TBool CModemAtSrv::IsEchoNotified( const TUint8 aEchoValue )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   926
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   927
    OstTrace1( TRACE_NORMAL, CMODEMATSRV_ISECHONOTIFIED, "CModemAtSrv::IsEchoNotified;aEchoValue=%d", aEchoValue );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   928
    C_TRACE(( _T("CModemAtSrv::IsEchoNotified( %d )"), aEchoValue ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   929
    if( aEchoValue != iEchoNotified )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   930
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   931
        OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_ISECHONOTIFIED, "CModemAtSrv::IsEchoNotified - Echo value is not notified yet." );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   932
        C_TRACE(( _T("Echo value is not notified yet.") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   933
        return EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   934
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   935
    else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   936
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   937
        OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_ISECHONOTIFIED, "CModemAtSrv::IsEchoNotified - Echo value is the same as before" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   938
        C_TRACE(( _T("Echo value is the same as before") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   939
        return ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   940
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   941
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   942
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   943
TBool CModemAtSrv::IsSettingQueryOngoing()
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   944
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   945
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_ISSETTINGQUERYONGOING, "CModemAtSrv::IsSettingQueryOngoing" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   946
    C_TRACE(( _T("CModemAtSrv::IsSettingQueryOngoing()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   947
    if ( iEchoQueryIsOngoing || iVerboseQueryIsOngoing || iQuietQueryIsOngoing )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   948
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   949
        return ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   950
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   951
    else
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   952
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   953
        return EFalse;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   954
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   955
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   956
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   957
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   958
void CModemAtSrv::AddDevice( TUint8 aDevId, TUint8 aObjId )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   959
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   960
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_ADDDEVICE, "CModemAtSrv::AddDevice" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   961
    C_TRACE(( _T("CModemAtSrv::AddDevice()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   962
    TBool alreadyFound( EFalse );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   963
    
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   964
    for( int i = 0; i < iDteInfo.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   965
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   966
        if( aDevId == iDteInfo[i].iDevId && aObjId == iDteInfo[i].iObjId )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   967
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   968
            OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_ADDDEVICE, "CModemAtSrv::AddDevice - dte already found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   969
            C_TRACE(( _T("CModemAtSrv::AddDevice() dte already found") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   970
            alreadyFound = ETrue;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   971
            break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   972
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   973
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   974
    if( !alreadyFound )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   975
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   976
        OstTrace0( TRACE_NORMAL, DUP2_CMODEMATSRV_ADDDEVICE, "CModemAtSrv::AddDevice - adding dte" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   977
        C_TRACE(( _T("CModemAtSrv::AddDevice() adding dte") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   978
        TDteInfo devInfo;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   979
        devInfo.iDevId = aDevId;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   980
        devInfo.iObjId = aObjId;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   981
        devInfo.iSession = NULL;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   982
        iDteInfo.Append( devInfo );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   983
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   984
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   985
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   986
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   987
void CModemAtSrv::RemoveDevice( TUint8 aDevId, TUint8 aObjId )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   988
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   989
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_REMOVEDEVICE, "CModemAtSrv::RemoveDevice" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   990
    C_TRACE(( _T("CModemAtSrv::RemoveDevice()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   991
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   992
    for( int i = 0; i < iDteInfo.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   993
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   994
        if( aDevId == iDteInfo[i].iDevId && aObjId == iDteInfo[i].iObjId )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   995
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   996
            OstTrace0( TRACE_NORMAL, DUP1_CMODEMATSRV_REMOVEDEVICE, "CModemAtSrv::RemoveDevice - CModemAtSrv::RemoveDevice() device found" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   997
            C_TRACE(( _T("CModemAtSrv::RemoveDevice() device found") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   998
            iDteInfo.Remove( i );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
   999
            break;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1000
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1001
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1002
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1003
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1004
TUint8 CModemAtSrv::GetDteCount()
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1005
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1006
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_GETDTECOUNT, "CModemAtSrv::GetDteCount" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1007
    C_TRACE(( _T("CModemAtSrv::GetDteCount()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1008
    TUint8 count( 0 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1009
    for( int i = 0; i < iSessions.Count(); i++ )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1010
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1011
        if( ECommonPlugin == iSessions[i]->GetPluginType() )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1012
            {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1013
            count++;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1014
            }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1015
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1016
    return count;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1017
    }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1018
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1019
// -----------------------------------------------------------------------------
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1020
// CModemAtSrv::GetFreeChannelId
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1021
// Gets free ISC channel id for new connection
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1022
// -----------------------------------------------------------------------------
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1023
//
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1024
TInt CModemAtSrv::GetFreeChannelId( TUint8& aChannel )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1025
    {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1026
    OstTrace0( TRACE_NORMAL, CMODEMATSRV_GETFREECHANNELID, "CModemAtSrv::GetFreeChannelId" );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1027
    C_TRACE(( _T("CModemAtSrv::GetFreeChannelId()") ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1028
    TInt ret( KErrNotFound );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1029
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1030
    if( 0 < iFreeChannels.Size() )
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1031
        {
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1032
        ret = KErrNone;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1033
        aChannel = iFreeChannels[0];
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1034
        iFreeChannels.Delete( 0, 1 );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1035
        OstTrace1( TRACE_NORMAL, DUP1_CMODEMATSRV_GETFREECHANNELID, "CModemAtSrv::GetFreeChannelId  free channel found: 0x%x", aChannel );
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1036
        C_TRACE(( _T("CModemAtSrv::GetFreeChannelId: free channel found: 0x%x"), aChannel ));
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1037
        }
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1038
    return ret;
8486d82aef45 modemadaptation release 2010wk40
mikaruus
parents: 8
diff changeset
  1039
    }