devsound/a3fdevsound/src/mmfdevsoundserver/mmfdevsoundsession.cpp
author hgs
Tue, 02 Nov 2010 12:28:51 +0000
changeset 6 fe9d1bf55678
parent 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk46_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
#include <s32mem.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
#include "mmfaudioclientserver.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
#include "mmfaudioserver.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#include "mmfdevsoundserver.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#include "mmfdevsoundsession.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
#include <mmf/plugin/mmfdevsoundcustominterface.hrh>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
#include <mm/mmpluginutils.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include "e32debug.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
#define SYMBIAN_DEBPRN0(str)                RDebug::Print(str, this)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
#define SYMBIAN_DEBPRN1(str, val1)          RDebug::Print(str, this, val1)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
#define SYMBIAN_DEBPRN2(str, val1, val2)    RDebug::Print(str, this, val1, val2)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
#define SYMBIAN_DEBPRN3(str, val1, val2, val3)    RDebug::Print(str, this, val1, val2, val3)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
#else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
#define SYMBIAN_DEBPRN0(str)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
#define SYMBIAN_DEBPRN1(str, val1)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
#define SYMBIAN_DEBPRN2(str, val1, val2)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
#define SYMBIAN_DEBPRN3(str, val1, val2, val3)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
#endif //_DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
const TInt KMaxQueueRequest = 6;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
//	MEMBER FUNCTIONS 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
TMMFDevSoundRequest::TMMFDevSoundRequest() 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	: iMessageCompleted(EFalse), 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	iRequestType(EUndefinedType),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	iCallBackPF(KCallbackNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
TMMFDevSoundRequest::TMMFDevSoundRequest(TInt aIsCallBack)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	: iMessageCompleted(EFalse), 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	iRequestType(ECallBackType),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	iCallBackPF(aIsCallBack)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
TMMFDevSoundRequest::TMMFDevSoundRequest(const TMMFDevSoundRequest& aRequest)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
	: iMessageCompleted(EFalse), 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	iMessage(aRequest.iMessage),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	iCallBackPF(aRequest.iCallBackPF)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
	iRequestType = ResolveType();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
TBool TMMFDevSoundRequest::operator==(const TMMFDevSoundRequest& aRequest) const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	TBool retval = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	if ( aRequest.Function() == Function() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
		retval = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
		retval = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	return retval;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
const RMmfIpcMessage& TMMFDevSoundRequest::Message() 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	{ 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	return iMessage; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
void TMMFDevSoundRequest::SetMessage(const RMmfIpcMessage& aMessage) 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
	iMessageCompleted = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	iMessage = aMessage;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	iRequestType = ResolveType();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
void TMMFDevSoundRequest::SetMessageCallback() 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	iMessageCompleted = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	iRequestType = ECallBackType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	}	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
TInt TMMFDevSoundRequest::IsCallBack() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	return iCallBackPF;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
TMMFDevSoundRequest::TA3FDevSoundRequestType TMMFDevSoundRequest::ResolveType()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	TA3FDevSoundRequestType type = EUndefinedType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	switch(iMessage.Function())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
		case EMMFDevSoundProxyInitialize1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
		case EMMFDevSoundProxyInitialize2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
		case EMMFDevSoundProxyInitialize4:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
		case EMMFDevSoundProxyPlayInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
		case EMMFDevSoundProxyRecordInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
		case EMMFDevSoundProxyPlayTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
		case EMMFDevSoundProxyPlayDualTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
		case EMMFDevSoundProxyPlayDTMFString:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
		case EMMFDevSoundProxyPlayToneSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
		case EMMFDevSoundProxyPlayFixedSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
			type = EAction_PseudoAsynchronous;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
		case EMMFDevSoundProxyStop:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
		case EMMFDevSoundProxyPause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
		case EMMFDevSoundProxyClose:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
		case EMMFDevSoundProxyCancelInitialize:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
		case EMMFDevSoundProxyResume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
		case EMMFDevSoundProxyEmptyBuffers:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
			type = EAction_Asynchronous;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
		case EMMFDevSoundProxySetConfig:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
		case EMMFDevSoundProxyPostOpen: // Although this is not a configure operation technically, it has same calling pattern.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
		case EMMFDevSoundProxySetVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
		case EMMFDevSoundProxySetGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
		case EMMFDevSoundProxySetPlayBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
		case EMMFDevSoundProxySetRecordBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
		case EMMFDevSoundProxySetVolumeRamp:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
		case EMMFDevSoundProxySetPrioritySettings:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
			type = EConfigure_Asynchronous;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
		case EMMFDevSoundProxySetDTMFLengths:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
		case EMMFDevSoundProxySetToneRepeats:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
			type = EConfigure_Synchronous;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
		case EMMFDevSoundProxyCapabilities:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
			type = EQuery_Asynchronous;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
		case EMMFDevSoundProxyMaxVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
		case EMMFDevSoundProxyMaxGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
		case EMMFDevSoundProxyConfig:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
		case EMMFDevSoundProxyVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
		case EMMFDevSoundProxyGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
		case EMMFDevSoundProxyPlayBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
		case EMMFDevSoundProxyRecordBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
		case EMMFDevSoundProxyGetSupportedInputDataTypes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
		case EMMFDevSoundProxyGetSupportedOutputDataTypes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
		case EMMFDevSoundProxyFixedSequenceName:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
		case EMMFDevSoundProxyFixedSequenceCount:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
		case EMMFDevSoundProxySamplesRecorded:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
		case EMMFDevSoundProxySamplesPlayed:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
		case EMMFDevSoundProxyCopyFourCCArrayData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
		case EMMFDevSoundProxyGetTimePlayed:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
		case EMMFDevSoundProxyIsResumeSupported:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
			type = EQuery_Synchronous;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
		case EMMFDevSoundProxyBTBFData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
		case EMMFDevSoundProxyBTBEData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
		case EMMFDevSoundProxyPlayData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
		case EMMFDevSoundProxyRecordData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
			type = EBufferExchangeRelated;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
		// Custom Interfaces
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
		case EMMFDevSoundProxySyncCustomCommand:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
		case EMMFDevSoundProxySyncCustomCommandResult:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
		case EMMFDevSoundProxyAsyncCustomCommand:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
		case EMMFDevSoundProxyAsyncCustomCommandResult:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
		case EMMFDevSoundProxyCustomInterface:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
			type = ECustomInterfacesRelated;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
		case RMessage2::EDisConnect:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
			type = ESessionEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
	return type;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
void TMMFDevSoundRequest::Complete(TInt aError)	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
	if(!iMessageCompleted && iRequestType != EUndefinedType && iRequestType != ECallBackType)	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
		iMessage.Complete(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
		iMessageCompleted = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
		iRequestType = EUndefinedType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
TInt TMMFDevSoundRequest::Function() const 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
	return iMessage.Function(); 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
TMMFDevSoundRequest::TA3FDevSoundRequestType TMMFDevSoundRequest::Type() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
	return iRequestType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
// CMMFDevSoundSession::CreateL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
// Creates a new object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
void CMMFDevSoundSession::CreateL(const CMmfIpcServer& aServer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
	CMmfIpcSession::CreateL(aServer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
	CMMFDevSoundServer& server =
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
	const_cast<CMMFDevSoundServer&>(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
			static_cast<const CMMFDevSoundServer&>(aServer));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
	server.IncrementSessionId();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
	iDevSoundSessionId = server.DevSoundSessionId();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
// NeedToQueue - mid-commit cycle or async queue start AO is active
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
TBool CMMFDevSoundSession::NeedToQueue() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
    return iOperationCompletePending || iAsyncQueueStart->IsActive();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
// CMMFDevSoundSession::ServiceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
void CMMFDevSoundSession::ServiceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
	SYMBIAN_DEBPRN2(_L("\nCMMFDevSoundSession[0x%x] NEW REQUEST %02x while pending=%d"),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
	        aMessage.Function(), NeedToQueue());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
	if(NeedToQueue())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
		// if not possible to service now, then queue request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
		EnqueueRequest(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
		// If there is no oustanding operation service inmediately
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
		TRAPD(err, DoServiceRequestL(aMessage));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
		if (err)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
		    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
            aMessage.Complete(err); // repeat normal ServiceL() behaviour since we may keep going
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
		    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
	    if (!iOperationCompletePending && iQueuedRequests.Count() != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
	        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
	        //dequeue next
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
	        DequeueRequest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
	        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
// CMMFDevSoundSession::DoServiceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
void CMMFDevSoundSession::DoServiceRequestL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
	iRequestBeingServiced.SetMessage(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
	iAsyncQueueStart->Cancel(); // just in case.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
    ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
    if (aMessage.Function() == RMessage2::EDisConnect)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
        TBool complete = iAdapter->CloseDevSound();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
        if(!complete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
            iRequestBeingServiced.SetMessage(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
            iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
            ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
            // if we get here, iClosing wait will have been started and we'd be waiting
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
            iClosingWait->AsyncStop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
        return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
    TMMFMessageDestinationPckg destinationPckg;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
	User::LeaveIfError(MessageRead(aMessage, 0, destinationPckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
	SYMBIAN_DEBPRN2(_L("CMMFDevSoundSession[0x%x]::DoServiceRequestL - DestinationHandle [%d] InterfaceId [%d] "), destinationPckg().DestinationHandle(), destinationPckg().InterfaceId());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
	if ((destinationPckg().DestinationHandle() == KMMFObjectHandleDevSound) &&
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
	    (destinationPckg().InterfaceId() == KUidInterfaceMMFDevSound))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
        SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoServiceRequestL - Request [%d]"), aMessage.Function());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
		TBool complete = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
		switch(aMessage.Function())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
			case EMMFDevSoundProxyPostOpen:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
				complete = DoPostOpenL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
			case EMMFDevSoundProxyInitialize1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
				complete = DoInitialize1L(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
			case EMMFDevSoundProxyInitialize2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
				complete = DoInitialize2L(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
			case EMMFDevSoundProxyInitialize4:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
				complete = DoInitialize4L(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
			case EMMFDevSoundProxyCapabilities:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
				complete = DoCapabilitiesL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
			case EMMFDevSoundProxyConfig:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
				complete = DoConfigL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
			case EMMFDevSoundProxySetConfig:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
				complete = DoSetConfigL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
			case EMMFDevSoundProxyMaxVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
				complete = DoMaxVolumeL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
			case EMMFDevSoundProxyVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
				complete = DoVolumeL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
			case EMMFDevSoundProxySetVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
				complete = DoSetVolumeL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
			case EMMFDevSoundProxyMaxGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
				complete = DoMaxGainL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
			case EMMFDevSoundProxyGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
				complete = DoGainL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
			case EMMFDevSoundProxySetGain:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
				complete = DoSetGainL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
			case EMMFDevSoundProxyPlayBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
				complete = DoGetPlayBalanceL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341
			case EMMFDevSoundProxySetPlayBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   342
				complete = DoSetPlayBalanceL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   343
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   344
			case EMMFDevSoundProxyRecordBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   345
				complete = DoGetRecordBalanceL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   346
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   347
			case EMMFDevSoundProxySetRecordBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   348
				complete = DoSetRecordBalanceL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   349
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   350
			case EMMFDevSoundProxyBTBFData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   351
				complete = DoBufferToBeFilledDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   352
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   353
			case EMMFDevSoundProxyBTBEData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   354
				complete = DoBufferToBeEmptiedDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   355
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   356
			case EMMFDevSoundProxyPlayInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   357
				complete = DoPlayInitL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   358
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   359
			case EMMFDevSoundProxyRecordInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   360
				complete = DoRecordInitL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   361
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   362
			case EMMFDevSoundProxyPlayData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   363
				complete = DoPlayDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   364
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   365
			case EMMFDevSoundProxyRecordData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   366
				complete = DoRecordDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   367
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   368
			case EMMFDevSoundProxyStop:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   369
				complete = DoStopL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   370
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   371
			case EMMFDevSoundProxyPause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   372
				complete = DoPauseL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   373
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   374
			case EMMFDevSoundProxyPlayTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   375
				complete = DoPlayToneL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   376
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   377
			case EMMFDevSoundProxyPlayDualTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   378
				complete = DoPlayDualToneL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   379
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   380
			case EMMFDevSoundProxyPlayDTMFString:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   381
				complete = DoPlayDTMFStringL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   382
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   383
			case EMMFDevSoundProxyPlayToneSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   384
				complete = DoPlayToneSequenceL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   385
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   386
			case EMMFDevSoundProxySetDTMFLengths:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   387
				complete = DoSetDTMFLengthsL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   388
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   389
			case EMMFDevSoundProxySetVolumeRamp:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   390
				complete = DoSetVolumeRampL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   391
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   392
			case EMMFDevSoundProxyGetSupportedInputDataTypes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   393
				complete = DoGetSupportedInputDataTypesL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   394
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   395
			case EMMFDevSoundProxyGetSupportedOutputDataTypes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   396
				complete = DoGetSupportedOutputDataTypesL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   397
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   398
			case EMMFDevSoundProxyCopyFourCCArrayData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   399
				complete = DoCopyFourCCArrayDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   400
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   401
			case EMMFDevSoundProxySamplesRecorded:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   402
				complete = DoSamplesRecordedL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   403
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   404
			case EMMFDevSoundProxySamplesPlayed:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   405
				complete = DoSamplesPlayedL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   406
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   407
			case EMMFDevSoundProxySetToneRepeats:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   408
				complete = DoSetToneRepeatsL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   409
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   410
			case EMMFDevSoundProxySetPrioritySettings:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   411
				complete = DoSetPrioritySettingsL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   412
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   413
			case EMMFDevSoundProxyCancelInitialize:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   414
				complete = DoCancelInitializeL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   415
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   416
			case EMMFDevSoundProxyEmptyBuffers:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   417
				complete = DoEmptyBuffersL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   418
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   419
			case EMMFDevSoundProxyGetTimePlayed:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   420
				complete = DoGetTimePlayedL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   421
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   422
			case EMMFDevSoundProxyIsResumeSupported:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   423
				complete = DoQueryResumeSupportedL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   424
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   425
			case EMMFDevSoundProxyResume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   426
				complete = DoResumeL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   427
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   428
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   429
			// DevSound custom command support
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   430
			case EMMFDevSoundProxySyncCustomCommand:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   431
			case EMMFDevSoundProxySyncCustomCommandResult:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   432
			case EMMFDevSoundProxyAsyncCustomCommand:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   433
			case EMMFDevSoundProxyAsyncCustomCommandResult:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   434
				complete = DoCustomCommandL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   435
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   436
			case EMMFDevSoundProxyClose:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   437
				complete = DoPrepareCloseL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   438
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   439
			case EMMFDevSoundProxyRequestResourceNotification:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   440
				complete = DoRegisterAsClientL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   441
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   442
			case EMMFDevSoundProxyCancelRequestResourceNotification:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   443
				complete = DoCancelRegisterAsClientL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   444
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   445
			case EMMFDevSoundProxyGetResourceNotificationData:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   446
				complete = DoGetResourceNotificationDataL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   447
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   448
			case EMMFDevSoundProxyWillResumePlay:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   449
				complete = DoWillResumePlayL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   450
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   451
			case EMMFDevSoundProxySetClientThreadInfo:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   452
				complete = DoSetClientThreadInfoL(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   453
				break;						
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   454
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   455
				User::Leave(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   456
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   457
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   458
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   459
		// Check if can complete the message now
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   460
		if (complete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   461
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   462
			// Complete the message
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   463
			// Synchronous requests & Pseudo-asynchronous
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   464
			aMessage.Complete(KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   465
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   466
			// Store function if we need to re-apply it again due to pre-emption clash
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   467
			if(iRequestBeingServiced.Type() == TMMFDevSoundRequest::EAction_PseudoAsynchronous)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   468
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   469
				iRedoFunction = aMessage.Function();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   470
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   471
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   472
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   473
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   474
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   475
		// If there's a CI extension, see if that handles this request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   476
		TInt err = KErrNotSupported;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   477
		if (iCIExtension)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   478
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   479
            SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoServiceRequestL - CIExtensionRequest [%d]"), aMessage.Function());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   480
            iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   481
			iHandlingExtdCI = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   482
			TRAPD(err2, err = iCIExtension->HandleMessageL(aMessage));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   483
			if (err2)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   484
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   485
				err = err2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   486
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   487
			iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   488
			iHandlingExtdCI = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   489
			SYMBIAN_DEBPRN2(_L("CMMFDevSoundSession[0x%x]::DoServiceRequestL - CIExtensionRequest[%d] - Exit with Error[%d] "), aMessage.Function(),err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   490
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   491
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   492
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   493
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   494
			// Not been handled, the request is not supported
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   495
			aMessage.Complete(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   496
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   497
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   498
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   499
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   500
void CMMFDevSoundSession::DoServiceAlreadyCompletedRequestL(const TInt aFunction)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   501
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   502
    ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   503
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   504
	switch(aFunction)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   505
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   506
		case EMMFDevSoundProxyInitialize1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   507
			DoAlreadyCompletedInitialize1L();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   508
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   509
		case EMMFDevSoundProxyInitialize2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   510
			DoAlreadyCompletedInitialize2L();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   511
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   512
		case EMMFDevSoundProxyInitialize4:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   513
			DoAlreadyCompletedInitialize4L();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   514
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   515
		case EMMFDevSoundProxyPlayInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   516
			DoAlreadyCompletedPlayInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   517
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   518
		case EMMFDevSoundProxyRecordInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   519
			DoAlreadyCompletedRecordInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   520
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   521
		case EMMFDevSoundProxyPlayTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   522
			DoAlreadyCompletedPlayToneL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   523
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   524
		case EMMFDevSoundProxyPlayDualTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   525
			DoAlreadyCompletedPlayDualToneL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   526
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   527
		case EMMFDevSoundProxyPlayDTMFString:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   528
			DoAlreadyCompletedPlayDTMFStringL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   529
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   530
		case EMMFDevSoundProxyPlayToneSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   531
			DoAlreadyCompletedPlayToneSequenceL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   532
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   533
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   534
			User::Leave(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   535
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   536
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   537
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   538
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   539
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   540
void CMMFDevSoundSession::HandleAlreadyCompletedRequest()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   541
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   542
	TRAPD(err,DoServiceAlreadyCompletedRequestL(iRedoFunction));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   543
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   544
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   545
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   546
		switch(iRedoFunction)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   547
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   548
			case EMMFDevSoundProxyInitialize1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   549
			case EMMFDevSoundProxyInitialize2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   550
			case EMMFDevSoundProxyInitialize4:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   551
				InitializeComplete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   552
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   553
			case EMMFDevSoundProxyPlayInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   554
				PlayError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   555
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   556
			case EMMFDevSoundProxyRecordInit:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   557
				RecordError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   558
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   559
			case EMMFDevSoundProxyPlayTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   560
			case EMMFDevSoundProxyPlayDualTone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   561
			case EMMFDevSoundProxyPlayDTMFString:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   562
			case EMMFDevSoundProxyPlayToneSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   563
			case EMMFDevSoundProxyPlayFixedSequence:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   564
				ToneFinished(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   565
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   566
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   567
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   568
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   569
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   570
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   571
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   572
void CMMFDevSoundSession::EnqueueRequest(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   573
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   574
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::EnqueueRequest - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   575
	// Encapsule the request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   576
	TMMFDevSoundRequest request;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   577
	request.SetMessage(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   578
	// Append
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   579
	TInt error = iQueuedRequests.Append(request);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   580
	__ASSERT_DEBUG(error == KErrNone, Panic(EQueueRequestsFailedToAppend));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   581
	SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::EnqueueRequest - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   582
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   583
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   584
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   585
// CMMFDevSoundSession::DoPostOpenL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   586
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   587
TBool CMMFDevSoundSession::DoPostOpenL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   588
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   589
	iAdapter->PostOpenL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   590
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   591
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   592
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   593
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   594
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   595
// CMMFDevSoundSession::DoInitialize1L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   596
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   597
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   598
TBool CMMFDevSoundSession::DoInitialize1L(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   599
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   600
    iMsgQueue.Close(); // close if already open
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   601
	TInt err = iMsgQueue.Open(aMessage, 2, EOwnerThread); // a global queue but owned by thread
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   602
	User::LeaveIfError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   603
	DoSetClientConfigL();// added here instead of the CreateL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   604
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   605
	User::LeaveIfError(MessageRead(aMessage,1,devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   606
	iCachedClientData = devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   607
	TMMFState mode = devSoundBuf().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   608
	iAdapter->InitializeL(mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   609
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   610
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   611
	// Flag to queue any further request 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   612
	// but the message can be completed now
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   613
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   614
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   615
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   616
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   617
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   618
// CMMFDevSoundSession::DoAlreadyCompletedInitialize1L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   619
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   620
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   621
void CMMFDevSoundSession::DoAlreadyCompletedInitialize1L()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   622
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   623
	TMMFState mode = iCachedClientData().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   624
	iAdapter->InitializeL(mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   625
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   626
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   627
	// Flag to queue any further request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   628
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   629
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   630
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   631
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   632
// CMMFDevSoundSession::DoInitialize2L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   633
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   634
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   635
TBool CMMFDevSoundSession::DoInitialize2L(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   636
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   637
    iMsgQueue.Close(); // close if already open
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   638
	TInt err = iMsgQueue.Open(aMessage, 2, EOwnerThread); // a global queue but owned by thread
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   639
	User::LeaveIfError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   640
	DoSetClientConfigL();// added here instead of the CreateL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   641
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   642
	User::LeaveIfError(MessageRead(aMessage,1,devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   643
	iCachedClientData = devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   644
	TUid HWDev = devSoundBuf().iHWDev;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   645
	TMMFState mode = devSoundBuf().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   646
	iAdapter->InitializeL(HWDev, mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   647
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   648
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   649
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   650
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   651
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   652
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   653
// CMMFDevSoundSession::DoAlreadyCompletedInitialize2L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   654
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   655
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   656
void CMMFDevSoundSession::DoAlreadyCompletedInitialize2L()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   657
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   658
	TUid HWDev = iCachedClientData().iHWDev;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   659
	TMMFState mode = iCachedClientData().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   660
	iAdapter->InitializeL(HWDev, mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   661
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   662
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   663
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   664
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   665
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   666
// CMMFDevSoundSession::DoInitialize4L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   667
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   668
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   669
TBool CMMFDevSoundSession::DoInitialize4L(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   670
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   671
    iMsgQueue.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   672
	TInt err = iMsgQueue.Open(aMessage, 2, EOwnerThread); // a global queue but owned by thread
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   673
	User::LeaveIfError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   674
	DoSetClientConfigL();// added here instead of the CreateL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   675
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   676
	User::LeaveIfError(MessageRead(aMessage, TInt(1), devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   677
	iCachedClientData = devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   678
	TFourCC desiredFourCC = devSoundBuf().iDesiredFourCC;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   679
	TMMFState mode = devSoundBuf().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   680
	iAdapter->InitializeL(desiredFourCC, mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   681
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   682
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   683
	// Flag to queue any further request 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   684
	// but the message can be completed now
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   685
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   686
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   687
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   688
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   689
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   690
// CMMFDevSoundSession::DoAlreadyCompletedInitialize4L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   691
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   692
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   693
void CMMFDevSoundSession::DoAlreadyCompletedInitialize4L()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   694
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   695
	TFourCC desiredFourCC = iCachedClientData().iDesiredFourCC;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   696
	TMMFState mode = iCachedClientData().iMode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   697
	iAdapter->InitializeL(desiredFourCC, mode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   698
	iBufferPlay = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   699
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   700
	// Flag to queue any further request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   701
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   702
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   703
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   704
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   705
// CMMFDevSoundSession::DoCancelInitialize
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   706
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   707
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   708
TBool CMMFDevSoundSession::DoCancelInitializeL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   709
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   710
	TInt err=iAdapter->CancelInitialize();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   711
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   712
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   713
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   714
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   715
		iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   716
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   717
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   718
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   719
		iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   720
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   721
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   722
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   723
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   724
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   725
// CMMFDevSoundSession::DoCapabilitiesL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   726
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   727
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   728
TBool CMMFDevSoundSession::DoCapabilitiesL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   729
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   730
	TInt err = iAdapter->Capabilities(iDevSoundCapabilities);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   731
	if(err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   732
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   733
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   734
		iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   735
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   736
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   737
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   738
		iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   739
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   740
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   741
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   742
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   743
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   744
// CMMFDevSoundSession::DoConfigL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   745
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   746
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   747
TBool CMMFDevSoundSession::DoConfigL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   748
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   749
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   750
	devSoundSet.iConfig = iAdapter->Config();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   751
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   752
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   753
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   754
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   755
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   756
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   757
// CMMFDevSoundSession::DoSetConfigL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   758
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   759
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   760
TBool CMMFDevSoundSession::DoSetConfigL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   761
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   762
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   763
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   764
	TMMFCapabilities config = devSoundBuf().iConfig;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   765
	iAdapter->SetConfigL(config);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   766
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   767
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   768
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   769
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   770
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   771
// CMMFDevSoundSession::axVolumeL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   772
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   773
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   774
TBool CMMFDevSoundSession::DoMaxVolumeL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   775
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   776
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   777
	devSoundSet.iMaxVolume = iAdapter->MaxVolume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   778
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   779
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   780
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   781
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   782
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   783
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   784
// CMMFDevSoundSession::DoVolumeL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   785
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   786
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   787
TBool CMMFDevSoundSession::DoVolumeL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   788
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   789
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   790
	devSoundSet.iVolume = iAdapter->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   791
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   792
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   793
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   794
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   795
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   796
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   797
// CMMFDevSoundSession::DoSetVolumeL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   798
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   799
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   800
TBool CMMFDevSoundSession::DoSetVolumeL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   801
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   802
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   803
	User::LeaveIfError(MessageRead(aMessage, TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   804
	TInt volume = devSoundBuf().iVolume;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   805
	TBool asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   806
	User::LeaveIfError(iAdapter->SetVolume(volume, asyncOperation));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   807
	iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   808
	return !asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   809
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   810
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   811
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   812
// CMMFDevSoundSession::DoMaxGainL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   813
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   814
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   815
TBool CMMFDevSoundSession::DoMaxGainL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   816
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   817
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   818
	devSoundSet.iMaxGain = iAdapter->MaxGain();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   819
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   820
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   821
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   822
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   823
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   824
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   825
// CMMFDevSoundSession::DoGainL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   826
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   827
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   828
TBool CMMFDevSoundSession::DoGainL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   829
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   830
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   831
	devSoundSet.iGain = iAdapter->Gain();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   832
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   833
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   834
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   835
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   836
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   837
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   838
// CMMFDevSoundSession::DoSetGainL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   839
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   840
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   841
TBool CMMFDevSoundSession::DoSetGainL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   842
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   843
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   844
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   845
	TInt gain = devSoundBuf().iGain;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   846
	TBool asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   847
	User::LeaveIfError(iAdapter->SetGain(gain, asyncOperation));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   848
	iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   849
	return !asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   850
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   851
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   852
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   853
// CMMFDevSoundSession::DoGetPlayBalanceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   854
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   855
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   856
TBool CMMFDevSoundSession::DoGetPlayBalanceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   857
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   858
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   859
	iAdapter->GetPlayBalanceL(devSoundSet.iLeftPercentage, devSoundSet.iRightPercentage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   860
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   861
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   862
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   863
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   864
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   865
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   866
// CMMFDevSoundSession::DoSetPlayBalanceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   867
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   868
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   869
TBool CMMFDevSoundSession::DoSetPlayBalanceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   870
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   871
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   872
    User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   873
	TInt leftPercentage = devSoundBuf().iLeftPercentage;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   874
	TInt rightPercentage = devSoundBuf().iRightPercentage;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   875
	TBool asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   876
	iAdapter->SetPlayBalanceL(leftPercentage, rightPercentage, asyncOperation);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   877
	iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   878
	return !asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   879
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   880
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   881
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   882
// CMMFDevSoundSession::DoGetRecordBalanceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   883
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   884
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   885
TBool CMMFDevSoundSession::DoGetRecordBalanceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   886
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   887
	TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   888
	iAdapter->GetRecordBalanceL(devSoundSet.iLeftPercentage, devSoundSet.iRightPercentage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   889
	TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   890
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   891
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   892
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   893
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   894
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   895
// CMMFDevSoundSession::DoSetRecordBalanceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   896
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   897
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   898
TBool CMMFDevSoundSession::DoSetRecordBalanceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   899
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   900
	TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   901
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   902
	TInt leftPercentage = devSoundBuf().iLeftPercentage;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   903
	TInt rightPercentage = devSoundBuf().iRightPercentage;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   904
	TBool asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   905
	iAdapter->SetRecordBalanceL(leftPercentage, rightPercentage, asyncOperation);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   906
	iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   907
	return !asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   908
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   909
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   910
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   911
// CMMFDevSoundSession::DoPlayInitL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   912
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   913
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   914
TBool CMMFDevSoundSession::DoPlayInitL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   915
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   916
	iAdapter->PlayInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   917
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   918
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   919
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   920
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   921
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   922
// CMMFDevSoundSession::DoAlreadyCompletedPlayInitL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   923
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   924
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   925
void CMMFDevSoundSession::DoAlreadyCompletedPlayInitL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   926
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   927
	iAdapter->PlayInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   928
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   929
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   930
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   931
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   932
// CMMFDevSoundSession::DoRecordInitL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   933
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   934
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   935
TBool CMMFDevSoundSession::DoRecordInitL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   936
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   937
	iAdapter->RecordInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   938
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   939
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   940
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   941
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   942
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   943
// CMMFDevSoundSession::DoAlreadyCompletedRecordInitL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   944
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   945
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   946
void CMMFDevSoundSession::DoAlreadyCompletedRecordInitL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   947
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   948
	iAdapter->RecordInitL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   949
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   950
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   951
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   952
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   953
// CMMFDevSoundSession::DoPlayDataL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   954
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   955
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   956
TBool CMMFDevSoundSession::DoPlayDataL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   957
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   958
	SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayDataL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   959
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   960
	if( iPlayErrorOccured )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   961
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   962
		SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayDataL - Ignore and Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   963
		return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   964
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   965
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   966
	TMMFDevSoundProxyHwBufPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   967
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   968
	iBufferPlay->SetLastBuffer(devSoundBuf().iLastBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   969
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   970
	TPtr8 dataPtr(iChunk.Base(), devSoundBuf().iBufferSize, devSoundBuf().iBufferSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   971
	// Copy data over from chunk
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   972
	iBufferPlay->Data().Copy(dataPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   973
	iAdapter->PlayData();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   974
	SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayDataL - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   975
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   976
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   977
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   978
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   979
// CMMFDevSoundSession::DoRecordDataL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   980
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   981
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   982
TBool CMMFDevSoundSession::DoRecordDataL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   983
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   984
	iAdapter->RecordData();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   985
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   986
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   987
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   988
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   989
// CMMFDevSoundSession::DoStopL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   990
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   991
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   992
TBool CMMFDevSoundSession::DoStopL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   993
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   994
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoStopL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   995
    // Sometimes Stop is not involved on a commit cycle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   996
	TBool completed = iAdapter->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   997
	if (completed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   998
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   999
        FlushQueuedRequests();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1000
		FlushEventQueue(); // completed returned here means we were idle to start with. TODO could possibly skip this flush
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1001
		iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1002
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1003
	iOperationCompletePending = !completed;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1004
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoStopL - Exit. Return value is [%d]"), completed);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1005
	return completed;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1006
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1007
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1008
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1009
// CMMFDevSoundSession::DoPauseL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1010
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1011
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1012
TBool CMMFDevSoundSession::DoPauseL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1013
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1014
	User::LeaveIfError(iAdapter->Pause());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1015
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1016
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1017
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1018
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1019
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1020
// CMMFDevSoundSession::DoPlayToneL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1021
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1022
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1023
TBool CMMFDevSoundSession::DoPlayToneL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1024
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1025
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayToneL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1026
    TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1027
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1028
	iCachedClientData = devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1029
	TInt frequency = devSoundBuf().iFrequencyOne;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1030
	TTimeIntervalMicroSeconds duration(devSoundBuf().iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1031
	iAdapter->PlayToneL(frequency, duration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1032
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1033
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoPlayToneL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1034
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1035
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1036
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1037
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1038
// CMMFDevSoundSession::DoAlreadyCompletedPlayToneL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1039
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1040
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1041
void CMMFDevSoundSession::DoAlreadyCompletedPlayToneL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1042
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1043
	TInt frequency = iCachedClientData().iFrequencyOne;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1044
	TTimeIntervalMicroSeconds duration(iCachedClientData().iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1045
	iAdapter->PlayToneL(frequency, duration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1046
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1047
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1048
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1049
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1050
// CMMFDevSoundSession::DoPlayDualToneL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1051
// (other items were commented in a header).	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1052
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1053
TBool CMMFDevSoundSession::DoPlayDualToneL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1054
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1055
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayDualToneL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1056
    TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1057
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1058
	iCachedClientData = devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1059
	TInt frequencyOne = devSoundBuf().iFrequencyOne;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1060
	TInt frequencyTwo = devSoundBuf().iFrequencyTwo;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1061
	TTimeIntervalMicroSeconds duration(devSoundBuf().iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1062
	iAdapter->PlayDualToneL(frequencyOne, frequencyTwo, duration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1063
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1064
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoPlayDualToneL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1065
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1066
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1067
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1068
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1069
// CMMFDevSoundSession::DoAlreadyCompletedPlayDualToneL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1070
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1071
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1072
void CMMFDevSoundSession::DoAlreadyCompletedPlayDualToneL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1073
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1074
	TInt frequencyOne = iCachedClientData().iFrequencyOne;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1075
	TInt frequencyTwo = iCachedClientData().iFrequencyTwo;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1076
	TTimeIntervalMicroSeconds duration(iCachedClientData().iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1077
	iAdapter->PlayDualToneL(frequencyOne, frequencyTwo, duration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1078
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1079
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1080
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1081
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1082
// CMMFDevSoundSession::DoPlayDTMFStringL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1083
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1084
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1085
TBool CMMFDevSoundSession::DoPlayDTMFStringL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1086
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1087
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayDTMFStringL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1088
    TInt dtmfLength = aMessage.GetDesLength(2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1089
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1090
	if(iDtmfString)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1091
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1092
		delete iDtmfString;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1093
		iDtmfString = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1094
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1095
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1096
	iDtmfString = HBufC::NewL(dtmfLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1097
	TPtr dtmfPtr = iDtmfString->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1098
    User::LeaveIfError(MessageRead(aMessage, TInt(2), dtmfPtr));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1099
	iAdapter->PlayDTMFStringL(*iDtmfString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1100
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1101
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoPlayDTMFStringL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1102
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1103
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1104
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1105
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1106
// CMMFDevSoundSession::DoAlreadyCompletedPlayDTMFStringL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1107
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1108
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1109
void CMMFDevSoundSession::DoAlreadyCompletedPlayDTMFStringL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1110
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1111
	iAdapter->PlayDTMFStringL(*iDtmfString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1112
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1113
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1114
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1115
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1116
// CMMFDevSoundSession::DoPlayToneSequenceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1117
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1118
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1119
TBool CMMFDevSoundSession::DoPlayToneSequenceL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1120
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1121
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoPlayToneSequenceL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1122
    TInt toneLength = aMessage.GetDesLength(1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1123
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1124
	if(iToneSeqBuf)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1125
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1126
		delete iToneSeqBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1127
		iToneSeqBuf = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1128
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1129
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1130
	iToneSeqBuf = HBufC8::NewL(toneLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1131
	TPtr8 toneSeqPtr = iToneSeqBuf->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1132
	User::LeaveIfError(MessageRead(aMessage,TInt(1), toneSeqPtr));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1133
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1134
	iAdapter->PlayToneSequenceL(*iToneSeqBuf);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1135
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1136
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoPlayToneSequenceL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1137
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1138
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1139
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1140
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1141
// CMMFDevSoundSession::DoAlreadyCompletedPlayToneSequenceL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1142
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1143
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1144
void CMMFDevSoundSession::DoAlreadyCompletedPlayToneSequenceL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1145
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1146
	iAdapter->PlayToneSequenceL(*iToneSeqBuf);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1147
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1148
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1150
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1151
// CMMFDevSoundSession::DoSetDTMFLengthsL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1152
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1153
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1154
TBool CMMFDevSoundSession::DoSetDTMFLengthsL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1155
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1156
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoSetDTMFLengthsL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1157
    TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1158
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1159
	TTimeIntervalMicroSeconds32 toneOnLength = devSoundBuf().iToneOnLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1160
	TTimeIntervalMicroSeconds32 toneOffLength = devSoundBuf().iToneOffLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1161
	TTimeIntervalMicroSeconds32 pauseLength = devSoundBuf().iPauseLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1162
	User::LeaveIfError(iAdapter->SetDTMFLengths(toneOnLength, toneOffLength, pauseLength));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1163
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoSetDTMFLengthsL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1164
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1165
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1166
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1167
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1168
// CMMFDevSoundSession::DoSetVolumeRampL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1169
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1170
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1171
TBool CMMFDevSoundSession::DoSetVolumeRampL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1172
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1173
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoSetVolumeRampL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1174
    TMMFDevSoundProxySettingsPckg devSoundBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1175
	User::LeaveIfError(MessageRead(aMessage,TInt(1),devSoundBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1176
	TTimeIntervalMicroSeconds duration = devSoundBuf().iDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1177
	User::LeaveIfError(iAdapter->SetVolumeRamp(duration));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1178
	iOperationCompletePending = EFalse; // Volume ramp doesn't result on commit
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1179
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoSetVolumeRampL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1180
	return ETrue; // operation complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1181
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1182
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1183
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1184
// CMMFDevSoundSession::DoGetSupportedInputDataTypesL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1185
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1186
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1187
TBool CMMFDevSoundSession::DoGetSupportedInputDataTypesL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1188
							const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1189
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1190
	iArray.Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1191
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1192
	TMMFPrioritySettingsPckg prioritySetBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1193
	User::LeaveIfError(MessageRead(aMessage,TInt(1),prioritySetBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1194
	TMMFPrioritySettings prioritySet = prioritySetBuf();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1195
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1196
	iAdapter->GetSupportedInputDataTypesL(iArray, prioritySet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1197
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1198
	TPckgBuf<TInt> pckg;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1199
	pckg() = iArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1200
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1201
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1202
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1203
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1204
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1205
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1206
// CMMFDevSoundSession::DoGetSupportedOutputDataTypesL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1207
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1208
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1209
TBool CMMFDevSoundSession::DoGetSupportedOutputDataTypesL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1210
							const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1211
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1212
	iArray.Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1213
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1214
	TMMFPrioritySettingsPckg prioritySetBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1215
	User::LeaveIfError(MessageRead(aMessage,TInt(1),prioritySetBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1216
	TMMFPrioritySettings prioritySet = prioritySetBuf();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1217
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1218
	iAdapter->GetSupportedOutputDataTypesL(iArray, prioritySet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1219
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1220
	TPckgBuf<TInt> pckg;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1221
	pckg() = iArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1222
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1223
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1224
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1225
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1226
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1227
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1228
// CMMFDevSoundSession::DoSamplesRecordedL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1229
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1230
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1231
TBool CMMFDevSoundSession::DoSamplesRecordedL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1232
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1233
	TPckgBuf<TInt> pckg;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1234
	pckg() = iAdapter->SamplesRecorded();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1235
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1236
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1237
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1239
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1240
// CMMFDevSoundSession::DoSamplesPlayedL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1241
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1242
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1243
TBool CMMFDevSoundSession::DoSamplesPlayedL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1244
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1245
	TPckgBuf<TInt> pckg;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1246
	pckg() = iAdapter->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1247
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),pckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1248
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1249
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1250
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1251
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1252
// CMMFDevSoundSession::DoSetToneRepeatsL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1253
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1254
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1255
TBool CMMFDevSoundSession::DoSetToneRepeatsL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1256
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1257
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DoSetToneRepeatsL - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1258
    TPckgBuf<TInt> countRepeat;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1259
	User::LeaveIfError(MessageRead(aMessage,TInt(1),countRepeat));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1260
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1261
	TPckgBuf<TTimeIntervalMicroSeconds> repeatTS;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1262
	User::LeaveIfError(MessageRead(aMessage,TInt(2),repeatTS));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1263
	User::LeaveIfError(iAdapter->SetToneRepeats(countRepeat(), repeatTS()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1264
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::DoSetToneRepeatsL - Exit. Return value is [%d]"), ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1265
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1266
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1267
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1268
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1269
// CMMFDevSoundSession::DoSetPrioritySettingsL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1270
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1271
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1272
TBool CMMFDevSoundSession::DoSetPrioritySettingsL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1273
						const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1274
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1275
	TPckgBuf<TMMFPrioritySettings> prioritySet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1276
	User::LeaveIfError(MessageRead(aMessage,TInt(1),prioritySet));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1277
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1278
	User::LeaveIfError(iAdapter->SetPrioritySettings(prioritySet()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1279
	iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1280
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1281
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1282
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1283
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1284
// CMMFDevSoundSession::DoCopyFourCCArrayDataL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1285
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1286
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1287
TBool CMMFDevSoundSession::DoCopyFourCCArrayDataL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1288
						const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1289
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1290
	const TInt KBufExpandSize8 = 8;//two TInts
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1291
	CBufFlat* dataCopyBuffer = CBufFlat::NewL(KBufExpandSize8);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1292
	CleanupStack::PushL(dataCopyBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1293
	RBufWriteStream stream;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1294
	stream.Open(*dataCopyBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1295
	CleanupClosePushL(stream);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1296
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1297
	TInt i = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1298
	TInt count = iArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1299
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1300
	while (i < count)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1301
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1302
		stream.WriteInt32L(iArray[i].FourCC());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1303
		i++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1304
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1305
	User::LeaveIfError(MessageWrite(aMessage, TInt(2), dataCopyBuffer->Ptr(0)));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1306
	stream.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1307
	CleanupStack::PopAndDestroy(&stream);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1308
	CleanupStack::PopAndDestroy(dataCopyBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1309
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1310
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1311
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1312
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1313
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1314
// CMMFDevSoundSession::DoBufferToBeFilledDataL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1315
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1316
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1317
TBool CMMFDevSoundSession::DoBufferToBeFilledDataL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1318
							const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1319
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1320
	// if CMMFDevSoundSession::PlayError() has been called, RChunk would have got closed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1321
	// Need to check if Chunk Handle is still valid. If it is not,complete the message immediately and send a error to the Client.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1322
	if(!iChunk.Handle())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1323
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1324
		aMessage.Complete(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1325
		return EFalse;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1326
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1327
	TPckgBuf<TInt> requestChunkBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1328
	User::LeaveIfError(MessageRead(aMessage, TInt(1), requestChunkBuf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1329
	TBool requestChunk = requestChunkBuf();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1330
	if (requestChunk)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1331
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1332
		// if the client requests, always do EOpen
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1333
		iHwBufPckgFill().iChunkOp = EOpen;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1334
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1335
	TInt err = MessageWrite(aMessage, TInt(2), iHwBufPckgFill);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1336
	if ( (err == KErrNone) && (iHwBufPckgFill().iChunkOp == EOpen) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1337
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1338
		aMessage.Complete(iChunk);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1339
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1340
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1341
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1342
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1343
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1344
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1345
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1346
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1347
// CMMFDevSoundSession::DoBufferToBeEmptiedDataL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1348
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1349
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1350
TBool CMMFDevSoundSession::DoBufferToBeEmptiedDataL(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1351
						const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1352
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1353
	// if CMMFDevSoundSession::RecordError() has been called, RChunk would have got closed.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1354
	// Need to check if Chunk Handle is still valid. If it is not,complete the message immediately and send a error to the Client.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1355
	if(!iChunk.Handle())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1356
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1357
		aMessage.Complete(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1358
		return EFalse;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1359
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1360
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1361
	TInt err = MessageWrite(aMessage, TInt(2), iHwBufPckgEmpty);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1362
	if ( (err == KErrNone) && (iHwBufPckgEmpty().iChunkOp == EOpen) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1363
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1364
		aMessage.Complete(iChunk);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1365
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1366
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1367
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1368
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1369
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1370
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1371
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1372
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1373
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1374
// CMMFDevSoundSession::DoEmptyBuffersL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1375
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1376
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1377
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1378
TBool CMMFDevSoundSession::DoEmptyBuffersL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1379
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1380
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1381
	FilterQueueEvent(EMMFDevSoundProxyBTBFEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1382
	// This is now asynchronous
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1383
	err = iAdapter->EmptyBuffers();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1384
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1385
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1386
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1387
		return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1388
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1389
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1390
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1391
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1392
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1393
// CMMFDevSoundSession::DoGetTimePlayedL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1394
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1395
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1396
TBool CMMFDevSoundSession::DoGetTimePlayedL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1397
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1398
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1399
	TTimeIntervalMicroSeconds time(0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1400
	TPckgBuf<TTimeIntervalMicroSeconds> timePckg(time);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1401
	err = iAdapter->GetTimePlayed(timePckg());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1402
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1403
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1404
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1405
		return EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1406
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1407
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),timePckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1408
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1409
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1410
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1411
TBool CMMFDevSoundSession::DoQueryResumeSupportedL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1412
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1413
	TBool isSupported = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1414
	TPckgBuf<TBool> isSupportedPckg(isSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1415
	isSupportedPckg() = iAdapter->IsResumeSupported();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1416
	User::LeaveIfError(MessageWrite(aMessage,TInt(2),isSupportedPckg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1417
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1418
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1419
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1420
TBool CMMFDevSoundSession::DoResumeL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1421
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1422
	User::LeaveIfError( iAdapter->Resume() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1423
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1424
	FilterQueueEvent(EMMFDevSoundProxyPausedRecordCompleteEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1425
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1426
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1427
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1428
TBool CMMFDevSoundSession::DoPrepareCloseL(const RMmfIpcMessage& /*aMessage*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1429
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1430
	TBool complete = iAdapter->CloseDevSound();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1431
	if(!complete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1432
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1433
		iOperationCompletePending = ETrue;	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1434
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1435
	return complete;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1436
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1437
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1438
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1439
TBool CMMFDevSoundSession::DoCustomCommandL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1440
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1441
	TInt retVal = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1442
	TRAPD(err, retVal = iDeMuxUtility->ProcessCustomInterfaceCommandL(aMessage));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1443
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1444
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1445
		// the framework left with an error condition
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1446
		// so we complete the message with this error
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1447
		// irrespective of whether its a Sync or Async custom command
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1448
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1449
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1450
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1451
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1452
		TInt messageType = aMessage.Function();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1453
		if ((messageType == EMMFDevSoundProxySyncCustomCommand) ||
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1454
			(messageType == EMMFDevSoundProxySyncCustomCommandResult))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1455
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1456
			// If its a sync custom command
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1457
			// we can pass back valid values here since command
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1458
			// has been handled by the DeMux framework
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1459
			aMessage.Complete(retVal);	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1460
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1461
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1462
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1463
	// we complete our own message so don't need the framework to do so
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1464
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1465
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1466
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1467
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1468
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1469
// CMMFDevSoundSession::CMMFDevSoundSession
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1470
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1471
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1472
CMMFDevSoundSession::CMMFDevSoundSession() :
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1473
	iSetClientConfigApplied (EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1474
	iDisconnecting (EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1475
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1476
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1477
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1478
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1479
// CMMFDevSoundSession::~CMMFDevSoundSession
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1480
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1481
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1482
CMMFDevSoundSession::~CMMFDevSoundSession()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1483
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1484
	delete iAsyncQueueStart;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1485
	// clear the array of custom interfaces
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1486
	TInt count = iCustomInterfaceArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1487
	for (TInt i = 0; i < count; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1488
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1489
		// we could have already deleted interfaces without
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1490
		// removing them from the array so check for this
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1491
		// and only delete release plugin if non-null
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1492
		MMMFDevSoundCustomInterfaceDeMuxPlugin* ptr = iCustomInterfaceArray[i].iInterface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1493
		if (ptr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1494
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1495
			iCustomInterfaceArray[i].iInterface->Release();	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1496
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1497
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1498
	iCustomInterfaceArray.Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1499
	iCustomInterfaceArray.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1500
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1501
	delete iDeMuxUtility;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1502
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1503
	if (iCIExtension)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1504
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1505
		iCIExtension->Release();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1506
		iCIExtension = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1507
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1508
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1509
	iMsgQueue.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1510
	iArray.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1511
	iQueuedRequests.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1512
	delete iDtmfString;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1513
	delete iToneSeqBuf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1514
	delete iAdapter;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1515
	delete iClosingWait;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1516
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1517
	CMMFDevSoundServer* server =
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1518
			const_cast<CMMFDevSoundServer*>(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1519
			static_cast<const CMMFDevSoundServer*>(Server()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1520
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1521
	if (server)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1522
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1523
		server->DecrementSessionId();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1524
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1525
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1526
//	delete iCustomCommandParserManager;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1527
//	delete iMMFObjectContainer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1528
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1529
	// Close chunk
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1530
	iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1531
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1532
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1533
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1534
// CMMFDevSoundSession::FlushEventQueue()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1535
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1536
void CMMFDevSoundSession::FlushEventQueue()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1537
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1538
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::FlushEventQueue - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1539
    if(iMsgQueue.Handle() != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1540
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1541
		TMMFDevSoundQueueItem queueItem;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1542
		TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1543
		while(err != KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1544
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1545
			err = iMsgQueue.Receive(queueItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1546
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1547
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1548
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::FlushEventQueue - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1549
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1550
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1551
void CMMFDevSoundSession::FilterQueueEvent(TMMFDevSoundProxyRequest aRequest)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1552
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1553
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::FilterQueueEvent - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1554
    if(iMsgQueue.Handle() != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1555
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1556
		// Pop and push events result at the queue 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1557
		// can be seen as "circular list"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1558
		// set a mark to traverse it safely 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1559
		TMMFDevSoundQueueItem markItem;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1560
		markItem.iRequest = EMMFDevSoundProxyMarkEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1561
		// assumes sufficient space in the queue
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1562
		TInt err = iMsgQueue.Send(markItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1563
		__ASSERT_DEBUG(err == KErrNone, Panic(EMsgQueueFailedToSendMsg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1564
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1565
		while(ETrue)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1566
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1567
			// At least the markEvent is at the queue so ignore the error
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1568
			TMMFDevSoundQueueItem queueItem;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1569
			err = iMsgQueue.Receive(queueItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1570
			if(queueItem.iRequest == EMMFDevSoundProxyMarkEvent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1571
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1572
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1573
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1574
			// Look for the specific event
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1575
			else if(queueItem.iRequest != aRequest)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1576
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1577
				// assumes sufficient space in the queue
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1578
				err = iMsgQueue.Send(queueItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1579
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1580
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1581
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1582
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::FilterQueueEvent - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1583
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1584
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1585
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1586
// CMMFDevSoundSession::Disconnect
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1587
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1588
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1589
void CMMFDevSoundSession::Disconnect(const RMessage2& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1590
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1591
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::Disconnect - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1592
    iDisconnecting = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1593
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1594
    if (NeedToQueue())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1595
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1596
        // if we are in the middle of something, enqueue and wait
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1597
        SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::Disconnect - Add to queue"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1598
        EnqueueRequest(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1599
        iClosingWait->Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1600
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1601
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1602
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1603
        // else do now. Enter ActiveSchedulerWait to wait for AsyncOpComplete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1604
        TBool complete = iAdapter->CloseDevSound();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1605
        if(!complete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1606
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1607
            iRequestBeingServiced.SetMessage(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1608
            iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1609
            ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1610
            iClosingWait->Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1611
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1612
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1613
	CSession2::Disconnect(aMessage);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1614
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::Disconnect - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1615
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1616
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1617
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1618
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1619
// CMMFDevSoundSession::NewL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1620
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1621
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1622
CMMFDevSoundSession* CMMFDevSoundSession::NewL(MGlobalProperties& aGlobalProperties)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1623
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1624
	CMMFDevSoundSession* self = new (ELeave) CMMFDevSoundSession;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1625
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1626
	self->ConstructL(aGlobalProperties);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1627
	CleanupStack::Pop(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1628
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1629
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1630
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1631
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1632
// CMMFDevSoundSession::ConstructL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1633
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1634
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1635
void CMMFDevSoundSession::ConstructL(MGlobalProperties& aGlobalProperties)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1636
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1637
	iAdapter = CMMFDevSoundAdaptation::NewL(*this, aGlobalProperties);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1638
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1639
	iClosingWait = new(ELeave) CActiveSchedulerWait();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1640
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1641
	// Create the Custom Interface DeMux Utility
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1642
	iDeMuxUtility = CMMFDevSoundCIDeMuxUtility::NewL(this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1643
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1644
	// Create the Custom Interface extension
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1645
	TUid implUid = {KMmfUidCIServerExtensionImpl};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1646
	TInt uidAsInteger = implUid.iUid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1647
	const TInt KCIExtTempBufferSize = 20;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1648
	TBuf8<KCIExtTempBufferSize> tempBuffer;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1649
	tempBuffer.Num(uidAsInteger, EHex);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1650
	TUid interfaceUid = {KUidDevSoundCIServerExtension};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1651
	TUid destructorKey;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1652
	TRAPD(err, iCIExtension = static_cast<MDevSoundCIServerExtension*>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1653
		 (MmPluginUtils::CreateImplementationL(interfaceUid, destructorKey, tempBuffer, KRomOnlyResolverUid)));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1654
	if (KErrNotSupported == err)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1655
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1656
		iCIExtension = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1657
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1658
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1659
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1660
		User::LeaveIfError(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1661
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1662
	if (iCIExtension)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1663
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1664
		// Extension exists. Complete the setup
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1665
		iCIExtension->PassDestructorKey(destructorKey);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1666
		User::LeaveIfError(iCIExtension->Setup(*this));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1667
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1668
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1669
	iQueuedRequests.ReserveL(KMaxQueueRequest);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1670
	iAsyncQueueStart = new (ELeave) CAsyncCallBack(CActive::EPriorityStandard);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1671
	TCallBack asyncCallback(AsyncQueueStartCallback, this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1672
	iAsyncQueueStart->Set(asyncCallback);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1673
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1674
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1675
// CMMFDevSoundSession::InitializeComplete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1676
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1677
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1678
void CMMFDevSoundSession::InitializeComplete(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1679
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1680
	// this may be a re-initialization and so we need to
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1681
	// re-get our custom interfaces on the DeMux plugins
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1682
	TInt count = iCustomInterfaceArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1683
	for (TInt i = 0; i < count; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1684
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1685
		// we could have already deleted interfaces without
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1686
		// removing them from the array so check for this
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1687
		// and only refresh plugin if non-null
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1688
		MMMFDevSoundCustomInterfaceDeMuxPlugin* ptr = iCustomInterfaceArray[i].iInterface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1689
		if (ptr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1690
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1691
			// we can't keep track of..
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1692
			// 1. where a custom interface is implemented
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1693
			// 2. the uid of the custom interface to be refreshed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1694
			// so assume all have to be refreshed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1695
			TRAPD(err, ptr->RefreshL());	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1696
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1697
			// Error indicates this is no longer a valid interface
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1698
			if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1699
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1700
				TMMFEvent event;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1701
				TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1702
				item.iRequest = EMMFDevSoundCustomCommandCloseMuxDemuxPair;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1703
				item.iErrorCode = err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1704
				event.iEventType.iUid = i+1;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1705
				item.iEventPckg() = event;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1706
				TInt lErr = iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1707
				__ASSERT_DEBUG(lErr == KErrNone, Panic(EMsgQueueFailedToSendMsg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1708
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1709
// NB proper panic code required here for this part.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1710
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1711
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1712
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1713
	TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1714
	item.iRequest = EMMFDevSoundProxyICEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1715
	item.iErrorCode = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1716
	// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1717
	iMsgQueue.Send(item); 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1718
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1719
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1720
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1721
// CMMFDevSoundSession::ToneFinished
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1722
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1723
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1724
void CMMFDevSoundSession::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1725
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1726
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::ToneFinished - Enter. Error [%d]"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1727
    TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1728
	item.iRequest = EMMFDevSoundProxyTFEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1729
	item.iErrorCode = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1730
	// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1731
	iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1732
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::ToneFinished - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1733
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1734
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1735
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1736
// CMMFDevSoundSession::BufferToBeFilled
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1737
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1738
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1739
void CMMFDevSoundSession::BufferToBeFilled(CMMFBuffer* aBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1740
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1741
	SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::BufferToBeFilled - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1742
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1743
	// Set play error flag to false 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1744
	iPlayErrorOccured = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1745
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1746
	// Store pointer to the buffer to use it later with PlayData
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1747
	iBufferPlay = reinterpret_cast<CMMFDataBuffer*>(aBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1748
	TInt status = CreateChunk(iHwBufPckgFill, iBufferPlay->RequestSize());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1749
	iHwBufPckgFill().iRequestSize = iBufferPlay->RequestSize();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1750
	iHwBufPckgFill().iBufferSize = iBufferPlay->Data().MaxLength();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1751
	iHwBufPckgFill().iLastBuffer = iBufferPlay->LastBuffer();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1752
	TMMFDevSoundQueueItem queueItem;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1753
	if ( status != KErrNone )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1754
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1755
		BufferErrorEvent();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1756
		PlayError(status);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1757
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1758
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1759
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1760
		queueItem.iRequest = EMMFDevSoundProxyBTBFEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1761
		// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1762
		status = iMsgQueue.Send(queueItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1763
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1764
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1765
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::BufferToBeFilled - Exit [%d]"), status);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1766
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1767
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1768
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1769
// CMMFDevSoundSession::PlayError
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1770
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1771
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1772
void CMMFDevSoundSession::PlayError(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1773
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1774
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::PlayError - Enter [%d]"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1775
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1776
	// Set play error flag to ignore following PlayData requests
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1777
	iPlayErrorOccured = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1778
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1779
	TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1780
	item.iRequest = EMMFDevSoundProxyPEEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1781
	item.iErrorCode = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1782
	iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1783
	// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1784
	iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1785
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PlayError - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1786
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1787
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1788
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1789
// CMMFDevSoundSession::BufferToBeEmptied
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1790
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1791
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1792
void CMMFDevSoundSession::BufferToBeEmptied(CMMFBuffer* aBuffer)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1793
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1794
	// Store pointer to the buffer to use it later with RecordData
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1795
	iBufferRecord = reinterpret_cast<CMMFDataBuffer*>(aBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1796
	TInt status = CreateChunk(iHwBufPckgEmpty, iBufferRecord->RequestSize());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1797
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1798
	if ( status != KErrNone )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1799
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1800
		BufferErrorEvent();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1801
		RecordError(status);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1802
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1803
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1804
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1805
		iHwBufPckgEmpty().iRequestSize = iBufferRecord->RequestSize();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1806
		iHwBufPckgEmpty().iBufferSize = iBufferRecord->Data().MaxLength();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1807
		iHwBufPckgEmpty().iLastBuffer = iBufferRecord->LastBuffer();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1808
		//copy the data into the chunk    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1809
		Mem::Copy(iChunk.Base(),iBufferRecord->Data().Ptr(),iBufferRecord->RequestSize());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1810
	    TMMFDevSoundQueueItem queueItem;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1811
		queueItem.iRequest = EMMFDevSoundProxyBTBEEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1812
		// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1813
		iMsgQueue.Send(queueItem);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1814
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1815
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1816
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1817
// CMMFDevSoundSession::RecordError
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1818
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1819
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1820
void CMMFDevSoundSession::RecordError(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1821
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1822
	SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::Record Error [%d]"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1823
	TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1824
	item.iRequest = EMMFDevSoundProxyREEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1825
	item.iErrorCode = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1826
	iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1827
	// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1828
	iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1829
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1830
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1831
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1832
// CMMFDevSoundSession::DeviceMessage
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1833
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1834
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1835
void CMMFDevSoundSession::DeviceMessage(TUid /*aMessageType*/,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1836
									const TDesC8& /*aMsg*/)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1837
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1838
	// Not used
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1839
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1840
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1841
void CMMFDevSoundSession::InterfaceDeleted(TUid aInterfaceId)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1842
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1843
	MMMFDevSoundCustomInterfaceDeMuxPlugin* ptr = InterfaceFromUid(aInterfaceId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1844
	if (ptr == NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1845
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1846
		// Not found
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1847
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1848
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1849
	TRAPD(err, ptr->RefreshL());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1850
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1851
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1852
		// Refresh failed, so tear down Mux/DeMux pair
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1853
		TMMFEvent event;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1854
		TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1855
		item.iRequest = EMMFDevSoundCustomCommandCloseMuxDemuxPair;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1856
		item.iErrorCode = err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1857
		event.iEventType = aInterfaceId;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1858
		item.iEventPckg() = event;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1859
		iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1860
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1861
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1862
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1863
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1864
// CMMFDevSoundSession::CallbackFromAdaptorReceived
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1865
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1866
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1867
void CMMFDevSoundSession::CallbackFromAdaptorReceived(TInt aType, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1868
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1869
    SYMBIAN_DEBPRN2(_L("CMMFDevSoundSession[0x%x]::CallbackFromAdaptorReceived - Enter. Type[%d] Error[%d]"), aType, aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1870
	if(aType == KCallbackRecordPauseComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1871
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1872
		TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1873
		item.iRequest = EMMFDevSoundProxyPausedRecordCompleteEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1874
		item.iErrorCode = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1875
		TInt status = iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1876
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1877
	else if(aType == KCallbackAutoPauseResume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1878
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1879
		TMMFEvent event;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1880
		event.iErrorCode = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1881
		event.iEventType = KMMFEventCategoryAudioResourceAvailable;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1882
		SendEventToClient(event);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1883
		//coverity[uninit_use_in_call]
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1884
		// Disabled Coverity warning, since it complains about iReserved1 member in TMMFEvent being uninitialised
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1885
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1886
	else if (aType == KCallbackFlushComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1887
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1888
		if(!iHandlingExtdCI && iRequestBeingServiced.Function()==EMMFDevSoundProxyEmptyBuffers)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1889
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1890
			//If we come here then it is due to a EMMFDevSoundProxyEmptyBuffers request from client.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1891
			SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::CallbackFromAdaptorReceived - Calling TMMFDevSoundRequest::Complete on iRequestBeingServiced"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1892
		    iRequestBeingServiced.Complete(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1893
		    iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1894
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1895
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1896
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1897
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1898
		if( NeedToQueue() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1899
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1900
			// If not possible to service now, then queue request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1901
			// Encapsule the request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1902
			TMMFDevSoundRequest request(aType);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1903
			// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1904
			iQueuedRequests.Insert(request, 0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1905
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1906
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1907
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1908
			// If there is no oustanding operation service inmediately
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1909
			if (aType == KCallbackProcessingFinished)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1910
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1911
				DoProcessingFinished();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1912
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1913
			else if(aType == KCallbackProcessingUnitError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1914
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1915
				DoProcessingError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1916
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1917
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1918
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1919
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::CallbackFromAdaptorReceived - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1920
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1921
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1922
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1923
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1924
// CMMFDevSoundSession::PreemptionStartedCallbackReceived
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1925
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1926
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1927
void CMMFDevSoundSession::PreemptionStartedCallbackReceived()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1928
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1929
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PreemptionStartedCallbackReceived - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1930
    // Solution: Enqueue any request that arrives before preemption is completed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1931
	iOperationCompletePending = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1932
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PreemptionStartedCallbackReceived - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1933
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1934
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1935
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1936
// CMMFDevSoundSession::PreemptionFinishedCallbackReceived
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1937
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1938
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1939
void CMMFDevSoundSession::PreemptionFinishedCallbackReceived(TBool aCanStartNewOperation)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1940
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1941
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PreemptionFinishedCallbackReceived - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1942
    if (iHandlingExtdCI)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1943
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1944
        // we are in the middle of handling a CI, so ignore - will handle later when unwinding
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1945
        SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PreemptionFinishedCallbackReceived - Exit. Exiting from if block for CI"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1946
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1947
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1948
	iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1949
	if ( aCanStartNewOperation && iQueuedRequests.Count() != 0 )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1950
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1951
		DequeueRequest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1952
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1953
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::PreemptionFinishedCallbackReceived - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1954
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1955
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1956
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1957
// CMMFDevSoundSession::PreemptionClash
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1958
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1959
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1960
void CMMFDevSoundSession::PreemptionClash()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1961
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1962
	//assumes sufficient space in the queue so ignore the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1963
	iQueuedRequests.Insert(iRequestBeingServiced, 0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1964
	iPreemptionClash=ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1965
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1966
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1967
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1968
// CMMFDevSoundSession::PreemptionClashWithStateChange
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1969
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1970
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1971
void CMMFDevSoundSession::PreemptionClashWithStateChange()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1972
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1973
	#ifdef _DEBUG
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1974
		TMMFDevSoundRequest msg = iQueuedRequests[0];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1975
		// message being removed should be the one we previously pushed via PreemptionClash()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1976
		__ASSERT_DEBUG(iRequestBeingServiced==msg, Panic(ERequestBeingServicedMismatch));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1977
	#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1978
	// remove without processing request with AsynchronousOperationComplete() completing the message
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1979
	iQueuedRequests.Remove(0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1980
	iPreemptionClash=EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1981
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1982
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1983
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1984
// CMMFDevSoundSession::AdaptorControlsContext()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1985
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1986
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1987
TBool CMMFDevSoundSession::AdaptorControlsContext() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1988
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1989
    return !iHandlingExtdCI;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1990
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1991
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1992
MMMFDevSoundCustomInterfaceDeMuxPlugin* CMMFDevSoundSession::InterfaceFromUid(TUid aUid)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1993
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1994
	TInt count = iCustomInterfaceArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1995
	TInt id = aUid.iUid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1996
	MMMFDevSoundCustomInterfaceDeMuxPlugin* interface = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1997
	for (TInt i = 0; i < count; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1998
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1999
		if (id == iCustomInterfaceArray[i].iId.iUid)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2000
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2001
			interface = iCustomInterfaceArray[i].iInterface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2002
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2003
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2004
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2005
	return interface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2006
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2007
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2008
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2009
// CMMFDevSoundSession::SendEventToClient
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2010
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2011
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2012
void CMMFDevSoundSession::SendEventToClient(const TMMFEvent& aEvent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2013
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2014
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::SendEventToClient - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2015
    TMMFDevSoundQueueItem item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2016
	item.iRequest = EMMFDevSoundProxySETCEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2017
	item.iErrorCode = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2018
	item.iEventPckg() = aEvent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2019
	// assumes sufficient space in the queue so ignores the return value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2020
	TInt err = iMsgQueue.Send(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2021
    __ASSERT_DEBUG(err == KErrNone, Panic(EMsgQueueFailedToSendMsg));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2022
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::SendEventToClient - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2023
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2024
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2025
void CMMFDevSoundSession::AsynchronousOperationComplete(TInt aError, TBool aCanStartNewOperation)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2026
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2027
    __ASSERT_DEBUG(!iHandlingExtdCI, Panic(EUnexpectedAsyncOpCompleteHandlingCI));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2028
        // when handling CIs we should not reach here
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2029
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2030
    TInt error = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2031
    if (!error)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2032
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2033
        // if have no error payload, use notified error. It will be KErrNone if not set, so just use.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2034
        error = NotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2035
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2036
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2037
	switch (iRequestBeingServiced.Type())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2038
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2039
		case TMMFDevSoundRequest::ESessionEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2040
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2041
			SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x] ==== ClosingDueException ==== "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2042
			iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2043
			if(iClosingWait->IsStarted())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2044
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2045
				iClosingWait->AsyncStop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2046
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2047
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2048
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2049
		// Complete the message for asynchronous requests
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2050
		case TMMFDevSoundRequest::EConfigure_Asynchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2051
		case TMMFDevSoundRequest::EAction_Asynchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2052
		case TMMFDevSoundRequest::EQuery_Asynchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2053
		case TMMFDevSoundRequest::ECustomInterfacesRelated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2054
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2055
			if(iOperationCompletePending && aCanStartNewOperation)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2056
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2057
				if (iRequestBeingServiced.Function()==EMMFDevSoundProxyStop)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2058
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2059
					// flush the queue - will have removed any stale items added between initial call and MMRC's reaction
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2060
                    FlushQueuedRequests();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2061
					FlushEventQueue();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2062
					iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2063
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2064
					
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2065
				if(iRequestBeingServiced.Function()==EMMFDevSoundProxyCapabilities)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2066
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2067
					TMMFDevSoundProxySettings devSoundSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2068
					devSoundSet.iCaps = iDevSoundCapabilities;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2069
					TMMFDevSoundProxySettingsPckg pckg(devSoundSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2070
					MessageWrite(iRequestBeingServiced.Message(),TInt(2),pckg);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2071
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2072
				
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2073
				if(iRequestBeingServiced.Function()==EMMFDevSoundProxyCancelInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2074
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2075
					FlushEventQueue();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2076
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2077
				
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2078
				iRequestBeingServiced.Complete(error);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2079
				iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2080
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2081
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2082
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2083
		case TMMFDevSoundRequest::EAction_PseudoAsynchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2084
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2085
			if(iOperationCompletePending && aCanStartNewOperation)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2086
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2087
				iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2088
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2089
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2090
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2091
		case TMMFDevSoundRequest::EQuery_Synchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2092
		case TMMFDevSoundRequest::EConfigure_Synchronous:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2093
		case TMMFDevSoundRequest::EBufferExchangeRelated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2094
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2095
		case TMMFDevSoundRequest::ECallBackType:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2096
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2097
			if(iOperationCompletePending && aCanStartNewOperation)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2098
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2099
				iOperationCompletePending = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2100
				}	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2101
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2102
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2103
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2104
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2105
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2106
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2107
	if(iRequestBeingServiced.Type() == TMMFDevSoundRequest::ECallBackType )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2108
	    {	    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2109
	    SYMBIAN_DEBPRN2(_L("CMMFDevSoundSession[0x%x] AsynchronousOperationComplete CallbackPF=%d pending=%d"),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2110
	            iRequestBeingServiced.IsCallBack(), iOperationCompletePending );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2111
	    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2112
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2113
	    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2114
	    SYMBIAN_DEBPRN3(_L("CMMFDevSoundSession[0x%x] AsynchronousOperationComplete %x pending=%d Requestype=%d"),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2115
	            iRequestBeingServiced.Function(), iOperationCompletePending, iRequestBeingServiced.Type() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2116
	    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2118
	    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2119
	if ( aCanStartNewOperation && iQueuedRequests.Count() != 0 )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2120
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2121
		DequeueRequest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2122
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2123
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2124
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2125
void CMMFDevSoundSession::DequeueRequest()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2126
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2127
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DequeueRequest - Enter"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2128
    iAsyncQueueStart->Cancel(); // if we're in here cancel any background request
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2129
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2130
	TMMFDevSoundRequest msg = iQueuedRequests[0];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2131
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2132
	if (msg.IsCallBack() > 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2133
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2134
		iRequestBeingServiced.SetMessageCallback();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2135
		//Call iPf function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2136
		SYMBIAN_DEBPRN0(_L("\n CMMFDevSoundSession[0x%x] ======== Service a queued request\n"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2137
		if (msg.IsCallBack() == KCallbackProcessingFinished)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2138
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2139
			iQueuedRequests.Remove(0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2140
			DoProcessingFinished();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2141
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2142
		else if(msg.IsCallBack() == KCallbackProcessingUnitError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2143
		    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2144
		    iQueuedRequests.Remove(0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2145
		    DoProcessingError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2146
		    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2148
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2150
	if (iQueuedRequests.Count()>0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2151
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2152
		// Some rules about what request can be followed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2153
		SYMBIAN_DEBPRN0(_L("\n CMMFDevSoundSession[0x%x]======== Flag can service new request\n"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2154
		iAsyncQueueStart->CallBack();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2155
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2156
	SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::DequeueRequest - Exit"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2157
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2158
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2159
// 	AsyncQueueStartCallback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2160
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2161
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2162
TInt CMMFDevSoundSession::AsyncQueueStartCallback(TAny* aPtr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2163
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2164
	CMMFDevSoundSession* self = static_cast<CMMFDevSoundSession*>(aPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2165
	self->AsyncQueueStartCallback();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2166
	return KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2167
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2168
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2169
void CMMFDevSoundSession::AsyncQueueStartCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2170
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2171
	SYMBIAN_DEBPRN0(_L("\n CMMFDevSoundSession[0x%x]======== Service a queued request\n"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2172
	TMMFDevSoundRequest msg = iQueuedRequests[0];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2173
	iQueuedRequests.Remove(0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2174
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2175
	TBool doRequest = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2176
	if(iPreemptionClash)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2177
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2178
		SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::AsyncQueueStartCallback - Re-applying client request due to Pre-emption clash"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2179
		iPreemptionClash=EFalse; // clear flag before reading next request in queue
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2180
		iAdapter->RollbackAdaptorActiveStateToBeforeCommit();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2181
		if ((iRequestBeingServiced.Type() == TMMFDevSoundRequest::EAction_PseudoAsynchronous))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2182
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2183
		    doRequest = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2184
		    HandleAlreadyCompletedRequest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2185
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2186
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2187
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2188
	if (doRequest)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2189
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2190
		TRAP(err,DoServiceRequestL(msg.Message()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2191
		if(err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2192
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2193
			msg.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2194
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2195
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2196
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2197
	if (!iOperationCompletePending && iQueuedRequests.Count() != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2198
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2199
		//dequeue next
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2200
		DequeueRequest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2201
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2202
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2203
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2204
// CMMFDevSoundSession::CustomInterface()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2205
// Returns a pointer reference to custom interface implementation returned by
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2206
// adaptation::CustomInterface method.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2207
// Note this method is called indirectly by CI server-side plugins - both DeMux and 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2208
// CIServerExtension call this variously via MMMFDevSoundCustomInterfaceTarget or MCustomInterface 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2209
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2210
TAny* CMMFDevSoundSession::CustomInterface(TUid aInterfaceId)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2211
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2212
	TInt err = DoSetClientConfig(); // if required, this will connect to MMRC etc
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2213
	if (err)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2214
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2215
		return NULL; // on any error, return NULL - not much more we can do
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2216
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2217
	return iAdapter->CustomInterface(aInterfaceId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2218
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2219
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2220
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2221
// CMMFDevSoundSession::DoProcessingFinished()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2222
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2223
void CMMFDevSoundSession::DoProcessingFinished()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2224
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2225
    ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2226
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2227
	TBool asyncOperation = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2228
	//ProcessingFinished should never fail
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2229
	__ASSERT_ALWAYS(KErrNone, iAdapter->ProcessingFinishedReceived(asyncOperation));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2230
	iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2231
	if (iOperationCompletePending)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2232
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2233
		iRequestBeingServiced.SetMessageCallback();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2234
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2235
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2236
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2237
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2238
// CMMFDevSoundSession::DoProcessingError()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2239
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2240
void CMMFDevSoundSession::DoProcessingError()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2241
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2242
    ResetNotifiedError();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2243
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2244
    TBool asyncOperation = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2245
    //ProcessingFinished should never fail
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2246
    __ASSERT_ALWAYS(KErrNone, iAdapter->ProcessingError(asyncOperation));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2247
    iOperationCompletePending = asyncOperation;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2248
    if (iOperationCompletePending)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2249
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2250
        iRequestBeingServiced.SetMessageCallback();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2251
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2252
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2253
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2254
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2255
// CMMFDevSoundSession::DoSetClientConfigL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2256
// Sets client configuration information to Adaptation.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2257
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2258
TInt CMMFDevSoundSession::DoSetClientConfig()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2259
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2260
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2261
	if(!iSetClientConfigApplied)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2262
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2263
		CMMFDevSoundServer* server =
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2264
			const_cast<CMMFDevSoundServer*>(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2265
				static_cast<const CMMFDevSoundServer*>(Server()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2266
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2267
		ASSERT(server); // session should always have a server!
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2268
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2269
		TProcessId actualProcessId = server->ActualProcessId();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2270
		TProcessId processId = server->ProcessId();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2271
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2272
		if (actualProcessId!=processId)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2273
		    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2274
            // we have a differing actual process id, so pass that to the adaptor too
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2275
            err = iAdapter->SetClientConfig(actualProcessId, processId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2276
		    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2277
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2278
		    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2279
            err = iAdapter->SetClientConfig(processId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2280
		    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2281
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2282
		if (!err)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2283
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2284
			iSetClientConfigApplied = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2285
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2286
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2287
	return err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2288
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2289
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2290
// CMMFDevSoundSession::DoSetClientConfigL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2291
// Sets client configuration information to Adaptation.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2292
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2293
void CMMFDevSoundSession::DoSetClientConfigL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2294
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2295
	User::LeaveIfError(DoSetClientConfig());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2296
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2297
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2298
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2299
// CMMFDevSoundSession::CreateChunk()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2300
// Requests kernel to create global RChunk
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2301
// 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2302
TInt CMMFDevSoundSession::CreateChunk(TMMFDevSoundProxyHwBufPckg& aBufPckg, TInt aRequestedSize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2303
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2304
	TInt status(KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2305
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2306
	if ( iChunk.Handle() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2307
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2308
		// If the DevSound Adaptation component requests a buffer size
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2309
		// that can fit into current chunk's size, then re-use chunk.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2310
		if ( aRequestedSize <= iChunk.Size() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2311
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2312
			if (iForceSendOfChunkHandle)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2313
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2314
				iForceSendOfChunkHandle = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2315
				aBufPckg().iChunkOp = EOpen;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2316
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2317
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2318
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2319
				aBufPckg().iChunkOp = ENull;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2320
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2321
			return status;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2322
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2323
		// The new request size exceeds the current chunk's area, close it. We
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2324
		// will be creating new one in the following sequences. Note we could
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2325
		// try to Adjust() the chunk, and see if the existing chunk could be
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2326
		// extended instead, but this is assumed too rare an event for this 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2327
		// optimisation
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2328
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2329
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2330
			iChunk.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2331
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2332
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2333
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2334
	// Request kernel to create global RChunk if needed
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2335
	if ( !iChunk.Handle() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2336
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2337
		status = iChunk.CreateGlobal(KNullDesC, aRequestedSize, aRequestedSize, EOwnerThread);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2338
		if ( status == KErrNone )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2339
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2340
			aBufPckg().iChunkOp = EOpen;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2341
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2342
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2343
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2344
			aBufPckg().iChunkOp = ENull;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2345
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2346
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2347
	iForceSendOfChunkHandle = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2348
	return status;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2349
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2350
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2351
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2352
// Custom Interface //
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2353
TInt CMMFDevSoundSession::DoOpenSlaveL(TUid aInterface, const TDesC8& aPackageBuf)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2354
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2355
	// it shouldn't be necessary to check if we have already instantiated this
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2356
	// interface since the client would already know - however this is something
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2357
	// that a licensee could implement if they required additional functionality
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2358
	// e.g. many : 1 mappings between client and DevSound.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2359
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2360
	MMMFDevSoundCustomInterfaceDeMuxPlugin* ptr = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2361
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2362
	// try and instantiate a plugin tunnelling
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2363
	// pair to support this Custom Interface
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2364
	ptr = iDeMuxUtility->CreateCustomInterfaceDeMuxL(aInterface);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2365
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2366
	TInt handle = KNullHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2367
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2368
	if (ptr)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2369
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2370
		TMMFDevSoundCustomInterfaceDeMuxData data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2371
		data.iInterface = ptr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2372
		data.iId = aInterface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2373
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2374
		CleanupReleasePushL(*ptr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2375
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2376
		// setup demux plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2377
		ptr->SetInterfaceTarget(this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2378
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2379
		// try and open interface
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2380
		// this will fetch the interface from the svr implementation
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2381
		ptr->DoOpenSlaveL(aInterface, aPackageBuf);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2382
		User::LeaveIfError(iCustomInterfaceArray.Append(data));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2383
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2384
		CleanupStack::Pop();	// ptr
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2385
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2386
		handle = iCustomInterfaceArray.Count();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2387
		return handle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2388
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2389
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2390
	// we couldn't set up the interface correctly so return a NULL
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2391
	// handle to the client
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2392
	return KNullHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2393
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2394
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2395
void CMMFDevSoundSession::DoCloseSlaveL(TInt aHandle)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2396
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2397
	if (aHandle==KNullHandle)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2398
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2399
		// null-handle -> NOP
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2400
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2401
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2402
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2403
	if (aHandle<KNullHandle || aHandle > iCustomInterfaceArray.Count())
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2404
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2405
		// handle out of range - should not happen, but leave to show error
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2406
		User::Leave(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2407
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2408
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2409
	TMMFDevSoundCustomInterfaceDeMuxData& data = iCustomInterfaceArray[aHandle-1];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2410
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2411
	// close and delete the plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2412
	MMMFDevSoundCustomInterfaceDeMuxPlugin* ptr = data.iInterface;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2413
	ptr->DoCloseSlaveL(aHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2414
	ptr->Release();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2415
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2416
	// clear the entry
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2417
	data.iInterface = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2418
	data.iId.iUid = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2419
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2420
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2421
TInt CMMFDevSoundSession::DoSendSlaveSyncCommandL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2422
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2423
	// use the demux utility to get the handle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2424
	TMMFDevSoundCIMessageData data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2425
	iDeMuxUtility->GetSyncMessageDataL(aMessage, data);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2426
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2427
	TInt handle = data.iHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2428
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2429
	if ((handle <= 0) || (handle > (iCustomInterfaceArray.Count())))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2430
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2431
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2432
		User::Leave(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2433
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2434
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2435
	// call on demux plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2436
	return iCustomInterfaceArray[handle-1].iInterface->DoSendSlaveSyncCommandL(aMessage);	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2437
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2438
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2439
TInt CMMFDevSoundSession::DoSendSlaveSyncCommandResultL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2440
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2441
	// use the demux utility to get the handle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2442
	TMMFDevSoundCIMessageData data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2443
	iDeMuxUtility->GetSyncMessageDataL(aMessage, data);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2444
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2445
	TInt handle = data.iHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2446
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2447
	if ((handle <= 0) || (handle > (iCustomInterfaceArray.Count())))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2448
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2449
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2450
		User::Leave(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2451
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2452
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2453
	// call on demux plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2454
	return iCustomInterfaceArray[handle-1].iInterface->DoSendSlaveSyncCommandResultL(aMessage);	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2455
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2456
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2457
void CMMFDevSoundSession::DoSendSlaveAsyncCommandL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2458
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2459
	// use the demux utility to get the handle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2460
	TMMFDevSoundCIMessageData data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2461
	iDeMuxUtility->GetAsyncMessageDataL(aMessage, data);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2462
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2463
	TInt handle = data.iHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2464
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2465
	if ((handle <= 0) || (handle > (iCustomInterfaceArray.Count())))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2466
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2467
		User::Leave(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2468
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2469
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2470
	// call on demux plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2471
	iCustomInterfaceArray[handle-1].iInterface->DoSendSlaveAsyncCommandL(aMessage);	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2472
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2473
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2474
void CMMFDevSoundSession::DoSendSlaveAsyncCommandResultL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2475
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2476
	// use the demux utility to get the handle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2477
	TMMFDevSoundCIMessageData data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2478
	iDeMuxUtility->GetAsyncMessageDataL(aMessage, data);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2479
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2480
	TInt handle = data.iHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2481
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2482
	if ((handle <= 0) || (handle > (iCustomInterfaceArray.Count())))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2483
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2484
		User::Leave(KErrBadHandle);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2485
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2486
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2487
	// call on demux plugin
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2488
	iCustomInterfaceArray[handle-1].iInterface->DoSendSlaveAsyncCommandResultL(aMessage);	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2489
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2490
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2491
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2492
TBool CMMFDevSoundSession::DoRegisterAsClientL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2493
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2494
	TMMFDevSoundProxySettingsPckg buf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2495
	User::LeaveIfError(MessageRead(aMessage,0,buf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2496
	HBufC8* notificationRegistrationData = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2497
	notificationRegistrationData = HBufC8::NewLC(User::LeaveIfError(aMessage.GetDesLengthL(1)));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2498
	TPtr8 dataPtr(notificationRegistrationData->Des());  	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2499
	User::LeaveIfError(MessageRead(aMessage,1,dataPtr));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2500
	DoSetClientConfigL();// added here instead of the CreateL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2501
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2502
	err = iAdapter->RegisterAsClient(buf().iNotificationEventUid,dataPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2503
	CleanupStack::PopAndDestroy(1); // Notification Registeration data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2504
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2505
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2506
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2507
		return EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2508
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2509
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2510
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2511
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2512
TBool CMMFDevSoundSession::DoCancelRegisterAsClientL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2513
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2514
	TMMFDevSoundProxySettingsPckg buf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2515
	User::LeaveIfError(MessageRead(aMessage,0,buf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2516
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2517
	err = iAdapter->CancelRegisterAsClient(buf().iNotificationEventUid);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2518
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2519
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2520
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2521
		return EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2522
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2523
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2524
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2525
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2526
TBool CMMFDevSoundSession::DoGetResourceNotificationDataL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2527
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2528
	TMMFDevSoundProxySettingsPckg buf;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2529
	User::LeaveIfError(MessageRead(aMessage,0,buf));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2530
	HBufC8* notificationData = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2531
	notificationData = HBufC8::NewLC(User::LeaveIfError(aMessage.GetDesMaxLengthL(2)));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2532
	TPtr8 dataPtr(notificationData->Des());  	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2533
	User::LeaveIfError(MessageRead(aMessage,2,dataPtr));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2534
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2535
	err = iAdapter->GetResourceNotificationData(buf().iNotificationEventUid,dataPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2536
	User::LeaveIfError(MessageWrite(aMessage,2,*notificationData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2537
	CleanupStack::PopAndDestroy(1); // Notification data
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2538
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2539
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2540
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2541
		return EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2542
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2543
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2544
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2545
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2546
TBool CMMFDevSoundSession::DoWillResumePlayL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2547
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2548
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2549
	err = iAdapter->WillResumePlay();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2550
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2551
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2552
		aMessage.Complete(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2553
		return EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2554
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2555
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2556
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2557
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2558
TBool CMMFDevSoundSession::DoSetClientThreadInfoL(const RMmfIpcMessage& aMessage)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2559
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2560
	if(!iSetClientConfigApplied)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2561
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2562
		if (aMessage.HasCapability(ECapabilityMultimediaDD) && aMessage.HasCapability(ECapabilityUserEnvironment))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2563
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2564
			TPckgBuf<TThreadId> threadId;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2565
			User::LeaveIfError(MessageRead(aMessage, 1, threadId));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2566
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2567
			CMMFDevSoundServer* server = 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2568
				const_cast<CMMFDevSoundServer*>(static_cast<const CMMFDevSoundServer*>(Server()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2569
			server->SetClientProcessIdL(threadId()); 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2570
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2571
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2572
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2573
			User::Leave(KErrPermissionDenied);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2574
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2575
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2576
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2577
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2578
		User::Leave(KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2579
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2580
	return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2581
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2582
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2583
void CMMFDevSoundSession::Panic(TMMFDevSoundSessionPanicCodes aCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2584
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2585
    User::Panic(KMMFDevSoundSessionPanicCategory, aCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2586
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2587
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2588
void CMMFDevSoundSession::BufferErrorEvent()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2589
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2590
	// this will generate an processing error event and callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2591
	iAdapter->BufferErrorEvent();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2592
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2593
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2594
void CMMFDevSoundSession::FlushQueuedRequests()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2595
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2596
    for (TInt queueIndex = (iQueuedRequests.Count() - 1); queueIndex >= 0; --queueIndex)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2597
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2598
        if ((iQueuedRequests[queueIndex].Type() == TMMFDevSoundRequest::ESessionEvents) && 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2599
                (iQueuedRequests[queueIndex].Function() == RMessage2::EDisConnect))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2600
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2601
            continue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2602
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2603
        iQueuedRequests.Remove(queueIndex);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2604
        }    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2605
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2606
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2607
TInt CMMFDevSoundSession::MessageRead(const RMmfIpcMessage& aMessage, TInt aParam, TDes8& aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2608
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2609
    if (!iDisconnecting)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2610
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2611
        return MmfMessageUtil::Read(aMessage, aParam, aResult);    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2612
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2613
    return KErrBadHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2614
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2615
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2616
TInt CMMFDevSoundSession::MessageRead(const RMmfIpcMessage& aMessage, TInt aParam, TDes16& aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2617
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2618
    if (!iDisconnecting)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2619
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2620
        return aMessage.Read(aParam, aResult);    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2621
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2622
    return KErrBadHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2623
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2624
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2625
TInt CMMFDevSoundSession::MessageWrite(const RMmfIpcMessage& aMessage, TInt aParam, const TDesC8& aValue)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2626
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2627
    if (!iDisconnecting)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2628
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2629
        return MmfMessageUtil::Write(aMessage, aParam, aValue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2630
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2631
    return KErrBadHandle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2632
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2633
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2634
void CMMFDevSoundSession::ResetNotifiedError()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2635
// called at beginning of commit cycle, so any error will be from callbacks
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2636
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2637
    SYMBIAN_DEBPRN0(_L("CMMFDevSoundSession[0x%x]::ResetNotifiedError"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2638
    iNotifiedError = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2639
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2640
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2641
TInt CMMFDevSoundSession::NotifiedError() const
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2642
// NotifiedError property
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2643
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2644
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::NotifiedError(%d)"), iNotifiedError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2645
    return iNotifiedError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2646
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2647
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2648
void CMMFDevSoundSession::NotifyError(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2649
// cache notified error
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2650
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2651
    SYMBIAN_DEBPRN1(_L("CMMFDevSoundSession[0x%x]::NotifyError(%d)"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2652
    iNotifiedError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2653
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2654
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2655
// End of file