mmdevicefw/mdfunittest/codecapi/audio/src/tsu_mdf_audiocodecs_resolver.cpp
author hgs
Fri, 08 Oct 2010 19:40:43 +0100
changeset 0 79dd3e2336a0
permissions -rw-r--r--
2010wk36_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     2
// All rights reserved.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     7
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    10
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    11
// Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    12
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    13
// Description:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    14
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    15
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    16
#include "tsu_mdf_audiocodecs_resolver.h"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    17
#include <openmax/il/khronos/v1_x/OMX_Core.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    18
#include <mmf/server/mmfhwdevicesetup.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    19
#include <mdf/codecapiresolverdata.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    20
#include <mdf/codecapiuids.hrh>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    21
#include <mmf/server/mmfhwdevicesetup.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    22
#include <mmf/common/mmffourcc.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    23
#include <mdf/codecapiresolverutils.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    24
#include <mdf/codecapivideoresolverutils.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    25
#include <mdf/codecapiresolverutils.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    26
#include <mmf/devvideo/devvideoplay.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    27
#include <mm/mmcleanup.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    28
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    29
const TInt  KPicSizeX  = 320;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    30
const TInt  KPicSizeY  = 200;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    31
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    32
const TReal KPicRate  = 100;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    33
const TInt  KPicWidth = 20;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    34
const TInt  KPicHeight = 4000;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    35
_LIT8(KTextManufactor, "Manufacturer");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    36
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    37
// *********************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    38
// Loads a PU using the FourCC and using the Custom Resolver 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    39
// *********************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    40
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    41
RTestStepAudioCodecLoadFourCC::RTestStepAudioCodecLoadFourCC()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    42
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    43
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0004");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    44
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    45
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    46
TVerdict RTestStepAudioCodecLoadFourCC::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    47
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    48
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    49
	TFourCC aSrcDataType, aDestDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    50
	INFO_PRINTF1(_L("Test loading two PU using 2 FourCCs"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    51
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    52
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    53
	customMatchData->SetMatchType(EMatchInputAndOutputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    54
	customMatchData->SetImplementationType(TUid::Uid(0x1027379e));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    55
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    56
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    57
	TPtr8 sourceData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    58
	TFourCC srcDataType = KMMFFourCCCodeTestPCM8;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    59
	srcDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    60
	customMatchData->SetInputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    61
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    62
	TFourCC destDataType = KMMFFourCCCodePCM16;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    63
	destDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    64
	customMatchData->SetOutputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    65
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    66
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    67
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    68
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    69
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    70
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    71
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    72
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    73
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    74
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(KUidMdfProcessingUnit), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    75
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    76
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    77
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    78
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    79
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    80
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    81
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    82
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    83
	// verify if the resolver found any PUs 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    84
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    85
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    86
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    87
		INFO_PRINTF1(_L("PU Resolver did not find any PU with these data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    88
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    89
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    90
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    91
	// verify if one of the PUs found is what we are looking for
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    92
	for(TInt index = 0; index < noOfProcessingUnits; index++)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    93
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    94
		TUid uid = ecomArray[index]->ImplementationUid();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    95
		CCodecApiOpaqueData* parse = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    96
		const TDesC8* opaqueData = &(ecomArray[index]->OpaqueData());
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    97
		// if opaque data is empty, move to the next element in the list
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    98
		if (opaqueData->Length() == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    99
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   100
			INFO_PRINTF1(_L("PU Resolver returned a PU with empty opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   101
			return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   102
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   103
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   104
		TRAPD(error, parse = CCodecApiOpaqueData::NewL(*opaqueData));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   105
		if (error!=KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   106
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   107
			if (error==KErrNotSupported)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   108
				{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   109
				// means that the resource entry was not valid
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   110
				INFO_PRINTF1(_L("PU Resolver returned a PU with invalid opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   111
				return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   112
				}				
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   113
			}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   114
		CleanupStack::PushL(parse);	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   115
		HBufC8* inputDataFormat 		= customMatchData->InputDataFormat().AllocLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   116
		HBufC8* outputDataFormat		= customMatchData->OutputDataFormat().AllocLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   117
		if(!parse->CompareInputDataType(*inputDataFormat) 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   118
			&& !parse->CompareOutputDataType(*outputDataFormat))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   119
			{	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   120
			INFO_PRINTF1(_L("PU Resolver returned a PU with a different input and output data type"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   121
			return EFail;			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   122
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   123
		CleanupStack::PopAndDestroy(3);		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   124
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   125
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   126
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   127
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   128
	__UHEAP_MARKEND;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   129
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   130
	INFO_PRINTF1(_L("PU Resolver returned the correct PU"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   131
	return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   132
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   133
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   134
// ***************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   135
// Finds a PU using the FourCC and Custom Resolver with P8 src 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   136
// ***************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   137
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   138
RTestStepAudioCodecFindP8InputFourCC::RTestStepAudioCodecFindP8InputFourCC()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   139
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   140
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0005");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   141
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   142
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   143
TVerdict RTestStepAudioCodecFindP8InputFourCC::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   144
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   145
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   146
	TFourCC aSrcDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   147
	INFO_PRINTF1(_L("Test locates the PU using just the source data type (P8) and the version"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   148
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   149
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   150
	customMatchData->SetMatchType(EMatchInputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   151
	customMatchData->SetImplementationType(TUid::Uid(0x1027379e));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   152
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   153
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   154
	TPtr8 sourceData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   155
	TFourCC srcDataType = KMMFFourCCCodeTestPCM8;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   156
	srcDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   157
	customMatchData->SetInputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   158
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   159
	// Not setting destination type
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   160
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   161
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   162
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   163
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   164
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   165
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   166
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   167
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   168
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(KUidMdfProcessingUnit), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   169
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   170
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   171
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   172
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   173
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   174
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   175
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   176
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   177
	// check if there are any 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   178
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   179
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   180
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   181
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   182
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   183
		// verify if one of the PUs found is what we are looking for
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   184
	for(TInt index = 0; index < noOfProcessingUnits; index++)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   185
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   186
		TUid uid = ecomArray[index]->ImplementationUid();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   187
		CCodecApiOpaqueData* parse = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   188
		const TDesC8* opaqueData = &(ecomArray[index]->OpaqueData());
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   189
		// if opaque data is empty, move to the next element in the list
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   190
		if (opaqueData->Length() == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   191
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   192
			INFO_PRINTF1(_L("PU Resolver returned a PU with empty opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   193
			return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   194
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   195
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   196
		TRAPD(error, parse = CCodecApiOpaqueData::NewL(*opaqueData));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   197
		if (error!=KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   198
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   199
			if (error==KErrNotSupported)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   200
				{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   201
				// means that the resource entry was not valid
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   202
				INFO_PRINTF1(_L("PU Resolver returned a PU with invalid opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   203
				return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   204
				}				
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   205
			}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   206
		CleanupStack::PushL(parse);	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   207
		HBufC8* inputDataFormat 		= customMatchData->InputDataFormat().AllocLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   208
		if(!parse->CompareInputDataType(*inputDataFormat) )
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   209
			{	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   210
			INFO_PRINTF1(_L("PU Resolver returned a PU with a different input data type"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   211
			return EFail;			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   212
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   213
		CleanupStack::PopAndDestroy(2);		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   214
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   215
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   216
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   217
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   218
	__UHEAP_MARKEND;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   219
	INFO_PRINTF1(_L("The resolver located correctly the PU using just the source data type (P8) and the version"));	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   220
	return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   221
	}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   222
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   223
// ********************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   224
// Finds a PU using the FourCC and using the Custom Resolver with PU8 destination 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   225
// ********************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   226
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   227
RTestStepAudioCodecFindPU8OutputFourCC::RTestStepAudioCodecFindPU8OutputFourCC()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   228
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   229
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0006");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   230
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   231
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   232
TVerdict RTestStepAudioCodecFindPU8OutputFourCC::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   233
	{	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   234
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   235
	TFourCC aDestDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   236
	INFO_PRINTF1(_L("Test locates the PU using just the destination data type (PU8) and the version"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   237
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   238
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   239
	customMatchData->SetMatchType(EMatchOutputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   240
	customMatchData->SetImplementationType(TUid::Uid(0x1027379e));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   241
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   242
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   243
	TPtr8 destData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   244
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   245
	// Not setting source type
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   246
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   247
	TFourCC destDataType = KMMFFourCCCodeTestPCMU8;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   248
	destDataType.FourCC(&destData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   249
	customMatchData->SetOutputDataL(destData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   250
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   251
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   252
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   253
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   254
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   255
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   256
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   257
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   258
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   259
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(KUidMdfProcessingUnit), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   260
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   261
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   262
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   263
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   264
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   265
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   266
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   267
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   268
	// check if there are any 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   269
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   270
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   271
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   272
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   273
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   274
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   275
	// verify if one of the PUs found is what we are looking for
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   276
	for(TInt index = 0; index < noOfProcessingUnits; index++)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   277
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   278
		TUid uid = ecomArray[index]->ImplementationUid();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   279
		CCodecApiOpaqueData* parse = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   280
		const TDesC8* opaqueData = &(ecomArray[index]->OpaqueData());
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   281
		// if opaque data is empty, move to the next element in the list
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   282
		if (opaqueData->Length() == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   283
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   284
			INFO_PRINTF1(_L("PU Resolver returned a PU with empty opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   285
			return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   286
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   287
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   288
		TRAPD(error, parse = CCodecApiOpaqueData::NewL(*opaqueData));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   289
		if (error!=KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   290
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   291
			if (error==KErrNotSupported)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   292
				{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   293
				// means that the resource entry was not valid
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   294
				INFO_PRINTF1(_L("PU Resolver returned a PU with invalid opaque data"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   295
				return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   296
				}				
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   297
			}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   298
		CleanupStack::PushL(parse);	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   299
		HBufC8* outputDataFormat = customMatchData->OutputDataFormat().AllocLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   300
		if(!parse->CompareOutputDataType(*outputDataFormat))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   301
			{	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   302
			INFO_PRINTF1(_L("PU Resolver returned a PU with a different output data type"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   303
			return EFail;			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   304
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   305
		CleanupStack::PopAndDestroy(2);		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   306
		}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   307
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   308
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   309
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   310
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   311
	__UHEAP_MARKEND;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   312
	INFO_PRINTF1(_L("The resolver located the PU using just the destination data type (PU8) and the version"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   313
	return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   314
	}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   315
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   316
// **************************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   317
// Attempts to find a PU using the FourCC and Custom Resolver with correct version but incorrect src
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   318
// **************************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   319
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   320
RTestStepAudioCodecFindIncorrectInputFourCC::RTestStepAudioCodecFindIncorrectInputFourCC()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   321
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   322
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0008");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   323
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   324
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   325
TVerdict RTestStepAudioCodecFindIncorrectInputFourCC::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   326
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   327
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   328
	TFourCC aSrcDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   329
	INFO_PRINTF1(_L("Test attempts to locate the PU using the correct version, but incorrect source data type"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   330
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   331
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   332
	customMatchData->SetMatchType(EMatchInputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   333
	customMatchData->SetImplementationType(TUid::Uid(0x1027379e));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   334
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   335
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   336
	TPtr8 sourceData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   337
	TFourCC srcDataType = KMMFFourCCCodeNULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   338
	srcDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   339
	customMatchData->SetInputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   340
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   341
	// Not setting destination type
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   342
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   343
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   344
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   345
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   346
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   347
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   348
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   349
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   350
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   351
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(KUidMdfProcessingUnit), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   352
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   353
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   354
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   355
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   356
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   357
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   358
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   359
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   360
	// check if there are any 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   361
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   362
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   363
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   364
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   365
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   366
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   367
		// Should be zero, since no implementations of type KCMdfProcessingUnit can deal with KMMFFourCCCodeNULL
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   368
		return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   369
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   370
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   371
	return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   372
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   373
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   374
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   375
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   376
// Attempts to find a PU using the FourCC and Custom Resolver with the correct interface UID,
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   377
// but incorrect implementation UID.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   378
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   379
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   380
RTestStepAudioCodecFindIncorrectImpUid::RTestStepAudioCodecFindIncorrectImpUid()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   381
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   382
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0009");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   383
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   384
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   385
TVerdict RTestStepAudioCodecFindIncorrectImpUid::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   386
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   387
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   388
	TFourCC aSrcDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   389
	INFO_PRINTF1(_L("Test attempts to locate the PU  with the correct interface UID, but incorrect implementation UID."));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   390
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   391
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   392
	customMatchData->SetMatchType(EMatchInputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   393
	// Set implementation interface as incorrect - from KUidMediaTypeAudio
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   394
	customMatchData->SetImplementationType(TUid::Uid(0x101f5d07));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   395
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   396
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   397
	TPtr8 sourceData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   398
	TFourCC srcDataType = KMMFFourCCCodeTestPCM8;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   399
	srcDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   400
	customMatchData->SetInputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   401
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   402
	TFourCC destDataType = KMMFFourCCCodePCM16;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   403
	destDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   404
	customMatchData->SetOutputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   405
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   406
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   407
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   408
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   409
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   410
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   411
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   412
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   413
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   414
	// Interface Uid is correct
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   415
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(KUidMdfProcessingUnit), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   416
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   417
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   418
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   419
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   420
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   421
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   422
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   423
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   424
	// check if there are any 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   425
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   426
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   427
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   428
	__UHEAP_MARKEND;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   429
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   430
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   431
		// Should be zero, since no implementations
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   432
		return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   433
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   434
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   435
	return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   436
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   437
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   438
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   439
// Attempts to find a PU using the FourCC and Custom Resolver with the correct implementation
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   440
// UID, but incorrect interface UID.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   441
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   442
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   443
RTestStepAudioCodecFindIncorrectInterfaceUid::RTestStepAudioCodecFindIncorrectInterfaceUid()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   444
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   445
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0010");	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   446
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   447
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   448
TVerdict RTestStepAudioCodecFindIncorrectInterfaceUid::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   449
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   450
	__UHEAP_MARK;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   451
	TFourCC aSrcDataType;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   452
	INFO_PRINTF1(_L("Test attempts to locate the PU  with the correct interface UID, but incorrect implementation UID."));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   453
	// create the OMX Core
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   454
	CCodecApiResolverData* customMatchData = CCodecApiResolverData::NewLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   455
	customMatchData->SetMatchType(EMatchInputDataFormat);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   456
	// Set implementation interface as correct
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   457
	customMatchData->SetImplementationType(TUid::Uid(0x1027379e));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   458
	// string value of the input source data	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   459
	HBufC8* packageData = HBufC8::NewLC(KMaxDataTypeLength);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   460
	TPtr8 sourceData = packageData->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   461
	TFourCC srcDataType = KMMFFourCCCodeTestPCM8;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   462
	srcDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   463
	customMatchData->SetInputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   464
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   465
	TFourCC destDataType = KMMFFourCCCodePCM16;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   466
	destDataType.FourCC(&sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   467
	customMatchData->SetOutputDataL(sourceData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   468
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   469
 	HBufC8* package  = customMatchData->NewPackLC();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   470
	TPtr8 packageDes = package->Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   471
	TEComResolverParams resolverParams; // Parameters on which to match
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   472
	resolverParams.SetDataType(packageDes);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   473
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   474
	RImplInfoPtrArray ecomArray;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   475
	CleanupResetAndDestroyPushL(ecomArray);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   476
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   477
	// Interface Uid is incorrect - from KMmfUidPluginInterfaceDataSource			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   478
	TRAPD(error, REComSession::ListImplementationsL(TUid::Uid(0x101F53AF), 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   479
		  resolverParams, TUid::Uid(0x1027379b), ecomArray));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   480
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   481
	if (error != KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   482
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   483
		CleanupStack::PopAndDestroy(3); // customMatchData, packageData, package	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   484
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   485
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   486
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   487
	// check if there are any 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   488
	TInt noOfProcessingUnits = ecomArray.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   489
	CleanupStack::PopAndDestroy(4); // customMatchData, packageData, package, ecomArray		  
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   490
	REComSession::FinalClose();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   491
	__UHEAP_MARKEND;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   492
	if(noOfProcessingUnits == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   493
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   494
		// Should be zero, since no implementations
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   495
		return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   496
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   497
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   498
	return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   499
	}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   500
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   501
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   502
RTestStepVideoResolverUtils::RTestStepVideoResolverUtils()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   503
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   504
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0011");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   505
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   506
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   507
TVerdict RTestStepVideoResolverUtils::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   508
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   509
	INFO_PRINTF1(_L("Tests the video resolver utility "));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   510
	_LIT8(KText, "<m>Manufacturer<p>320,200<l>100,20,4000");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   511
	TBufC8<50> data(KText);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   512
	TPtr8 ptrData = data.Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   513
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   514
	CCodecApiVideoOpaqueData* codecApiVideoOpaqueData = CCodecApiVideoOpaqueData::NewLC(ptrData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   515
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   516
	// verify the picture size
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   517
	TSize picSize = codecApiVideoOpaqueData->MaxPictureSize();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   518
	if (picSize.iWidth != KPicSizeX &&
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   519
		picSize.iHeight != KPicSizeY)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   520
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   521
		INFO_PRINTF1(_L("Incorrect picture size"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   522
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   523
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   524
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   525
	RArray<TPictureRateAndSize> pictureRateAndSize = codecApiVideoOpaqueData->MaxPictureRates();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   526
	TUint arraySize = pictureRateAndSize.Count();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   527
	if (arraySize == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   528
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   529
		INFO_PRINTF1(_L("No picture rate and size extracted from the opaque data"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   530
		CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   531
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   532
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   533
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   534
	INFO_PRINTF2(_L("No picture rate and size extracted from the opaque data, %d"), pictureRateAndSize[0].iPictureRate);	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   535
	if (pictureRateAndSize[0].iPictureRate != KPicRate)	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   536
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   537
		INFO_PRINTF1(_L("Incorrect picture rate"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   538
		CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   539
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   540
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   541
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   542
	if (pictureRateAndSize[0].iPictureSize.iWidth != KPicWidth)	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   543
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   544
		INFO_PRINTF1(_L("Incorrect picture width"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   545
		CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   546
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   547
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   548
			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   549
	if (pictureRateAndSize[0].iPictureSize.iHeight != KPicHeight)	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   550
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   551
		INFO_PRINTF1(_L("Incorrect picture heigh"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   552
		CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   553
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   554
		}		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   555
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   556
	TDesC8 manufacturer = codecApiVideoOpaqueData->Manufacturer();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   557
	if(manufacturer.Compare(KTextManufactor) == 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   558
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   559
		INFO_PRINTF1(_L("Incorrect manufacturer"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   560
		CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   561
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   562
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   563
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   564
	CleanupStack::PopAndDestroy(codecApiVideoOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   565
	return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   566
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   567
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   568
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   569
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   570
// Attempts to find a PU using the FourCC and Custom Resolver with the correct implementation
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   571
// UID, but incorrect interface UID.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   572
// *******************************************************************************************
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   573
RTestStepResolverUtils::RTestStepResolverUtils()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   574
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   575
	iTestStepName = _L("MM-MDF-AUDIOCODECS-0012");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   576
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   577
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   578
TVerdict RTestStepResolverUtils::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   579
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   580
	INFO_PRINTF1(_L("Tests the video resolver utility "));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   581
	_LIT8(KText, "<s>");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   582
	TBufC8<50> data(KText);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   583
	TPtr8 ptrData = data.Des();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   584
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   585
	CCodecApiOpaqueData* codecApiOpaqueData = CCodecApiOpaqueData::NewLC(ptrData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   586
	const TDesC8 inputData = codecApiOpaqueData->InputDataType();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   587
	if (inputData.CompareF(KNullDesC8) != 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   588
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   589
		INFO_PRINTF1(_L("Incorrect manufacturer"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   590
		CleanupStack::PopAndDestroy(codecApiOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   591
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   592
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   593
		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   594
	const TDesC8 outputData = codecApiOpaqueData->OutputDataType();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   595
	if (outputData.CompareF(KNullDesC8) != 0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   596
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   597
		INFO_PRINTF1(_L("Incorrect manufacturer"));		
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   598
		CleanupStack::PopAndDestroy(codecApiOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   599
		return EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   600
		}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   601
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   602
	CleanupStack::PopAndDestroy(codecApiOpaqueData);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   603
	return EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   604
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   605