/*----------------------------------------------------------------------------
 *
 * 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