os/mm/devsound/sounddevbt/src/swcodecwrapper/mmfBtSwCodecDataPath.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// source\server\MmfBtSwCodecDatapath.cpp
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include "mmfBtSwCodecDataPath.h"
sl@0
    19
sl@0
    20
CMMFSwCodecDataPath::~CMMFSwCodecDataPath()
sl@0
    21
	{
sl@0
    22
	}
sl@0
    23
sl@0
    24
/*
sl@0
    25
 * CycleAudioBufferL
sl@0
    26
 *
sl@0
    27
 * Sets up a usable buffer for passing to MMF
sl@0
    28
 *	
sl@0
    29
 * This method has been written such that it must allocate a new buffer before
sl@0
    30
 * replacing the existing one. The purpose of this is to force creation of a 
sl@0
    31
 * new buffer. Simply deleting and then re-allocing may result in the same 
sl@0
    32
 * address being used.
sl@0
    33
 * 
sl@0
    34
 * Only cycles if there is enough memory
sl@0
    35
 *
sl@0
    36
 */
sl@0
    37
#ifdef __CYCLE_MMF_DATABUFFERS__
sl@0
    38
CMMFDataBuffer* CMMFSwCodecDataPath::CycleAudioBuffer(CMMFDataBuffer* aBuffer)
sl@0
    39
	{
sl@0
    40
	CMMFDataBuffer* buffer = NULL;
sl@0
    41
	TUint bufferSize = aBuffer->Data().MaxLength();
sl@0
    42
sl@0
    43
#ifdef __USE_MMF_TRANSFERBUFFERS__
sl@0
    44
	TRAPD(err, buffer = CreateTransferBufferL(bufferSize, static_cast<CMMFTransferBuffer*>(aBuffer)));
sl@0
    45
#else
sl@0
    46
	TRAPD(err,buffer = CMMFDataBuffer::NewL(bufferSize));
sl@0
    47
sl@0
    48
	if (err == KErrNone)
sl@0
    49
		{
sl@0
    50
		delete aBuffer;
sl@0
    51
		}
sl@0
    52
#endif
sl@0
    53
	if (err != KErrNone)
sl@0
    54
		{//there was a problem creating buffer eg OOM so use same buffer
sl@0
    55
		buffer = aBuffer;
sl@0
    56
		}
sl@0
    57
sl@0
    58
	return buffer;
sl@0
    59
sl@0
    60
	}
sl@0
    61
#endif
sl@0
    62
sl@0
    63
/*
sl@0
    64
 * DoCleanupRHandleBase
sl@0
    65
 *
sl@0
    66
 * This method will initially Close the handle and then delete it.
sl@0
    67
 *
sl@0
    68
 */
sl@0
    69
#ifdef __USE_MMF_TRANSFERBUFFERS__
sl@0
    70
inline static void DoCleanupRHandleBase(TAny* aRHandleBase)
sl@0
    71
	{
sl@0
    72
	ASSERT(aRHandleBase);
sl@0
    73
	RHandleBase* rHandleBase = STATIC_CAST(RHandleBase*, aRHandleBase);
sl@0
    74
	TRAPD(error, rHandleBase->Close());
sl@0
    75
	delete aRHandleBase;
sl@0
    76
	}
sl@0
    77
sl@0
    78
CMMFTransferBuffer* CMMFSwCodecDataPath::CreateTransferBufferL(TUint aBufferSize, CMMFTransferBuffer* aOldBuffer)
sl@0
    79
	{
sl@0
    80
	CMMFTransferBuffer* buffer = NULL;
sl@0
    81
sl@0
    82
	RTransferBuffer* transBuffer = new  (ELeave) RTransferBuffer;
sl@0
    83
	
sl@0
    84
	TCleanupItem bufferCleanupItem(DoCleanupRHandleBase, transBuffer); //closes and deletes.
sl@0
    85
	CleanupStack::PushL(bufferCleanupItem);
sl@0
    86
sl@0
    87
	RTransferWindow* transWindow = new (ELeave) RTransferWindow;
sl@0
    88
	
sl@0
    89
	TCleanupItem windowCleanupItem(DoCleanupRHandleBase, transWindow); //closes and deletes.
sl@0
    90
	CleanupStack::PushL(windowCleanupItem);
sl@0
    91
sl@0
    92
	User::LeaveIfError(transBuffer->Create(aBufferSize));
sl@0
    93
	User::LeaveIfError(transWindow->Create(aBufferSize));
sl@0
    94
	User::LeaveIfError(transWindow->MapInBuffer(*transBuffer));
sl@0
    95
sl@0
    96
	buffer = CMMFTransferBuffer::NewL(*transWindow);
sl@0
    97
sl@0
    98
	delete aOldBuffer; //closes RTransferWindow
sl@0
    99
	delete iTransferWindow;
sl@0
   100
sl@0
   101
	if(iTransferBuffer)
sl@0
   102
		{
sl@0
   103
		iTransferBuffer->Close();
sl@0
   104
		}
sl@0
   105
	delete iTransferBuffer;
sl@0
   106
sl@0
   107
	iTransferBuffer = transBuffer;
sl@0
   108
	iTransferWindow = transWindow;
sl@0
   109
sl@0
   110
	CleanupStack::Pop(transWindow); 
sl@0
   111
	CleanupStack::Pop(transBuffer); 
sl@0
   112
sl@0
   113
	return buffer;
sl@0
   114
	}
sl@0
   115
#endif
sl@0
   116
sl@0
   117
sl@0
   118
#ifdef __USE_MMF_PTRBUFFERS__
sl@0
   119
CMMFPtrBuffer* CMMFSwCodecDataPath::CreatePtrBufferL(TUint aBufferSize)
sl@0
   120
	{
sl@0
   121
	CMMFPtrBuffer* buffer = NULL;
sl@0
   122
	if (iPtrBufferMemoryBlock)
sl@0
   123
		delete iPtrBufferMemoryBlock;//incase already exisits
sl@0
   124
	iPtrBufferMemoryBlock = HBufC8::NewL(aBufferSize);
sl@0
   125
	TPtr8 ptrMemoryBlock(iPtrBufferMemoryBlock->Des());
sl@0
   126
	buffer = CMMFPtrBuffer::NewL(ptrMemoryBlock);
sl@0
   127
	return buffer;
sl@0
   128
	}
sl@0
   129
#endif  // __USE_MMF_PTRBUFFERS__
sl@0
   130
sl@0
   131