C++程序  |  158行  |  7.51 KB

/*----------------------------------------------------------------------------
 *
 * File:
 * eas_pcmdata.h
 *
 * Contents and purpose:
 * Data declarations for the PCM engine
 *
 *
 * Copyright Sonic Network Inc. 2005

 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 *----------------------------------------------------------------------------
 * Revision Control:
 *   $Revision: 847 $
 *   $Date: 2007-08-27 21:30:08 -0700 (Mon, 27 Aug 2007) $
 *----------------------------------------------------------------------------
*/

#ifndef _EAS_PCMDATA_H
#define _EAS_PCMDATA_H

/* sets the maximum number of simultaneous PCM streams */
#ifndef MAX_PCM_STREAMS
#define MAX_PCM_STREAMS             16
#define PCM_STREAM_THRESHOLD        (MAX_PCM_STREAMS - 4)
#endif

/* coefficents for high-pass filter in ADPCM */
#define INTEGRATOR_COEFFICIENT      100     /* coefficient for leaky integrator */

/* additional flags in S_PCM_STATE.flags used internal to module */
#define PCM_FLAGS_EMPTY             0x01000000  /* unsigned format */

/*----------------------------------------------------------------------------
 * S_PCM_STATE
 *
 * Retains state information for PCM streams.
 *----------------------------------------------------------------------------
*/
typedef struct s_decoder_state_tag
{
    EAS_I32             output;             /* last output for DC offset filter */
    EAS_I32             acc;                /* accumulator for DC offset filter */
    EAS_I32             step;               /* current ADPCM step size */
    EAS_PCM             x1;                 /* current generated sample */
    EAS_PCM             x0;                 /* previous generated sample */
} S_DECODER_STATE;

typedef enum
{
    PCM_ENV_START = 0,
    PCM_ENV_ATTACK,
    PCM_ENV_DECAY,
    PCM_ENV_SUSTAIN,
    PCM_ENV_RELEASE,
    PCM_ENV_END
} E_PCM_ENV_STATE;

typedef struct s_pcm_state_tag
{
#ifdef _CHECKED_BUILD
    EAS_U32             handleCheck;        /* signature check for checked build */
#endif
    EAS_FILE_HANDLE     fileHandle;         /* pointer to input file */
    EAS_PCM_CALLBACK    pCallback;          /* pointer to callback function */
    EAS_VOID_PTR        cbInstData;         /* instance data for callback function */
    struct s_decoder_interface_tag EAS_CONST * pDecoder;    /* pointer to decoder interface */
    EAS_STATE           state;              /* stream state */
    EAS_I32             time;               /* media time */
    EAS_I32             startPos;           /* start of PCM stream */
    EAS_I32             loopLocation;       /* file location where loop starts */
    EAS_I32             byteCount;          /* size of file */
    EAS_U32             loopStart;          /* loop start, offset in samples from startPos */
                                            /* NOTE: For CMF, we use this to store total sample size */
    EAS_U32             loopSamples;        /* total loop length, in samples, 0 means no loop */
                                            /* NOTE: For CMF, non-zero means looped */
    EAS_U32             samplesInLoop;      /* samples left in the loop to play back */
    EAS_I32             samplesTilLoop;     /* samples left to play until top of loop */
    EAS_I32             bytesLeft;          /* count of bytes left in stream */
    EAS_I32             bytesLeftLoop;      /* count of bytes left in stream, value at start of loop */
    EAS_U32             phase;              /* current phase for interpolator */
    EAS_U32             basefreq;           /* frequency multiplier */
    EAS_U32             flags;              /* stream flags */
    EAS_U32             envData;            /* envelope data (and LFO data) */
    EAS_U32             envValue;           /* current envelope value */
    EAS_U32             envScale;           /* current envelope scale */
    EAS_U32             startOrder;         /* start order index, first is 0, next is 1, etc. */
    S_DECODER_STATE     decoderL;           /* left (mono) ADPCM state */
    S_DECODER_STATE     decoderR;           /* right ADPCM state */
    S_DECODER_STATE     decoderLLoop;       /* left (mono) ADPCM state, value at start of loop */
    S_DECODER_STATE     decoderRLoop;       /* right ADPCM state, value at start of loop */
    E_PCM_ENV_STATE     envState;           /* current envelope state */
    EAS_I16             volume;             /* volume for stream */
    EAS_I16             pitch;              /* relative pitch in cents - zero is unity playback */
    EAS_I16             gainLeft;           /* requested gain */
    EAS_I16             gainRight;          /* requested gain */
    EAS_I16             currentGainLeft;    /* current gain for anti-zipper filter */
    EAS_I16             currentGainRight;   /* current gain for anti-zipper filter */
    EAS_U16             blockSize;          /* block size for ADPCM decoder */
    EAS_U16             blockCount;         /* block counter for ADPCM decoder */
    EAS_U16             sampleRate;         /* input sample rate */
    EAS_U8              srcByte;            /* source byte */
    EAS_U8              msBitCount;         /* count keeps track of MS bits */
    EAS_U8              msBitMask;          /* mask keeps track of MS bits */
    EAS_U8              msBitValue;         /* value keeps track of MS bits */
    EAS_U8              msBitCountLoop;     /* count keeps track of MS bits, value at loop start */
    EAS_U8              msBitMaskLoop;      /* mask keeps track of MS bits, value at loop start */
    EAS_U8              msBitValueLoop;     /* value keeps track of MS bits, value at loop start */
    EAS_BOOL8           hiNibble;           /* indicates high/low nibble is next */
    EAS_BOOL8           hiNibbleLoop;       /* indicates high/low nibble is next, value loop start */
    EAS_U8              rateShift;          /* for playback rate greater than 1.0 */
} S_PCM_STATE;

/*----------------------------------------------------------------------------
 * S_DECODER_INTERFACE
 *
 * Generic interface for audio decoders
 *----------------------------------------------------------------------------
*/
typedef struct s_decoder_interface_tag
{
    EAS_RESULT (* EAS_CONST pfInit)(EAS_DATA_HANDLE pEASData, S_PCM_STATE *pState);
    EAS_RESULT (* EAS_CONST pfDecodeSample)(EAS_DATA_HANDLE pEASData, S_PCM_STATE *pState);
    EAS_RESULT (* EAS_CONST pfLocate)(EAS_DATA_HANDLE pEASData, S_PCM_STATE *pState, EAS_I32 time);
} S_DECODER_INTERFACE;


/* header chunk for SMAF ADPCM */
#define TAG_YAMAHA_ADPCM    0x4d776100
#define TAG_MASK            0xffffff00
#define TAG_RIFF_FILE       0x52494646
#define TAG_WAVE_CHUNK      0x57415645
#define TAG_FMT_CHUNK       0x666d7420

/*----------------------------------------------------------------------------
 * EAS_PESeek
 *----------------------------------------------------------------------------
 * Purpose:
 * Locate to a particular byte in a PCM stream
 *----------------------------------------------------------------------------
*/
EAS_RESULT EAS_PESeek (EAS_DATA_HANDLE pEASData, S_PCM_STATE *pState, EAS_I32 *pLocation);

#endif /* _EAS_PCMDATA_H */