os/mm/mmlibs/mmfw/Codecs/Src/MMFCodecCommon/MMFAudioMuLawToS16PcmCodec.cpp
changeset 0 bde4ae8d615e
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/os/mm/mmlibs/mmfw/Codecs/Src/MMFCodecCommon/MMFAudioMuLawToS16PcmCodec.cpp	Fri Jun 15 03:10:57 2012 +0200
     1.3 @@ -0,0 +1,63 @@
     1.4 +// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
     1.5 +// All rights reserved.
     1.6 +// This component and the accompanying materials are made available
     1.7 +// under the terms of "Eclipse Public License v1.0"
     1.8 +// which accompanies this distribution, and is available
     1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
    1.10 +//
    1.11 +// Initial Contributors:
    1.12 +// Nokia Corporation - initial contribution.
    1.13 +//
    1.14 +// Contributors:
    1.15 +//
    1.16 +// Description:
    1.17 +//
    1.18 +
    1.19 +#include "MMFAudioMuLawToS16PcmCodec.h"
    1.20 +
    1.21 +/***
    1.22 +*
    1.23 +* Convert
    1.24 +*
    1.25 +*/
    1.26 +EXPORT_C void TMMFAudioMuLawToS16PcmCodec::Convert(TUint8* aSrc, TUint8* aDst, TInt aSamples)
    1.27 +	{
    1.28 +	ASSERT(aSrc);
    1.29 +	ASSERT(aDst);
    1.30 +	
    1.31 +	TInt pcm;
    1.32 +	while (aSamples--)
    1.33 +		{
    1.34 +		pcm = MulawSampleToPcm(*aSrc++);
    1.35 +		*aDst++ = STATIC_CAST( TUint8, pcm&KAndMask8bit);
    1.36 +		*aDst++ = STATIC_CAST( TUint8, pcm>>8);
    1.37 +		}
    1.38 +	
    1.39 +	}
    1.40 +
    1.41 +/***
    1.42 +*
    1.43 +* MulawSampleToPcm
    1.44 +* @param aMuLaw
    1.45 +* @return TInt
    1.46 +*
    1.47 +*/
    1.48 +TInt TMMFAudioMuLawToS16PcmCodec::MulawSampleToPcm(TUint8 aMulaw)
    1.49 +	{
    1.50 +	TInt sign, exponent, mantissa, sample;
    1.51 +	
    1.52 +    aMulaw = STATIC_CAST( TUint8, ~aMulaw);
    1.53 +    sign = ( aMulaw & KMaskSign8bit );
    1.54 +    exponent = ( aMulaw >> 4 ) & 0x07;
    1.55 +    mantissa = aMulaw & 0x0F;
    1.56 +    sample = KExpLut[exponent] + ( mantissa << ( exponent + 3 ) );
    1.57 +    if ( sign != 0 )
    1.58 +		sample = -sample;
    1.59 +	
    1.60 +    return sample;
    1.61 +	}
    1.62 +
    1.63 +const TInt TMMFAudioMuLawToS16PcmCodec::KExpLut[KMdaMulawTo16PcmExpLutSize] = 
    1.64 +	{
    1.65 +	0, 132, 396, 924, 1980, 4092, 8316, 16764
    1.66 +	};