/*----------------------------------------------------------------------------
 *
 * File:
 * eas_wt_IPC_frame.h
 *
 * Contents and purpose:
 * This module contains data definitions for the interprocessor
 * communications framework for a split-architecture synthesizer.
 *
 * This sample version writes IPC data to a file that can be used
 * as a test vector for the DSP simulator. For a real-time system
 * the file I/O is replaced with an IPC protocol in the hardware.
 *
 * Synchronization with the DSP is accomplished at the API level,
 * i.e. the host code should call EAS_Render when it is ready to
 * buffer another block of data for transmission to the DSP.
 *
 * 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: 818 $
 *   $Date: 2007-08-02 15:19:41 -0700 (Thu, 02 Aug 2007) $
 *----------------------------------------------------------------------------
*/

#ifndef _EAS_WT_IPC_FRAME_H
#define _EAS_WT_IPC_FRAME_H

/*----------------------------------------------------------------------------
 * S_WT_FRAME
 *
 * This structure contains the common parameters that are updated
  *for each frame of audio.
 *----------------------------------------------------------------------------
*/
typedef struct s_wt_frame_tag
{
    EAS_I32         gainTarget;
    EAS_I32         phaseIncrement;

#if defined(_FILTER_ENABLED)
    EAS_I32         k;
    EAS_I32         b1;
    EAS_I32         b2;
#endif
} S_WT_FRAME;

/*----------------------------------------------------------------------------
 * S_WT_CONFIG
 *
 * This structure contains state data for the wavetable engine
 *----------------------------------------------------------------------------
*/
typedef struct s_wt_config_tag
{
    EAS_U32             loopEnd;                /* points to last PCM sample (not 1 beyond last) */
    EAS_U32             loopStart;              /* points to first sample at start of loop */
    EAS_U32             phaseAccum;             /* current sample, integer portion of phase */

#if (NUM_OUTPUT_CHANNELS == 2)
    EAS_I16             gainLeft;               /* left channel gain */
    EAS_I16             gainRight;              /* right channel gain */
#endif

    EAS_I16             gain;                   /* current voice gain */
} S_WT_CONFIG;

#endif