localconnectivityservice/dun/utils/src/DunSignalCopy.cpp
author hgs
Fri, 15 Oct 2010 15:05:57 +0800
changeset 54 4dc88a4ac6f4
parent 52 866b4af7ffbe
permissions -rw-r--r--
201041_02
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) 2008-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:  Copies signals changes between network and local media
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
#ifdef PRJ_USE_NETWORK_STUBS
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include <c32comm_stub.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <d32comm.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include "DunTransporter.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
#include "DunSignalCopy.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
#include "DunDebug.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
const TUint KDunSixLowestBitsMask = 0x3F;  // Symbian magic
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
// ======== MEMBER FUNCTIONS ========
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
// Two-phased constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
CDunSignalCopy* CDunSignalCopy::NewL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
    CDunSignalCopy* self = new (ELeave) CDunSignalCopy();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
    CleanupStack::PushL( self );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
    self->ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
    CleanupStack::Pop( self );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
    return self;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
// Destructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
CDunSignalCopy::~CDunSignalCopy()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
    FTRACE(FPrint( _L("CDunSignalCopy::~CDunSignalCopy()") ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
    ResetData();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
    FTRACE(FPrint( _L("CDunSignalCopy::~CDunSignalCopy() complete") ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
// Resets data to initial values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
void CDunSignalCopy::ResetData()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    FTRACE(FPrint( _L("CDunSignalCopy::ResetData()") ));
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
    // AddCallback()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    iCallbacks.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    // Internal
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
    FTRACE(FPrint( _L("CDunSignalCopy::ResetData() complete") ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
// Adds callback for line status change controlling
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
// The callback will be called when RunL error is detected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
TInt CDunSignalCopy::AddCallback( MDunConnMon* aCallback )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
    FTRACE(FPrint( _L("CDunSignalCopy::AddCallback()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    if ( !aCallback )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
        FTRACE(FPrint( _L("CDunSignalCopy::AddCallback() (aCallback) not initialized!" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    TInt retTemp = iCallbacks.Find( aCallback );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    if ( retTemp != KErrNotFound )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
        FTRACE(FPrint( _L("CDunSignalCopy::AddCallback() (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
    retTemp = iCallbacks.Append( aCallback );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    if ( retTemp != KErrNone )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
        FTRACE(FPrint( _L("CDunSignalCopy::AddCallback() (append failed!) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
        return retTemp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    FTRACE(FPrint( _L("CDunSignalCopy::AddCallback() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
// Sets media to use for this endpoint monitor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
TInt CDunSignalCopy::SetMedia( RComm* aComm,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
                               RComm* aNetwork,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
                               TDunStreamType aStreamType )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
    FTRACE(FPrint( _L("CDunSignalCopy::SetMedia()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
    if ( !aNetwork )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
        FTRACE(FPrint( _L("CDunSignalCopy::SetMedia() (aComm) not initialized!" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
    RComm* comm = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
    if ( aStreamType == EDunStreamTypeUpstream )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        iContextInUse = EDunMediaContextLocal;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        comm = aComm;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    else if ( aStreamType == EDunStreamTypeDownstream )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
        iContextInUse = EDunMediaContextNetwork;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
        comm = aNetwork;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
        FTRACE(FPrint( _L("CDunSignalCopy::SetMedia() (aStreamtype) not initialized!" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    // No possibility to do iUtility->GetLocalId() here as aComm is not yet
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
    // in channel data; use aComm directly
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
    TCommCaps2 caps;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
    comm->Caps( caps );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
    if ( !(caps().iNotificationCaps & KNotifySignalsChangeSupported) )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
        FTRACE(FPrint( _L("CDunSignalCopy::SetMedia() (RComm) (not supported) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
        return KErrNotSupported;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
    iComm = aComm;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    iNetwork = aNetwork;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    iStreamType = aStreamType;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
    FTRACE(FPrint( _L("CDunSignalCopy::SetMedia() (RComm) complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
// Issues request to start monitoring the endpoint for line status change
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
TInt CDunSignalCopy::IssueRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest()" )));
54
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   155
    if ( IsActive() )
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
        FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() (not ready) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
        return KErrNotReady;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
    RComm* comm = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
    if ( iStreamType == EDunStreamTypeUpstream )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
        iListenSignals = KSignalDCEInputs;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
        comm = iComm;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
    else if ( iStreamType == EDunStreamTypeDownstream )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
        iListenSignals = KSignalDTEInputs;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
        comm = iNetwork;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
        FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() (ERROR) complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
        return KErrGeneral;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    TUint currentSignals = comm->Signals( iListenSignals );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
    TUint oldSignalsLow = iSignals & KDunSixLowestBitsMask;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
    TUint newSignalsLow = currentSignals & KDunSixLowestBitsMask;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    TUint oldSignalsHigh = oldSignalsLow * KSignalChanged;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
    TUint newSignalsHigh = newSignalsLow * KSignalChanged;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() oldSignalsLow=0x%08X" ), oldSignalsLow ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() newSignalsLow=0x%08X" ), newSignalsLow ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() oldSignalsHigh=0x%08X" ), oldSignalsHigh ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() newSignalsHigh=0x%08X" ), newSignalsHigh ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
    if ( newSignalsLow != oldSignalsLow )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
        FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() signals already set..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
        iSignals = newSignalsLow | (oldSignalsHigh ^ newSignalsHigh);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
        ManageSignalChange();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
        FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() start waiting for change..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
        comm->NotifySignalChange( iStatus, iSignals, iListenSignals );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
        SetActive();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
    FTRACE(FPrint( _L("CDunSignalCopy::IssueRequest() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
// Stops monitoring the endpoint for line status change
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
//
54
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   205
void CDunSignalCopy::Stop()
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
    FTRACE(FPrint( _L("CDunSignalCopy::Stop()" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
    Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
    FTRACE(FPrint( _L("CDunSignalCopy::Stop() complete" )));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
// CDunSignalCopy::CDunSignalCopy
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
CDunSignalCopy::CDunSignalCopy() :
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
    CActive( EPriorityHigh )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
    Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
// CDunSignalCopy::ConstructL
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
void CDunSignalCopy::ConstructL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
    FTRACE(FPrint( _L("CDunSignalCopy::ConstructL()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
    CActiveScheduler::Add( this );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
    FTRACE(FPrint( _L("CDunSignalCopy::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 CDunSignalCopy::Initialize()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
    FTRACE(FPrint( _L("CDunSignalCopy::Initialize()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
    iContextInUse = EDunMediaContextUndefined;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
    iStreamType = EDunStreamTypeUndefined;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
    iListenSignals = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
    iSignals = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
    iNetwork = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
    iComm = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
    FTRACE(FPrint( _L("CDunSignalCopy::Initialize() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
// Manages signal changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
void CDunSignalCopy::ManageSignalChange()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChange()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   256
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
    if ( iStreamType == EDunStreamTypeUpstream )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
        // Manage upstream case
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
        ManageSignalChangeUpstream();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
    else  // iStreamType == EDunStreamTypeDownstream
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
        // Manage downstream case
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
        ManageSignalChangeDownstream();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChange() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
// Manages upstream signal changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
void CDunSignalCopy::ManageSignalChangeUpstream()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
    // For upstream the following signals are set for local media:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
    // KSignalDCEInputs = KSignalRTS | KSignalDTR
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
    if ( iSignals & KRTSChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() checking RTS..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
        if ( iSignals & KSignalRTS )  // RTS changed to high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
            ChangeUpstreamSignal( KSignalRTS, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() RTS changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
        else  // RTS changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
            ChangeUpstreamSignal( 0, KSignalRTS );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() RTS changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
    if ( iSignals & KDTRChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() checking DTR..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
        if ( iSignals & KSignalDTR )  // DTR changed to high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   299
            ChangeUpstreamSignal( KSignalDTR, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() DTR changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
        else  // DTR changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
            ChangeUpstreamSignal( 0, KSignalDTR );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() DTR changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
    IssueRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeUpstream() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   311
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   312
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   313
// Manages downstream signal changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   314
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   315
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   316
void CDunSignalCopy::ManageSignalChangeDownstream()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   317
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
    // For downstream the following signals are set for network:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   320
    // KSignalDTEInputs = KSignalCTS | KSignalDSR | KSignalDCD | KSignalRNG
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   321
    if ( iSignals & KCTSChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   322
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   323
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() checking CTS..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   324
        if ( iSignals & KSignalCTS )  // CTS changed to high or initially high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   325
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   326
            ChangeDownstreamSignal( KSignalCTS, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() CTS changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
        else  // CTS changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   330
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   331
            ChangeDownstreamSignal( 0, KSignalCTS );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   332
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() CTS changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   333
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   334
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   335
    if ( iSignals & KDSRChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   336
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   337
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() checking DSR..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   338
        if ( iSignals & KSignalDSR )  // DSR changed to high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   339
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   340
            ChangeDownstreamSignal( KSignalDSR, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   341
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() DSR changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   342
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   343
        else  // DSR changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   344
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   345
            ChangeDownstreamSignal( 0, KSignalDSR );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   346
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() DSR changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   347
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   348
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   349
    if ( iSignals & KDCDChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   350
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   351
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() checking DCD..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   352
        if ( iSignals & KSignalDCD )  // DCD changed to high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   353
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   354
            ChangeDownstreamSignal( KSignalDCD, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   355
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() DCD changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   356
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   357
        else  // DCD changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   358
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   359
            ChangeDownstreamSignal( 0, KSignalDCD );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   360
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() DCD changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   361
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   362
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   363
    if ( iSignals & KRNGChanged )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   364
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   365
        FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() checking RNG..." ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   366
        if ( iSignals & KSignalRNG )  // RNG changed to high
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   367
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   368
            ChangeDownstreamSignal( KSignalRNG, 0 );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   369
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() RNG changed high" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   370
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   371
        else  // RNG changed to low
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   372
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   373
            ChangeDownstreamSignal( 0, KSignalRNG );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   374
            FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() RNG changed low" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   375
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   376
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   377
    IssueRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   378
    FTRACE(FPrint( _L("CDunSignalCopy::ManageSignalChangeDownstream() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   379
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   380
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   381
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   382
// Changes upstream signal
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   383
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   384
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   385
void CDunSignalCopy::ChangeUpstreamSignal( TUint aSetMask, TUint aClearMask )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   386
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   387
    FTRACE(FPrint( _L("CDunSignalCopy::ChangeUpstreamSignal()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   388
    if ( iNetwork )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   389
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   390
        iNetwork->SetSignals( aSetMask, aClearMask );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   391
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   392
    // Add other cases here if necessary
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   393
    FTRACE(FPrint( _L("CDunSignalCopy::ChangeUpstreamSignal() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   394
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   395
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   396
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   397
// Changes downstream signal
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   398
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   399
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   400
void CDunSignalCopy::ChangeDownstreamSignal( TUint aSetMask, TUint aClearMask )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   401
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   402
    FTRACE(FPrint( _L("CDunSignalCopy::ChangeDownstreamSignal()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   403
    if ( iComm )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   404
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   405
        iComm->SetSignals( aSetMask, aClearMask );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   406
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   407
    // Add other cases here if necessary
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   408
    FTRACE(FPrint( _L("CDunSignalCopy::ChangeDownstreamSignal() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   409
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   410
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   411
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   412
// From class CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   413
// Gets called when line status changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   414
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   415
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   416
void CDunSignalCopy::RunL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   417
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   418
    FTRACE(FPrint( _L("CDunSignalCopy::RunL()" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   419
    TInt retTemp = iStatus.Int();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   420
    if ( retTemp != KErrNone )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   421
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   422
        FTRACE(FPrint( _L("CDunSignalCopy::RunL() (failed) complete (%d)"), retTemp));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   423
        TInt i;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   424
        TInt count = iCallbacks.Count();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   425
        TDunConnectionReason connReason;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   426
        connReason.iReasonType = EDunReasonTypeRunL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   427
        connReason.iContext = iContextInUse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   428
        connReason.iSignalType = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   429
        connReason.iSignalHigh = EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   430
        connReason.iDirection = EDunDirectionUndefined;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   431
        connReason.iErrorCode = retTemp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   432
        for ( i=0; i<count; i++ )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   433
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   434
            TRAP_IGNORE(
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   435
                iCallbacks[i]->NotifyProgressChangeL( iComm, connReason ) );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   436
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   437
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   438
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   439
    FTRACE(FPrint( _L("CDunSignalCopy::RunL() managing signal 0x%08X" ), iSignals ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   440
    ManageSignalChange();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   441
    FTRACE(FPrint( _L("CDunSignalCopy::RunL() complete" ) ));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   442
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   443
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   444
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   445
// From class CActive.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   446
// Gets called on cancel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   447
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   448
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   449
void CDunSignalCopy::DoCancel()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   450
    {
54
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   451
    FTRACE(FPrint( _L("CDunSignalCopy::DoCancel()" ) ));
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   452
    if ( iStreamType == EDunStreamTypeUpstream )
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   453
        {
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   454
        iComm->NotifySignalChangeCancel();
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   455
        }
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   456
    else if ( iStreamType == EDunStreamTypeDownstream )
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   457
        {
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   458
        iNetwork->NotifySignalChangeCancel();
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   459
        }
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   460
    else
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   461
        {
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   462
        FTRACE(FPrint( _L("CDunSignalCopy::DoCancel() (ERROR) complete" )));
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   463
        }
4dc88a4ac6f4 201041_02
hgs
parents: 52
diff changeset
   464
    FTRACE(FPrint( _L("CDunSignalCopy::DoCancel() complete" ) ));
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   465
    }