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