phoneplugins/csplugin/src/tmshandler.cpp
author hgs
Fri, 03 Sep 2010 13:33:36 +0300
changeset 65 2a5d4ab426d3
parent 27 2f8f8080a020
child 76 cfea66083b62
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     1
/*
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     2
 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     3
 * All rights reserved.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     8
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     9
 * Initial Contributors:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    10
 * Nokia Corporation - initial contribution.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    11
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    12
 * Contributors:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    13
 *
65
hgs
parents: 27
diff changeset
    14
 * Description: Activates TMS call audio control streams.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    15
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    16
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    17
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    18
#include <tmsfactory.h>
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    19
#include <tmscall.h>
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    20
#include <tmsstream.h>
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    21
#include "tmshandler.h"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    22
#include "csplogger.h"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    23
#include "csppanic.pan"
65
hgs
parents: 27
diff changeset
    24
#include "mtmshandlerobserver.h"
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    25
65
hgs
parents: 27
diff changeset
    26
const TInt KStreamInitRetry = 1000000; //1 sec
hgs
parents: 27
diff changeset
    27
const TInt KRetryForever = -1;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    28
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    29
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    30
// Static constructor
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    31
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    32
//
65
hgs
parents: 27
diff changeset
    33
TmsHandler* TmsHandler::NewL(MTmsHandlerObserver& aObserver)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    34
    {
65
hgs
parents: 27
diff changeset
    35
    TmsHandler* self = TmsHandler::NewLC(aObserver);
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    36
    CleanupStack::Pop(self);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    37
    return self;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    38
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    39
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    40
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    41
// Static constructor
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    42
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    43
//
65
hgs
parents: 27
diff changeset
    44
TmsHandler* TmsHandler::NewLC(MTmsHandlerObserver& aObserver)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    45
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    46
    TmsHandler* self = new (ELeave) TmsHandler();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    47
    CleanupStack::PushL(self);
65
hgs
parents: 27
diff changeset
    48
    self->ConstructL(aObserver);
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    49
    return self;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    50
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    51
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    52
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    53
// Destructor
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    54
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    55
//
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    56
TmsHandler::~TmsHandler()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    57
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    58
    if (iTmsUplink && iTmsCall)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    59
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    60
        iTmsCall->DeleteStream(iTmsUplink);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    61
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    62
    if (iTmsDnlink && iTmsCall)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    63
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    64
        iTmsCall->DeleteStream(iTmsDnlink);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    65
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    66
    if (iFactory && iTmsCall)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    67
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    68
        iFactory->DeleteCall(iTmsCall);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    69
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    70
    if (iFactory && iTmsMicSource)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    71
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    72
        iFactory->DeleteSource(iTmsMicSource);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    73
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    74
    if (iFactory && iTmsModemSource)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    75
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    76
        iFactory->DeleteSource(iTmsModemSource);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    77
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    78
    if (iFactory && iTmsSpeakerSink)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    79
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    80
        iFactory->DeleteSink(iTmsSpeakerSink);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    81
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    82
    if (iFactory && iTmsModemSink)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    83
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    84
        iFactory->DeleteSink(iTmsModemSink);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    85
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    86
    delete iFactory;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    87
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    88
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    89
// ---------------------------------------------------------------------------
65
hgs
parents: 27
diff changeset
    90
// TmsHandler::StartStreams
hgs
parents: 27
diff changeset
    91
// Activates TMS call audio control streams. If called in the middle of an
hgs
parents: 27
diff changeset
    92
// ongoing stream initialization, the request is cashed in until both streams
hgs
parents: 27
diff changeset
    93
// transition to initialized state.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    94
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    95
//
65
hgs
parents: 27
diff changeset
    96
TInt TmsHandler::StartStreams()
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    97
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    98
    CSPLOGSTRING(CSPINT, "TmsHandler::StartStreams");
65
hgs
parents: 27
diff changeset
    99
    TInt status(TMS_RESULT_SUCCESS);
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   100
65
hgs
parents: 27
diff changeset
   101
    if (iTmsUplink)
hgs
parents: 27
diff changeset
   102
        {
hgs
parents: 27
diff changeset
   103
        if (iTmsUplink->GetState() == TMS_STREAM_INITIALIZED)
hgs
parents: 27
diff changeset
   104
            {
hgs
parents: 27
diff changeset
   105
            status = iTmsUplink->Start(KRetryForever);
hgs
parents: 27
diff changeset
   106
            }
hgs
parents: 27
diff changeset
   107
        else if (iUplInitializing)
hgs
parents: 27
diff changeset
   108
            {
hgs
parents: 27
diff changeset
   109
            iStartAfterInitComplete = ETrue;
hgs
parents: 27
diff changeset
   110
            }
hgs
parents: 27
diff changeset
   111
        }
hgs
parents: 27
diff changeset
   112
hgs
parents: 27
diff changeset
   113
    if (iTmsDnlink && status == TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   114
        {
hgs
parents: 27
diff changeset
   115
        if (iTmsDnlink->GetState() == TMS_STREAM_INITIALIZED)
hgs
parents: 27
diff changeset
   116
            {
hgs
parents: 27
diff changeset
   117
            status = iTmsDnlink->Start(KRetryForever);
hgs
parents: 27
diff changeset
   118
            }
hgs
parents: 27
diff changeset
   119
        else if (iDnlInitializing)
hgs
parents: 27
diff changeset
   120
            {
hgs
parents: 27
diff changeset
   121
            iStartAfterInitComplete = ETrue;
hgs
parents: 27
diff changeset
   122
            }
hgs
parents: 27
diff changeset
   123
        }
hgs
parents: 27
diff changeset
   124
hgs
parents: 27
diff changeset
   125
    CSPLOGSTRING2(CSPINT, "TmsHandler::StartStreams status %d", status);
hgs
parents: 27
diff changeset
   126
hgs
parents: 27
diff changeset
   127
    if (status != TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   128
        {
hgs
parents: 27
diff changeset
   129
        // Cancel any pending retry and cancel.
hgs
parents: 27
diff changeset
   130
        StopStreams();
hgs
parents: 27
diff changeset
   131
        status = KErrCancel;
hgs
parents: 27
diff changeset
   132
        }
hgs
parents: 27
diff changeset
   133
    return status;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   134
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   135
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   136
// ---------------------------------------------------------------------------
65
hgs
parents: 27
diff changeset
   137
// TmsHandler::StopStreams
hgs
parents: 27
diff changeset
   138
// Deactivates TMS call audio control streams. If streams are not started yet,
hgs
parents: 27
diff changeset
   139
// any pending request on TMS streams will be canceled.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   140
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   141
//
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   142
void TmsHandler::StopStreams()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   143
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   144
    CSPLOGSTRING(CSPINT, "TmsHandler::StopStreams");
65
hgs
parents: 27
diff changeset
   145
hgs
parents: 27
diff changeset
   146
    if (iTmsUplink)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   147
        {
65
hgs
parents: 27
diff changeset
   148
        iTmsUplink->Stop();
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   149
        }
65
hgs
parents: 27
diff changeset
   150
    if (iTmsDnlink)
hgs
parents: 27
diff changeset
   151
        {
hgs
parents: 27
diff changeset
   152
        iTmsDnlink->Stop();
hgs
parents: 27
diff changeset
   153
        }
hgs
parents: 27
diff changeset
   154
    iUplInitializing = EFalse;
hgs
parents: 27
diff changeset
   155
    iDnlInitializing = EFalse;
hgs
parents: 27
diff changeset
   156
    iStartAfterInitComplete = EFalse;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   157
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   158
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   159
// ---------------------------------------------------------------------------
65
hgs
parents: 27
diff changeset
   160
// TmsHandler::AreStreamsStarted
hgs
parents: 27
diff changeset
   161
// Indicates whether both audio control streams have been started.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   162
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   163
//
65
hgs
parents: 27
diff changeset
   164
TBool TmsHandler::AreStreamsStarted()
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   165
    {
65
hgs
parents: 27
diff changeset
   166
    TBool status(EFalse);
hgs
parents: 27
diff changeset
   167
hgs
parents: 27
diff changeset
   168
    if (iTmsUplink && iTmsDnlink)
hgs
parents: 27
diff changeset
   169
        {
hgs
parents: 27
diff changeset
   170
        if (iTmsUplink->GetState() == TMS_STREAM_STARTED &&
hgs
parents: 27
diff changeset
   171
                iTmsDnlink->GetState() == TMS_STREAM_STARTED)
hgs
parents: 27
diff changeset
   172
            {
hgs
parents: 27
diff changeset
   173
            status = ETrue;
hgs
parents: 27
diff changeset
   174
            }
hgs
parents: 27
diff changeset
   175
        }
hgs
parents: 27
diff changeset
   176
    return status;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   177
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   178
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   179
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   180
// Constructor
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   181
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   182
//
65
hgs
parents: 27
diff changeset
   183
TmsHandler::TmsHandler()
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   184
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   185
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   186
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   187
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   188
// Second phase constructor
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   189
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   190
//
65
hgs
parents: 27
diff changeset
   191
void TmsHandler::ConstructL(MTmsHandlerObserver& aObserver)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   192
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   193
    CSPLOGSTRING(CSPINT, "TmsHandler::ConstructL");
65
hgs
parents: 27
diff changeset
   194
    iObserver = &aObserver;
hgs
parents: 27
diff changeset
   195
    User::LeaveIfError(CreateTMSCallControl());
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   196
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   197
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   198
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   199
// TmsHandler::CreateTMSCallControl()
65
hgs
parents: 27
diff changeset
   200
// Allocates and initializes all TMS resources needed for call audio control.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   201
// ---------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   202
//
65
hgs
parents: 27
diff changeset
   203
TInt TmsHandler::CreateTMSCallControl()
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   204
    {
65
hgs
parents: 27
diff changeset
   205
    CSPLOGSTRING(CSPINT, "TmsHandler::CreateTMSCallControl");
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   206
    TMSVer* v = NULL;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   207
    TInt status;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   208
    status = TMSFactory::CreateFactory(iFactory, *v);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   209
65
hgs
parents: 27
diff changeset
   210
    __ASSERT_ALWAYS(iFactory, Panic(ECSPPanicBadHandle));
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   211
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   212
    status = iFactory->CreateCall(TMS_CALL_CS, iTmsCall, 0);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   213
65
hgs
parents: 27
diff changeset
   214
    if (iTmsCall && status == TMS_RESULT_SUCCESS)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   215
        {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   216
        status = iTmsCall->CreateStream(TMS_STREAM_UPLINK, iTmsUplink);
65
hgs
parents: 27
diff changeset
   217
        status |= iTmsCall->CreateStream(TMS_STREAM_DOWNLINK, iTmsDnlink);
hgs
parents: 27
diff changeset
   218
        status |= iFactory->CreateSource(TMS_SOURCE_MIC, iTmsMicSource);
hgs
parents: 27
diff changeset
   219
        status |= iFactory->CreateSink(TMS_SINK_MODEM, iTmsModemSink);
hgs
parents: 27
diff changeset
   220
        status |= iFactory->CreateSource(TMS_SOURCE_MODEM, iTmsModemSource);
hgs
parents: 27
diff changeset
   221
        status |= iFactory->CreateSink(TMS_SINK_SPEAKER, iTmsSpeakerSink);
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   222
        }
65
hgs
parents: 27
diff changeset
   223
    if (iTmsUplink && iTmsMicSource && iTmsModemSink &&
hgs
parents: 27
diff changeset
   224
            status == TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   225
        {
hgs
parents: 27
diff changeset
   226
        status = iTmsUplink->AddSource(iTmsMicSource);
hgs
parents: 27
diff changeset
   227
        status |= iTmsUplink->AddSink(iTmsModemSink);
hgs
parents: 27
diff changeset
   228
        status |= iTmsUplink->AddObserver(*this, NULL);
hgs
parents: 27
diff changeset
   229
        status |= iTmsUplink->Init(KStreamInitRetry);
hgs
parents: 27
diff changeset
   230
        }
hgs
parents: 27
diff changeset
   231
    if (iTmsDnlink && iTmsModemSource && iTmsSpeakerSink &&
hgs
parents: 27
diff changeset
   232
            status == TMS_RESULT_SUCCESS)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   233
        {
65
hgs
parents: 27
diff changeset
   234
        status = iTmsDnlink->AddSource(iTmsModemSource);
hgs
parents: 27
diff changeset
   235
        status |= iTmsDnlink->AddSink(iTmsSpeakerSink);
hgs
parents: 27
diff changeset
   236
        status |= iTmsDnlink->AddObserver(*this, NULL);
hgs
parents: 27
diff changeset
   237
        status |= iTmsDnlink->Init(KStreamInitRetry);
hgs
parents: 27
diff changeset
   238
        }
hgs
parents: 27
diff changeset
   239
    if (status == TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   240
        {
hgs
parents: 27
diff changeset
   241
        iUplInitializing = ETrue;
hgs
parents: 27
diff changeset
   242
        iDnlInitializing = ETrue;
hgs
parents: 27
diff changeset
   243
        }
hgs
parents: 27
diff changeset
   244
    else
hgs
parents: 27
diff changeset
   245
        {
hgs
parents: 27
diff changeset
   246
        status = KErrCancel; // Convert to Symbian error and cancel
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   247
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   248
    return status;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   249
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   250
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   251
// ----------------------------------------------------------------------------
65
hgs
parents: 27
diff changeset
   252
// TmsHandler::ProcessUplinkStreamChangeEvent
hgs
parents: 27
diff changeset
   253
// Processes Uplink stream state change events.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   254
// ----------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   255
//
65
hgs
parents: 27
diff changeset
   256
void TmsHandler::ProcessUplinkStreamChangeEvent(TInt aState)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   257
    {
65
hgs
parents: 27
diff changeset
   258
    CSPLOGSTRING(CSPINT, "TmsHandler::ProcessUplinkStreamChangeEvent");
hgs
parents: 27
diff changeset
   259
    switch (aState)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   260
        {
65
hgs
parents: 27
diff changeset
   261
        case TMS_STREAM_INITIALIZED:
hgs
parents: 27
diff changeset
   262
            iUplInitializing = EFalse;
hgs
parents: 27
diff changeset
   263
            if (iStartAfterInitComplete)
hgs
parents: 27
diff changeset
   264
                {
hgs
parents: 27
diff changeset
   265
                iStartAfterInitComplete = EFalse;
hgs
parents: 27
diff changeset
   266
                TInt status = StartStreams();
hgs
parents: 27
diff changeset
   267
                if (status != TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   268
                    {
hgs
parents: 27
diff changeset
   269
                    iObserver->AudioStreamsError(status);
hgs
parents: 27
diff changeset
   270
                    }
hgs
parents: 27
diff changeset
   271
                }
hgs
parents: 27
diff changeset
   272
            break;
hgs
parents: 27
diff changeset
   273
        case TMS_STREAM_UNINITIALIZED:
hgs
parents: 27
diff changeset
   274
            // As result of Deinit() or error
hgs
parents: 27
diff changeset
   275
            iUplInitializing = EFalse;
hgs
parents: 27
diff changeset
   276
            iStartAfterInitComplete = EFalse;
hgs
parents: 27
diff changeset
   277
            break;
hgs
parents: 27
diff changeset
   278
        case TMS_STREAM_PAUSED:
hgs
parents: 27
diff changeset
   279
            break;
hgs
parents: 27
diff changeset
   280
        case TMS_STREAM_STARTED:
hgs
parents: 27
diff changeset
   281
            if (AreStreamsStarted())
hgs
parents: 27
diff changeset
   282
                {
hgs
parents: 27
diff changeset
   283
                iObserver->AudioStreamsStarted();
hgs
parents: 27
diff changeset
   284
                }
hgs
parents: 27
diff changeset
   285
            break;
hgs
parents: 27
diff changeset
   286
        default:
hgs
parents: 27
diff changeset
   287
            break;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   288
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   289
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   290
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   291
// ----------------------------------------------------------------------------
65
hgs
parents: 27
diff changeset
   292
// TmsHandler::ProcessDownlinkStreamChangeEvent
hgs
parents: 27
diff changeset
   293
// Processes Downlink stream state change events.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   294
// ----------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   295
//
65
hgs
parents: 27
diff changeset
   296
void TmsHandler::ProcessDownlinkStreamChangeEvent(TInt aState)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   297
    {
65
hgs
parents: 27
diff changeset
   298
    CSPLOGSTRING(CSPINT, "TmsHandler::ProcessDownlinkStreamChangeEvent");
hgs
parents: 27
diff changeset
   299
    switch (aState)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   300
        {
65
hgs
parents: 27
diff changeset
   301
        case TMS_STREAM_INITIALIZED:
hgs
parents: 27
diff changeset
   302
            iDnlInitializing = EFalse;
hgs
parents: 27
diff changeset
   303
            if (iStartAfterInitComplete)
hgs
parents: 27
diff changeset
   304
                {
hgs
parents: 27
diff changeset
   305
                iStartAfterInitComplete = EFalse;
hgs
parents: 27
diff changeset
   306
                TInt status = StartStreams();
hgs
parents: 27
diff changeset
   307
                if (status != TMS_RESULT_SUCCESS)
hgs
parents: 27
diff changeset
   308
                    {
hgs
parents: 27
diff changeset
   309
                    iObserver->AudioStreamsError(status);
hgs
parents: 27
diff changeset
   310
                    }
hgs
parents: 27
diff changeset
   311
                }
hgs
parents: 27
diff changeset
   312
            break;
hgs
parents: 27
diff changeset
   313
        case TMS_STREAM_UNINITIALIZED:
hgs
parents: 27
diff changeset
   314
            // As result of Deinit() or error
hgs
parents: 27
diff changeset
   315
            iDnlInitializing = EFalse;
hgs
parents: 27
diff changeset
   316
            iStartAfterInitComplete = EFalse;
hgs
parents: 27
diff changeset
   317
            break;
hgs
parents: 27
diff changeset
   318
        case TMS_STREAM_PAUSED:
hgs
parents: 27
diff changeset
   319
            break;
hgs
parents: 27
diff changeset
   320
        case TMS_STREAM_STARTED:
hgs
parents: 27
diff changeset
   321
            if (AreStreamsStarted())
hgs
parents: 27
diff changeset
   322
                {
hgs
parents: 27
diff changeset
   323
                iObserver->AudioStreamsStarted();
hgs
parents: 27
diff changeset
   324
                }
hgs
parents: 27
diff changeset
   325
            break;
hgs
parents: 27
diff changeset
   326
        default:
hgs
parents: 27
diff changeset
   327
            break;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   328
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   329
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   330
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   331
// TMS CALLBACKS
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   332
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   333
// ----------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   334
// TmsHandler::TMSStreamEvent
65
hgs
parents: 27
diff changeset
   335
// From TMSStreamObserver
hgs
parents: 27
diff changeset
   336
// TMS call audio stream control event handler.
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   337
// ----------------------------------------------------------------------------
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   338
//
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   339
void TmsHandler::TMSStreamEvent(const TMSStream& stream, TMSSignalEvent event)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   340
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   341
    CSPLOGSTRING2(CSPINT, "TmsHandler::TMSStreamEvent status %d", event.reason);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   342
65
hgs
parents: 27
diff changeset
   343
    TMSStreamType strmType = const_cast<TMSStream&> (stream).GetStreamType();
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   344
65
hgs
parents: 27
diff changeset
   345
    if (strmType == TMS_STREAM_UPLINK)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   346
        {
65
hgs
parents: 27
diff changeset
   347
        if (event.type == TMS_EVENT_STREAM_STATE_CHANGED)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   348
            {
65
hgs
parents: 27
diff changeset
   349
            ProcessUplinkStreamChangeEvent(event.curr_state);
hgs
parents: 27
diff changeset
   350
            }
hgs
parents: 27
diff changeset
   351
        else if (event.type == TMS_EVENT_STREAM_STATE_CHANGE_ERROR)
hgs
parents: 27
diff changeset
   352
            {
hgs
parents: 27
diff changeset
   353
#ifndef __WINS__
hgs
parents: 27
diff changeset
   354
            Panic( ECSPPanicAudioStreamInitFailure );
hgs
parents: 27
diff changeset
   355
#endif
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   356
            }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   357
        }
65
hgs
parents: 27
diff changeset
   358
    else if (strmType == TMS_STREAM_DOWNLINK)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   359
        {
65
hgs
parents: 27
diff changeset
   360
        if (event.type == TMS_EVENT_STREAM_STATE_CHANGED)
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   361
            {
65
hgs
parents: 27
diff changeset
   362
            ProcessDownlinkStreamChangeEvent(event.curr_state);
hgs
parents: 27
diff changeset
   363
            }
hgs
parents: 27
diff changeset
   364
        else if (event.type == TMS_EVENT_STREAM_STATE_CHANGE_ERROR)
hgs
parents: 27
diff changeset
   365
            {
hgs
parents: 27
diff changeset
   366
#ifndef __WINS__
hgs
parents: 27
diff changeset
   367
            Panic( ECSPPanicAudioStreamInitFailure );
hgs
parents: 27
diff changeset
   368
#endif
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   369
            }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   370
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   371
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   372
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   373
//  End of File