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 + };