cannam@88: /******************************************************************** cannam@88: * * cannam@88: * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. * cannam@88: * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS * cannam@88: * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE * cannam@88: * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. * cannam@88: * * cannam@88: * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2001 * cannam@88: * by the Xiph.Org Foundation http://www.xiph.org/ * cannam@88: cannam@88: ******************************************************************** cannam@88: cannam@88: function: libvorbis codec headers cannam@88: last mod: $Id: codec.h 17021 2010-03-24 09:29:41Z xiphmont $ cannam@88: cannam@88: ********************************************************************/ cannam@88: cannam@88: #ifndef _vorbis_codec_h_ cannam@88: #define _vorbis_codec_h_ cannam@88: cannam@88: #ifdef __cplusplus cannam@88: extern "C" cannam@88: { cannam@88: #endif /* __cplusplus */ cannam@88: cannam@88: #include cannam@88: cannam@88: typedef struct vorbis_info{ cannam@88: int version; cannam@88: int channels; cannam@88: long rate; cannam@88: cannam@88: /* The below bitrate declarations are *hints*. cannam@88: Combinations of the three values carry the following implications: cannam@88: cannam@88: all three set to the same value: cannam@88: implies a fixed rate bitstream cannam@88: only nominal set: cannam@88: implies a VBR stream that averages the nominal bitrate. No hard cannam@88: upper/lower limit cannam@88: upper and or lower set: cannam@88: implies a VBR bitstream that obeys the bitrate limits. nominal cannam@88: may also be set to give a nominal rate. cannam@88: none set: cannam@88: the coder does not care to speculate. cannam@88: */ cannam@88: cannam@88: long bitrate_upper; cannam@88: long bitrate_nominal; cannam@88: long bitrate_lower; cannam@88: long bitrate_window; cannam@88: cannam@88: void *codec_setup; cannam@88: } vorbis_info; cannam@88: cannam@88: /* vorbis_dsp_state buffers the current vorbis audio cannam@88: analysis/synthesis state. The DSP state belongs to a specific cannam@88: logical bitstream ****************************************************/ cannam@88: typedef struct vorbis_dsp_state{ cannam@88: int analysisp; cannam@88: vorbis_info *vi; cannam@88: cannam@88: float **pcm; cannam@88: float **pcmret; cannam@88: int pcm_storage; cannam@88: int pcm_current; cannam@88: int pcm_returned; cannam@88: cannam@88: int preextrapolate; cannam@88: int eofflag; cannam@88: cannam@88: long lW; cannam@88: long W; cannam@88: long nW; cannam@88: long centerW; cannam@88: cannam@88: ogg_int64_t granulepos; cannam@88: ogg_int64_t sequence; cannam@88: cannam@88: ogg_int64_t glue_bits; cannam@88: ogg_int64_t time_bits; cannam@88: ogg_int64_t floor_bits; cannam@88: ogg_int64_t res_bits; cannam@88: cannam@88: void *backend_state; cannam@88: } vorbis_dsp_state; cannam@88: cannam@88: typedef struct vorbis_block{ cannam@88: /* necessary stream state for linking to the framing abstraction */ cannam@88: float **pcm; /* this is a pointer into local storage */ cannam@88: oggpack_buffer opb; cannam@88: cannam@88: long lW; cannam@88: long W; cannam@88: long nW; cannam@88: int pcmend; cannam@88: int mode; cannam@88: cannam@88: int eofflag; cannam@88: ogg_int64_t granulepos; cannam@88: ogg_int64_t sequence; cannam@88: vorbis_dsp_state *vd; /* For read-only access of configuration */ cannam@88: cannam@88: /* local storage to avoid remallocing; it's up to the mapping to cannam@88: structure it */ cannam@88: void *localstore; cannam@88: long localtop; cannam@88: long localalloc; cannam@88: long totaluse; cannam@88: struct alloc_chain *reap; cannam@88: cannam@88: /* bitmetrics for the frame */ cannam@88: long glue_bits; cannam@88: long time_bits; cannam@88: long floor_bits; cannam@88: long res_bits; cannam@88: cannam@88: void *internal; cannam@88: cannam@88: } vorbis_block; cannam@88: cannam@88: /* vorbis_block is a single block of data to be processed as part of cannam@88: the analysis/synthesis stream; it belongs to a specific logical cannam@88: bitstream, but is independent from other vorbis_blocks belonging to cannam@88: that logical bitstream. *************************************************/ cannam@88: cannam@88: struct alloc_chain{ cannam@88: void *ptr; cannam@88: struct alloc_chain *next; cannam@88: }; cannam@88: cannam@88: /* vorbis_info contains all the setup information specific to the cannam@88: specific compression/decompression mode in progress (eg, cannam@88: psychoacoustic settings, channel setup, options, codebook cannam@88: etc). vorbis_info and substructures are in backends.h. cannam@88: *********************************************************************/ cannam@88: cannam@88: /* the comments are not part of vorbis_info so that vorbis_info can be cannam@88: static storage */ cannam@88: typedef struct vorbis_comment{ cannam@88: /* unlimited user comment fields. libvorbis writes 'libvorbis' cannam@88: whatever vendor is set to in encode */ cannam@88: char **user_comments; cannam@88: int *comment_lengths; cannam@88: int comments; cannam@88: char *vendor; cannam@88: cannam@88: } vorbis_comment; cannam@88: cannam@88: cannam@88: /* libvorbis encodes in two abstraction layers; first we perform DSP cannam@88: and produce a packet (see docs/analysis.txt). The packet is then cannam@88: coded into a framed OggSquish bitstream by the second layer (see cannam@88: docs/framing.txt). Decode is the reverse process; we sync/frame cannam@88: the bitstream and extract individual packets, then decode the cannam@88: packet back into PCM audio. cannam@88: cannam@88: The extra framing/packetizing is used in streaming formats, such as cannam@88: files. Over the net (such as with UDP), the framing and cannam@88: packetization aren't necessary as they're provided by the transport cannam@88: and the streaming layer is not used */ cannam@88: cannam@88: /* Vorbis PRIMITIVES: general ***************************************/ cannam@88: cannam@88: extern void vorbis_info_init(vorbis_info *vi); cannam@88: extern void vorbis_info_clear(vorbis_info *vi); cannam@88: extern int vorbis_info_blocksize(vorbis_info *vi,int zo); cannam@88: extern void vorbis_comment_init(vorbis_comment *vc); cannam@88: extern void vorbis_comment_add(vorbis_comment *vc, const char *comment); cannam@88: extern void vorbis_comment_add_tag(vorbis_comment *vc, cannam@88: const char *tag, const char *contents); cannam@88: extern char *vorbis_comment_query(vorbis_comment *vc, const char *tag, int count); cannam@88: extern int vorbis_comment_query_count(vorbis_comment *vc, const char *tag); cannam@88: extern void vorbis_comment_clear(vorbis_comment *vc); cannam@88: cannam@88: extern int vorbis_block_init(vorbis_dsp_state *v, vorbis_block *vb); cannam@88: extern int vorbis_block_clear(vorbis_block *vb); cannam@88: extern void vorbis_dsp_clear(vorbis_dsp_state *v); cannam@88: extern double vorbis_granule_time(vorbis_dsp_state *v, cannam@88: ogg_int64_t granulepos); cannam@88: cannam@88: extern const char *vorbis_version_string(void); cannam@88: cannam@88: /* Vorbis PRIMITIVES: analysis/DSP layer ****************************/ cannam@88: cannam@88: extern int vorbis_analysis_init(vorbis_dsp_state *v,vorbis_info *vi); cannam@88: extern int vorbis_commentheader_out(vorbis_comment *vc, ogg_packet *op); cannam@88: extern int vorbis_analysis_headerout(vorbis_dsp_state *v, cannam@88: vorbis_comment *vc, cannam@88: ogg_packet *op, cannam@88: ogg_packet *op_comm, cannam@88: ogg_packet *op_code); cannam@88: extern float **vorbis_analysis_buffer(vorbis_dsp_state *v,int vals); cannam@88: extern int vorbis_analysis_wrote(vorbis_dsp_state *v,int vals); cannam@88: extern int vorbis_analysis_blockout(vorbis_dsp_state *v,vorbis_block *vb); cannam@88: extern int vorbis_analysis(vorbis_block *vb,ogg_packet *op); cannam@88: cannam@88: extern int vorbis_bitrate_addblock(vorbis_block *vb); cannam@88: extern int vorbis_bitrate_flushpacket(vorbis_dsp_state *vd, cannam@88: ogg_packet *op); cannam@88: cannam@88: /* Vorbis PRIMITIVES: synthesis layer *******************************/ cannam@88: extern int vorbis_synthesis_idheader(ogg_packet *op); cannam@88: extern int vorbis_synthesis_headerin(vorbis_info *vi,vorbis_comment *vc, cannam@88: ogg_packet *op); cannam@88: cannam@88: extern int vorbis_synthesis_init(vorbis_dsp_state *v,vorbis_info *vi); cannam@88: extern int vorbis_synthesis_restart(vorbis_dsp_state *v); cannam@88: extern int vorbis_synthesis(vorbis_block *vb,ogg_packet *op); cannam@88: extern int vorbis_synthesis_trackonly(vorbis_block *vb,ogg_packet *op); cannam@88: extern int vorbis_synthesis_blockin(vorbis_dsp_state *v,vorbis_block *vb); cannam@88: extern int vorbis_synthesis_pcmout(vorbis_dsp_state *v,float ***pcm); cannam@88: extern int vorbis_synthesis_lapout(vorbis_dsp_state *v,float ***pcm); cannam@88: extern int vorbis_synthesis_read(vorbis_dsp_state *v,int samples); cannam@88: extern long vorbis_packet_blocksize(vorbis_info *vi,ogg_packet *op); cannam@88: cannam@88: extern int vorbis_synthesis_halfrate(vorbis_info *v,int flag); cannam@88: extern int vorbis_synthesis_halfrate_p(vorbis_info *v); cannam@88: cannam@88: /* Vorbis ERRORS and return codes ***********************************/ cannam@88: cannam@88: #define OV_FALSE -1 cannam@88: #define OV_EOF -2 cannam@88: #define OV_HOLE -3 cannam@88: cannam@88: #define OV_EREAD -128 cannam@88: #define OV_EFAULT -129 cannam@88: #define OV_EIMPL -130 cannam@88: #define OV_EINVAL -131 cannam@88: #define OV_ENOTVORBIS -132 cannam@88: #define OV_EBADHEADER -133 cannam@88: #define OV_EVERSION -134 cannam@88: #define OV_ENOTAUDIO -135 cannam@88: #define OV_EBADPACKET -136 cannam@88: #define OV_EBADLINK -137 cannam@88: #define OV_ENOSEEK -138 cannam@88: cannam@88: #ifdef __cplusplus cannam@88: } cannam@88: #endif /* __cplusplus */ cannam@88: cannam@88: #endif cannam@88: