localconnectivityservice/dun/utils/src/DunDownstream.cpp
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 52 866b4af7ffbe
permissions -rw-r--r--
201044_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  Definitions needed for one "stream" of CDunTransporter
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    17
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    18
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
 * TODO: When local media is of type RComm, listening on it is started with
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
 * RComm::NotifyDataAvailable() call. Check that USB ACM port and Irda RCOMM
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
 * (and any other new media in the future) behaves correctly so that when
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
 * RComm::ReadOneOrMore() is issued, the read is issued immediately without
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
 * checking for new data. If waiting for new data happens in this
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
 * NotifyDataAvailable/ReadOneOrMore combination, raise a defect to Symbian.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
#include "DunTransporter.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
#include "DunDownstream.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
#include "DunUpstream.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
#include "DunDebug.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
// Two-phased constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
CDunDownstream* CDunDownstream::NewL( MDunTransporterUtilityAux* aUtility )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
    CDunDownstream* self = new (ELeave) CDunDownstream( aUtility );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
    CleanupStack::PushL( self );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
    self->ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
    CleanupStack::Pop( self );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
    return self;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
// Destructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
CDunDownstream::~CDunDownstream()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
    FTRACE(FPrint( _L("CDunDownstream::~CDunDownstream()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
    ResetData();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    FTRACE(FPrint( _L("CDunDownstream::~CDunDownstream() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
// Resets data to initial values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
void CDunDownstream::ResetData()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
    // APIs affecting this:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    // IssueRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
    Stop();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
    // InitializeForDataPushing()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    delete iPushData.iDataPusher;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    iPushData.iDataPusher = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    // AddConnMonCallbackL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
    iCallbacksR.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    iCallbacksW.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
    // AddSkippedErrorL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
    iOkErrorsR.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    iOkErrorsW.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    // Internal
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
    Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
// Initializes this stream for AT command notifications
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
TInt CDunDownstream::InitializeForDataPushing(
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    MDunAtCmdHandler* aAtCmdHandler )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    FTRACE(FPrint( _L("CDunDownstream::InitializeForDataPushing()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    if ( iPushData.iDataPusher || iPushData.iAtCmdHandler )  // optional
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
        FTRACE(FPrint( _L("CDunDownstream::InitializeForDataPushing() (already exists) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
        return KErrAlreadyExists;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    if ( !aAtCmdHandler )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
        FTRACE(FPrint( _L("CDunDownstream::InitializeForDataPushing() (aAtCmdHandler) not initialized!" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
    CDunDataPusher* dataPusher = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    TRAPD( retTrap, dataPusher = CDunDataPusher::NewL(*this,this) );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    if ( retTrap != KErrNone )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
        FTRACE(FPrint( _L("CDunDownstream::InitializeForDataPushing() (trapped!) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
        return retTrap;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
    if ( iComm )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
        dataPusher->SetMedia( iComm );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
    else if ( iSocket )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
        dataPusher->SetMedia( iSocket );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    iPushData.iDataPusher = dataPusher;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
    iPushData.iAtCmdHandler = aAtCmdHandler;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
    FTRACE(FPrint( _L("CDunDownstream::InitializeForDataPushing() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
// Checks if data is in queue
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
TBool CDunDownstream::IsDataInQueue( const TDesC8* aDataToPush )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
    FTRACE(FPrint( _L("CDunDownstream::IsDataInQueue()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    if ( !iPushData.iDataPusher )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
        FTRACE(FPrint( _L("CDunDownstream::IsDataInQueue() (iPushData.iDataPusher not initialized!) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        return EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
    TInt foundIndex = iPushData.iDataPusher->FindEventFromQueue( aDataToPush );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
    FTRACE(FPrint( _L("CDunDownstream::IsDataInQueue() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    return ( foundIndex >= 0 ) ? ETrue : EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
// Adds data to event queue and starts sending if needed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
TInt CDunDownstream::AddToQueueAndSend( const TDesC8* aDataToPush,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
                                        MDunCompletionReporter* aCallback )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    FTRACE(FPrint( _L("CDunDownstream::AddToQueueAndSend()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    if ( !iPushData.iDataPusher )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
        FTRACE(FPrint( _L("CDunDownstream::AddToQueueAndSend() (iPushData.iDataPusher not initialized!) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
    // Add to event queue. If something went wrong, just return
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
    TInt retTemp = iPushData.iDataPusher->AddToEventQueue( aDataToPush, aCallback );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
    if ( retTemp != KErrNone )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
        FTRACE(FPrint( _L("CDunDownstream::AddToQueueAndSend() (ERROR) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
        return retTemp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
    // Now push the data. If already active, push will start later, if not
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
    // active it will start immediately.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
    iPushData.iDataPusher->SendQueuedData();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
    FTRACE(FPrint( _L("CDunDownstream::AddToQueueAndSend() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
// Starts downstream by issuing read request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
TInt CDunDownstream::StartStream()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
    FTRACE(FPrint( _L("CDunDownstream::StartStream()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
    FTRACE(FPrint( _L("CDunDownstream::StartStream() (buffer=0x%08X)" ), iBufferPtr ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
    // Note: only start URC here.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    // The downstream read request is started when command mode ends.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
    // This is done to make the data arrive in the correct order (reply vs.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
    // data) with "ATD" command.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
    TInt retVal = KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
    if ( iPushData.iAtCmdHandler )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
        retVal = iPushData.iAtCmdHandler->StartUrc();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    FTRACE(FPrint( _L("CDunDownstream::StartStream() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
    return retVal;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
// Stops transfer for read or write endpoints
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
TInt CDunDownstream::Stop( TBool aStopMplex )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
    FTRACE(FPrint( _L("CDunDownstream::Stop() (Dir=%d)" ), iDirection));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
    // Stop the downstream related AT command handling functionality
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
    if ( aStopMplex )  // optional
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
        if ( iPushData.iAtCmdHandler )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
            iPushData.iAtCmdHandler->StopAtCmdHandling();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
        // Stop the multiplexer separately
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   198
        if ( iPushData.iDataPusher )
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
            {
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   200
            iPushData.iDataPusher->Stop();
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
        }
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   203
    Cancel();
52
866b4af7ffbe 201039_01
hgs
parents: 29
diff changeset
   204
    iOperationType = EDunOperationTypeUndefined;
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
    FTRACE(FPrint( _L("CDunDownstream::Stop() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
// CDunDownstream::CDunDownstream
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
CDunDownstream::CDunDownstream( MDunTransporterUtilityAux* aUtility ) :
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
    iUtility( aUtility )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
    Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
// CDunDownstream::ConstructL
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
void CDunDownstream::ConstructL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
    FTRACE(FPrint( _L("CDunDownstream::ConstructL()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
    if ( !iUtility )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
        User::Leave( KErrGeneral );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
    FTRACE(FPrint( _L("CDunDownstream::ConstructL() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   231
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   232
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   233
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
// Initializes this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
void CDunDownstream::Initialize()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
    // Don't initialize iUtility here (it is set through NewL)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
    iPushData.iDataMode = EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
    iPushData.iDataPusher = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
    iPushData.iAtCmdHandler = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
// Issues transfer request for this stream
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
TInt CDunDownstream::IssueRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
    // Set direction
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
    iDirection = static_cast<TDunDirection>( EDunStreamTypeDownstream | iOperationType );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
    FTRACE(FPrint( _L("CDunDownstream::IssueRequest() (Dir=%d)" ), iDirection));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   256
    if ( IsActive() )
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
        FTRACE(FPrint( _L("CDunDownstream::IssueRequest() (not ready) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
        return KErrNotReady;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
    if ( iOperationType == EDunOperationTypeRead )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
        iBufferPtr->SetLength( iBufferPtr->MaxLength() );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
        FTRACE(FPrint( _L("CDunDownstream::IssueRequest() trying to read %d bytes... (Dir=%d)" ), iBufferPtr->Length(), iDirection));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
    else // iOperationType == EDunOperationTypeWrite
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
        FTRACE(FPrint( _L("CDunDownstream::IssueRequest() writing %d bytes... (Dir=%d)" ), iBufferPtr->Length(), iDirection));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
    switch ( iDirection )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
        case EDunReaderDownstream:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
            iNetwork->ReadOneOrMore( iStatus, *iBufferPtr );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
            SetActive();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
            FTRACE(FPrint( _L("CDunDownstream::IssueRequest() RComm ReadOneOrMore() requested" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
            break;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
        case EDunWriterDownstream:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
            AddToQueueAndSend( iBufferPtr, this );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
            break;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
        default:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
            FTRACE(FPrint( _L("CDunDownstream::IssueRequest() (ERROR) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
            return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
    FTRACE(FPrint( _L("CDunDownstream::IssueRequest() (Dir=%d) complete" ), iDirection));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
// From class CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
// Gets called when endpoint data read complete
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
void CDunDownstream::RunL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
    FTRACE(FPrint( _L("CDunDownstream::RunL() (Dir=%d)" ), iDirection));
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   299
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
    if ( iOperationType != EDunOperationTypeRead )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
        FTRACE(FPrint( _L("CDunDownstream::RunL() (wrong operation type!) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
    TBool isError;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
    TInt retTemp = iStatus.Int();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
    TInt stop = ProcessErrorCondition( retTemp, isError );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
    if ( !stop )  // no real error detected -> continue
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   311
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   312
        if ( !isError )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   313
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   314
            // Operation type was read so now set to write
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   315
            iOperationType = EDunOperationTypeWrite;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   316
            }  // if ( !isError )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   317
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
        IssueRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   320
        }  // if ( !stop )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   321
    else  // stop -> tear down connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   322
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   323
        // Now CDunDataPusher notifies to write case so here we just notify the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   324
        // read case.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   325
        TDunConnectionReason connReason;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   326
        connReason.iReasonType = EDunReasonTypeRW;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
        connReason.iContext = GetMediaContext( EDunStreamTypeDownstream );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
        connReason.iSignalType = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
        connReason.iSignalHigh = EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   330
        connReason.iDirection = iDirection;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   331
        connReason.iErrorCode = retTemp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   332
        iUtility->DoNotifyConnectionNotOk( iComm,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   333
                                           iSocket,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   334
                                           connReason,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   335
                                           iCallbacksR );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   336
        FTRACE(FPrint( _L("CDunDownstream::RunL() stop" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   337
        }  // else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   338
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   339
    FTRACE(FPrint( _L("CDunDownstream::RunL() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   340
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   341
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   342
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   343
// From class CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   344
// Gets called on cancel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   345
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   346
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   347
void CDunDownstream::DoCancel()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   348
    {
52
866b4af7ffbe 201039_01
hgs
parents: 29
diff changeset
   349
    FTRACE(FPrint( _L("CDunDownstream::DoCancel()" )));
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   350
    iNetwork->ReadCancel();
52
866b4af7ffbe 201039_01
hgs
parents: 29
diff changeset
   351
    FTRACE(FPrint( _L("CDunDownstream::DoCancel() complete" )));
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   352
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   353
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   354
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   355
// From class MDunStreamManipulator.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   356
// Gets called when outside party wants to push data to the existing stream
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   357
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   358
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   359
TInt CDunDownstream::NotifyDataPushRequest( const TDesC8* aDataToPush,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   360
                                            MDunCompletionReporter* aCallback )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   361
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   362
    FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushRequest()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   363
    // If in data mode push the reply anyway as "CONNECT" or "NO CARRIER"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   364
    // reply could arrive before/after the command mode information itself.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   365
    TInt retVal = AddToQueueAndSend( aDataToPush, aCallback );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   366
    FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushRequest() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   367
    return retVal;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   368
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   369
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   370
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   371
// From class MDunCompletionReporter.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   372
// Gets called when data push is complete
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   373
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   374
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   375
void CDunDownstream::NotifyDataPushComplete( TBool aAllPushed )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   376
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   377
    FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   378
    // Next just skip the notifications of atomic operations because also this
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   379
    // class initiates the pushing of atomic data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   380
    if ( !aAllPushed )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   381
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   382
        FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete() (continue) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   383
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   384
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   385
    if ( !iPushData.iDataPusher )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   386
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   387
        FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete() (iPushData.iDataPusher not initialized!) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   388
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   389
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   390
    // Now the multiplexer might have pushed the contained data in this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   391
    // or it might have pushed only the external data. If the pushed data
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   392
    // contains this classes data then reissue request, otherwise just clear
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   393
    // the queue.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   394
    TInt foundIndex = iPushData.iDataPusher->FindEventFromQueue( iBufferPtr );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   395
    iPushData.iDataPusher->SignalCompletionAndClearQueue();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   396
    FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete() (find event)" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   397
    if ( foundIndex >= 0 )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   398
        {
52
866b4af7ffbe 201039_01
hgs
parents: 29
diff changeset
   399
        iOperationType = EDunOperationTypeUndefined;
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   400
        FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete() (issue request)" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   401
        if ( iPushData.iDataMode )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   402
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   403
            iOperationType = EDunOperationTypeRead;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   404
            IssueRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   405
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   406
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   407
    FTRACE(FPrint( _L("CDunDownstream::NotifyDataPushComplete() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   408
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   409
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   410
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   411
// From class MDunCmdModeMonitor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   412
// Notifies about command mode start
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   413
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   414
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   415
void CDunDownstream::NotifyCommandModeStart()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   416
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   417
    FTRACE(FPrint( _L("CDunDownstream::NotifyCommandModeStart()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   418
    iPushData.iDataMode = EFalse;
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   419
    // Now the data mode has ended. Stop read operation but not the multiplexer.
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   420
    Stop( EFalse );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   421
    FTRACE(FPrint( _L("CDunDownstream::NotifyCommandModeStart() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   422
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   423
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   424
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   425
// From class MDunCmdModeMonitor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   426
// Notifies about command mode end
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   427
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   428
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   429
void CDunDownstream::NotifyCommandModeEnd()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   430
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   431
    FTRACE(FPrint( _L("CDunDownstream::NotifyCommandModeEnd()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   432
    iPushData.iDataMode = ETrue;
60
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   433
    iOperationType = EDunOperationTypeRead;  // just in case
841f70763fbe 201044_04
hgs
parents: 52
diff changeset
   434
    IssueRequest();
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   435
    FTRACE(FPrint( _L("CDunDownstream::NotifyCommandModeEnd() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   436
    }